/* ─────────────────────────────────────────────
   DESIGN TOKENS — exact match to homepage v2
   ───────────────────────────────────────────── */

   .tier-premium{background:rgba(245,158,11,.25);border:1px solid rgba(245,158,11,.5);color:#FCD34D !important;}

   :root {
    --black:#03010A; --navy:#07041A; --card:#0D0925;
    --purple:#7C3AED; --purpleL:#A78BFA; --purpleX:#C084FC;
    --white:#F1EFFE; --muted:rgba(241,239,254,.45);
    --border:rgba(124,58,237,.18); --borderH:rgba(124,58,237,.48);
    --green:#10B981; --greenL:#6EE7B7;
    --amber:#F59E0B; --amberL:#FCD34D; --amberX:#FBBF24;
    /* Layout */
    --nav-h:60px;
    --sidebar-w:280px;   /* slightly slimmer sidebar for wider result cards */
    --map-w:316px;
  }
  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;width:100%;overflow-x: hidden;}
  body{font-family:'DM Sans',sans-serif;background:var(--black);color:var(--white);overflow-x:hidden;line-height:1.5}
  /* Film grain noise — matches homepage */
  body::after{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
    opacity:.032;background-size:256px 256px}
  
  /* ─────────────────────────────────────────────
     KEYFRAMES
     ───────────────────────────────────────────── */
  @keyframes livePulse    {0%,100%{opacity:1}50%{opacity:.4}}
  @keyframes spotPulse    {0%,100%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}
  @keyframes borderSweep  {0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
  @keyframes ringPulse    {0%,100%{box-shadow:0 0 0 0 rgba(124,58,237,.5);border-color:var(--purple)}50%{box-shadow:0 0 0 6px rgba(124,58,237,0);border-color:var(--purpleX)}}
  @keyframes spotNavGlow  {0%,100%{box-shadow:0 0 5px rgba(245,158,11,.4);opacity:1}50%{box-shadow:0 0 12px rgba(245,158,11,.7);opacity:.8}}
  @keyframes fadeUp       {from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
  @keyframes drawerIn     {from{transform:translateY(100%)}to{transform:translateY(0)}}
  @keyframes shimmer      {0%{background-position:-400px 0}100%{background-position:400px 0}}
  @keyframes dropdownFadeIn {from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
  @keyframes dropdownSlideIn {from{opacity:0;transform:translateY(-12px) scale(0.98)}to{opacity:1;transform:translateY(0) scale(1)}}
  
  /* ─────────────────────────────────────────────
     NAV — exact match to homepage + Spotlight pill
     ───────────────────────────────────────────── */
  nav{
    position:sticky;top:0;z-index:800;height:var(--nav-h);
    display:flex;align-items:center;padding:0 48px;gap:32px;
    background:rgba(3,1,10,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border);transition:background .3s,border-color .3s;
    justify-content: space-between;
  }
  nav.scrolled{background:rgba(3,1,10,.97);border-bottom-color:rgba(124,58,237,.3)}
  .nav-logo{flex-shrink:0;cursor:pointer}.nav-logo img{height:28px;display:block}
  .nav-links{display:flex;align-items:center;gap:4px;flex:1;margin-left:16px}
  /* Standard nav link — exact match homepage */
  .nl{font-size:13.5px;font-weight:500;color:var(--muted);padding:7px 14px;border-radius:6px;
    cursor:pointer;transition:all .2s;text-decoration:none;letter-spacing:.01em}
  .nl:hover{color:var(--white);background:rgba(124,58,237,.1)}
  .nl.active{color:var(--white);background:rgba(124,58,237,.12)}
  
  /* ★ SPOTLIGHT nav pill — amber accent, clearly premium */
  .nl-spotlight{
    display:inline-flex;align-items:center;gap:7px;
    font-size:13.5px;font-weight:600;letter-spacing:.01em;
    color:var(--amberL);
    padding:7px 15px;border-radius:7px;
    background:rgba(245,158,11,.08);
    border:1.5px solid rgba(245,158,11,.3);
    cursor:pointer;transition:all .25s;text-decoration:none
  }
  .nl-spotlight:hover{
    background:rgba(245,158,11,.16);border-color:rgba(245,158,11,.6);
    color:var(--amberX);box-shadow:0 0 18px rgba(245,158,11,.18)
  }
  .spot-dot{
    width:6px;height:6px;border-radius:50%;
    background:var(--amber);box-shadow:0 0 5px rgba(245,158,11,.6);
    animation:spotNavGlow 2s ease-in-out infinite;flex-shrink:0
  }
  /* Nav right */
  .nav-right{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-left:auto}
  .nav-signin{font-size:13.5px;font-weight:500;color:var(--muted);cursor:pointer;padding:8px 12px;transition:color .2s}
  .nav-signin:hover{color:var(--white)}
  .nav-cta{
    background:var(--purple);color:var(--white);border:none;border-radius:8px;
    font-family:'DM Sans',sans-serif;font-size:13.5px;font-weight:600;
    padding:9px 20px;cursor:pointer;transition:all .25s;letter-spacing:.01em
  }
  .nav-cta:hover{background:#6D28D9;box-shadow:0 0 20px rgba(124,58,237,.4);transform:translateY(-1px)}
  /* Hamburger */
  .nav-hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--white)}
  /* Mobile menu */
  .mobile-menu{
    display:none;position:fixed;inset:var(--nav-h) 0 0;
    background:rgba(3,1,10,.98);z-index:799;
    padding:24px;flex-direction:column;gap:4px;overflow-y:auto
  }
  .mobile-menu.open{display:flex}
  .mm-item{padding:14px 16px;border-radius:8px;font-size:15px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .2s}
  .mm-item:hover{background:rgba(124,58,237,.1);color:var(--white)}
  .mm-item.active{color:var(--white);background:rgba(124,58,237,.12)}
  /* Mobile Spotlight menu item */
  .mm-spot{
    display:flex;align-items:center;gap:9px;padding:14px 16px;border-radius:8px;
    font-size:15px;font-weight:600;color:var(--amberL);
    background:rgba(245,158,11,.06);border:1px solid rgba(245,158,11,.2);cursor:pointer
  }
  .mm-cta{margin-top:12px;background:var(--purple);color:var(--white);text-align:center;padding:14px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer}
  
  /* ─────────────────────────────────────────────
     SEARCH HEADER STRIP
     ───────────────────────────────────────────── */
  .search-header{
    background:linear-gradient(180deg,var(--navy) 0%,var(--black) 100%);
    border-bottom:1px solid var(--border);
    padding:24px 0 0;position:relative;overflow:visible;
    padding-bottom: 8px;
    display:flex;
    flex-direction:column;
    align-items:center;
    z-index:300;
  }
  .search-header::before{
    content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
    width:800px;height:160px;pointer-events:none;z-index:0;
    background:radial-gradient(ellipse 60% 100% at 50% 0%,rgba(124,58,237,.1) 0%,transparent 70%)
  }
  .search-header>*{position:relative;z-index:1}
  .sh-input-autocomplete-wrapper{z-index:10002;min-width:0;width:100%;display:flex;align-items:stretch}
  /* Search row */
  .sh-top{display:flex;align-items:center;gap:12px;margin-bottom:18px;position:relative;z-index:100;justify-content:flex-start;width:100%;padding:0 48px;}
  .sh-search-wrap{flex:0 1 1040px;position:relative;overflow:visible;z-index:100;min-width:0}
  .sh-search{
    display:grid;align-items:stretch;
    grid-template-columns:auto minmax(0,1.9fr) auto minmax(160px,.85fr) auto;
    background:rgba(13,9,37,.9);border:1.5px solid var(--border);
    border-radius:10px;transition:border-color .25s,box-shadow .25s;
    position:relative;
    width: 80%;
  }
  .sh-search:focus-within{
    border-color: var(--purple);
    box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.25), 0 0 20px rgba(124, 58, 237, 0.1);
    transform: translateY(-1px);
  }
  .sh-icon{padding:0 14px;display:flex;align-items:center;font-size:16px;flex-shrink:0;color:var(--purpleL)}
  .sh-input{display:block;width:100%;min-width:0;background:none;border:none;outline:none;font-family:'DM Sans',sans-serif;font-size:15px;color:var(--white);padding:14px 0}
  .sh-input::placeholder{color:var(--muted)}
  .sh-loc-sep{width:1px;background:var(--border);flex-shrink:0;margin:10px 0}
  .sh-loc{display:flex;align-items:center;gap:6px;padding:0 10px;font-size:13px;color:var(--muted);cursor:pointer;white-space:nowrap;min-width:0;max-width:280px;transition:color .2s}
  .sh-loc span{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .sh-loc:hover{color:var(--white)}
  .sh-btn{border-radius: 0px 6px 6px 0px;background:var(--purple);color:var(--white);border:none;padding:0 24px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;flex-shrink:0;transition:background .2s}
  .sh-btn:hover{background:#6D28D9}
  /* Map toggle button in header */
  .sh-map-toggle{
    display:flex;align-items:center;gap:7px;padding:10px 18px;
    border-radius:9px;border:1.5px solid var(--border);background:transparent;
    font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;
    color:var(--muted);cursor:pointer;transition:all .25s;flex-shrink:0;white-space:nowrap
  }
  .sh-map-toggle:hover,.sh-map-toggle.on{border-color:rgba(124,58,237,.45);color:var(--white);background:rgba(124,58,237,.1)}
  
  /* ─────────────────────────────────────────────
     TAB BAR
     ───────────────────────────────────────────── */
  .tab-bar{
    display:flex;align-items:flex-end;gap:0;justify-content:center;
    border-top:1px solid rgba(124,58,237,.1);
    overflow-x:auto;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    width:100%;
    justify-content:flex-start;
    padding:0 48px
  }
  .tab-bar::-webkit-scrollbar{display:none}
  .tab-btn{
    display:flex;align-items:center;gap:8px;
    padding:13px 22px;cursor:pointer;flex-shrink:0;
    font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;
    color:var(--muted);border:none;background:none;
    border-bottom:2px solid transparent;
    transition:all .22s;white-space:nowrap
  }
  .tab-btn:hover{color:var(--white)}
  .tab-btn.active{color:var(--white);border-bottom-color:var(--purple)}
  .tab-count{
    font-family:'Space Mono',monospace;font-size:10px;
    padding:2px 7px;border-radius:10px;
    background:rgba(124,58,237,.15);color:var(--purpleL);letter-spacing:.04em
  }
  .tab-btn.active .tab-count{background:rgba(124,58,237,.3);color:var(--purpleX)}
  
  /* ─────────────────────────────────────────────
     MAIN 3-PANEL LAYOUT
     ───────────────────────────────────────────── */
  .search-body{display:flex;align-items:flex-start;height:calc(100vh - var(--nav-h) - 130px);overflow:hidden}
  
  /* ── SIDEBAR ── */
  .sidebar{
    width:var(--sidebar-w);flex-shrink:0;
    padding:22px 18px;border-right:1px solid var(--border);
    position:sticky;top:var(--nav-h);
    height:100%;
    overflow-y:auto;overflow-x:hidden;
    scrollbar-width:thin;scrollbar-color:rgba(124,58,237,.2) transparent;
    background:var(--navy)
  }
  .sidebar::-webkit-scrollbar{width:3px}
  .sidebar::-webkit-scrollbar-thumb{background:rgba(124,58,237,.25);border-radius:2px}
  .filter-group{margin-bottom:24px}
  .fg-label{
    font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.18em;
    text-transform:uppercase;color:var(--muted);margin-bottom:10px;display:block
  }
  .fg-input{
    width:100%;background:rgba(7,4,26,.6);border:1px solid var(--border);
    border-radius:8px;padding:9px 12px;font-family:'DM Sans',sans-serif;
    font-size:13px;color:var(--white);outline:none;transition:border-color .2s
  }
  .fg-input:focus{border-color:rgba(124,58,237,.5)}
  .fg-input::placeholder{color:var(--muted)}
  .venue-date-input{
    margin-top:8px;
    padding:10px 40px 10px 12px;
    border:1px solid rgba(167,139,250,.45);
    border-radius:10px;
    color:var(--white);
    color-scheme:dark;
    background:
      linear-gradient(180deg,rgba(124,58,237,.18) 0%, rgba(124,58,237,.08) 100%),
      rgba(7,4,26,.8);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 0 0 1px rgba(124,58,237,.1);
    transition:all .22s ease;
  }
  .venue-date-input:hover{
    border-color:rgba(167,139,250,.6);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 0 0 1px rgba(124,58,237,.2), 0 8px 18px rgba(124,58,237,.14);
  }
  .venue-date-input:focus{
    border-color:var(--purpleX);
    box-shadow:0 0 0 3px rgba(124,58,237,.22), 0 10px 22px rgba(124,58,237,.2);
    transform:translateY(-1px);
  }
  .venue-date-input::-webkit-calendar-picker-indicator{
    cursor:pointer;
    padding:4px;
    border-radius:6px;
    background-color:rgba(124,58,237,.22);
    filter:invert(82%) sepia(19%) saturate(1155%) hue-rotate(213deg) brightness(101%) contrast(97%);
    transition:all .18s ease;
  }
  .venue-date-input::-webkit-calendar-picker-indicator:hover{
    background-color:rgba(124,58,237,.34);
    transform:scale(1.06);
  }
  .venue-date-input::-webkit-datetime-edit,
  .venue-date-input::-webkit-datetime-edit-year-field,
  .venue-date-input::-webkit-datetime-edit-month-field,
  .venue-date-input::-webkit-datetime-edit-day-field{
    color:var(--white);
    font-family:'Space Mono',monospace;
    letter-spacing:.02em;
  }
  .fg-row{display:flex;gap:8px;align-items:center}
  .fg-select{
    flex:1;background:rgba(7,4,26,.6);border:1px solid var(--border);
    border-radius:8px;padding:9px 10px;font-family:'DM Sans',sans-serif;
    font-size:13px;color:var(--white);cursor:pointer;outline:none;
    transition:border-color .2s;appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23A78BFA'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 10px center;
    padding-right:28px
  }
  .fg-select:focus{border-color:rgba(124,58,237,.5)}
  .fg-select option{background:#0D0925}
  .fg-chips{display:flex;flex-wrap:wrap;gap:6px}
  .fg-chip{
    padding:5px 11px;border-radius:6px;cursor:pointer;
    font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;
    color:var(--muted);background:rgba(13,9,37,.8);
    border:1px solid rgba(124,58,237,.2);transition:all .2s
  }
  .fg-chip:hover{color:var(--white);border-color:rgba(124,58,237,.45)}
  .fg-chip.on{
    color:var(--purpleL);background:rgba(124,58,237,.15);
    border-color:rgba(124,58,237,.5)
  }
  /* Radius slider */
  .radius-wrap{display:flex;align-items:center;gap:10px}
  .radius-slider{
    flex:1;-webkit-appearance:none;appearance:none;height:3px;
    background:linear-gradient(90deg,var(--purple) 0%,var(--purple) 30%,rgba(124,58,237,.2) 30%,rgba(124,58,237,.2) 100%);
    border-radius:2px;outline:none;cursor:pointer
  }
  .radius-slider::-webkit-slider-thumb{
    -webkit-appearance:none;width:16px;height:16px;border-radius:50%;
    background:var(--purpleL);border:2px solid var(--card);cursor:pointer;
    box-shadow:0 0 8px rgba(124,58,237,.4)
  }
  .radius-val{
    font-family:'Space Mono',monospace;font-size:10px;color:var(--purpleL);
    white-space:nowrap;letter-spacing:.04em;width:36px;flex-shrink:0
  }
  /* Toggle switch */
  .fg-toggle-row{display:flex;align-items:center;justify-content:space-between}
  .fg-toggle-label{font-size:13px;color:var(--muted)}
  .toggle-sw{position:relative;width:38px;height:21px;cursor:pointer;flex-shrink:0}
  .toggle-sw input{opacity:0;width:0;height:0;position:absolute}
  .toggle-track{
    position:absolute;inset:0;border-radius:11px;
    background:rgba(124,58,237,.2);border:1px solid rgba(124,58,237,.3);
    transition:all .25s
  }
  .toggle-track::after{
    content:'';position:absolute;top:3px;left:3px;
    width:13px;height:13px;border-radius:50%;
    background:var(--muted);transition:all .25s
  }
  .toggle-sw input:checked + .toggle-track{background:rgba(124,58,237,.5);border-color:var(--purple)}
  .toggle-sw input:checked + .toggle-track::after{left:20px;background:var(--purpleL)}
  /* Sidebar divider + reset */
  .sidebar-divider{height:1px;background:var(--border);margin:8px 0 20px}
  .sidebar-reset{
    width:100%;padding:10px;border-radius:8px;
    background:transparent;border:1px solid rgba(124,58,237,.25);
    font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;
    color:var(--muted);cursor:pointer;transition:all .2s
  }
  .sidebar-reset:hover{border-color:rgba(124,58,237,.5);color:var(--purpleL);background:rgba(124,58,237,.08)}
  
  /* ── RESULTS PANEL ── */
  .results-panel{flex:1;min-width:0;padding:14px 14px;background:var(--black);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:rgba(124,58,237,.35) transparent;height:100%}
  /* Active filter chips */
  .active-filters{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px;align-items:center}
  .af-chip{
    display:inline-flex;align-items:center;gap:5px;
    padding:4px 10px;border-radius:6px;
    background:rgba(124,58,237,.12);border:1px solid rgba(124,58,237,.3);
    font-size:12px;color:var(--purpleL)
  }
  .af-chip-x{cursor:pointer;opacity:.6;transition:opacity .2s}
  .af-chip-x:hover{opacity:1}
  .af-clear{font-size:12px;color:var(--muted);cursor:pointer;margin-left:4px;transition:color .2s}
  .af-clear:hover{color:var(--purpleL)}
  /* Toolbar */
  .results-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;min-width:0}
  .results-tools{display:flex;align-items:center;gap:10px;min-width:0;flex:0 0 auto;justify-content:flex-end}
  .results-query{min-width:240px;flex:0 1 360px;width:360px;max-width:360px}
  .results-query-input{
    width:100%;max-width:none;
    background:rgba(13,9,37,.9);border:1px solid var(--border);
    border-radius:7px;padding:7px 10px;
    font-family:'DM Sans',sans-serif;font-size:13px;color:var(--white);
    outline:none;transition:border-color .2s, box-shadow .2s
  }
  .results-query-input::placeholder{color:var(--muted)}
  .results-query-input:focus{border-color:rgba(124,58,237,.5);box-shadow:0 0 0 2px rgba(124,58,237,.12)}
  .results-count{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.04em;color:var(--muted);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .results-count span{color:var(--purpleL)}
  .results-loading{display:inline-flex;align-items:center;gap:7px;font-family:'Space Mono',monospace;font-size:9.5px;letter-spacing:.08em;color:var(--purpleL);text-transform:uppercase;flex-shrink:0}
  .results-loading::before{content:'';width:10px;height:10px;border-radius:50%;border:2px solid rgba(124,58,237,.25);border-top-color:var(--purpleL);animation:spinLoader .75s linear infinite}
  @keyframes spinLoader{to{transform:rotate(360deg)}}
  .results-sort{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);flex-shrink:0;white-space:nowrap}
  .sort-select{
    background:rgba(13,9,37,.9);border:1px solid var(--border);
    border-radius:7px;padding:7px 28px 7px 10px;
    font-family:'DM Sans',sans-serif;font-size:13px;color:var(--white);
    cursor:pointer;outline:none;transition:border-color .2s;appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23A78BFA'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 10px center
  }
  .sort-select:focus{border-color:rgba(124,58,237,.5)}
  .sort-select option{background:#0D0925}

  @media(max-width:1280px){
    .results-query{min-width:200px;flex-basis:300px;width:300px;max-width:300px}
  }
  
  /* ─────────────────────────────────────────────
     SPOTLIGHT TIER WRAPPER
     Reconciled: purple animated gradient border
     matching homepage purple brand language
     ───────────────────────────────────────────── */
  .spotlight-wrap{
    position:relative;border-radius:16px;padding:1.5px;
    background:linear-gradient(135deg,var(--purple),var(--purpleX),rgba(124,58,237,.25),var(--purple));
    background-size:300% 300%;
    animation:borderSweep 4s linear infinite
  }
  /* Outer glow halo — stronger than Pro */
  .spotlight-wrap::before{
    content:'';position:absolute;inset:-5px;border-radius:20px;z-index:-1;
    background:inherit;filter:blur(14px);opacity:.28;
    animation:borderSweep 4s linear infinite
  }
  
  /* PRO TIER WRAPPER — subtler purple */
  .pro-wrap{
    position:relative;border-radius:16px;padding:1.5px;
    background:linear-gradient(135deg,rgba(124,58,237,.7),rgba(124,58,237,.2),rgba(124,58,237,.7));
    background-size:200% 200%;
    animation:borderSweep 7s linear infinite
  }
  .pro-wrap::before{
    content:'';position:absolute;inset:-4px;border-radius:20px;z-index:-1;
    background:inherit;filter:blur(10px);opacity:.15;
    animation:borderSweep 7s linear infinite
  }
  .venue-wrap{display:block;width:100%}
  /* PLAIN / BASIC / PLUS WRAPPERS */
  .plain-wrap,.basic-wrap,.plus-wrap{display:block;width:100%;border-radius:14px}
  .venue-wrap.basic-wrap,.venue-wrap.plus-wrap{
    --venue-box-cut:clamp(180px,22vw,340px);
    width:calc(100% - var(--venue-box-cut));
    margin-right:auto
  }
  .venue-wrap.basic-wrap::after,.venue-wrap.plus-wrap::after{
    content:none
  }
  .venue-wrap.basic-wrap .vr-card,.venue-wrap.plus-wrap .vr-card{
    width:100%;
    flex:1 1 auto;
    min-width:0;
    border-radius:14px
  }

  /* ─────────────────────────────────────────────
     VENUE RESULT CARDS (horizontal)
     ───────────────────────────────────────────── */
  .venue-results{display:flex;flex-direction:column;gap:8px;transition:filter .2s ease,opacity .2s ease}
  .venue-results.is-loading{filter:blur(2px);opacity:.55;pointer-events:none}
  .vr-card{
    background:var(--card);border-radius:14px;overflow:hidden;
    cursor:pointer;display:flex;transition:all .28s;
    border:2px solid #3f2c83;position:relative;
    height:330px
  }
  .spotlight-wrap .vr-card{background:rgba(11,8,30,.98);border-color:rgba(124,58,237,.25)}
  .pro-wrap .vr-card{border-color:rgba(124,58,237,.18)}
  .plain-wrap .vr-card{border:1px solid var(--border)}
  .vr-card:hover{transform:translateX(3px);box-shadow:0 16px 48px rgba(0,0,0,.4)}
  .spotlight-wrap .vr-card:hover{box-shadow:0 16px 50px rgba(124,58,237,.2)}
  .pro-wrap .vr-card:hover{box-shadow:0 16px 48px rgba(124,58,237,.14)}
  
  /* ★ Spotlight inner top bar — purple gradient, matches homepage ev-card.spotlight */
  .spotlight-wrap .vr-card::after{
    content:'';position:absolute;top:0;left:0;right:0;height:2px;z-index:6;
    background:linear-gradient(90deg,transparent,var(--purple),var(--purpleX),transparent)
  }
  
  /* Venue image column */
  .vr-img-col{width:228px;flex-shrink:0;position:relative;overflow:hidden}
  .vr-img-col img{width:100%;height:63%;object-fit:cover;display:block;filter:saturate(.85)}
  .vr-img-col::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(3,1,10,.06) 22%,rgba(3,1,10,.28) 58%,rgba(3,1,10,.86) 100%)}
  .vr-img-info{
    position:absolute;
    left:10px;
    right:10px;
    bottom:38px;
    z-index:3;
    display:flex;
    flex-direction:column;
    gap:3px;
  }
  .vr-img-actions{
    position:absolute;
    top:10px;
    left:10px;
    z-index:4;
    display:flex;
    align-items:center;
    gap:6px;
    flex-wrap:nowrap;
    justify-content:flex-start;
    white-space:nowrap;
    background:rgba(3,1,10,.65);
    padding:6px 8px;
    border-radius:8px;
    backdrop-filter:blur(8px);
  }
  .vr-img-name{font-family:'Bebas Neue',cursive;font-size:26px;letter-spacing:.04em;color:var(--white);line-height:1.0;text-shadow:0 2px 10px rgba(0,0,0,.75)}
  .vr-img-meta{font-size:11px;color:rgba(241,239,254,.9);line-height:1.25;text-shadow:0 2px 8px rgba(0,0,0,.72);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  
  /* Tier badge on image */
  .vr-tier-badge{
    position:absolute;top:12px;left:12px;z-index:3;
    padding:4px 10px;border-radius:5px;
    font-family:'Space Mono',monospace;font-size:9px;
    letter-spacing:.08em;text-transform:uppercase;font-weight:700;backdrop-filter:blur(8px)
  }
  /* Spotlight badge — purple-themed, matches homepage ev-img-spot */
  .badge-spotlight{
    background:rgba(124,58,237,.3);border:1px solid rgba(167,139,250,.55);
    color:var(--purpleX);
    display:inline-flex;align-items:center;gap:5px
  }
  .badge-spotlight::before{content:'◉';animation:livePulse 2s infinite;font-size:8px}
  .badge-pro{background:rgba(124,58,237,.25);border:1px solid rgba(124,58,237,.45);color:var(--purpleL)}
  .badge-plus{background:rgba(16,185,129,.15);border:1px solid rgba(16,185,129,.35);color:var(--greenL)}
  .badge-basic{
    background:rgb(96 95 95);
    border:1px solid rgb(255 255 255 / 56%);
    color:rgb(255 255 255 / 67%);
  }
  .vr-dist-badge{
    position:absolute;bottom:12px;left:12px;z-index:3;
    padding:3px 8px;border-radius:4px;
    background:rgba(3,1,10,.7);backdrop-filter:blur(6px);
    font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.06em;color:rgba(241,239,254,.7);
    display:inline-flex;align-items:center;gap:6px
  }
  .vr-tier-inline{
    display:inline-flex;align-items:center;
    padding:2px 7px;border-radius:4px;
    font-size:8px;line-height:1.1;
    letter-spacing:.08em;text-transform:uppercase;
    font-weight:700;
  }
  
  /* Venue card content */
  .vr-content{flex:1;padding:14px 16px;display:flex;flex-direction:column;gap:0;min-width:0}
  .vr-top{display:flex;align-items:flex-start;justify-content:flex-end;gap:10px;margin-bottom:4px}
  .vr-top-left{min-width:0;flex:1}
  .vr-top-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}
  .vr-name{font-family:'Bebas Neue',cursive;font-size:24px;letter-spacing:.04em;color:var(--white);line-height:1.0}
  .vr-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end;max-width:190px}
  .vr-action-btn{
    width:28px;height:28px;border-radius:8px;
    display:inline-flex;align-items:center;justify-content:center;
    border:1px solid rgba(167,139,250,.35);
    background:linear-gradient(135deg,rgba(124,58,237,.16),rgba(13,9,37,.92));
    color:var(--purpleX);text-decoration:none;
    box-shadow:0 6px 14px rgba(3,1,10,.32);
    transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease,color .2s ease
  }
  .vr-action-btn[type="button"]{cursor:pointer}
  .vr-action-btn:hover{
    transform:translateY(-1px);
    border-color:rgba(167,139,250,.65);
    box-shadow:0 10px 22px rgba(124,58,237,.25);
    color:var(--white)
  }
  .vr-action-btn.is-disabled{opacity:.38;cursor:not-allowed;pointer-events:none}

  /* Opening hours mini modal */
  .venue-hours-modal .venue-hours-content{
    width:min(92vw,420px);
    max-width:420px;
    background:linear-gradient(145deg,rgba(13,9,37,.96),rgba(7,4,26,.96));
    border:1px solid rgba(167,139,250,.35);
    box-shadow:0 22px 56px rgba(3,1,10,.72),0 0 0 1px rgba(124,58,237,.2) inset;
    border-radius:14px;
    overflow:hidden;
  }
  .venue-hours-modal .modal-header{
    padding:12px 14px;
    border-bottom:1px solid rgba(124,58,237,.2);
  }
  .venue-hours-modal .modal-header h3{
    margin:0;
    font-family:'Bebas Neue',cursive;
    letter-spacing:.05em;
    font-size:23px;
    color:var(--white);
    line-height:1;
  }
  .venue-hours-schedule{
    padding:12px 14px 14px;
    display:grid;
    gap:6px;
  }
  .venue-hours-day-row{
    display:flex;
    align-items:center;
    gap:8px;
    padding:6px 8px;
    border-radius:8px;
    background:rgba(124,58,237,.07);
    border:1px solid rgba(124,58,237,.16);
  }
  .venue-hours-day-label{
    min-width:38px;
    font-family:'Space Mono',monospace;
    font-size:19px;
    line-height:1;
    color:#ff3b3b;
    font-weight:700;
    letter-spacing:.01em;
  }
  .venue-hours-day-time{
    font-family:'Space Mono',monospace;
    font-size:14px;
    color:rgba(241,239,254,.9);
    font-weight:600;
    letter-spacing:.01em;
  }
  .venue-hours-day-time.is-closed{
    color:rgba(241,239,254,.68);
    font-weight:700;
  }
  /* Spotlight label chip — small, inside card header */
  .vr-spot-label{
    display:inline-flex;align-items:center;gap:5px;
    padding:3px 9px;border-radius:4px;
    background:rgba(124,58,237,.15);border:1px solid rgba(124,58,237,.35);
    font-family:'Space Mono',monospace;font-size:8px;letter-spacing:.12em;text-transform:uppercase;
    color:var(--purpleX);flex-shrink:0;margin-top:2px;white-space:nowrap
  }
  .vr-spot-label::before{content:'◉';animation:livePulse 2s infinite}
  .vr-meta{font-size:12.5px;color:var(--muted);margin-bottom:7px}
  .vr-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
  .vtag{padding:3px 9px;border-radius:4px;font-size:11px;font-weight:500;background:rgba(124,58,237,.1);border:1px solid var(--border);color:var(--muted)}
  
  /* Event sub-rows */
  .vr-events{border-top:1px solid var(--border);padding-top:9px;margin-top:0}
  .vr-events-head{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-bottom:6px}
  .vr-events-label{font-family:'Space Mono',monospace;font-size:8.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:0}
  .vr-event-tabs{display:flex;align-items:center;gap:6px}
  .vr-event-tab{border:1px solid rgba(124,58,237,.22);background:rgba(124,58,237,.07);color:var(--muted);font-family:'Space Mono',monospace;font-size:8.5px;letter-spacing:.08em;text-transform:uppercase;border-radius:999px;padding:4px 8px;cursor:pointer;transition:all .2s}
  .vr-event-tab:hover{border-color:rgba(124,58,237,.45);color:var(--purpleL)}
  .vr-event-tab.active{background:rgba(124,58,237,.22);border-color:rgba(167,139,250,.45);color:var(--purpleX)}
  .vr-gig-type-tabs{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;margin:0;flex-shrink:0;margin-right:auto}
  .vr-gig-type-tab{border:1px solid rgba(167,139,250,.25);background:rgba(15,11,39,.7);color:var(--muted);font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.07em;text-transform:uppercase;border-radius:999px;padding:3px 8px;cursor:pointer;transition:all .2s}
  .vr-gig-type-tab:hover{border-color:rgba(167,139,250,.45);color:var(--purpleL)}
  .vr-gig-type-tab.active{background:rgba(124,58,237,.2);border-color:rgba(167,139,250,.5);color:var(--purpleX)}
  .vr-events-list{display:flex;flex-direction:column;max-height:280px;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(124,58,237,.35) transparent}
  .vr-events-list::-webkit-scrollbar{width:4px}
  .vr-events-list::-webkit-scrollbar-thumb{background:rgba(124,58,237,.35);border-radius:999px}
  .vr-event-row.is-hidden{display:none}
  .vr-event-row{
    display:flex;align-items:stretch;gap:10px;
    padding:6px 0;border-top:1px solid rgba(124,58,237,.07);
    cursor:pointer;border-radius:6px;transition:background .15s
  }
  .vr-event-row:first-of-type{border-top:none}
  .vr-event-row:hover .vr-ev-name{color:var(--purpleL)}
  .vr-ev-thumb{width:80px;height:80px;border-radius:8px;flex-shrink:0;object-fit:cover;object-position:50% 18%;border:1px solid rgba(124,58,237,.25);background:rgba(255,255,255,.9)}
  .vr-ev-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px;justify-content:space-between}
  .vr-ev-main{display:flex;align-items:stretch;gap:10px;min-width:0}
  .vr-ev-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:2px}
  .vr-ev-artist{font-size:12px;font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .vr-ev-name{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s}
  .vr-ev-meta{display:flex;flex-direction:column;justify-content:center;align-items:flex-end;flex-shrink:0;gap:3px}
  .vr-ev-time{font-family:'Space Mono',monospace;font-size:9.5px;color:var(--muted);letter-spacing:.04em}
  .vr-ev-status{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;letter-spacing:.06em;padding:2px 7px;border-radius:3px;margin-top:3px}
  .vr-ev-status.live{background:rgba(16,185,129,.15);color:var(--greenL);border:1px solid rgba(16,185,129,.3)}
  .vr-ev-status.tonight,.vr-ev-status.today{background:rgba(124,58,237,.12);color:var(--purpleL);border:1px solid rgba(124,58,237,.25)}
  .vr-ev-status.tomorrow{background:rgba(16,185,129,.14);color:var(--greenL);border:1px solid rgba(16,185,129,.3)}
  .vr-ev-status.upcoming{background:rgba(241,239,254,.05);color:var(--muted);border:1px solid rgba(241,239,254,.1)}
  .vr-events-empty{padding:8px 0 2px;font-size:11px;color:var(--muted)}
  .vr-ev-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:auto;padding-top:2px}
  .vr-ev-action-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:5px;
    border:1px solid rgba(124,58,237,.3);
    background:rgba(124,58,237,.08);
    color:var(--purpleL);
    border-radius:999px;
    padding:4px 9px;
    font-family:'Space Mono',monospace;
    font-size:8.5px;
    letter-spacing:.05em;
    text-transform:uppercase;
    cursor:pointer;
    transition:all .2s;
    line-height:1.2;
  }
  .vr-ev-action-icon{display:none;font-size:12px;line-height:1}
  .vr-ev-action-label{display:inline}
  .vr-ev-action-btn:hover{
    background:rgba(124,58,237,.2);
    border-color:rgba(167,139,250,.55);
    color:var(--white)
  }
  .vr-ev-audio{font-size:9.5px;color:rgba(167,139,250,.5);cursor:pointer;transition:color .2s;flex-shrink:0}
  button.vr-ev-audio{background:transparent;border:none;padding:0;font-family:inherit;line-height:1.2;text-align:left}
  .vr-ev-audio:hover{color:var(--purpleL)}
  
  /* Venue card footer */
  .vr-footer{display:flex;align-items:center;justify-content:space-between;padding-top:8px;margin-top:auto;border-top:1px solid rgba(124,58,237,.1)}
  .vr-capacity{font-family:'Space Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:.04em}
  .vr-cta-row{display:flex;gap:8px}
  .vr-btn-follow{padding:7px 14px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid rgba(124,58,237,.4);background:transparent;color:var(--purpleL);transition:all .25s;font-family:'DM Sans',sans-serif}
  .vr-btn-follow:hover{background:rgba(124,58,237,.18);border-color:var(--purple);color:var(--white)}
  .vr-btn-follow.following{color:var(--greenL);border-color:rgba(16,185,129,.4);background:rgba(16,185,129,.1)}
  .vr-btn-view{padding:7px 14px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;border:none;background:var(--purple);color:var(--white);transition:all .25s;font-family:'DM Sans',sans-serif}
  .vr-btn-view:hover{background:#6D28D9;box-shadow:0 4px 16px rgba(124,58,237,.3)}
  
  /* ─────────────────────────────────────────────
     GIG CARDS (2-col grid)
     ───────────────────────────────────────────── */
  .gig-results{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
  .gig-card{
    background:var(--card);border:1px solid var(--border);
    border-radius:14px;overflow:hidden;cursor:pointer;
    transition:all .28s;display:flex;flex-direction:column;position:relative
  }
  .spotlight-wrap .gig-card{background:rgba(11,8,30,.98);border:none}
  .pro-wrap .gig-card{background:rgba(11,8,30,.95);border:none}
  .plain-wrap .gig-card{background:var(--card)}
  .gig-card:hover{transform:translateY(-4px);border-color:var(--borderH);box-shadow:0 18px 48px rgba(124,58,237,.16)}
  .spotlight-wrap .gig-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;z-index:6;background:linear-gradient(90deg,transparent,var(--purple),var(--purpleX),transparent)}
  .gig-img{position:relative;height:160px;overflow:hidden;flex-shrink:0}
  .gig-img img{width:100%;height:100%;object-fit:cover;object-position:center 22%;display:block;transition:transform .55s ease;filter:saturate(.85)}
  .gig-card:hover .gig-img img{transform:scale(1.06)}
  .gig-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,9,37,.1) 0%,rgba(13,9,37,.8) 100%)}
  .gig-img-badges{position:absolute;bottom:10px;left:12px;right:12px;z-index:3;display:flex;align-items:flex-end;justify-content:space-between}
  .gig-type-tag{padding:3px 9px;border-radius:4px;background:rgba(13,9,37,.75);backdrop-filter:blur(8px);border:1px solid rgba(167,139,250,.3);font-family:'Space Mono',monospace;font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--purpleL)}
  .gig-live-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:4px;background:rgba(16,185,129,.18);border:1px solid rgba(16,185,129,.45);backdrop-filter:blur(8px);font-size:9px;font-weight:700;letter-spacing:.06em;color:var(--greenL)}
  .gig-live-badge::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--green);animation:livePulse 1.5s infinite}
  .gig-body{padding:16px 18px 18px;flex:1;display:flex;flex-direction:column}
  .gig-artist-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
  .gig-artist-thumb{width:30px;height:30px;border-radius:50%;object-fit:cover;border:1.5px solid rgba(124,58,237,.35);flex-shrink:0}
  .gig-artist-name{font-size:13px;font-weight:600;color:var(--white)}
  .gig-artist-type{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
  .gig-title{font-family:'Bebas Neue',cursive;font-size:22px;letter-spacing:.04em;color:var(--white);line-height:1.0;margin-bottom:6px}
  .gig-venue-row{font-size:12.5px;color:var(--muted);margin-bottom:auto}
  .gig-venue-row span{color:var(--purpleL)}
  .gig-footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid rgba(124,58,237,.1);margin-top:14px}
  .gig-datetime{font-family:'Space Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:.04em;line-height:1.6}
  .gig-price{font-family:'Bebas Neue',cursive;font-size:18px;letter-spacing:.04em;color:var(--white)}
  .gig-price.free{color:var(--greenL)}
  .gig-ticket-btn{padding:7px 14px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;border:none;background:var(--purple);color:var(--white);transition:all .25s;font-family:'DM Sans',sans-serif}
  .gig-ticket-btn:hover{background:#6D28D9;box-shadow:0 4px 14px rgba(124,58,237,.3)}
  
  /* ─────────────────────────────────────────────
     ARTIST CARDS (2-col grid)
     ───────────────────────────────────────────── */
  .artist-results{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
  .artist-card{
    background:var(--card);border:1px solid var(--border);
    border-radius:14px;padding:18px 20px;cursor:pointer;
    transition:all .28s;display:flex;gap:16px;align-items:flex-start;position:relative
  }
  .spotlight-wrap .artist-card{background:rgba(11,8,30,.98);border:none}
  .pro-wrap .artist-card{background:rgba(11,8,30,.95);border:none}
  .artist-card:hover{transform:translateY(-3px);border-color:var(--borderH);box-shadow:0 16px 40px rgba(124,58,237,.15)}
  .spotlight-wrap .artist-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;z-index:3;background:linear-gradient(90deg,transparent,var(--purple),var(--purpleX),transparent)}
  .artist-photo-wrap{flex-shrink:0;position:relative}
  .artist-photo{width:68px;height:68px;border-radius:12px;object-fit:cover;display:block;border:2px solid rgba(124,58,237,.25);transition:border-color .25s}
  .spotlight-wrap .artist-photo{border-color:rgba(124,58,237,.5)}
  .artist-card:hover .artist-photo{border-color:rgba(124,58,237,.6)}
  .artist-type-pill{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);white-space:nowrap;padding:2px 8px;border-radius:4px;font-family:'Space Mono',monospace;font-size:7.5px;letter-spacing:.1em;text-transform:uppercase;background:var(--navy);border:1px solid var(--border);color:var(--purpleL)}
  .artist-info{flex:1;min-width:0}
  .artist-name-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:5px}
  .artist-name{font-family:'Bebas Neue',cursive;font-size:21px;letter-spacing:.04em;color:var(--white);line-height:1.0}
  .artist-dist{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.06em;color:var(--muted);white-space:nowrap;flex-shrink:0;margin-top:2px}
  .artist-members{font-size:12px;color:var(--muted);margin-bottom:8px;line-height:1.5}
  .artist-members b{color:rgba(241,239,254,.7);font-weight:500}
  .artist-tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px}
  .atag{padding:3px 8px;border-radius:4px;font-size:11px;font-weight:500;background:rgba(124,58,237,.1);border:1px solid var(--border);color:var(--muted)}
  .artist-footer{display:flex;gap:7px;align-items:center;padding-top:12px;border-top:1px solid rgba(124,58,237,.1)}
  .artist-btn{padding:6px 12px;border-radius:6px;font-size:11.5px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .25s}
  .artist-btn-follow{border:1.5px solid rgba(124,58,237,.4);background:transparent;color:var(--purpleL)}
  .artist-btn-follow:hover{background:rgba(124,58,237,.18);border-color:var(--purple);color:var(--white)}
  .artist-btn-follow.following{color:var(--greenL);border-color:rgba(16,185,129,.4);background:rgba(16,185,129,.1)}
  .artist-btn-book{border:none;background:var(--purple);color:var(--white)}
  .artist-btn-book:hover{background:#6D28D9}
  .artist-next-gig{margin-left:auto;font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.06em;color:var(--purpleL);text-align:right;white-space:nowrap}
  
  /* ─────────────────────────────────────────────
     MAP PANEL
     ───────────────────────────────────────────── */
  .map-panel{
    width:var(--map-w);flex-shrink:0;position:sticky;top:var(--nav-h);
    height:calc(100vh - var(--nav-h));
    background:var(--navy);border-left:1px solid var(--border);
    overflow:hidden;transition:width .3s ease
  }
  .map-panel.hidden{width:0;border-left:none}
  .map-inner{width:var(--map-w);height:100%;position:relative}
  .map-bg{width:100%;height:100%;background:linear-gradient(135deg,rgba(7,4,26,1) 0%,rgba(13,9,37,.95) 100%);position:relative;overflow:hidden}
  .map-bg::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(124,58,237,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(124,58,237,.05) 1px,transparent 1px);background-size:40px 40px}
  .map-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 80% at 50% 40%,rgba(124,58,237,.07) 0%,transparent 70%)}
  .map-overlay-top{position:absolute;top:0;left:0;right:0;z-index:10;padding:14px 16px;background:linear-gradient(180deg,rgba(7,4,26,.95) 0%,transparent 100%);display:flex;align-items:center;justify-content:space-between}
  .map-label{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
  .map-count{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.08em;color:var(--purpleL)}
  .map-pins{position:absolute;inset:0;z-index:5}
  .map-pin{position:absolute;cursor:pointer;display:flex;flex-direction:column;align-items:center;transition:transform .2s}
  .map-pin:hover{transform:scale(1.15) translateY(-2px)}
  .pin-dot{width:12px;height:12px;border-radius:50%;background:var(--purple);border:2px solid rgba(167,139,250,.6);box-shadow:0 0 10px rgba(124,58,237,.5)}
  .pin-dot.spotlight{background:var(--purple);border-color:var(--purpleX);box-shadow:0 0 14px rgba(124,58,237,.7)}
  .pin-dot.live{background:var(--green);border-color:rgba(110,231,183,.5);box-shadow:0 0 10px rgba(16,185,129,.5);animation:livePulse 1.5s infinite}
  .pin-label{font-family:'Space Mono',monospace;font-size:8px;color:var(--white);background:rgba(3,1,10,.85);padding:2px 6px;border-radius:3px;margin-top:3px;white-space:nowrap;max-width:80px;overflow:hidden;text-overflow:ellipsis;letter-spacing:.04em}
  .map-legend{position:absolute;bottom:50px;left:16px;z-index:10;display:flex;flex-direction:column;gap:6px}
  .legend-item{display:flex;align-items:center;gap:7px;font-family:'Space Mono',monospace;font-size:8px;color:var(--muted);letter-spacing:.06em}
  .legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
  .map-overlay-bottom{position:absolute;bottom:0;left:0;right:0;z-index:10;padding:14px 16px;background:linear-gradient(0deg,rgba(7,4,26,.95) 0%,transparent 100%)}
  .map-expand-btn{width:100%;padding:9px;border-radius:7px;background:rgba(124,58,237,.1);border:1px solid rgba(124,58,237,.25);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;color:var(--purpleL);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:7px}
  .map-expand-btn:hover{background:rgba(124,58,237,.2);border-color:rgba(124,58,237,.5);color:var(--white)}
  
  /* Load more */
  .load-more-wrap{margin-top:24px;text-align:center}
  .load-more{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:8px;border:1.5px solid var(--border);background:transparent;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;color:var(--purpleL);cursor:pointer;transition:all .25s}
  .load-more:hover{border-color:rgba(124,58,237,.5);background:rgba(124,58,237,.1);color:var(--white)}
  
  /* ─────────────────────────────────────────────
     MOBILE FILTER DRAWER (bottom sheet)
     ───────────────────────────────────────────── */
  .filter-overlay{
    display:none;position:fixed;inset:0;z-index:900;
    background:rgba(3,1,10,.7);backdrop-filter:blur(4px)
  }
  .filter-overlay.open{display:block}
  .filter-drawer{
    position:fixed;bottom:0;left:0;right:0;z-index:901;
    background:var(--navy);border-top:1px solid var(--border);
    border-radius:20px 20px 0 0;
    max-height:82vh;overflow-y:auto;
    transform:translateY(100%);transition:transform .32s cubic-bezier(.32,1,.36,1)
  }
  .filter-drawer.open{transform:translateY(0)}
  .drawer-handle-wrap{display:flex;justify-content:center;padding:14px 0 6px;cursor:pointer;sticky;top:0;background:var(--navy);z-index:2;border-bottom:1px solid rgba(124,58,237,.08)}
  .drawer-handle{width:36px;height:4px;border-radius:2px;background:rgba(124,58,237,.3)}
  .drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px 10px}
  .drawer-title{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--purpleL)}
  .drawer-reset{font-size:12px;color:var(--muted);cursor:pointer;transition:color .2s}
  .drawer-reset:hover{color:var(--purpleL)}
  .drawer-body{padding:0 24px 20px}
  /* Tab switcher inside drawer */
  .drawer-tabs{display:flex;gap:3px;background:rgba(13,9,37,.7);border:1px solid var(--border);border-radius:8px;padding:4px;margin-bottom:20px}
  .drawer-tab{flex:1;padding:8px 6px;border-radius:5px;text-align:center;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s;border:none;background:transparent;font-family:'DM Sans',sans-serif;white-space:nowrap}
  .drawer-tab.active{background:var(--card);color:var(--white);box-shadow:0 2px 6px rgba(0,0,0,.4)}
  /* Filter footer with apply button */
  .drawer-footer{position:sticky;bottom:0;background:var(--navy);padding:14px 24px 20px;border-top:1px solid var(--border)}
  .drawer-apply{width:100%;padding:13px;border-radius:10px;background:var(--purple);border:none;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;color:var(--white);cursor:pointer;transition:background .2s;letter-spacing:.02em}
  .drawer-apply:hover{background:#6D28D9}
  
  /* ─────────────────────────────────────────────
     MOBILE TOOLBAR (filter + sort buttons)
     ───────────────────────────────────────────── */
  .mobile-toolbar{
    display:none;
    position:sticky;top:var(--nav-h);z-index:200;
    background:var(--navy);border-bottom:1px solid var(--border);
    padding:10px 16px;gap:8px;align-items:center
  }
  .mt-filter-btn{
    display:flex;align-items:center;gap:7px;
    padding:9px 16px;border-radius:8px;flex:1;
    background:rgba(124,58,237,.08);border:1.5px solid rgba(124,58,237,.25);
    font-family:'DM Sans',sans-serif;font-size:13.5px;font-weight:600;
    color:var(--purpleL);cursor:pointer;transition:all .2s;justify-content:center
  }
  .mt-filter-btn:hover{background:rgba(124,58,237,.15);border-color:rgba(124,58,237,.5)}
  .mt-filter-count{
    display:none;width:18px;height:18px;border-radius:50%;
    background:var(--purple);font-size:10px;font-weight:700;
    color:var(--white);align-items:center;justify-content:center
  }
  .mt-filter-count.visible{display:flex}
  .mt-sort-wrap{position:relative;flex-shrink:0}
  .mt-sort-select{
    padding:9px 32px 9px 14px;border-radius:8px;
    background:rgba(13,9,37,.9);border:1.5px solid var(--border);
    font-family:'DM Sans',sans-serif;font-size:13.5px;font-weight:500;
    color:var(--white);cursor:pointer;outline:none;appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23A78BFA'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 10px center
  }
  .mt-sort-select option{background:#0D0925}
  
  /* ─────────────────────────────────────────────
     RESPONSIVE BREAKPOINTS
     ───────────────────────────────────────────── */
  
  /* ── 1199px: hide map, show map toggle ── */
  @media(max-width:1199px){
    .map-panel{display:none}
    .map-panel.mobile-visible{display:block;position:fixed;right:0;top:var(--nav-h);z-index:400;height:calc(100vh - var(--nav-h))}
    .sh-map-toggle{display:flex}
  }
  
  /* ── 900px: sidebar → drawer, show mobile toolbar ── */
  @media(max-width:1024px){
    .active-filters{
      display:flex;
      flex-wrap:nowrap !important;
      overflow-x:auto;
      overflow-y:hidden;
      -webkit-overflow-scrolling:touch;
      width:100%;
      max-width:100%;
      gap:6px;
      padding-bottom:4px;
      margin-bottom:12px;
      scrollbar-width:thin;
      scrollbar-color:rgba(124,58,237,.35) transparent;
    }
    .active-filters::-webkit-scrollbar{height:3px}
    .active-filters::-webkit-scrollbar-thumb{background:rgba(124,58,237,.35);border-radius:999px}
    .af-chip{
      flex:0 0 auto;
      white-space:nowrap;
      max-width:70vw;
      overflow:hidden;
      text-overflow:ellipsis;
    }
  }

  @media(max-width:900px){
    nav{padding:0 20px;gap:16px}
    .nav-links{display:none}
    .nl-spotlight{display:none}
    .nav-hamburger{display:flex}
    .nav-right .nav-signin{display:none}
  
    .search-header{padding:16px 20px 0}
    .sh-loc-sep,.sh-loc{display:none}
    .sh-top{gap:10px;flex-wrap:wrap;padding:0}
    .sh-search-wrap{order:1;flex:1 1 100%;max-width:100%}
    .sh-search{min-width:0;display:flex;flex-wrap:nowrap;gap:0}
    .sh-input{min-width:0}
    .sh-input-autocomplete-wrapper{min-width:0;flex:1 1 auto}
    .sh-icon{padding:0 10px}
    .sh-map-toggle{order:2;flex-shrink:0;padding:10px 14px;font-size:12px}
    .sh-btn{padding:0 14px;min-width:96px;font-size:12px;border-radius:0 10px 10px 0}
  
    .sidebar{display:none}
    .mobile-toolbar{display:flex}
  
    .search-body{flex-direction:column}
    .results-panel{padding:14px 14px}
  
    /* Hide desktop sort in toolbar, use mobile sort select */
    .results-toolbar .results-sort{display:none}
    .results-tools{width:100%}
    .results-query{flex:1}
    .results-query-input{width:100%;max-width:none}
    .results-toolbar{margin-bottom:10px}
  
    .tab-bar{padding:0 12px}
    .tab-btn{padding:11px 13px;font-size:13px}
    .tab-count{font-size:9px;padding:1px 6px}

    .af-chip{max-width:78vw}

    .results-count{
      white-space:normal;
      overflow:visible;
      text-overflow:clip;
      line-height:1.35;
      font-size:9px;
      letter-spacing:.02em;
    }
  }
  
  /* ── 768px: cards go 1-col ── */
  @media(max-width:768px){
    .venue-wrap.basic-wrap,.venue-wrap.plus-wrap{--venue-box-cut:120px}
    .gig-results{grid-template-columns:1fr}
    .artist-results{grid-template-columns:1fr}
  
    /* Venue card: shrink image column */
    .vr-card{height:312px}
    .vr-img-col{width:116px}
    .vr-img-info{left:8px;right:8px;bottom:34px}
    .vr-img-actions{top:8px;left:8px;gap:5px;padding:5px 7px;border-radius:7px;font-size:12px}
    .vr-img-name{font-size:18px}
    .vr-img-meta{font-size:10px;-webkit-line-clamp:1}
    .vr-name{font-size:20px}
    .vr-content{padding:14px 16px}
    .vr-actions{max-width:160px;gap:5px}
    .vr-action-btn{width:26px;height:26px}
    .vr-ev-thumb{width:40px;height:40px}
    .vr-events-list{max-height:166px}
    .vr-ev-actions{gap:7px}
    .vr-ev-action-btn{width:30px;height:30px;padding:0;border-radius:999px;font-size:0}
    .vr-ev-action-icon{display:inline-block;font-size:13px}
    .vr-ev-action-label{display:none}


    .tab-btn{padding:10px 14px;font-size:12.5px}
    .tab-count{font-size:9px;padding:1px 5px}
  }

  @media(min-width:769px) and (max-width:1100px){
    .venue-wrap.basic-wrap,.venue-wrap.plus-wrap{--venue-box-cut:clamp(120px,16vw,220px)}
  }

  /* ── 480px: compact cards ── */
  @media(max-width:480px){
    .venue-wrap.basic-wrap,.venue-wrap.plus-wrap{display:block;width:100%;border:none}
    .venue-wrap.basic-wrap::after,.venue-wrap.plus-wrap::after{content:none}
    .venue-wrap.basic-wrap .vr-card,.venue-wrap.plus-wrap .vr-card{width:100%;border-radius:14px;border-right:none}
    .sh-map-toggle{display:none}

    .search-header{padding:14px 12px 0}
    .sh-top{margin-bottom:12px}
    .sh-icon{font-size:14px;padding:0 9px}
    .sh-input{font-size:14px;padding:12px 0}
    .sh-btn{min-width:88px;padding:0 10px;font-size:11.5px}
    .tab-bar{padding:0 10px}
    .tab-btn{padding:10px 11px;font-size:12px;gap:6px}
    .mobile-toolbar{padding:8px 10px;gap:6px}
    .mt-filter-btn{padding:8px 10px;font-size:12.5px}
    .mt-sort-select{padding:8px 26px 8px 10px;font-size:12.5px}
    .results-panel{padding:12px 10px}
    .af-chip{max-width:84vw}
  
    /* Venue card goes vertical on very small screens */
    .vr-card{flex-direction:column}
    .vr-card{height:auto;min-height:470px}
    .vr-img-col{width:100%;height:160px}
    .vr-img-col img{height:100%}
    .vr-img-col::after{background:linear-gradient(180deg,transparent 40%,rgba(13,9,37,.8) 100%)}
    .vr-img-info{left:10px;right:10px;bottom:34px}
    .vr-img-actions{top:10px;left:10px;justify-content:flex-start;padding:6px 8px;border-radius:8px}
    .vr-img-name{font-size:22px}
    .vr-img-meta{font-size:10.5px;-webkit-line-clamp:2}
    .vr-content{padding:14px}
    .vr-events-list{max-height:292px}
    .vr-event-row{
      display:grid;
      grid-template-columns:92px minmax(0,1fr);
      grid-template-areas:
        'thumb body'
        'actions actions';
      align-items:start;
      column-gap:10px;
      row-gap:8px;
      padding:10px 0;
    }
    .vr-ev-thumb{
      grid-area:thumb;
      width:92px;
      height:92px;
      border-radius:10px;
      object-position:center 18%;
    }
    .vr-ev-body{display:contents}
    .vr-ev-main{grid-area:body;display:flex;flex-direction:column;gap:4px;min-width:0}
    .vr-ev-info{justify-content:flex-start;gap:4px;padding-top:1px}
    .vr-ev-meta{
      align-items:flex-start;
      justify-content:flex-start;
      gap:6px;
      margin-top:2px;
      padding:0;
      border-radius:0;
      background:transparent;
      border:none;
    }
    .vr-ev-artist,.vr-ev-name{
      white-space:normal;
      overflow:visible;
      text-overflow:clip;
      line-height:1.28;
    }
    .vr-ev-artist{font-size:12px}
    .vr-ev-name{font-size:10.5px}
    .vr-ev-time{
      font-size:11px;
      line-height:1.45;
      color:var(--white);
      letter-spacing:.03em;
      font-weight:700;
    }
    .vr-ev-status{margin-top:2px;font-size:9.5px}
    .vr-ev-actions{
      grid-area:actions;
      gap:6px;
      margin-top:5px;
      flex-wrap:nowrap;
      overflow-x:auto;
      padding-top:0;
      scrollbar-width:none;
    }
    .vr-ev-actions::-webkit-scrollbar{display:none}
    .vr-ev-action-btn{
      width:auto;
      height:auto;
      padding:4px 8px;
      border-radius:999px;
      font-size:8px;
      flex:0 0 auto;
    }
    .vr-ev-action-icon{display:none}
    .vr-ev-action-label{display:inline}
    .vr-top{flex-direction:column;gap:8px}
    .vr-top-right{align-items:flex-start;width:100%}
    .vr-actions{max-width:none;justify-content:flex-start}
    .venue-hours-modal .venue-hours-content{width:min(94vw,380px)}
    .vr-footer{flex-wrap:wrap;gap:10px}
    .vr-cta-row{width:100%}
    .vr-btn-follow,.vr-btn-view{flex:1;text-align:center}


    .gig-title{font-size:19px}
    .artist-name{font-size:18px}
  
    .nav-right{display:none}
    .nav-hamburger{display:flex}
  }

/* ──────────────────────────────────────────────
   ADDRESS AUTOCOMPLETE DROPDOWN
   ────────────────────────────────────────────── */
.sh-input-autocomplete-wrapper {
  position: relative;
  flex: 1;
  overflow: visible;
  z-index: 10002;
}

.sh-autocomplete-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  width: 100%;
  background: linear-gradient(135deg, rgba(13, 9, 37, 0.98) 0%, rgba(7, 4, 26, 0.98) 100%);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 2px solid var(--purple);
  border-radius: 12px;
  max-height: 360px;
  overflow-y: auto;
  z-index: 99999;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.9), 0 0 0 1px rgba(124, 58, 237, 0.3), 0 0 60px rgba(124, 58, 237, 0.15);
  margin: 0;
  padding: 12px 0;
  animation: dropdownSlideIn 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  scrollbar-width: thin;
  scrollbar-color: var(--purple) rgba(124, 58, 237, 0.1);
}

.sh-autocomplete-dropdown::-webkit-scrollbar {
  width: 6px;
}

.sh-autocomplete-dropdown::-webkit-scrollbar-track {
  background: rgba(124, 58, 237, 0.1);
  border-radius: 3px;
}

.sh-autocomplete-dropdown::-webkit-scrollbar-thumb {
  background: var(--purple);
  border-radius: 3px;
}

.sh-autocomplete-item {
  padding: 16px 20px;
  cursor: pointer;
  border-bottom: 1px solid rgba(124, 58, 237, 0.25);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  font-size: 14px;
  color: var(--muted);
  position: relative;
  margin: 4px 8px;
  border-radius: 10px;
  overflow: hidden;
}

.sh-autocomplete-item:last-child {
  border-bottom: none;
}

.sh-autocomplete-item:hover {
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.3) 0%, rgba(167, 139, 250, 0.2) 100%);
  color: var(--white);
  transform: translateX(8px);
  box-shadow: 0 8px 24px rgba(124, 58, 237, 0.4);
  border-color: var(--purple);
}

.sh-autocomplete-item:hover .sh-autocomplete-item-primary {
  color: var(--purpleX);
}

.sh-autocomplete-item-primary {
  display: block;
  color: var(--white);
  font-weight: 700;
  margin-bottom: 4px;
  font-size: 15px;
  line-height: 1.4;
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sh-autocomplete-item-secondary {
  font-size: 12px;
  color: var(--purpleL);
  opacity: 0.85;
  font-weight: 500;
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sh-autocomplete-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 4px 16px 10px;
  margin: 0 8px 6px;
  border-bottom: 1px solid rgba(124, 58, 237, 0.2);
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--purpleL);
}

.sh-autocomplete-clear {
  background: transparent;
  border: 1px solid rgba(124, 58, 237, 0.35);
  color: var(--muted);
  border-radius: 999px;
  padding: 2px 8px;
  font-family: 'DM Sans', sans-serif;
  font-size: 11px;
  cursor: pointer;
  transition: all 0.2s;
}

.sh-autocomplete-clear:hover {
  color: var(--white);
  border-color: rgba(124, 58, 237, 0.55);
  background: rgba(124, 58, 237, 0.12);
}

/* ─────────────────────────────────────────────
     MODAL POPUP
     ───────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(3,1,10,.8);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s
}
.modal-overlay.open{opacity:1;visibility:visible}
.modal-content{
  background:var(--card);border:1px solid var(--border);border-radius:12px;
  max-width:400px;width:90%;box-shadow:0 20px 40px rgba(0,0,0,.5);
  transform:scale(.9);transition:transform .3s
}
.modal-overlay.open .modal-content{transform:scale(1)}
.modal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--border)
}
.modal-header h3{font-size:18px;font-weight:600;color:var(--white);margin:0}
.modal-close{
  background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;
  padding:4px;transition:color .2s
}
.modal-close:hover{color:var(--white)}
.modal-body{padding:24px;color:var(--muted);line-height:1.6}
.modal-body p{margin-bottom:12px}
.modal-footer{
  padding:16px 24px;border-top:1px solid var(--border);text-align:right
}
.modal-btn{
  background:var(--purple);color:var(--white);border:none;border-radius:8px;
  padding:10px 20px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;
  cursor:pointer;transition:background .2s
}
.modal-btn:hover{background:#6D28D9}
.modal-btn-ghost{
  background:transparent;
  border:1px solid rgba(124,58,237,.35);
  color:var(--muted);
  margin-right:8px;
}
.modal-btn-ghost:hover{background:rgba(124,58,237,.12);color:var(--white)}

.gig-music-content,
.gig-playlist-content,
.gig-share-content{max-width:620px;width:min(94vw,620px)}
.gig-music-content{max-width:760px;width:min(96vw,760px)}

.gig-clip-tabs{
  display:flex;
  gap:8px;
  padding:14px 18px 0;
}
.gig-clip-tab{
  border:1px solid rgba(124,58,237,.28);
  background:rgba(124,58,237,.08);
  color:var(--muted);
  border-radius:8px;
  padding:7px 12px;
  font-family:'Space Mono',monospace;
  font-size:11px;
  letter-spacing:.06em;
  text-transform:uppercase;
  cursor:pointer;
}
.gig-clip-tab.active{
  background:rgba(124,58,237,.22);
  border-color:rgba(167,139,250,.55);
  color:var(--purpleX)
}
.gig-clip-pane{padding:16px 18px 20px;display:none;gap:10px;align-content:start;min-height:280px}
.gig-clip-pane.active{display:grid}
.gig-clip-pane audio,
.gig-clip-pane video,
.gig-clip-pane iframe{
  width:100%;
  border-radius:10px;
  border:1px solid rgba(124,58,237,.25);
  background:rgba(3,1,10,.55);
  min-height:56px;
}
.gig-clip-pane video,
.gig-clip-pane iframe{aspect-ratio:16/9;min-height:280px}
.gig-clip-pane video{object-fit:contain;background:#000}
.clip-open-link{
  color:var(--purpleL);
  font-size:12px;
  text-decoration:none;
}
.clip-open-link:hover{color:var(--white)}
.clip-empty{font-size:13px;color:var(--muted);padding:10px 2px}

.gig-playlist-body{padding-top:14px}
.gig-playlist-meta{font-size:12px;color:var(--purpleL);margin-bottom:6px}
.gig-playlist-recipient{font-size:12px;color:var(--muted);margin-bottom:14px}
.gig-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.gig-field-full{grid-column:1 / -1}
.gig-form-field{display:grid;gap:5px}
.gig-form-field span{font-size:11px;color:var(--muted);letter-spacing:.04em}
.gig-form-field input,
.gig-form-field textarea{
  width:100%;
  background:rgba(7,4,26,.7);
  border:1px solid rgba(124,58,237,.25);
  border-radius:8px;
  color:var(--white);
  font-family:'DM Sans',sans-serif;
  padding:9px 10px;
  font-size:13px;
  outline:none;
}
.gig-form-field input:focus,
.gig-form-field textarea:focus{border-color:rgba(167,139,250,.6)}
.playlist-songs-wrap{
  max-height:170px;
  overflow:auto;
  border:1px solid rgba(124,58,237,.24);
  border-radius:8px;
  background:rgba(7,4,26,.62);
  padding:8px;
  display:grid;
  gap:6px;
}
.playlist-song-option{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  border:1px solid rgba(124,58,237,.16);
  border-radius:7px;
  padding:7px 8px;
  color:var(--white);
  font-size:12px;
  cursor:pointer;
  transition:all .2s;
  min-width:0;
}
.playlist-song-option:hover{
  border-color:rgba(167,139,250,.45);
  background:rgba(124,58,237,.12);
}
.playlist-song-option input{
  margin:0;
  width:14px;
  height:14px;
  min-width:14px;
  flex:0 0 14px;
  accent-color:var(--purpleX);
}
.playlist-song-option span{
  display:block;
  flex:1;
  min-width:0;
  color:var(--white);
  text-align:left;
  line-height:1.35;
  white-space:normal;
  word-break:break-word;
  overflow-wrap:anywhere;
}
.playlist-songs-hint{font-size:11px;color:var(--muted);margin-top:5px}
.playlist-empty,
.playlist-loading{font-size:12px;color:var(--muted);padding:6px 2px}

.gig-share-body{display:grid;gap:14px}
.gig-share-platforms{display:flex;flex-wrap:wrap;gap:8px}
.gig-share-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(124,58,237,.3);
  background:rgba(124,58,237,.1);
  color:var(--purpleL);
  border-radius:8px;
  padding:8px 11px;
  font-size:12px;
  text-decoration:none;
  font-weight:600;
  cursor:pointer;
}
.gig-share-btn:hover{background:rgba(124,58,237,.2);color:var(--white)}
.gig-share-copy-row{display:flex;gap:8px;align-items:center}
.gig-share-copy-row input{
  flex:1;
  min-width:0;
  background:rgba(7,4,26,.8);
  border:1px solid rgba(124,58,237,.28);
  border-radius:8px;
  color:var(--white);
  padding:9px 10px;
  font-size:12px;
}

.gig-info-content{max-width:620px;width:min(94vw,620px)}
.gig-info-body{display:grid;gap:16px}
.gig-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.gig-info-item{
  display:grid;
  gap:4px;
  padding:10px 12px;
  border-radius:10px;
  background:rgba(124,58,237,.08);
  border:1px solid rgba(124,58,237,.18);
}
.gig-info-item span{
  font-size:10px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
  font-family:'Space Mono',monospace;
}
.gig-info-item strong{
  font-size:13px;
  line-height:1.35;
  color:var(--white);
  font-weight:600;
}
.gig-info-summary{
  padding:12px 14px;
  border-radius:10px;
  background:rgba(7,4,26,.72);
  border:1px solid rgba(124,58,237,.18);
  color:var(--muted);
  line-height:1.6;
  font-size:13px;
}

@media(max-width:640px){
  .gig-form-grid{grid-template-columns:1fr}
  .gig-share-copy-row{flex-direction:column;align-items:stretch}
  .gig-info-grid{grid-template-columns:1fr}
}