/* ============================================================
   Glint · Global Sales Clock
   Aesthetic: midnight observatory / sales mission-control
   ============================================================ */

:root{
  /* surfaces */
  --bg:        #070b16;
  --bg-2:      #0b1120;
  --panel:     #0e1526;
  --panel-2:   #121b30;
  --raised:    #16203a;
  --line:      rgba(150,170,210,0.10);
  --line-2:    rgba(150,170,210,0.16);

  /* ink */
  --ink:       #e9eef9;
  --muted:     #8a97b2;
  --faint:     #5d6883;

  /* brand + status */
  --glint:     #f5b13d;   /* amber — the glint */
  --glint-2:   #ffd27a;
  --open:      #38d9a9;   /* reachable now */
  --edge:      #f2c14e;   /* edge hours */
  --closed:    #7d8aa6;   /* off-hours */
  --asleep:    #5e6bc4;   /* night */
  --weekend:   #b07ad6;   /* weekend */

  /* map */
  --ocean:     #080d1b;
  --land:      #1a2540;
  --land-edge: #2c3b63;
  --graticule: rgba(150,175,230,0.06);
  --night:     rgba(8,11,30,0.62);

  --radius:    16px;
  --radius-sm: 10px;
  --shadow:    0 18px 50px -22px rgba(0,0,0,0.85);
  --font-ui:   'Hanken Grotesk', ui-sans-serif, system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono: 'Space Mono', ui-monospace, 'SFMono-Regular', 'Cascadia Mono', monospace;
  --font-disp: 'Instrument Serif', 'Hanken Grotesk', serif;
}

*{ box-sizing:border-box; }
/* The [hidden] attribute MUST win over component display rules — the overlay
   panels (.pop-scrim / .palette-scrim) set display:grid, which would otherwise
   override hidden and render them on load, blocking the whole page. */
[hidden]{ display:none !important; }
html,body{ margin:0; height:100%; }
body{
  background:
    radial-gradient(1200px 700px at 78% -8%, rgba(245,177,61,0.07), transparent 60%),
    radial-gradient(1000px 800px at 8% 110%, rgba(94,107,196,0.10), transparent 55%),
    var(--bg);
  color:var(--ink);
  font-family:var(--font-ui);
  font-size:15px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* film grain for atmosphere */
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.5;
  mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.45'/%3E%3C/svg%3E");
}

/* ---------- top bar ---------- */
.topbar{
  position:sticky; top:0; z-index:30;
  display:flex; align-items:center; gap:22px; flex-wrap:wrap;
  padding:14px 22px;
  background:linear-gradient(180deg, rgba(8,12,24,0.92), rgba(8,12,24,0.66) 70%, transparent);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.brand{ display:flex; align-items:center; gap:12px; margin-right:auto; }
.brand-mark{
  color:var(--glint); display:grid; place-items:center;
  filter:drop-shadow(0 0 10px rgba(245,177,61,0.55));
  animation:spin 60s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg); } }
.brand-text{ font-weight:600; font-size:16px; letter-spacing:.2px; line-height:1.1;
  display:flex; flex-direction:column; }
.brand-text em{ font-family:var(--font-disp); font-style:italic; font-weight:400;
  font-size:22px; color:var(--glint-2); margin-right:2px; letter-spacing:.3px; }
.brand-text small{ color:var(--faint); font-size:11.5px; font-weight:500; letter-spacing:.3px; margin-top:1px; }

.home-readout{
  display:flex; flex-direction:column; align-items:flex-end; gap:1px;
  padding:6px 16px; border-left:1px solid var(--line); border-right:1px solid var(--line);
  cursor:pointer; background:transparent; border-top:none; border-bottom:none;
  transition:background .15s ease; outline:none; font:inherit; color:inherit;
}
.home-readout:hover, .home-readout:focus-visible{ background:rgba(245,177,61,0.06); }
.home-readout:hover .home-label, .home-readout:focus-visible .home-label{ color:var(--glint-2); }
.home-readout:hover .chev{ transform:translateY(1px); }
.home-label{ font-size:11px; color:var(--muted); letter-spacing:.4px; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:5px; transition:color .15s ease; }
.home-label b{ color:var(--ink); font-weight:700; }
.home-label .loc-ico{ color:var(--glint); opacity:.85; }
.home-label .chev{ color:var(--faint); transition:transform .15s ease; }
.home-clock{ font-family:var(--font-mono); font-size:26px; font-weight:700; letter-spacing:1px;
  color:var(--glint-2); line-height:1; font-variant-numeric:tabular-nums;
  text-shadow:0 0 18px rgba(245,177,61,0.35); }
.home-date{ font-size:11.5px; color:var(--faint); letter-spacing:.3px; }

.controls{ display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.btn{
  appearance:none; border:1px solid var(--line-2); background:var(--panel-2);
  color:var(--ink); font-family:var(--font-ui); font-size:13px; font-weight:600;
  padding:9px 13px; border-radius:11px; cursor:pointer; line-height:1;
  display:inline-flex; align-items:center; gap:7px; letter-spacing:.2px;
  transition:transform .12s ease, border-color .15s ease, background .15s ease, color .15s ease;
}
.btn:hover{ border-color:var(--line-2); background:var(--raised); transform:translateY(-1px); }
.btn:active{ transform:translateY(0); }
.btn-accent{ background:linear-gradient(180deg, #f7bd55, var(--glint)); color:#241701; border-color:transparent;
  box-shadow:0 8px 22px -10px rgba(245,177,61,0.8); }
.btn-accent:hover{ background:linear-gradient(180deg, #ffca6c, #f7bd55); }
.btn-ghost{ background:transparent; color:var(--muted); }
.btn-ghost:hover{ color:var(--ink); }

.tz-health{ display:inline-flex; align-items:center; gap:7px; padding:9px 12px; border-radius:11px;
  border:1px solid var(--line-2); background:var(--panel-2); font-size:12px; font-weight:600;
  color:var(--muted); cursor:help; letter-spacing:.2px; outline:none; transition:border-color .15s, color .15s; }
.tz-health:hover, .tz-health:focus-visible{ border-color:rgba(56,217,169,0.4); color:var(--ink); }
.tz-health .tz-dot{ width:8px; height:8px; border-radius:50%; background:var(--open); box-shadow:0 0 9px var(--open); }
.tz-health.ok .tz-dot{ animation:tzpulse 2.4s ease-in-out infinite; }
@keyframes tzpulse{ 0%,100%{ opacity:1; transform:scale(1); } 50%{ opacity:.4; transform:scale(.82); } }
.tz-health.warn{ color:var(--edge); border-color:color-mix(in srgb, var(--edge) 45%, transparent);
  background:color-mix(in srgb, var(--edge) 10%, var(--panel-2)); cursor:pointer; }
.tz-health.warn .tz-dot{ background:var(--edge); box-shadow:0 0 9px var(--edge); animation:none; }
.select-wrap{ position:relative; display:inline-flex; }
.select-wrap select{ padding-right:13px; }
select.btn{ -webkit-appearance:none; appearance:none; }

/* ---------- main layout ---------- */
main{ position:relative; z-index:2; display:grid; grid-template-columns:1fr; gap:0; }

/* ---------- map ---------- */
.map-panel{ padding:18px 22px 6px; }
.map-stage{
  position:relative; border:1px solid var(--line); border-radius:var(--radius);
  background:
    radial-gradient(900px 520px at 50% -10%, rgba(94,107,196,0.10), transparent 60%),
    linear-gradient(180deg, #0a1020, #070b16);
  overflow:hidden; box-shadow:var(--shadow);
}
#map{ display:block; width:100%; height:clamp(470px, 68vh, 760px); cursor:grab; }
#map.grabbing{ cursor:grabbing; }
#map .land{ fill:var(--land); stroke:var(--land-edge); stroke-width:.5px; vector-effect:non-scaling-stroke; }
#map .sphere{ fill:var(--ocean); }
#map .graticule{ fill:none; stroke:var(--graticule); stroke-width:.5px; vector-effect:non-scaling-stroke; }
#map .night{ fill:var(--night); stroke:rgba(94,107,196,0.28); stroke-width:.6px; vector-effect:non-scaling-stroke; }
#map .sun-glow{ pointer-events:none; }

.pin{ cursor:pointer; }
.pin .halo{ opacity:.9; transition:r .2s ease; }
.pin .core{ stroke:#05080f; stroke-width:1px; vector-effect:non-scaling-stroke; }
.pin .ring{ fill:none; stroke:var(--glint); stroke-width:1.4px; vector-effect:non-scaling-stroke; opacity:.95; }
.pin.home .ring{ stroke:var(--glint-2); }
.pin-tag{ pointer-events:none; }
.pin-tag .tag-bg{ fill:rgba(9,13,26,0.88); stroke:rgba(150,170,210,0.30);
  stroke-width:1px; vector-effect:non-scaling-stroke; }
.pin-label{ font-family:var(--font-ui); font-size:11px; font-weight:700; fill:#eef2fb;
  letter-spacing:.2px; }
.pin.home .pin-tag .tag-bg{ fill:rgba(42,29,7,0.9); stroke:rgba(245,177,61,0.6); }
.pin.home .pin-label{ fill:var(--glint-2); }
.pin.active .pin-tag .tag-bg{ stroke:rgba(245,177,61,0.85); }
.pin.dim{ opacity:.34; transition:opacity .2s ease; }
.pin.active .core{ stroke:#fff; stroke-width:1.5px; }

.s-open   { color:var(--open); }      .fill-open   { fill:var(--open); }
.s-edge   { color:var(--edge); }      .fill-edge   { fill:var(--edge); }
.s-closed { color:var(--closed); }    .fill-closed { fill:var(--closed); }
.s-asleep { color:var(--asleep); }    .fill-asleep { fill:var(--asleep); }
.s-weekend{ color:var(--weekend); }   .fill-weekend{ fill:var(--weekend); }

.map-overlay{ position:absolute; left:14px; bottom:12px; right:14px; display:flex;
  justify-content:space-between; align-items:flex-end; gap:12px; pointer-events:none; }
.map-legend{ display:flex; flex-wrap:wrap; gap:12px; padding:8px 12px;
  background:rgba(8,12,24,0.66); border:1px solid var(--line); border-radius:12px;
  backdrop-filter:blur(8px); }
.map-legend .lg{ display:inline-flex; align-items:center; gap:6px; font-size:11.5px; color:var(--muted); font-weight:600; }
.map-legend .dot{ width:9px; height:9px; border-radius:50%; background:currentColor; box-shadow:0 0 8px currentColor; }
.map-hint{ position:absolute; right:14px; top:12px; font-size:11px; color:var(--faint);
  background:rgba(8,12,24,0.6); border:1px solid var(--line); padding:5px 9px; border-radius:9px;
  backdrop-filter:blur(8px); pointer-events:none; transition:opacity .4s ease; }

.map-tooltip{
  position:absolute; z-index:12; pointer-events:none; transform:translate(-50%, -130%);
  background:rgba(10,14,28,0.95); border:1px solid var(--line-2); border-radius:11px;
  padding:9px 12px; min-width:148px; box-shadow:var(--shadow); backdrop-filter:blur(10px);
}
.map-tooltip .tt-city{ font-weight:700; font-size:13px; }
.map-tooltip .tt-country{ color:var(--faint); font-size:11px; margin-bottom:5px; }
.map-tooltip .tt-time{ font-family:var(--font-mono); font-size:18px; font-weight:700; color:var(--glint-2);
  font-variant-numeric:tabular-nums; line-height:1.1; }
.map-tooltip .tt-zone{ font-size:10.5px; color:var(--faint); margin-top:3px; }
.map-tooltip .tt-status{ font-size:11.5px; font-weight:600; margin-top:3px; }

/* ---------- board ---------- */
.board{ padding:14px 22px 40px; }
.board-head{ display:flex; align-items:center; justify-content:space-between; gap:14px;
  margin:8px 2px 14px; }
.board-head h2{ font-size:14px; font-weight:700; letter-spacing:.4px; text-transform:uppercase;
  color:var(--muted); margin:0; display:flex; align-items:center; gap:9px; }
.count{ font-family:var(--font-mono); font-size:12px; color:var(--glint-2);
  background:rgba(245,177,61,0.12); border:1px solid rgba(245,177,61,0.25);
  padding:2px 8px; border-radius:20px; }
.reach-filter{ display:inline-flex; align-items:center; gap:8px; font-size:13px; color:var(--muted);
  cursor:pointer; user-select:none; font-weight:600; }
.reach-filter input{ accent-color:var(--glint); width:15px; height:15px; cursor:pointer; }

.cards{ display:grid; grid-template-columns:repeat(auto-fill, minmax(268px, 1fr)); gap:14px; }

.card{
  position:relative; border:1px solid var(--line); border-radius:var(--radius);
  background:linear-gradient(180deg, var(--panel), var(--bg-2));
  padding:16px 16px 14px; overflow:hidden;
  transition:transform .14s ease, border-color .18s ease, box-shadow .18s ease;
  animation:rise .5s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes rise{ from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:translateY(0); } }
.card:hover{ transform:translateY(-3px); border-color:var(--line-2); box-shadow:var(--shadow); }
.card.active{ border-color:rgba(245,177,61,0.5); box-shadow:0 0 0 1px rgba(245,177,61,0.35), var(--shadow); }
.card::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:currentColor; opacity:.9; }
.card.s-open{ color:var(--open); } .card.s-edge{ color:var(--edge); }
.card.s-closed{ color:var(--closed); } .card.s-asleep{ color:var(--asleep); } .card.s-weekend{ color:var(--weekend); }

.card-top{ display:flex; align-items:flex-start; gap:10px; }
.card-id{ min-width:0; flex:1; }
.card-city{ font-size:18px; font-weight:700; letter-spacing:.2px; color:var(--ink);
  display:flex; align-items:center; gap:8px; }
.card-city .daynight{ font-size:13px; filter:saturate(1.2); }
.card-sub{ display:flex; align-items:center; gap:8px; margin-top:2px; }
.card-country{ font-size:12px; color:var(--faint); }
.cc-chip{ font-family:var(--font-mono); font-size:10px; font-weight:700; color:var(--muted);
  border:1px solid var(--line-2); border-radius:5px; padding:1px 5px; letter-spacing:.5px; }
.card-note{ font-size:11.5px; color:var(--faint); margin-top:6px; font-style:italic; min-height:14px; }

.card-actions{ display:flex; gap:4px; }
.icon-btn{ appearance:none; background:transparent; border:1px solid transparent; color:var(--faint);
  width:28px; height:28px; border-radius:8px; cursor:pointer; display:grid; place-items:center;
  transition:color .15s, background .15s, border-color .15s; }
.icon-btn:hover{ color:var(--ink); background:var(--raised); }
.icon-btn.pinned{ color:var(--glint); }
.icon-btn.pinned:hover{ color:var(--glint-2); }

.card-clock{ display:flex; align-items:baseline; gap:9px; margin:12px 0 2px; }
.clock-time{ font-family:var(--font-mono); font-size:33px; font-weight:700; letter-spacing:.5px;
  color:var(--ink); line-height:1; font-variant-numeric:tabular-nums; }
.clock-ampm{ font-family:var(--font-mono); font-size:13px; color:var(--muted); font-weight:700; }
.card-meta{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-top:7px; }
.meta-pill{ font-size:11.5px; color:var(--muted); font-weight:600; }
.meta-pill b{ color:var(--ink); font-weight:700; }
.meta-pill.offset{ font-family:var(--font-mono); }
.day-tag{ font-size:10.5px; font-weight:700; letter-spacing:.3px; padding:1px 7px; border-radius:20px;
  text-transform:uppercase; }
.day-tag.next{ color:#ffd27a; background:rgba(245,177,61,0.12); border:1px solid rgba(245,177,61,0.28); }
.day-tag.prev{ color:#8fb6ff; background:rgba(94,140,255,0.12); border:1px solid rgba(94,140,255,0.28); }

.status-row{ display:flex; align-items:center; gap:8px; margin-top:12px; }
.status-badge{ display:inline-flex; align-items:center; gap:7px; font-size:12px; font-weight:700;
  padding:5px 10px; border-radius:9px; color:currentColor;
  background:color-mix(in srgb, currentColor 14%, transparent);
  border:1px solid color-mix(in srgb, currentColor 32%, transparent); }
.status-badge .bdot{ width:7px; height:7px; border-radius:50%; background:currentColor; box-shadow:0 0 8px currentColor; }

/* daypart strip */
.strip{ margin-top:13px; }
.strip-bar{ position:relative; display:grid; grid-template-columns:repeat(24,1fr); gap:1px;
  height:16px; border-radius:6px; overflow:hidden; background:#0a0f1d; }
.strip-bar i{ display:block; height:100%; }
.strip-bar i.h-open{ background:var(--open); }
.strip-bar i.h-edge{ background:var(--edge); }
.strip-bar i.h-closed{ background:#2a3553; }
.strip-bar i.h-asleep{ background:#171f3a; }
.strip-now{ position:absolute; top:-3px; bottom:-3px; width:2px; background:#fff;
  box-shadow:0 0 8px rgba(255,255,255,0.8); border-radius:2px; transform:translateX(-1px); }
.strip-you{ position:absolute; top:0; bottom:0; border-left:1.5px dashed var(--glint);
  border-right:1.5px dashed var(--glint); background:rgba(245,177,61,0.10); }
.strip-legend{ display:flex; justify-content:space-between; margin-top:5px;
  font-size:9.5px; color:var(--faint); font-family:var(--font-mono); letter-spacing:.3px; }
.strip-cap{ font-size:10.5px; color:var(--faint); margin-top:6px; }
.strip-cap b{ color:var(--glint-2); }

.empty-note{ text-align:center; color:var(--faint); font-size:14px; padding:40px 0; }

/* ---------- command palette ---------- */
.palette-scrim, .pop-scrim{
  position:fixed; inset:0; z-index:60; display:grid;
  background:rgba(4,7,14,0.66); backdrop-filter:blur(4px);
  animation:fade .18s ease both;
}
.palette-scrim{ place-items:start center; padding-top:12vh; }
.pop-scrim{ place-items:center; }
@keyframes fade{ from{ opacity:0; } to{ opacity:1; } }
.palette{ width:min(560px, 92vw); background:var(--panel); border:1px solid var(--line-2);
  border-radius:16px; box-shadow:var(--shadow); overflow:hidden; animation:pop .2s cubic-bezier(.2,.8,.2,1) both; }
@keyframes pop{ from{ opacity:0; transform:translateY(-10px) scale(.98); } to{ opacity:1; transform:none; } }
.palette-input{ display:flex; align-items:center; gap:10px; padding:15px 16px; border-bottom:1px solid var(--line);
  color:var(--muted); }
.palette-input input{ flex:1; background:transparent; border:none; outline:none; color:var(--ink);
  font-family:var(--font-ui); font-size:17px; font-weight:500; }
.palette-input kbd{ font-family:var(--font-mono); font-size:10px; color:var(--faint);
  border:1px solid var(--line-2); border-radius:6px; padding:2px 6px; }
.palette-results{ list-style:none; margin:0; padding:6px; max-height:46vh; overflow-y:auto; }
.palette-results li{ display:flex; align-items:center; gap:11px; padding:10px 12px; border-radius:10px;
  cursor:pointer; }
.palette-results li.sel, .palette-results li:hover{ background:var(--raised); }
.palette-results .r-city{ font-weight:700; font-size:14px; }
.palette-results .r-country{ color:var(--faint); font-size:12px; }
.palette-results .r-tz{ margin-left:auto; font-family:var(--font-mono); font-size:11px; color:var(--muted); }
.palette-results .r-added{ margin-left:auto; font-size:11px; color:var(--open); font-weight:700; }
.palette-results .r-none{ color:var(--faint); padding:14px 12px; }

/* ---------- popover ---------- */
.pop{ width:min(360px,92vw); background:var(--panel); border:1px solid var(--line-2);
  border-radius:16px; padding:20px; box-shadow:var(--shadow); animation:pop .2s cubic-bezier(.2,.8,.2,1) both; }
.pop h3{ margin:0 0 4px; font-size:17px; }
.pop-sub{ margin:0 0 14px; font-size:12.5px; color:var(--muted); }
.pop-row{ display:flex; gap:12px; }
.pop-row label{ flex:1; font-size:12px; color:var(--muted); font-weight:600;
  display:flex; flex-direction:column; gap:5px; }
.pop-row input{ background:var(--bg-2); border:1px solid var(--line-2); border-radius:9px;
  color:var(--ink); font-family:var(--font-mono); font-size:18px; padding:9px 11px; outline:none; }
.pop-row input:focus{ border-color:var(--glint); }
.pop-actions{ display:flex; gap:9px; margin-top:18px; }

/* ---------- responsive ---------- */
@media (max-width:720px){
  .topbar{ gap:12px; padding:12px 15px; }
  .home-readout{ order:3; border:none; padding:0; align-items:flex-start; }
  .home-clock{ font-size:22px; }
  .controls{ order:4; width:100%; }
  .map-panel{ padding:12px 13px 4px; }
  #map{ height:clamp(340px, 54vh, 560px); }
  .board{ padding:10px 13px 40px; }
  .cards{ grid-template-columns:1fr; }
  .map-hint{ display:none; }
  .map-legend{ gap:8px 10px; padding:6px 9px; }
  .map-legend .lg{ font-size:10.5px; }
  .brand-text{ font-size:14px; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; }
}
