/* ── VFX Design System tokens ─────────────────────────────── */
:root {
  --bg-0:#07070A; --bg-1:#0E0E12; --bg-2:#16161C; --bg-3:#1F1F27; --bg-4:#2A2A33;
  --fg-1:#F2F2F3; --fg-2:#B4B4BC; --fg-3:#7A7A85; --fg-4:#4A4A55;
  --line-1:rgba(255,255,255,.06); --line-2:rgba(255,255,255,.10); --line-3:rgba(255,255,255,.16);
  --amber:#F5A524; --amber-l:#FFE9B8; --amber-d:#A36811;
  --cyan:#2BC4D2; --green:#34D399;
  --new:#FF3D5A; --recent:#FF7A3D; --active:#F5A524; --ongoing:#2BC4D2;
  --disc-comp:#F5A524; --disc-light:#FFD166; --disc-anim:#C77DFF;
  --disc-fx:#FF3D5A; --disc-model:#6DE0EA; --disc-rig:#A8E10C;
  --disc-pipe:#2BC4D2; --disc-prod:#B4B4BC;
  --font-d:'Anton',sans-serif; --font-s:'Space Grotesk',sans-serif; --font-m:'JetBrains Mono',monospace;
  --ease-out:cubic-bezier(.2,.7,.2,1);
}
@keyframes vfxPulse { 0%{transform:scale(1);opacity:.6} 100%{transform:scale(2.4);opacity:0} }
@keyframes vfxBlink { 50%{opacity:.3} }
@keyframes vfxFade  { from{opacity:0} to{opacity:1} }
@keyframes vfxSlide { from{transform:translateX(20px);opacity:0} to{transform:translateX(0);opacity:1} }

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden}
body{background:var(--bg-0);color:var(--fg-1);font-family:var(--font-s);
  -webkit-font-smoothing:antialiased;display:flex;flex-direction:column}
button{font-family:inherit;cursor:pointer}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.07)}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.14)}

/* ── Theme cross-fade (View Transitions) ─────────────────── */
::view-transition-old(root) { animation: vt-fade-out 0.35s ease forwards; }
::view-transition-new(root) { animation: vt-fade-in  0.35s ease forwards; }
@keyframes vt-fade-out { from { opacity:1 } to { opacity:0 } }
@keyframes vt-fade-in  { from { opacity:0 } to { opacity:1 } }
#map { view-transition-name: vfxmap; }
::view-transition-old(vfxmap) { animation: vt-fade-out 0.35s ease forwards; }
::view-transition-new(vfxmap) { animation: vt-fade-in  0.35s ease forwards; }

/* ── Light mode ─────────────────────────────────────────── */
body.light{
  --bg-0:#F5F5F0; --bg-1:#EEEDE8; --bg-2:#E5E4DE; --bg-3:#DDDCD6; --bg-4:#D4D3CC;
  --fg-1:#1A1A18; --fg-2:#3A3A36; --fg-3:#6A6A64; --fg-4:#9A9A94;
  --line-1:rgba(0,0,0,.06); --line-2:rgba(0,0,0,.10); --line-3:rgba(0,0,0,.18);
}
body.light .topbar{background:rgba(245,245,240,.92)}
body.light .rail{background:rgba(238,237,232,.92)}
body.light .feed{background:rgba(238,237,232,.92)}
body.light .jcard{border-color:var(--line-2)}
body.light .jcard.selected{background:var(--bg-3)}
body.light .search-input{background:rgba(238,237,232,.8)}
body.light .legend{background:rgba(238,237,232,.92)}
body.light .hud{background:rgba(238,237,232,.85)}
body.light .studio-card{background:var(--bg-2)}
body.light .list-row:hover{background:rgba(0,0,0,.03)}

/* ── TopBar ──────────────────────────────────────────────── */
.topbar{
  flex:none;height:56px;display:flex;align-items:center;gap:24px;
  padding:0 20px;position:relative;z-index:50;
  background:rgba(7,7,10,.85);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line-2);
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit;flex:none}
.brand-icon svg{display:block}
.brand-text{
  font-family:var(--font-d);font-size:22px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--fg-1);white-space:nowrap;
}
.brand-dot{color:var(--amber)}
.search-wrap{
  position:relative;flex:1;max-width:540px;
  display:flex;align-items:center;
}
.search-icon{position:absolute;left:12px;color:var(--fg-3);display:flex}
.search-input{
  width:100%;
  background:rgba(14,14,18,.6);border:1px solid var(--line-2);
  color:var(--fg-1);font-family:var(--font-s);font-size:13px;
  padding:8px 48px 8px 36px;outline:none;
  transition:border-color .12s;
}
.search-input::placeholder{color:var(--fg-3)}
.search-input:focus{border-color:rgba(245,165,36,.4)}
.search-clear{
  position:absolute;right:10px;display:none;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;background:var(--fg-3);
  color:var(--bg-0);cursor:pointer;border:0;padding:0;flex:none;
  font-size:10px;line-height:1;transition:background .12s;
}
.search-clear:hover{background:var(--fg-1)}
.search-clear.visible{display:flex}
.search-kbd{
  position:absolute;right:10px;pointer-events:none;
  font-family:var(--font-m);font-size:10px;color:var(--fg-3);
  border:1px solid var(--line-2);padding:2px 6px;
}
.topnav{display:flex;gap:18px;flex:none}
.topnav a{
  font-family:var(--font-m);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--fg-2);cursor:pointer;text-decoration:none;
  transition:color .12s;
}
.topnav a:hover,.topnav a.active{color:var(--fg-1)}
.topright{margin-left:auto;display:flex;align-items:center;gap:8px;flex:none}
.icon-btn{
  position:relative;
  width:32px;height:32px;background:transparent;
  border:1px solid var(--line-2);color:var(--fg-2);
  display:flex;align-items:center;justify-content:center;
  transition:border-color .12s,color .12s;
}
.icon-btn:hover{border-color:var(--line-3);color:var(--fg-1)}
.topbar-badge{
  position:absolute;top:-5px;right:-5px;
  min-width:16px;height:16px;border-radius:8px;
  background:var(--new);color:#fff;
  font-family:var(--font-m);font-size:8px;font-weight:700;
  display:flex;align-items:center;justify-content:center;padding:0 3px;
  pointer-events:none;border:1px solid var(--bg-0);
}
.side-panel{
  position:fixed;top:56px;right:0;bottom:0;
  width:min(420px,90vw);
  background:var(--bg-1);border-left:1px solid var(--line-2);
  display:flex;flex-direction:column;z-index:90;
  box-shadow:-20px 0 50px rgba(0,0,0,.6);
  animation:vfxSlide .2s var(--ease-out);
}
.sp-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;border-bottom:1px solid var(--line-2);flex:none;
}
.sp-title{font-family:var(--font-m);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3)}
.sp-count{font-family:var(--font-m);font-size:10px;color:var(--fg-4)}
.sp-close{
  background:transparent;border:1px solid var(--line-2);color:var(--fg-2);
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  transition:all .12s;
}
.sp-close:hover{border-color:var(--line-3);color:var(--fg-1)}
.sp-body{flex:1;overflow-y:auto}
.sp-empty{
  padding:40px 20px;text-align:center;
  font-family:var(--font-m);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--fg-4);line-height:2;
}
.sp-saved-row{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;border-bottom:1px solid var(--line-1);
  cursor:pointer;transition:background .1s;
}
.sp-saved-row:hover{background:rgba(255,255,255,.025)}
.sp-rm{
  margin-left:auto;flex:none;width:22px;height:22px;
  background:transparent;border:1px solid var(--line-2);color:var(--fg-4);
  display:flex;align-items:center;justify-content:center;transition:all .12s;
}
.sp-rm:hover{border-color:var(--new);color:var(--new)}
body.light .side-panel{background:var(--bg-1)}
body.light .sp-saved-row:hover{background:rgba(0,0,0,.03)}
.primary-btn{
  background:var(--amber);color:#1a1200;border:0;
  padding:8px 16px;font-family:var(--font-m);font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;font-weight:500;
}
.primary-btn:hover{background:#D4881A}

/* ── Main layout ─────────────────────────────────────────── */
.main{display:flex;flex:1;min-height:0}
.view-panel{display:none;flex:1;min-height:0;overflow-y:auto;flex-direction:column}
.view-panel.active{display:flex}

/* ── List view ───────────────────────────────────────────── */
.list-view{padding:24px 32px;display:flex;flex-direction:column;gap:0}
.list-toolbar{display:flex;align-items:center;justify-content:space-between;padding-bottom:12px}
.list-toolbar-label{font-family:var(--font-m);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-4)}
.csv-btn{
  font-family:var(--font-m);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  background:transparent;border:1px solid var(--line-2);color:var(--fg-3);
  padding:6px 12px;cursor:pointer;transition:border-color .12s,color .12s;
}
.csv-btn:hover{border-color:var(--line-3);color:var(--fg-1)}
.list-table-head{
  display:grid;grid-template-columns:2fr 1.4fr 1fr .8fr .8fr .8fr;
  gap:12px;padding:8px 12px;
  font-family:var(--font-m);font-size:9px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--fg-4);border-bottom:1px solid var(--line-1);
}
.list-col-btn{
  background:none;border:none;padding:0;color:inherit;font:inherit;letter-spacing:inherit;
  text-transform:inherit;cursor:pointer;display:flex;align-items:center;gap:5px;
  transition:color .12s;
}
.list-col-btn:hover{color:var(--fg-2)}
.list-col-btn.active{color:var(--fg-1)}
.list-sort-icon{font-size:9px;opacity:.4;line-height:1}
.list-col-btn.active .list-sort-icon{opacity:1;color:var(--amber)}
.list-row{
  display:grid;grid-template-columns:2fr 1.4fr 1fr .8fr .8fr .8fr;
  gap:12px;padding:10px 12px;border-bottom:1px solid var(--line-1);
  cursor:pointer;transition:background .1s;align-items:center;
}
.list-row:hover{background:rgba(255,255,255,.025)}
.list-role{font-family:var(--font-s);font-size:13px;color:var(--fg-1)}
.list-studio{font-family:var(--font-s);font-size:12px;color:var(--fg-2)}
.list-loc{font-family:var(--font-m);font-size:11px;color:var(--fg-3)}
.list-badge{
  font-family:var(--font-m);font-size:9px;letter-spacing:.12em;text-transform:uppercase;
  padding:3px 7px;border:1px solid currentColor;width:fit-content;
}
.list-dot{width:7px;height:7px;border-radius:50%;flex:none}

/* ── Studios view ────────────────────────────────────────── */
.studios-view{padding:24px 32px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;align-content:start}
.studio-card{
  background:var(--bg-1);border:1px solid var(--line-1);padding:20px;
  cursor:pointer;transition:border-color .15s;
}
.studio-card:hover{border-color:var(--line-3)}
.sc-name{font-family:var(--font-s);font-size:15px;font-weight:600;color:var(--fg-1);margin-bottom:6px}
.sc-loc{font-family:var(--font-m);font-size:10px;letter-spacing:.12em;color:var(--fg-3);text-transform:uppercase;margin-bottom:14px}
.sc-roles{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.sc-role-chip{
  font-family:var(--font-m);font-size:9px;letter-spacing:.10em;text-transform:uppercase;
  padding:3px 7px;border:1px solid var(--line-2);color:var(--fg-3);
}
.sc-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px;padding-top:12px;border-top:1px solid var(--line-1)}
.sc-count{font-family:var(--font-m);font-size:22px;color:var(--amber);font-variant-numeric:tabular-nums}
.sc-count-l{font-family:var(--font-m);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-4)}

/* ── Filter Rail ─────────────────────────────────────────── */
.rail{
  width:280px;flex:none;
  background:rgba(14,14,18,.8);backdrop-filter:blur(10px);
  border-right:1px solid var(--line-1);
  overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:0;
  position:relative;z-index:1;
}
.rail-head{
  display:flex;align-items:center;gap:8px;
  padding-bottom:14px;margin-bottom:14px;
  border-bottom:1px solid var(--line-1);
}
.live-dot{
  width:6px;height:6px;border-radius:999px;flex:none;
  background:var(--green);box-shadow:0 0 8px var(--green);
  animation:vfxBlink 1.6s ease-in-out infinite;
}
.rail-head-title{font-family:var(--font-m);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.rail-head-count{margin-left:auto;font-family:var(--font-m);font-size:10px;letter-spacing:.14em;color:var(--fg-3)}
.f-section{margin-bottom:20px}
.f-section-head{
  font-family:var(--font-m);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--fg-3);margin-bottom:10px;
}
.chip-wrap{display:flex;flex-wrap:wrap;gap:6px}
.disc-chip{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.02);border:1px solid var(--line-2);
  color:var(--fg-2);font-family:var(--font-m);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;
  padding:5px 9px;transition:all .12s;
}
.disc-chip:hover{border-color:var(--line-3);color:var(--fg-1)}
.disc-chip.on{background:rgba(255,255,255,.05)}
.chip-dot{width:6px;height:6px;border-radius:999px;flex:none}
.guide-section{padding:20px 0 8px;border-top:1px solid var(--line-1);margin-top:8px}
.guide-head{font-family:var(--font-m);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-4);margin-bottom:12px}
.guide-list{list-style:none;display:flex;flex-direction:column;gap:9px}
.guide-list li{font-family:var(--font-m);font-size:10px;color:var(--fg-3);line-height:1.5;padding-left:10px;position:relative}
.guide-list li::before{content:'·';position:absolute;left:0;color:var(--fg-4)}
.guide-key{color:var(--fg-2);font-weight:500}
.soft-chip{
  background:rgba(255,255,255,.02);border:1px solid var(--line-2);
  color:var(--fg-2);font-family:var(--font-m);font-size:10px;
  letter-spacing:.10em;padding:5px 9px;transition:border-color .12s;
}
.soft-chip:hover{border-color:var(--line-3)}
.soft-chip.on{border-color:var(--cyan);color:var(--cyan);background:rgba(43,196,210,.10)}
.segmented{display:flex;border:1px solid var(--line-2)}
.seg-item{
  flex:1;background:transparent;border:0;padding:6px 0;
  color:var(--fg-3);font-family:var(--font-m);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;transition:all .12s;
}
.seg-item:hover{color:var(--fg-1)}
.seg-item.on{background:var(--amber);color:#1a1200}

/* ── Map Stage ───────────────────────────────────────────── */
.stage{position:relative;flex:1;min-width:0;background:var(--bg-0);overflow:hidden;z-index:0}
#map{position:absolute;inset:0}

/* Leaflet overrides */
.leaflet-container{background:#07070A!important}
.leaflet-control-zoom{border:1px solid var(--line-2)!important;border-radius:0!important;margin:16px!important}
.leaflet-control-zoom a{
  background:rgba(14,14,18,.9)!important;border:none!important;border-bottom:1px solid var(--line-2)!important;
  color:var(--fg-2)!important;font-family:var(--font-m)!important;font-size:14px!important;
  display:flex!important;align-items:center!important;justify-content:center!important;width:32px!important;height:32px!important;
}
.leaflet-control-zoom a:hover{background:rgba(30,30,38,.9)!important;color:var(--fg-1)!important}
.leaflet-control-zoom-in{border-bottom:1px solid var(--line-2)!important}
.leaflet-control-attribution{
  background:rgba(7,7,10,.6)!important;color:var(--fg-4)!important;
  font-family:var(--font-m)!important;font-size:9px!important;
}
.leaflet-control-attribution a{color:var(--fg-3)!important}
.leaflet-popup-content-wrapper{
  background:rgba(14,14,18,.95)!important;border-radius:0!important;
  border:1px solid var(--line-2)!important;
  box-shadow:0 8px 32px rgba(0,0,0,.65)!important;padding:0!important;
}
.leaflet-popup-content{margin:0!important;width:260px!important}
.leaflet-popup-tip-container{margin-top:-1px}
.leaflet-popup-tip{background:rgba(14,14,18,.95)!important}
.leaflet-popup-close-button{color:var(--fg-3)!important;font-size:18px!important;top:8px!important;right:10px!important}

/* Light mode — Leaflet overrides */
body.light .leaflet-control-zoom{border-color:rgba(0,0,0,.12)!important}
body.light .leaflet-control-zoom a{background:rgba(245,245,240,.95)!important;color:var(--fg-2)!important;border-bottom-color:rgba(0,0,0,.10)!important}
body.light .leaflet-control-zoom a:hover{background:rgba(230,229,224,.95)!important;color:var(--fg-1)!important}
body.light .leaflet-control-attribution{background:rgba(245,245,240,.7)!important}
body.light .leaflet-popup-content-wrapper{background:rgba(245,245,240,.98)!important;border-color:rgba(0,0,0,.12)!important;box-shadow:0 8px 32px rgba(0,0,0,.15)!important}
body.light .leaflet-popup-tip{background:rgba(245,245,240,.98)!important}
body.light .leaflet-popup-close-button{color:var(--fg-3)!important}
body.light .pop-job:hover{background:rgba(0,0,0,.04)}
body.light .timecode{background:rgba(245,245,240,.85)!important;border-color:rgba(0,0,0,.12)!important;color:var(--fg-2)}
body.light .stage{background:var(--bg-0)}
body.light #map{background:var(--bg-0)}
body.light .leaflet-container{background:var(--bg-0)!important}
body.light .studio-row{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.08)}

/* Custom pin marker */
.pin-wrap{position:relative;width:24px;height:24px;display:flex;align-items:center;justify-content:center}
.pin-pulse{
  position:absolute;width:24px;height:24px;border-radius:999px;border:1px solid;
  animation:vfxPulse 2.2s ease-out infinite;
}
.pin-dot{width:8px;height:8px;border-radius:999px;position:relative;z-index:2;flex:none}
.pin-count{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:var(--font-m);font-size:8px;font-weight:700;
  color:var(--bg-0);z-index:3;pointer-events:none;white-space:nowrap;
}
.pin-wrap.focused .pin-dot{width:12px;height:12px}

/* Popup content */
.pop-head{padding:12px 16px 10px;border-bottom:1px solid var(--line-1)}
.pop-city{font-family:var(--font-s);font-weight:600;font-size:14px;color:var(--fg-1)}
.pop-cnt{font-family:var(--font-m);font-size:10px;letter-spacing:.14em;color:var(--amber);margin-top:2px}
.pop-list{max-height:200px;overflow-y:auto}
.pop-job{
  padding:9px 16px;border-bottom:1px solid var(--line-1);cursor:pointer;
  transition:background .1s;
}
.pop-job:last-child{border-bottom:none}
.pop-job:hover{background:rgba(245,165,36,.04)}
.pop-job-title{font-size:13px;font-weight:600;color:var(--fg-1);letter-spacing:-.005em}
.pop-job-studio{font-family:var(--font-m);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-2);margin-top:2px}
.pop-tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:5px}
.ptag{font-family:var(--font-m);font-size:9px;letter-spacing:.14em;text-transform:uppercase;
  border:1px solid var(--line-2);padding:2px 6px;color:var(--fg-2)}

/* ── HUD Panel ───────────────────────────────────────────── */
.hud{
  position:absolute;top:20px;right:20px;z-index:800;
  background:rgba(14,14,18,.85);backdrop-filter:blur(10px);
  border:1px solid var(--line-2);min-width:340px;
  pointer-events:none;
}
.hud-head{
  display:flex;align-items:center;gap:8px;padding:8px 12px;
  border-bottom:1px solid var(--line-1);
  background:linear-gradient(180deg,rgba(255,255,255,.02),transparent);
}
.hud-dot{
  width:6px;height:6px;border-radius:999px;flex:none;
  background:var(--green);box-shadow:0 0 8px var(--green);
  animation:vfxBlink 1.6s ease-in-out infinite;
}
.hud-title{font-family:var(--font-m);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.hud-sig{margin-left:auto;font-family:var(--font-m);font-size:10px;letter-spacing:.14em;color:var(--fg-3)}
.hud-grid{display:grid;grid-template-columns:1fr 1fr 1fr;padding:14px;gap:18px}
.hud-stat{display:flex;flex-direction:column;gap:2px}
.hud-n{font-family:var(--font-m);font-size:26px;font-variant-numeric:tabular-nums;line-height:1}
.hud-l{font-family:var(--font-m);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3);margin-top:4px}

/* ── Legend ──────────────────────────────────────────────── */
.legend{
  position:absolute;bottom:56px;left:20px;z-index:800;
  background:rgba(14,14,18,.85);backdrop-filter:blur(10px);
  border:1px solid var(--line-2);padding:12px 14px;min-width:200px;
}
.legend-head{
  display:flex;justify-content:space-between;
  font-family:var(--font-m);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--fg-3);margin-bottom:8px;
}
.legend-head span:last-child{color:var(--amber)}
.legend-row{display:flex;align-items:center;gap:10px;padding:3px 0}
.legend-dot{width:10px;height:10px;border-radius:999px;flex:none}
.legend-name{font-family:var(--font-m);font-size:11px;letter-spacing:.14em;text-transform:uppercase;flex:1}
.legend-cnt{font-family:var(--font-m);font-size:11px;color:var(--fg-3);font-variant-numeric:tabular-nums}
.legend-age{font-family:var(--font-m);font-size:9px;color:var(--fg-4);letter-spacing:.08em;flex:1}

/* ── Film crops + Timecode ───────────────────────────────── */
.crop{
  position:absolute;width:18px;height:18px;
  border-color:rgba(245,165,36,.55);border-style:solid;
  z-index:800;pointer-events:none;
}
.crop-tl{top:12px;left:12px;border-width:1px 0 0 1px}
.crop-tr{top:12px;right:12px;border-width:1px 1px 0 0}
.crop-bl{bottom:12px;left:12px;border-width:0 0 1px 1px}
.crop-br{bottom:12px;right:12px;border-width:0 1px 1px 0}
.timecode{
  position:absolute;bottom:14px;left:50%;transform:translateX(-50%);z-index:800;
  display:flex;gap:10px;align-items:center;
  font-family:var(--font-m);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--fg-2);background:rgba(7,7,10,.7);backdrop-filter:blur(10px);
  border:1px solid var(--line-2);padding:6px 14px;white-space:nowrap;
}
.tc-live{color:var(--green)}
.tc-sep{color:var(--fg-4)}
.tc-sig{color:var(--amber)}

/* ── Live Feed ───────────────────────────────────────────── */
.feed{
  width:380px;flex:none;
  background:rgba(14,14,18,.92);backdrop-filter:blur(10px);
  border-left:1px solid var(--line-1);
  display:flex;flex-direction:column;
  position:relative;z-index:1;
}
.feed-head{
  display:flex;align-items:center;gap:8px;
  padding:14px 16px;border-bottom:1px solid var(--line-2);flex:none;
}
.feed-dot{
  width:6px;height:6px;border-radius:999px;flex:none;
  background:var(--amber);box-shadow:0 0 8px var(--amber);
  animation:vfxBlink 1.6s ease-in-out infinite;
}
.feed-title{font-family:var(--font-m);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.feed-right{margin-left:auto;font-family:var(--font-m);font-size:10px;letter-spacing:.14em;color:var(--fg-3)}
.feed-list{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}

/* Job Card */
.jcard{
  display:block;width:100%;text-align:left;
  background:var(--bg-2);border:1px solid var(--line-1);
  padding:12px 14px;transition:all .12s;color:inherit;
}
.jcard:hover{border-color:var(--line-2);background:var(--bg-3)}
.jcard.selected{
  border-color:rgba(245,165,36,.6);
  background:rgba(245,165,36,.04);
  box-shadow:0 0 0 1px rgba(245,165,36,.25);
}
.jcard-eye{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-m);font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--fg-3);margin-bottom:8px;
}
.eye-dot{width:6px;height:6px;border-radius:999px;display:inline-block;flex:none}
.eye-sep{color:var(--fg-4)}
.eye-id{margin-left:auto;color:var(--fg-4)}
.jcard-title{
  font-family:var(--font-s);font-weight:600;font-size:15px;
  color:var(--fg-1);line-height:1.25;letter-spacing:-.005em;margin-bottom:4px;
}
.jcard-studio{
  font-family:var(--font-m);font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--fg-2);margin-bottom:10px;
}
.jcard-tags{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.jtag{
  font-family:var(--font-m);font-size:9px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--fg-2);border:1px solid var(--line-2);padding:3px 7px;
}
.jtag-disc{border:1px solid;padding:3px 7px;
  font-family:var(--font-m);font-size:9px;letter-spacing:.14em;text-transform:uppercase;}
.jtag-ml{margin-left:auto}

/* ── Drawer ──────────────────────────────────────────────── */
.drawer-backdrop{
  position:fixed;inset:0;z-index:100;
  background:rgba(0,0,0,.5);backdrop-filter:blur(2px);
  animation:vfxFade .18s ease-out;
}
.drawer{
  position:absolute;right:0;top:0;bottom:0;
  width:min(520px,90vw);
  background:var(--bg-1);
  border-left:1px solid var(--line-2);
  padding:20px 24px;display:flex;flex-direction:column;gap:14px;
  overflow-y:auto;box-shadow:-24px 0 60px rgba(0,0,0,.7);
  animation:vfxSlide .22s var(--ease-out);
}
.drawer-head{display:flex;align-items:center;gap:10px}
.drawer-eye{
  flex:1;display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-m);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--fg-3);
}
.drawer-close{
  width:32px;height:32px;background:transparent;
  border:1px solid var(--line-2);color:var(--fg-2);
  display:flex;align-items:center;justify-content:center;
  transition:all .12s;
}
.drawer-close:hover{border-color:var(--line-3);color:var(--fg-1)}
.drawer-title{
  font-family:var(--font-s);font-weight:700;font-size:28px;
  color:var(--fg-1);line-height:1.1;letter-spacing:-.01em;
}
.drawer-studio{
  font-family:var(--font-m);font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--amber);
}
.drawer-city{
  font-family:var(--font-m);font-size:11px;letter-spacing:.14em;color:var(--fg-2);
  display:flex;align-items:center;gap:6px;
}
.drawer-tags{display:flex;flex-wrap:wrap;gap:6px;padding-top:4px}
.drawer-meta{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;
  padding:14px 0;border-top:1px solid var(--line-1);border-bottom:1px solid var(--line-1);
}
.dmeta-stat{display:flex;flex-direction:column;gap:4px}
.dmeta-l{font-family:var(--font-m);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3)}
.dmeta-v{font-family:var(--font-m);font-size:14px;color:var(--fg-1);font-variant-numeric:tabular-nums;letter-spacing:.02em}
.dmeta-sub{color:var(--fg-3);font-size:11px}
.drawer-section{display:flex;flex-direction:column;gap:8px}
.drawer-sec-head{font-family:var(--font-m);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3)}
.drawer-body{font-family:var(--font-s);font-size:14px;line-height:1.55;color:var(--fg-2)}
.studio-row{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--bg-2);border:1px solid var(--line-1);padding:12px 14px;
}
.studio-name{font-family:var(--font-s);font-weight:600;font-size:15px;color:var(--fg-1)}
.studio-meta{font-family:var(--font-m);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-3);margin-top:4px}
.ghost-btn{
  background:transparent;color:var(--fg-1);border:1px solid var(--line-2);
  padding:8px 14px;font-family:var(--font-m);font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;transition:border-color .12s;
}
.ghost-btn:hover{border-color:var(--line-3)}
.drawer-actions{display:flex;gap:8px;margin-top:auto;padding-top:16px;border-top:1px solid var(--line-1)}
.primary-btn-lg{
  flex:1;background:var(--amber);color:#1a1200;border:0;
  padding:12px 18px;font-family:var(--font-m);font-size:12px;
  letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
}
.primary-btn-lg:hover{background:#D4881A}
.ghost-btn-lg{
  background:transparent;color:var(--fg-1);border:1px solid var(--line-2);
  padding:12px 18px;font-family:var(--font-m);font-size:12px;
  letter-spacing:.18em;text-transform:uppercase;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
}
.ghost-btn-lg:hover{border-color:var(--line-3)}

.hidden{display:none!important}

/* ── Mobile bottom nav (hidden on desktop) ───────────────── */
.mobile-nav{display:none}

/* Sheet drag handle (hidden on desktop, shown via mobile sheet positioning) */
.sheet-handle{
  display:none;width:100%;padding:14px 0 8px;
  cursor:grab;flex-shrink:0;
}
.sheet-handle::after{
  content:'';display:block;
  width:36px;height:4px;border-radius:2px;
  background:var(--line-3);margin:0 auto;
}

/* ── Mobile layout (≤768px wide, or phone in landscape) ─── */
@media (max-width:768px), (max-height:500px) and (orientation:landscape) {

  /* Topbar — condense, hide desktop nav */
  .topnav{display:none}
  .topbar{gap:10px;padding:0 12px}
  .brand-text{font-size:17px;letter-spacing:.04em}
  .search-wrap{max-width:none}
  .search-kbd{display:none}
  .search-input{padding-right:36px}
  .topright>a.primary-btn{display:none}
  .topright>a.icon-btn{display:none}

  /* Body — reserve space for mobile nav */
  body{padding-bottom:56px}

  /* Stage fills all available space */
  .stage{flex:1;min-width:0}

  /* HUD — span full width, smaller numbers */
  .hud{
    top:12px;right:12px;left:12px;min-width:0;width:auto;
  }
  .hud-grid{padding:10px 12px;gap:8px}
  .hud-n{font-size:20px}

  /* Legend — float above mobile nav */
  .legend{bottom:calc(56px + 14px);left:12px}

  /* Zoom control — move to bottom-right, clear of feed sheet and HUD */
  .leaflet-top.leaflet-left{top:auto!important;bottom:12px!important;left:auto!important;right:12px!important}

  /* Timecode — too cramped on mobile */
  .timecode{display:none}

  /* Sheet handles — visible and interactive on mobile */
  .sheet-handle{display:block}

  /* Rail → bottom sheet */
  .rail{
    position:fixed;bottom:56px;left:0;right:0;
    width:100%;height:75vh;
    z-index:95;flex:none;
    border-right:none;border-top:1px solid var(--line-2);
    border-radius:16px 16px 0 0;
    box-shadow:0 -20px 60px rgba(0,0,0,.5);
    transform:translateY(100%);
    transition:transform .3s var(--ease-out);
  }
  .rail.sheet-open{transform:translateY(0)}
  body.light .rail{box-shadow:0 -20px 60px rgba(0,0,0,.15)}

  /* Feed → bottom sheet */
  .feed{
    position:fixed;bottom:56px;left:0;right:0;
    width:100%;height:75vh;
    z-index:95;flex:none;
    border-left:none;border-top:1px solid var(--line-2);
    border-radius:16px 16px 0 0;
    box-shadow:0 -20px 60px rgba(0,0,0,.5);
    transform:translateY(100%);
    transition:transform .3s var(--ease-out);
  }
  .feed.sheet-open{transform:translateY(0)}
  body.light .feed{box-shadow:0 -20px 60px rgba(0,0,0,.15)}

  /* Side panels (saved/notif) — full width on mobile */
  .side-panel{width:100%;top:56px}

  /* Drawer — full width, pad bottom so actions clear the mobile nav */
  .drawer{width:100%;padding-bottom:calc(56px + 20px)}

  /* Mobile bottom nav */
  .mobile-nav{
    display:flex;
    position:fixed;bottom:0;left:0;right:0;height:56px;
    z-index:100;
    background:var(--bg-1);border-top:1px solid var(--line-2);
  }
  body.light .mobile-nav{background:var(--bg-1)}
  .mnav-item{
    flex:1;display:flex;flex-direction:column;
    align-items:center;justify-content:center;gap:4px;
    background:transparent;border:none;
    color:var(--fg-3);font-family:var(--font-m);
    font-size:9px;letter-spacing:.14em;text-transform:uppercase;
    transition:color .12s;padding:8px 0;
  }
  .mnav-item.on{color:var(--amber)}
  .mnav-item svg{display:block}

  /* List + Studios — pad bottom so last row clears the nav bar */
  .list-view{padding:16px 12px calc(56px + 16px)}
  .studios-view{padding:16px 12px calc(56px + 16px)}

  /* Kill pulse animations — too GPU-heavy on mobile */
  .pin-pulse{animation:none}
}

/* ── Landscape mobile: side-panel split view ─────────── */
@media (max-height:500px) and (orientation:landscape) {

  /* HUD — collapse to a compact horizontal strip at top-left */
  .hud{
    display:flex;flex-direction:row;align-items:center;
    top:8px;left:8px;right:auto;width:auto;min-width:0;
  }
  .hud-head{
    border-bottom:none;border-right:1px solid var(--line-1);
    padding:5px 10px;background:none;
  }
  .hud-sig{display:none}
  .hud-grid{display:flex;flex-direction:row;padding:5px 12px;gap:16px}
  .hud-stat{flex-direction:row;align-items:center;gap:5px}
  .hud-n{font-size:13px}
  .hud-l{font-size:8px;margin-top:0}

  /* Rail: bottom sheet → slides in from right */
  .rail{
    top:56px;left:auto;right:0;bottom:56px;
    width:45vw;height:auto;
    transform:translateX(100%);
    border-radius:0;border-top:none;
    border-left:1px solid var(--line-2);
    box-shadow:-20px 0 60px rgba(0,0,0,.5);
  }
  .rail.sheet-open{transform:translateX(0)}
  body.light .rail{box-shadow:-20px 0 60px rgba(0,0,0,.15)}

  /* Feed: bottom sheet → slides in from right */
  .feed{
    top:56px;left:auto;right:0;bottom:56px;
    width:45vw;height:auto;
    transform:translateX(100%);
    border-radius:0;border-top:none;
    border-left:1px solid var(--line-2);
    box-shadow:-20px 0 60px rgba(0,0,0,.5);
  }
  .feed.sheet-open{transform:translateX(0)}
  body.light .feed{box-shadow:-20px 0 60px rgba(0,0,0,.15)}

  /* List + Studios stay fullscreen in landscape — too content-heavy for a narrow panel */

  /* No drag handles — panels slide horizontally */
  .sheet-handle{display:none}

  /* Legend — collapse to compact horizontal strip at bottom-left */
  .legend{
    bottom:8px;left:8px;
    display:flex;flex-direction:row;align-items:center;gap:12px;
    padding:5px 10px;min-width:0;
  }
  .legend-head{display:none}
  .legend-row{padding:0;gap:5px}
  .legend-age{display:none}
  .legend-dot{width:8px;height:8px}
  .legend-name{font-size:9px}
  .legend-cnt{font-size:9px}
}
