/* =====================================================================
   HUESEANDO v3 — COMPONENT LIBRARY (.h-*)
   =====================================================================
   WHERE TO PUT THIS FILE
   ----------------------
   Save as: public/assets/css/hueseando-components.css
   Include AFTER tokens.css and AFTER Bootstrap, BEFORE app.css overrides.

     <link rel="stylesheet" href="/assets/css/hueseando-tokens.css">
     <!-- bootstrap here -->
     <link rel="stylesheet" href="/assets/css/hueseando-components.css">
     <link rel="stylesheet" href="/assets/css/app.css">

   All class names are prefixed .h-* to avoid collisions with existing
   Bootstrap / app classes. Bootstrap overrides (card, form-control,
   form-select, navbar) are scoped and safe to remove if they conflict.
   ===================================================================== */

/* ═══════ 1 · STATUS BAR (top strip) ══════════════════════════════════ */
.h-statusbar {
    padding: 8px 0;
    border-bottom: 1px solid var(--h-line);
    font-family: var(--h-mono);
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--h-pink);
    position: relative; z-index: 2;
}
.h-statusbar .live::before {
    content: '◉';
    color: var(--h-lime);
    margin-right: 6px;
    animation: h-pulse 1.6s ease-in-out infinite;
}

/* ═══════ 2 · NAV ═══════════════════════════════════════════════════ */
.navbar.h-nav {
    background: transparent !important;
    border-bottom: 1px solid var(--h-line);
    padding: 18px 0;
    position: relative; z-index: 3;
}
.h-nav .nav-pill-group {
    display: inline-flex; gap: 4px; padding: 4px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--h-line);
    border-radius: var(--h-pill);
    backdrop-filter: blur(20px);
}
.h-nav .nav-pill-group .nav-link {
    padding: 8px 16px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--h-fg-dim);
    border-radius: var(--h-pill);
    white-space: nowrap;
}
.h-nav .nav-pill-group .nav-link.active {
    background: linear-gradient(135deg, var(--h-pink), var(--h-violet));
    color: var(--h-fg);
    box-shadow: none;
}

/* ═══════ 3 · BUTTONS ═══════════════════════════════════════════════ */
.h-btn-primary {
    background: linear-gradient(135deg, var(--h-pink), var(--h-violet));
    color: var(--h-fg);
    font-weight: 800; font-size: 0.8125rem;
    text-transform: uppercase; letter-spacing: 0.06em;
    padding: 14px 26px;
    border: none; border-radius: var(--h-r);
    box-shadow: var(--h-glow-pink);
    text-decoration: none;
    display: inline-flex; align-items: center; gap: 8px;
    white-space: nowrap; cursor: pointer;
    transition: transform 0.15s, box-shadow 0.15s;
}
.h-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 0 40px rgba(255,51,145,0.7); color: var(--h-fg); }

.h-btn-lime {
    background: var(--h-lime);
    color: var(--h-bg);
    font-weight: 900; font-size: 0.8125rem;
    text-transform: uppercase; letter-spacing: 0.05em;
    padding: 12px 22px;
    border: none; border-radius: var(--h-pill);
    box-shadow: var(--h-glow-lime);
    text-decoration: none;
    white-space: nowrap; cursor: pointer;
}
.h-btn-lime:hover { color: var(--h-bg); transform: translateY(-1px); }

.h-btn-outline {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(0,234,255,0.45);
    color: var(--h-cyan);
    font-family: var(--h-mono);
    font-weight: 600; font-size: 0.75rem;
    text-transform: uppercase; letter-spacing: 0.08em;
    padding: 10px 18px;
    border-radius: var(--h-r);
    text-decoration: none;
    display: inline-flex; align-items: center; gap: 8px;
    white-space: nowrap; cursor: pointer;
}
.h-btn-outline:hover { color: var(--h-cyan); border-color: var(--h-cyan); }

.h-btn-ghost {
    background: transparent;
    border: 1px solid var(--h-line);
    color: var(--h-fg-dim);
    font-family: var(--h-mono);
    font-weight: 600; font-size: 0.75rem;
    text-transform: uppercase; letter-spacing: 0.08em;
    padding: 10px 18px;
    border-radius: var(--h-r);
    text-decoration: none;
    display: inline-flex; align-items: center; gap: 8px;
    white-space: nowrap; cursor: pointer;
}
.h-btn-ghost:hover { color: var(--h-fg); border-color: var(--h-line-strong); }

/* ═══════ 4 · CARDS (Bootstrap .card override) ═════════════════════ */
.card {
    background: var(--h-surface) !important;
    border: 1px solid var(--h-line) !important;
    border-radius: var(--h-r-lg) !important;
    color: var(--h-fg);
}

/* ═══════ 5 · FORM CONTROLS (Bootstrap overrides) ══════════════════ */
.form-control, .form-select, textarea.form-control {
    background: var(--h-surface-2) !important;
    color: var(--h-fg) !important;
    border: 1px solid var(--h-line) !important;
    border-radius: var(--h-r) !important;
    padding: 14px 16px !important;
    font-family: var(--h-sans);
    font-size: 1rem;
    transition: all 0.15s;
}
.form-control::placeholder { color: var(--h-fg-muted); }
.form-control:focus, .form-select:focus {
    border-color: var(--h-pink) !important;
    box-shadow: 0 0 0 3px rgba(255,51,145,0.15), 0 0 20px rgba(255,51,145,0.15) !important;
    background: var(--h-surface-2) !important;
}
textarea.form-control { min-height: 140px; line-height: 1.55; }

.form-label {
    font-family: var(--h-mono);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--h-fg-dim);
    font-weight: 600;
    margin-bottom: 8px;
    white-space: nowrap;
}
.form-label .req { color: var(--h-pink); margin-left: 3px; }

.form-hint {
    font-family: var(--h-mono);
    font-size: 0.6875rem;
    color: var(--h-fg-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-top: 6px;
}
.form-hint.ok   { color: var(--h-lime); }
.form-hint.warn { color: var(--h-orange); }

/* ═══════ 6 · TYPOGRAPHY UTILITIES ═════════════════════════════════ */
.h-mono { font-family: var(--h-mono); }
.h-display { font-family: var(--h-display); font-weight: 800; letter-spacing: -0.02em; }
.h-mono-label {
    font-family: var(--h-mono);
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-weight: 600;
    white-space: nowrap;
}

.h-page-title {
    font-family: var(--h-display);
    font-size: clamp(44px, 7vw, 84px);
    font-weight: 900;
    letter-spacing: -0.04em;
    line-height: 0.92;
    text-transform: uppercase;
}
.h-page-title em {
    font-style: italic;
    background: linear-gradient(90deg, var(--h-pink), var(--h-lime));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.text-lime   { color: var(--h-lime)   !important; }
.text-pink   { color: var(--h-pink)   !important; }
.text-cyan   { color: var(--h-cyan)   !important; }
.text-violet { color: var(--h-violet) !important; }
.text-orange { color: var(--h-orange) !important; }
.text-dim    { color: var(--h-fg-dim) !important; }
.text-muted  { color: var(--h-fg-muted) !important; }

/* ═══════ 7 · BREADCRUMBS ══════════════════════════════════════════ */
.h-crumbs {
    font-family: var(--h-mono);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--h-fg-muted);
    margin-bottom: 14px;
}
.h-crumbs a { color: var(--h-cyan); text-decoration: none; }
.h-crumbs .sep { margin: 0 8px; }

/* ═══════ 8 · AMBIENT GLOWS ════════════════════════════════════════ */
.h-glow-bg {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    pointer-events: none;
    z-index: 0;
}
/* Use with inline style for position/size/color, e.g.:
   <div class="h-glow-bg" style="top:-100px; right:10%; width:600px; height:600px;
        background: radial-gradient(circle, var(--h-pink) 0%, transparent 60%); opacity:.22;"></div>
*/

/* ═══════ 9 · GIG CARD (override of gig-card.php) ═════════════════ */
.gig-card {
    background: var(--h-surface) !important;
    border: 1px solid var(--h-line) !important;
    border-left: 4px solid var(--gig-otro) !important;
    border-radius: var(--h-r-lg) !important;
    transition: all 0.2s;
    cursor: pointer;
}
.gig-card:hover { border-color: var(--h-line-strong) !important; transform: translateY(-2px); }
.gig-card.type-show      { border-left-color: var(--gig-show) !important; }
.gig-card.type-grabacion { border-left-color: var(--gig-grabacion) !important; }
.gig-card.type-ensayo    { border-left-color: var(--gig-ensayo) !important; }
.gig-card.type-sesion    { border-left-color: var(--gig-sesion) !important; }

.h-type-tag {
    font-family: var(--h-mono);
    font-size: 0.625rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    padding: 3px 8px;
    border-radius: var(--h-pill);
    display: inline-block;
    white-space: nowrap;
}
.h-type-tag.show      { background: rgba(0,234,255,0.15);   color: var(--h-cyan); }
.h-type-tag.grabacion { background: rgba(176,79,255,0.15);  color: var(--h-violet); }
.h-type-tag.ensayo    { background: rgba(214,255,61,0.15);  color: var(--h-lime); }
.h-type-tag.sesion    { background: rgba(255,107,43,0.15);  color: var(--h-orange); }

.h-pay {
    font-family: var(--h-display);
    font-weight: 900;
    letter-spacing: -0.03em;
    color: var(--h-lime);
    text-shadow: 0 0 20px rgba(214,255,61,0.35);
}

/* ═══════ 10 · URGENCY BADGES ══════════════════════════════════════ */
.h-urgent {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 3px 10px;
    border-radius: var(--h-pill);
    font-family: var(--h-mono);
    font-size: 0.625rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    white-space: nowrap;
}
.h-urgent.hot     { background: rgba(255,51,145,0.15); color: var(--h-pink); border: 1px solid rgba(255,51,145,0.4); animation: h-pulse 1.6s infinite; }
.h-urgent.new     { background: rgba(214,255,61,0.15); color: var(--h-lime); border: 1px solid rgba(214,255,61,0.4); }
.h-urgent.closing { background: rgba(255,107,43,0.15); color: var(--h-orange); border: 1px solid rgba(255,107,43,0.4); }

/* ═══════ 11 · SECTION STRIPE (list dividers) ═════════════════════ */
.h-stripe {
    display: flex; align-items: center; gap: 14px;
    padding: 12px 18px;
    background: var(--h-surface);
    border: 1px solid var(--h-line);
    border-left: 4px solid var(--h-pink);
    border-radius: var(--h-r);
    margin: 28px 0 14px;
}
.h-stripe .label { font-family: var(--h-mono); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.15em; color: var(--h-pink); font-weight: 700; }
.h-stripe .count { margin-left: auto; color: var(--h-fg-dim); font-family: var(--h-mono); font-size: 0.75rem; }
.h-stripe.cyan   { border-left-color: var(--h-cyan); }   .h-stripe.cyan .label   { color: var(--h-cyan); }
.h-stripe.lime   { border-left-color: var(--h-lime); }   .h-stripe.lime .label   { color: var(--h-lime); }
.h-stripe.violet { border-left-color: var(--h-violet); } .h-stripe.violet .label { color: var(--h-violet); }

/* ═══════ 12 · CHIPS (filter & picker) ═════════════════════════════ */
.h-chip {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 12px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--h-line);
    border-radius: var(--h-pill);
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--h-fg-dim);
    margin: 0 6px 6px 0;
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
}
.h-chip.on          { background: rgba(255,51,145,0.15);  border-color: var(--h-pink);   color: var(--h-pink); }
.h-chip.on.cyan     { background: rgba(0,234,255,0.15);   border-color: var(--h-cyan);   color: var(--h-cyan); }
.h-chip.on.lime     { background: rgba(214,255,61,0.15);  border-color: var(--h-lime);   color: var(--h-lime); }
.h-chip.on.violet   { background: rgba(176,79,255,0.15);  border-color: var(--h-violet); color: var(--h-violet); }
.h-chip.on.orange   { background: rgba(255,107,43,0.15);  border-color: var(--h-orange); color: var(--h-orange); }

/* Variant used in create form (larger hit target) */
.h-chip-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 14px;
    background: var(--h-surface-2);
    border: 1px solid var(--h-line);
    border-radius: var(--h-pill);
    font-size: 0.875rem; font-weight: 500;
    color: var(--h-fg-dim); cursor: pointer;
    white-space: nowrap; transition: all 0.15s;
}
.h-chip-btn:hover { border-color: var(--h-line-strong); color: var(--h-fg); }
.h-chip-btn.on    { background: rgba(255,51,145,0.15); border-color: var(--h-pink); color: var(--h-pink); box-shadow: 0 0 16px rgba(255,51,145,0.2); }

/* ═══════ 13 · MUSICIAN CARD (override of musician-card.php) ══════ */
.musician-card {
    background: var(--h-surface) !important;
    border: 1px solid var(--h-line) !important;
    border-radius: var(--h-r-lg) !important;
    overflow: hidden;
    transition: transform 0.15s, border-color 0.15s;
}
.musician-card:hover { transform: translateY(-3px); border-color: var(--h-line-strong) !important; }

.available-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--h-fg-muted); display: inline-block; }
.available-dot.on { background: var(--h-lime); box-shadow: 0 0 10px var(--h-lime); animation: h-pulse 1.8s infinite; }

/* Instrument badge (keeps existing name from partial) */
.badge.instrument-badge {
    font-family: var(--h-mono);
    font-size: 0.6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 4px 10px;
    border-radius: var(--h-pill);
    border: 1px solid var(--h-line);
    background: rgba(255,255,255,0.04);
    color: var(--h-fg-dim);
}
.badge.instrument-badge.inst-cat-strings   { border-color: rgba(0,234,255,0.35);   color: var(--h-cyan); }
.badge.instrument-badge.inst-cat-wind      { border-color: rgba(214,255,61,0.35);  color: var(--h-lime); }
.badge.instrument-badge.inst-cat-percussion{ border-color: rgba(255,107,43,0.35);  color: var(--h-orange); }
.badge.instrument-badge.inst-cat-voice     { border-color: rgba(255,51,145,0.35);  color: var(--h-pink); }
.badge.instrument-badge.inst-cat-keys      { border-color: rgba(176,79,255,0.35);  color: var(--h-violet); }

/* ═══════ 14 · META GRID (detail pages) ═════════════════════════════ */
.h-meta-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1px;
    background: var(--h-line);
    border: 1px solid var(--h-line);
    border-radius: var(--h-r-lg);
    overflow: hidden;
}
.h-meta-cell { padding: 16px; background: var(--h-surface); }
.h-meta-cell .l {
    font-family: var(--h-mono);
    font-size: 0.625rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--h-fg-dim);
    font-weight: 600;
    margin-bottom: 6px;
}
.h-meta-cell .v { font-family: var(--h-display); font-size: 1.125rem; font-weight: 700; letter-spacing: -0.01em; }
.h-meta-cell .v.sm { font-size: 0.9375rem; font-weight: 600; font-family: var(--h-sans); letter-spacing: 0; }

/* ═══════ 15 · SECTION CARD (modular content block) ═══════════════ */
.h-section-card {
    background: var(--h-surface);
    border: 1px solid var(--h-line);
    border-radius: var(--h-r-lg);
    padding: 24px;
    margin-bottom: 16px;
}
.h-section-card.active {
    border-color: rgba(255,51,145,0.4);
    box-shadow: 0 0 40px rgba(255,51,145,0.08);
}
.h-section-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--h-line);
    gap: 12px; flex-wrap: wrap;
}
.h-section-head h3 {
    font-family: var(--h-display);
    font-size: 1.125rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: -0.01em;
    margin: 0;
}
.h-section-head .h-mono-label { color: var(--h-cyan); margin-bottom: 2px; }

/* ═══════ 16 · TOGGLE SWITCH ═══════════════════════════════════════ */
.h-switch {
    width: 48px; height: 28px;
    border-radius: var(--h-pill);
    background: var(--h-surface-2);
    border: 1px solid var(--h-line);
    position: relative; cursor: pointer; flex-shrink: 0;
    transition: all 0.15s;
}
.h-switch::after {
    content: ''; position: absolute; top: 3px; left: 3px;
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--h-fg-muted);
    transition: all 0.15s;
}
.h-switch.on {
    background: linear-gradient(135deg, var(--h-pink), var(--h-violet));
    border-color: transparent;
    box-shadow: var(--h-glow-pink);
}
.h-switch.on::after { left: 23px; background: var(--h-fg); }

/* ═══════ 17 · SEGMENT CONTROL ═════════════════════════════════════ */
.h-segment {
    display: inline-flex;
    background: var(--h-surface-2);
    border: 1px solid var(--h-line);
    border-radius: var(--h-pill);
    padding: 4px; gap: 2px;
}
.h-segment button {
    background: transparent; border: none;
    color: var(--h-fg-dim);
    font-family: var(--h-mono);
    font-size: 0.75rem;
    text-transform: uppercase; letter-spacing: 0.08em;
    font-weight: 700;
    padding: 8px 16px;
    border-radius: var(--h-pill);
    cursor: pointer; white-space: nowrap;
}
.h-segment button.on {
    background: var(--h-bg);
    color: var(--h-lime);
    box-shadow: inset 0 0 0 1px rgba(214,255,61,0.35);
}

/* ═══════ 18 · STEPPER ═════════════════════════════════════════════ */
.h-stepper {
    display: flex; align-items: center; gap: 0;
    background: var(--h-surface);
    border: 1px solid var(--h-line);
    border-radius: var(--h-pill);
    padding: 6px;
    overflow-x: auto;
}
.h-step {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 18px;
    border-radius: var(--h-pill);
    white-space: nowrap;
    color: var(--h-fg-muted);
    font-family: var(--h-mono);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 600;
    flex-shrink: 0;
}
.h-step .num {
    width: 22px; height: 22px;
    border-radius: 50%;
    background: rgba(255,255,255,0.06);
    display: flex; align-items: center; justify-content: center;
    font-size: 11px; font-weight: 800;
    color: var(--h-fg-muted);
}
.h-step.done { color: var(--h-lime); }
.h-step.done .num { background: var(--h-lime); color: var(--h-bg); }
.h-step.on {
    background: linear-gradient(135deg, var(--h-pink), var(--h-violet));
    color: var(--h-fg);
    box-shadow: var(--h-glow-pink);
}
.h-step.on .num { background: var(--h-bg); color: var(--h-fg); }
.h-step-sep { width: 24px; height: 1px; background: var(--h-line); flex-shrink: 0; }

/* ═══════ 19 · PAGINATION ══════════════════════════════════════════ */
.h-pagination { display: flex; justify-content: center; gap: 6px; margin: 40px 0; }
.h-pagination a, .h-pagination span {
    min-width: 40px; height: 40px;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--h-surface);
    border: 1px solid var(--h-line);
    color: var(--h-fg-dim);
    text-decoration: none;
    border-radius: var(--h-r-sm);
    font-family: var(--h-mono);
    font-size: 0.8125rem;
    font-weight: 600;
}
.h-pagination .current {
    background: linear-gradient(135deg, var(--h-pink), var(--h-violet));
    color: var(--h-fg);
    border-color: transparent;
    box-shadow: var(--h-glow-pink);
}

/* ═══════ 20 · TIP CALLOUT ═════════════════════════════════════════ */
.h-tip {
    background: linear-gradient(135deg, rgba(0,234,255,0.08), rgba(176,79,255,0.04));
    border: 1px solid rgba(0,234,255,0.3);
    border-radius: var(--h-r);
    padding: 14px 16px;
    font-size: 0.875rem;
    display: flex; gap: 12px; align-items: flex-start;
}
.h-tip .ic { color: var(--h-cyan); font-size: 18px; flex-shrink: 0; margin-top: 1px; }
.h-tip b { color: var(--h-fg); }

/* ═══════ 21 · POSTER / MINI AVATAR ROW ════════════════════════════ */
.h-poster {
    display: flex; gap: 14px; align-items: center;
    background: var(--h-surface-2);
    border: 1px solid var(--h-line);
    border-radius: var(--h-r);
    padding: 14px;
}
.h-poster .av {
    width: 56px; height: 56px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--h-cyan), var(--h-violet));
    display: flex; align-items: center; justify-content: center;
    color: var(--h-fg); font-size: 22px; flex-shrink: 0;
}
.h-poster .nm { font-weight: 700; font-size: 1rem; }
.h-poster .mt {
    font-family: var(--h-mono);
    font-size: 0.6875rem;
    color: var(--h-fg-dim);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

/* ═══════ 22 · LIVE FEED (home) ════════════════════════════════════ */
.h-livefeed {
    background: var(--h-surface);
    border: 1px solid var(--h-line);
    border-radius: var(--h-r-lg);
    padding: 18px;
    font-family: var(--h-mono);
    font-size: 0.8125rem;
    line-height: 1.9;
}
.h-livefeed .row-item { padding: 6px 0; border-bottom: 1px dashed var(--h-line); }
.h-livefeed .row-item:last-child { border-bottom: none; }
.h-livefeed .t { color: var(--h-fg-muted); font-size: 0.6875rem; margin-right: 8px; }

/* ═══════ 23 · SUBMIT BAR (sticky bottom) ══════════════════════════ */
.h-submit-bar {
    position: sticky; bottom: 0;
    background: rgba(7,8,15,0.92);
    backdrop-filter: blur(20px);
    border-top: 1px solid var(--h-line);
    padding: 18px 0;
    margin-top: 32px;
    z-index: 10;
}

/* ═══════ 24 · COMPLETION METER ════════════════════════════════════ */
.h-meter {
    height: 6px;
    background: var(--h-surface-2);
    border-radius: var(--h-pill);
    overflow: hidden;
}
.h-meter .bar {
    height: 100%;
    background: linear-gradient(90deg, var(--h-pink), var(--h-lime));
    border-radius: var(--h-pill);
    transition: width 0.3s;
}
