/* ============================================================
   SYF — Command Deck  ·  Theme & Styles
   ============================================================ */

:root{
  /* Palette */
  --c-bg:        #04070f;
  --c-bg-2:      #060b18;
  --c-panel:     rgba(14, 22, 40, 0.55);
  --c-panel-2:   rgba(20, 30, 52, 0.7);
  --c-stroke:    rgba(120, 180, 255, 0.14);
  --c-stroke-2:  rgba(120, 180, 255, 0.28);

  --c-cyan:   #38e0ff;
  --c-blue:   #3a86ff;
  --c-violet: #9b8cff;
  --c-amber:  #ffb454;
  --c-green:  #4fe6a8;
  --c-red:    #ff6b8b;

  --c-text:    #e8f1ff;
  --c-muted:   #8aa0c6;
  --c-dim:     #5b6f93;

  --glow: 0 0 24px rgba(56, 224, 255, 0.35);
  --radius: 16px;
  --radius-sm: 11px;

  --font-display: 'Orbitron', sans-serif;
  --font: 'Space Grotesk', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html,body{ height:100%; }
body{
  font-family:var(--font);
  color:var(--c-text);
  background:
    radial-gradient(1200px 800px at 80% -10%, rgba(58,134,255,0.12), transparent 60%),
    radial-gradient(900px 700px at -10% 110%, rgba(155,140,255,0.10), transparent 55%),
    var(--c-bg);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
}
::selection{ background:rgba(56,224,255,0.3); }

/* Scrollbar */
::-webkit-scrollbar{ width:10px; height:10px; }
::-webkit-scrollbar-thumb{ background:rgba(120,180,255,0.18); border-radius:20px; }
::-webkit-scrollbar-thumb:hover{ background:rgba(120,180,255,0.3); }

/* ============================================================
   BOOT / LOADING SCREEN
   ============================================================ */
.boot{
  position:fixed; inset:0; z-index:100;
  /* transparent center so the live spinning globe shows through the loader */
  background:
    radial-gradient(circle at 50% 46%, transparent 0%, transparent 26%, rgba(4,7,15,0.55) 58%, #04070f 92%);
  transition:opacity .9s ease, visibility .9s;
}
.boot.is-hidden{ opacity:0; visibility:hidden; pointer-events:none; }

.boot__grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(56,224,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(56,224,255,0.05) 1px, transparent 1px);
  background-size:44px 44px;
  mask-image:radial-gradient(circle at 50% 46%, transparent 30%, #000 75%);
  animation:gridpan 18s linear infinite;
}
@keyframes gridpan{ to{ background-position:44px 44px; } }

/* sweeping scan line */
.boot__scan{
  position:absolute; inset:0; pointer-events:none; opacity:.5;
  background:linear-gradient(180deg, transparent 0%, rgba(56,224,255,0.10) 50%, transparent 100%);
  height:40%; animation:scan 4.5s ease-in-out infinite;
}
@keyframes scan{ 0%{ transform:translateY(-120%);} 50%{ transform:translateY(220%);} 100%{ transform:translateY(-120%);} }

/* reticle that frames the spinning earth */
.boot__reticle{
  position:absolute; top:46%; left:50%; transform:translate(-50%,-50%);
  width:min(62vmin,520px); height:min(62vmin,520px);
}
.boot__ring{ position:absolute; inset:0; border-radius:50%; }
.boot__ring--1{
  border:1px dashed rgba(56,224,255,0.30); animation:spin 26s linear infinite;
}
.boot__ring--2{
  inset:7%; border:1px solid rgba(56,224,255,0.16);
  border-top-color:var(--c-cyan); border-left-color:var(--c-violet);
  animation:spin 9s linear infinite reverse; box-shadow:0 0 40px rgba(56,224,255,0.12) inset;
}
@keyframes spin{ to{ transform:rotate(360deg); } }

.boot__cross{ position:absolute; background:rgba(56,224,255,0.22); }
.boot__cross--h{ top:50%; left:-6%; width:112%; height:1px; transform:translateY(-50%);
  mask-image:linear-gradient(90deg,transparent,#000 20%,transparent 38%,transparent 62%,#000 80%,transparent); }
.boot__cross--v{ left:50%; top:-6%; height:112%; width:1px; transform:translateX(-50%);
  mask-image:linear-gradient(180deg,transparent,#000 20%,transparent 38%,transparent 62%,#000 80%,transparent); }
.boot__br{ position:absolute; width:18px; height:18px; }
.boot__br--tl{ top:-2px; left:-2px; border-top:2px solid var(--c-cyan); border-left:2px solid var(--c-cyan); }
.boot__br--tr{ top:-2px; right:-2px; border-top:2px solid var(--c-cyan); border-right:2px solid var(--c-cyan); }
.boot__br--bl{ bottom:-2px; left:-2px; border-bottom:2px solid var(--c-cyan); border-left:2px solid var(--c-cyan); }
.boot__br--br{ bottom:-2px; right:-2px; border-bottom:2px solid var(--c-cyan); border-right:2px solid var(--c-cyan); }

.boot__top{ position:absolute; top:46%; left:0; right:0; transform:translateY(-50%); text-align:center; }
.boot__sigil{
  display:block; font-family:var(--font-display); font-weight:900; font-size:38px;
  letter-spacing:8px; color:#fff; text-shadow:0 0 22px rgba(56,224,255,0.7);
}
.boot__tag{
  display:block; margin-top:6px; font-family:var(--font-mono); font-size:10px;
  letter-spacing:6px; color:var(--c-cyan); opacity:.85;
}

.boot__console{
  position:absolute; bottom:12%; left:50%; transform:translateX(-50%);
  width:min(420px, 80vw); text-align:center;
}
.boot__line{ font-family:var(--font-mono); font-size:12px; color:var(--c-muted); letter-spacing:1px; height:16px; }
.dots::after{ content:''; animation:dots 1.4s steps(4,end) infinite; }
@keyframes dots{ 0%{content:'';}25%{content:'.';}50%{content:'..';}75%{content:'...';} }
.boot__bar{ margin:14px 0 8px; height:3px; border-radius:3px; background:rgba(120,180,255,0.12); overflow:hidden; }
.boot__bar i{ display:block; height:100%; width:0%; background:linear-gradient(90deg,var(--c-blue),var(--c-cyan)); box-shadow:var(--glow); transition:width .2s ease; }
.boot__pct{ font-family:var(--font-mono); font-size:11px; color:var(--c-cyan); letter-spacing:2px; }
.boot__pct small{ opacity:.6; }

/* ============================================================
   GLOBE STAGE
   ============================================================ */
.globe-stage{
  position:fixed; inset:0; z-index:10;
  transition:opacity 1.2s ease;
}
.globe-stage canvas{ display:block; width:100%; height:100%; }

/* When dashboard is revealed, globe becomes ambient backdrop */
body.revealed .globe-stage{ opacity:0.32; }
body.revealed .pin-label{ opacity:0; }

.pin-label{
  position:absolute; top:46%; left:54%;
  display:flex; gap:10px; align-items:center;
  padding:10px 14px; border-radius:12px;
  background:rgba(8,14,28,0.7); backdrop-filter:blur(8px);
  border:1px solid var(--c-stroke-2);
  box-shadow:0 8px 30px rgba(0,0,0,0.5);
  opacity:0; transform:translateY(8px); transition:opacity .6s ease, transform .6s ease;
  pointer-events:none;
}
.pin-label.show{ opacity:1; transform:translateY(0); }
.pin-label__dot{
  width:10px; height:10px; border-radius:50%; background:var(--c-cyan);
  box-shadow:0 0 0 0 rgba(56,224,255,.6); animation:pulse 1.8s ease-out infinite;
}
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(56,224,255,.55);} 100%{box-shadow:0 0 0 16px rgba(56,224,255,0);} }
.pin-label__txt strong{ display:block; font-family:var(--font-display); letter-spacing:2px; font-size:14px; }
.pin-label__txt em{ display:block; font-style:normal; font-size:11px; color:var(--c-muted); }
.pin-label__coord{ display:block; font-family:var(--font-mono); font-size:10px; color:var(--c-cyan); margin-top:2px; }

/* ============================================================
   APP SHELL
   ============================================================ */
.app{
  position:relative; z-index:20;
  height:100vh; height:100dvh; overflow:hidden;
  display:grid; grid-template-columns:260px 1fr; grid-template-rows:minmax(0,1fr);
  opacity:0; transform:scale(1.02);
  transition:opacity 1s ease, transform 1s ease;
  pointer-events:none;
}
body.revealed .app{ opacity:1; transform:scale(1); pointer-events:auto; }

/* HUD corner brackets */
.hud-corner{ position:fixed; width:26px; height:26px; z-index:30; pointer-events:none; opacity:.5; }
.hud-corner--tl{ top:14px; left:14px; border-top:2px solid var(--c-stroke-2); border-left:2px solid var(--c-stroke-2); }
.hud-corner--tr{ top:14px; right:14px; border-top:2px solid var(--c-stroke-2); border-right:2px solid var(--c-stroke-2); }
.hud-corner--bl{ bottom:14px; left:14px; border-bottom:2px solid var(--c-stroke-2); border-left:2px solid var(--c-stroke-2); }
.hud-corner--br{ bottom:14px; right:14px; border-bottom:2px solid var(--c-stroke-2); border-right:2px solid var(--c-stroke-2); }

/* ---------- Sidebar ---------- */
.sidebar{
  margin:14px 0 14px 14px; padding:20px 16px;
  display:flex; flex-direction:column; gap:22px;
  background:linear-gradient(180deg, rgba(16,26,46,0.66), rgba(8,14,28,0.5));
  border:1px solid var(--c-stroke); border-radius:var(--radius);
  backdrop-filter:blur(14px);
}
.sidebar__brand{ display:flex; align-items:center; padding:4px 2px 2px; }
.sidebar__name strong{
  font-family:var(--font-display); font-weight:900; letter-spacing:6px; font-size:24px; display:block;
  background:linear-gradient(135deg,#fff,var(--c-cyan)); -webkit-background-clip:text; background-clip:text; color:transparent;
  text-shadow:0 0 22px rgba(56,224,255,0.25);
}

.nav{ display:flex; flex-direction:column; gap:4px; }
.nav__item{
  display:flex; align-items:center; gap:12px;
  padding:11px 12px; border-radius:var(--radius-sm);
  background:transparent; border:1px solid transparent;
  color:var(--c-muted); font-family:var(--font); font-size:14px; font-weight:500;
  cursor:pointer; text-align:left; width:100%; transition:.18s;
}
.nav__item svg{ width:18px; height:18px; fill:currentColor; flex:none; }
.nav__item:hover{ color:var(--c-text); background:rgba(56,224,255,0.06); }
.nav__item.is-active{
  color:#fff;
  background:linear-gradient(90deg, rgba(56,224,255,0.16), rgba(56,224,255,0.02));
  border-color:var(--c-stroke-2);
  box-shadow:inset 2px 0 0 var(--c-cyan), 0 0 18px rgba(56,224,255,0.12);
}

.sidebar__foot{ margin-top:auto; display:flex; flex-direction:column; gap:14px; }
.lifebars{ display:flex; flex-direction:column; gap:11px; }
.lifebar__top{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:5px; }
.lifebar label{ font-size:11px; color:var(--c-muted); letter-spacing:.5px; }
.lifebar b{ font-family:var(--font-mono); font-size:10px; font-weight:500; color:var(--c-cyan); }
.lifebar i{ display:block; height:5px; border-radius:5px; background:rgba(120,180,255,0.10); overflow:hidden; }
.lifebar u{ display:block; height:100%; width:0%; border-radius:5px;
  background:linear-gradient(90deg,var(--c-blue),var(--c-cyan)); box-shadow:0 0 12px rgba(56,224,255,0.4);
  transition:width 1.1s cubic-bezier(.22,1,.36,1); }
.lifebar[data-span="life"] u{ background:linear-gradient(90deg,var(--c-violet),var(--c-cyan)); }
.lifebar[data-span="life"] b{ color:var(--c-violet); }
.sidebar__user{ display:flex; align-items:center; gap:10px; padding-top:12px; border-top:1px solid var(--c-stroke); }
.avatar{ width:36px; height:36px; border-radius:10px; display:grid; place-items:center; background:linear-gradient(135deg,var(--c-violet),var(--c-blue)); font-weight:700; color:#04070f; }
.sidebar__user strong{ display:block; font-size:13px; }
.sidebar__user small{ font-size:11px; color:var(--c-muted); }

/* ---------- Main ---------- */
.main{ display:flex; flex-direction:column; min-width:0; min-height:0; padding:14px; gap:14px; }

.topbar{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:12px 18px; border-radius:var(--radius);
  background:var(--c-panel); border:1px solid var(--c-stroke); backdrop-filter:blur(14px);
}
.topbar__loc{ display:flex; align-items:center; gap:10px; }
.ping{ width:9px; height:9px; border-radius:50%; background:var(--c-green); box-shadow:0 0 0 0 rgba(79,230,168,.6); animation:pulse 2s infinite; }
.topbar__loc strong{ display:block; font-size:14px; }
.topbar__loc small{ font-size:11px; color:var(--c-muted); }

.topbar__search{ flex:1; max-width:520px; display:flex; align-items:center; gap:10px; margin:0 auto;
  padding:9px 14px; border-radius:11px; background:rgba(6,11,24,0.6); border:1px solid var(--c-stroke); }
.topbar__search svg{ width:16px; height:16px; fill:var(--c-dim); flex:none; }
.topbar__search input{ flex:1; background:none; border:none; outline:none; color:var(--c-text); font-family:var(--font); font-size:13px; }
.topbar__search input::placeholder{ color:var(--c-dim); }
.topbar__search kbd{ font-family:var(--font-mono); font-size:10px; color:var(--c-muted); border:1px solid var(--c-stroke-2); padding:2px 6px; border-radius:6px; }

.topbar__right{ display:flex; align-items:center; gap:14px; }
.clock{ text-align:right; }
.clock strong{ display:block; font-family:var(--font-mono); font-size:15px; letter-spacing:1px; }
.clock small{ font-size:10px; color:var(--c-muted); }
.icon-btn{ position:relative; width:38px; height:38px; border-radius:10px; display:grid; place-items:center;
  background:rgba(6,11,24,0.6); border:1px solid var(--c-stroke); cursor:pointer; }
.icon-btn svg{ width:18px; height:18px; fill:var(--c-muted); }
.icon-btn:hover{ border-color:var(--c-stroke-2); }
.badge{ position:absolute; top:-5px; right:-5px; min-width:16px; height:16px; padding:0 4px; border-radius:8px;
  background:var(--c-red); color:#fff; font-size:10px; font-weight:700; display:grid; place-items:center; }

/* ---------- Content ---------- */
.content{ flex:1; min-height:0; overflow-y:auto; padding-right:4px; padding-bottom:24px; }
.sidebar{ overflow-y:auto; }
.panel{ display:none; animation:fadeUp .5s ease both; }
.panel.is-active{ display:block; }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:translateY(0); } }

.page-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:20px; flex-wrap:wrap; }
.page-head h1{ font-size:26px; font-weight:600; letter-spacing:.3px; }
.subtle{ color:var(--c-muted); font-size:13px; margin-top:4px; }
.page-head__actions{ display:flex; gap:10px; }

.btn{ padding:10px 16px; border-radius:11px; font-family:var(--font); font-size:13px; font-weight:600; cursor:pointer; border:1px solid transparent; transition:.18s; }
.btn--ghost{ background:rgba(6,11,24,0.5); border-color:var(--c-stroke); color:var(--c-text); }
.btn--ghost:hover{ border-color:var(--c-stroke-2); }
.btn--primary{ background:linear-gradient(135deg,var(--c-blue),var(--c-cyan)); color:#04070f; box-shadow:var(--glow); }
.btn--primary:hover{ filter:brightness(1.08); }

/* Card base */
.card{
  background:var(--c-panel); border:1px solid var(--c-stroke); border-radius:var(--radius);
  padding:18px; backdrop-filter:blur(14px); position:relative; overflow:hidden;
}
.card::before{ content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, rgba(56,224,255,0.4), transparent); opacity:.6; }
.card__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.card__head h3{ font-size:14px; font-weight:600; letter-spacing:.4px; }
.card__meta{ font-size:11px; color:var(--c-muted); font-family:var(--font-mono); }
.card__meta.live{ color:var(--c-green); }

/* KPI */
.kpi-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:14px; }
.kpi{ padding:16px; }
.kpi__top{ display:flex; align-items:center; justify-content:space-between; }
.kpi__label{ font-size:12px; color:var(--c-muted); }
.kpi__chip{ font-size:10px; font-family:var(--font-mono); padding:2px 7px; border-radius:20px; background:rgba(120,180,255,0.1); color:var(--c-muted); }
.kpi__chip.up{ color:var(--c-green); background:rgba(79,230,168,.12); }
.kpi__chip.down{ color:var(--c-cyan); background:rgba(56,224,255,.12); }
.kpi__val{ font-family:var(--font-display); font-weight:700; font-size:30px; margin:10px 0 12px; }
.kpi__val small{ font-family:var(--font); font-size:13px; font-weight:400; color:var(--c-muted); margin-left:6px; }
.spark{ display:flex; align-items:flex-end; gap:5px; height:34px; }
.spark i{ flex:1; height:var(--h); border-radius:3px; background:linear-gradient(180deg,var(--accent),transparent); opacity:.85; }

/* Overview grid */
.ov-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.span-2{ grid-column:span 2; }

/* Timeline */
.timeline{ list-style:none; display:flex; flex-direction:column; }
.timeline li{ display:grid; grid-template-columns:52px 18px 1fr; align-items:center; gap:6px; padding:9px 0; position:relative; }
.tl__time{ font-family:var(--font-mono); font-size:12px; color:var(--c-muted); }
.tl__dot{ width:11px; height:11px; border-radius:50%; border:2px solid var(--c-dim); justify-self:center; position:relative; }
.timeline li:not(:last-child) .tl__dot::after{ content:''; position:absolute; top:12px; left:50%; transform:translateX(-50%); width:2px; height:34px; background:var(--c-stroke); }
.timeline li.done .tl__dot{ background:var(--c-green); border-color:var(--c-green); }
.timeline li.now .tl__dot{ background:var(--c-cyan); border-color:var(--c-cyan); box-shadow:0 0 0 4px rgba(56,224,255,.18); }
.tl__body strong{ display:block; font-size:13px; }
.tl__body small{ font-size:11px; color:var(--c-muted); }
.timeline li.done .tl__body strong{ color:var(--c-muted); text-decoration:line-through; }

/* Feed */
.feed{ list-style:none; display:flex; flex-direction:column; gap:12px; }
.feed li{ display:flex; align-items:center; gap:11px; }
.feed__ic{ width:30px; height:30px; border-radius:9px; display:grid; place-items:center; font-size:13px; flex:none; }
.ic-c{ background:rgba(56,224,255,.14); color:var(--c-cyan); }
.ic-v{ background:rgba(155,140,255,.14); color:var(--c-violet); }
.ic-a{ background:rgba(255,180,84,.14); color:var(--c-amber); }
.ic-g{ background:rgba(79,230,168,.14); color:var(--c-green); }
.feed li div{ flex:1; min-width:0; }
.feed strong{ display:block; font-size:13px; }
.feed small{ font-size:11px; color:var(--c-muted); }
.feed time{ font-family:var(--font-mono); font-size:10px; color:var(--c-dim); }

/* Rings */
.rings{ display:flex; align-items:center; gap:18px; }
.rings__svg{ width:120px; height:120px; transform:rotate(-90deg); }
.rings__svg circle{ fill:none; stroke-width:9; stroke-linecap:round; }
.rg-bg{ stroke:rgba(120,180,255,0.08); }
.rg{ stroke-dasharray:calc(var(--p) * 6.283 * var(--r,52px)) 999; }
.rg-1{ stroke:var(--c-cyan); stroke-dasharray:255 999; }
.rg-2{ stroke:var(--c-violet); stroke-dasharray:155 999; }
.rg-3{ stroke:var(--c-green); stroke-dasharray:158 999; }
.rings__legend{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.rings__legend li{ font-size:12px; color:var(--c-muted); display:flex; align-items:center; gap:8px; }
.rings__legend strong{ color:var(--c-text); }
.rings__legend i{ width:9px; height:9px; border-radius:3px; }
.d1{ background:var(--c-cyan);} .d2{ background:var(--c-violet);} .d3{ background:var(--c-green);}

/* Business */
.biz{ display:grid; grid-template-columns:repeat(3,auto) 1fr; gap:20px; align-items:end; }
.biz__stat small{ display:block; font-size:11px; color:var(--c-muted); }
.biz__stat strong{ display:block; font-family:var(--font-display); font-size:22px; margin:4px 0; }
.biz__stat span{ font-size:11px; color:var(--c-muted); font-family:var(--font-mono); }
.up{ color:var(--c-green)!important; } .down{ color:var(--c-cyan)!important; }
.biz__chart{ display:flex; align-items:flex-end; gap:6px; height:80px; }
.biz__chart span{ flex:1; height:var(--h); border-radius:4px 4px 0 0; background:linear-gradient(180deg,var(--c-blue),rgba(58,134,255,0.1)); }

/* Placeholder panels */
.soon{ height:60vh; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:10px; }
.soon h2{ font-family:var(--font-display); letter-spacing:2px; font-size:24px; }
.soon p{ color:var(--c-muted); max-width:420px; }
.soon__tags{ display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin-top:14px; }
.soon__tags span{ font-size:11px; font-family:var(--font-mono); padding:5px 11px; border-radius:20px; border:1px solid var(--c-stroke-2); color:var(--c-cyan); }
.soon__tags .dim{ color:var(--c-dim); border-color:var(--c-stroke); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px){
  .kpi-grid{ grid-template-columns:repeat(2,1fr); }
  .ov-grid{ grid-template-columns:repeat(2,1fr); }
  .span-2{ grid-column:span 2; }
}
@media (max-width:780px){
  .app{ grid-template-columns:1fr; }
  .sidebar{ position:fixed; bottom:0; left:0; right:0; top:auto; margin:0; z-index:40; flex-direction:row;
    border-radius:16px 16px 0 0; padding:8px; overflow-x:auto; gap:8px; }
  .sidebar__brand,.sidebar__foot{ display:none; }
  .nav{ flex-direction:row; }
  .nav__item span{ display:none; }
  .nav__item{ padding:12px; }
  .main{ padding:10px 10px 90px; }
  .topbar__search{ display:none; }
  .kpi-grid,.ov-grid{ grid-template-columns:1fr; }
  .span-2{ grid-column:span 1; }
}

/* ============================================================
   MODULES — shared components (added in full build)
   ============================================================ */

/* nav badge */
.nav__badge{ margin-left:auto; min-width:20px; height:20px; padding:0 6px; border-radius:10px;
  background:rgba(56,224,255,0.16); color:var(--c-cyan); font-family:var(--font-mono);
  font-size:11px; display:grid; place-items:center; }
.nav__item.is-active .nav__badge{ background:rgba(56,224,255,0.28); }

/* filter chips */
.chips{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:16px; }
.chip{ padding:6px 13px; border-radius:20px; font-size:12px; cursor:pointer;
  background:rgba(6,11,24,0.5); border:1px solid var(--c-stroke); color:var(--c-muted); transition:.15s; }
.chip:hover{ border-color:var(--c-stroke-2); color:var(--c-text); }
.chip.is-on{ background:rgba(56,224,255,0.14); border-color:var(--c-stroke-2); color:var(--c-cyan); }

/* ---------- Kanban ---------- */
.kanban{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; align-items:start; }
.kcol{ background:rgba(8,14,28,0.4); border:1px solid var(--c-stroke); border-radius:var(--radius); padding:12px; min-height:120px; transition:.15s; }
.kcol.drop{ border-color:var(--c-stroke-2); background:rgba(56,224,255,0.05); }
.kcol__head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; padding:0 4px; }
.kcol__head strong{ font-size:13px; letter-spacing:.4px; }
.kcol__count{ font-family:var(--font-mono); font-size:11px; color:var(--c-muted); background:rgba(120,180,255,0.1); padding:1px 8px; border-radius:10px; }
.kcol__body{ display:flex; flex-direction:column; gap:10px; min-height:40px; }
.kcol__empty{ border:1px dashed var(--c-stroke); border-radius:11px; padding:18px; text-align:center; color:var(--c-dim); font-size:12px; }
.tcard{ background:var(--c-panel-2); border:1px solid var(--c-stroke); border-left:3px solid var(--c-dim);
  border-radius:11px; padding:11px 12px; cursor:grab; transition:.15s; }
.tcard:hover{ border-color:var(--c-stroke-2); transform:translateY(-1px); }
.tcard.dragging{ opacity:.4; }
.tcard.prio-high{ border-left-color:var(--c-red); }
.tcard.prio-med{ border-left-color:var(--c-amber); }
.tcard.prio-low{ border-left-color:var(--c-cyan); }
.tcard__top{ display:flex; justify-content:space-between; margin-bottom:7px; }
.tcard__tag{ font-size:10px; font-family:var(--font-mono); color:var(--c-cyan); background:rgba(56,224,255,0.1); padding:1px 7px; border-radius:8px; }
.tcard__prio{ font-size:10px; text-transform:uppercase; letter-spacing:1px; color:var(--c-muted); }
.tcard__title{ font-size:13px; line-height:1.35; margin-bottom:9px; }
.tcard__foot{ display:flex; justify-content:space-between; align-items:center; }
.tcard__due{ font-family:var(--font-mono); font-size:11px; color:var(--c-muted); }
.tcard__btns{ display:flex; gap:3px; }
.tcard__btns button,.trow__btns button,.rem__btns button,.photo__x{ width:24px; height:24px; border-radius:7px; border:1px solid transparent;
  background:transparent; color:var(--c-muted); cursor:pointer; font-size:13px; display:grid; place-items:center; transition:.15s; }
.tcard__btns button:hover,.trow__btns button:hover,.rem__btns button:hover{ background:rgba(56,224,255,0.1); color:var(--c-text); border-color:var(--c-stroke); }

/* ---------- Reminders ---------- */
.rem-group{ margin-bottom:14px; }
.rem{ display:flex; align-items:center; gap:12px; padding:10px 6px; border-top:1px solid var(--c-stroke); }
.rem:first-of-type{ border-top:none; }
.rem.done .rem__body strong{ color:var(--c-muted); text-decoration:line-through; }
.rem__check{ width:24px; height:24px; border-radius:7px; border:1.5px solid var(--c-stroke-2); background:transparent;
  color:var(--c-bg); cursor:pointer; flex:none; display:grid; place-items:center; font-size:13px; transition:.15s; }
.rem__check.on{ background:var(--c-green); border-color:var(--c-green); }
.rem__time{ font-family:var(--font-mono); font-size:12px; color:var(--c-muted); width:46px; }
.rem__time.over{ color:var(--c-red); }
.rem__body{ flex:1; min-width:0; }
.rem__body strong{ display:block; font-size:13px; }
.rem__body small{ font-size:11px; color:var(--c-cyan); }
.rem__btns{ display:flex; gap:3px; }

/* ---------- Training ---------- */
.prog{ display:grid; grid-template-columns:repeat(7,1fr); gap:8px; }
.prog__day{ background:rgba(8,14,28,0.4); border:1px solid var(--c-stroke); border-radius:11px; padding:11px 9px; min-height:78px; }
.prog__day.today{ border-color:var(--c-cyan); box-shadow:0 0 16px rgba(56,224,255,0.12) inset; }
.prog__day.rest{ opacity:.55; }
.prog__d{ display:block; font-family:var(--font-mono); font-size:10px; color:var(--c-muted); letter-spacing:1px; margin-bottom:6px; }
.prog__day strong{ font-size:12px; line-height:1.3; }

/* table rows (training history, invoices) */
.table{ display:flex; flex-direction:column; }
.trow{ display:grid; grid-template-columns:1fr auto auto auto; gap:14px; align-items:center; padding:11px 4px; border-top:1px solid var(--c-stroke); font-size:13px; }
.trow:first-child{ border-top:none; }
.trow__main{ display:flex; flex-direction:column; min-width:0; }
.trow__main strong{ font-size:13px; }
.trow__main small{ font-size:11px; color:var(--c-muted); }
.trow__btns{ display:flex; gap:3px; }

/* status pill */
.pill{ font-family:var(--font-mono); font-size:11px; padding:3px 11px; border-radius:20px; border:1px solid var(--c-stroke); cursor:pointer; text-transform:capitalize; }
.pill--paid{ color:var(--c-green); background:rgba(79,230,168,.12); border-color:transparent; }
.pill--pending{ color:var(--c-amber); background:rgba(255,180,84,.12); border-color:transparent; }
.pill--off{ color:var(--c-dim); cursor:default; }

/* ---------- Business pipeline ---------- */
.pipe-stage{ margin:14px 0 6px; }
.pipe-stage__head{ display:flex; justify-content:space-between; font-size:11px; text-transform:uppercase; letter-spacing:1px; color:var(--c-muted); }
.lead{ display:flex; justify-content:space-between; align-items:center; padding:9px 11px; margin-top:6px;
  background:rgba(8,14,28,0.4); border:1px solid var(--c-stroke); border-radius:10px; cursor:pointer; font-size:13px; transition:.15s; }
.lead:hover{ border-color:var(--c-stroke-2); }
.lead span{ font-family:var(--font-mono); font-size:12px; color:var(--c-cyan); }

/* ---------- Calendar ---------- */
.cal-nav{ display:flex; align-items:center; justify-content:center; gap:18px; margin-bottom:14px; }
.cal-nav strong{ font-family:var(--font-display); letter-spacing:1px; min-width:180px; text-align:center; }
.cal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:6px; }
.cal-dow{ text-align:center; font-family:var(--font-mono); font-size:10px; letter-spacing:1px; color:var(--c-muted); padding-bottom:4px; }
.cal-cell{ min-height:92px; background:rgba(8,14,28,0.4); border:1px solid var(--c-stroke); border-radius:10px; padding:7px; cursor:pointer; transition:.15s; overflow:hidden; }
.cal-cell:hover{ border-color:var(--c-stroke-2); background:rgba(56,224,255,0.04); }
.cal-cell.out{ background:transparent; border-color:transparent; cursor:default; }
.cal-cell.is-today{ border-color:var(--c-cyan); box-shadow:0 0 14px rgba(56,224,255,0.12) inset; }
.cal-num{ font-family:var(--font-mono); font-size:12px; color:var(--c-muted); }
.cal-cell.is-today .cal-num{ color:var(--c-cyan); }
.cal-evs{ display:flex; flex-direction:column; gap:3px; margin-top:5px; }
.cal-ev{ font-size:10px; padding:2px 5px; border-radius:5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  background:rgba(120,180,255,0.12); color:var(--c-text); border-left:2px solid var(--c-blue); }
.cal-ev.cat-fitness{ border-left-color:var(--c-amber); } .cal-ev.cat-health{ border-left-color:var(--c-green); }
.cal-ev.cat-business{ border-left-color:var(--c-cyan); } .cal-ev.cat-personal{ border-left-color:var(--c-violet); }
.cal-more{ font-size:10px; color:var(--c-muted); }
.daypop{ display:flex; flex-direction:column; gap:8px; min-width:280px; }
.daypop__row{ display:flex; align-items:center; gap:10px; padding:9px 11px; background:rgba(8,14,28,0.4); border:1px solid var(--c-stroke); border-left:3px solid var(--c-blue); border-radius:10px; }
.daypop__row.cat-fitness{ border-left-color:var(--c-amber); } .daypop__row.cat-health{ border-left-color:var(--c-green); }
.daypop__row.cat-business{ border-left-color:var(--c-cyan); } .daypop__row.cat-personal{ border-left-color:var(--c-violet); }
.daypop__row strong{ flex:1; font-size:13px; }
.daypop__time{ font-family:var(--font-mono); font-size:12px; color:var(--c-muted); width:42px; }

/* ---------- Fitness ---------- */
.wchart{ width:100%; height:220px; }
.wchart__dots circle{ fill:var(--c-cyan); }
.wchart__lbl text{ fill:var(--c-dim); font-family:var(--font-mono); font-size:9px; }
.hsync{ display:flex; flex-direction:column; gap:13px; margin-bottom:12px; }
.hsync__top{ display:flex; justify-content:space-between; font-size:12px; color:var(--c-muted); margin-bottom:5px; }
.hsync__top strong{ color:var(--c-text); }
.hsync__row i{ display:block; height:6px; border-radius:6px; background:rgba(120,180,255,0.1); overflow:hidden; }
.hsync__row u{ display:block; height:100%; border-radius:6px; background:linear-gradient(90deg,var(--c-blue),var(--c-cyan)); }
.hsync__meta{ font-size:11px; margin-bottom:10px; }
.photo-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:12px; }
.photo{ position:relative; border-radius:11px; overflow:hidden; border:1px solid var(--c-stroke); background:rgba(8,14,28,0.4); }
.photo img{ width:100%; height:150px; object-fit:cover; display:block; }
.photo__meta{ padding:7px 9px; }
.photo__meta span{ font-size:12px; display:block; } .photo__meta small{ font-size:10px; color:var(--c-muted); }
.photo__x{ position:absolute; top:6px; right:6px; background:rgba(4,7,15,0.7)!important; }
.card--locked{ opacity:.96; }
.locked{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:10px; padding:18px 8px; }
.locked__ic{ font-size:30px; opacity:.7; }
.locked p{ color:var(--c-muted); max-width:420px; font-size:13px; }

/* ---------- empty state ---------- */
.empty{ display:flex; flex-direction:column; align-items:center; gap:12px; padding:34px 12px; text-align:center; color:var(--c-muted); }
.empty__ic{ font-size:30px; opacity:.7; }

/* ---------- modal / forms / toast ---------- */
.modal-overlay{ position:fixed; inset:0; z-index:200; display:grid; place-items:center; padding:20px;
  background:rgba(2,5,12,0.6); backdrop-filter:blur(6px); opacity:0; transition:opacity .25s; }
.modal-overlay.show{ opacity:1; }
.modal{ width:min(440px,94vw); max-height:88vh; overflow:auto; background:linear-gradient(180deg,rgba(18,28,50,0.96),rgba(8,14,28,0.96));
  border:1px solid var(--c-stroke-2); border-radius:var(--radius); box-shadow:0 30px 80px rgba(0,0,0,0.6);
  transform:translateY(12px) scale(.98); transition:transform .25s; }
.modal-overlay.show .modal{ transform:translateY(0) scale(1); }
.modal__head{ display:flex; align-items:center; justify-content:space-between; padding:16px 18px; border-bottom:1px solid var(--c-stroke); }
.modal__head h3{ font-family:var(--font-display); letter-spacing:1px; font-size:16px; }
.modal__x{ width:30px; height:30px; border-radius:8px; border:1px solid var(--c-stroke); background:transparent; color:var(--c-muted); cursor:pointer; }
.modal__x:hover{ color:var(--c-text); border-color:var(--c-stroke-2); }
.modal__body{ padding:18px; }
.modal__foot{ padding:0 18px 18px; }
.form{ display:flex; flex-direction:column; gap:13px; }
.form__row{ display:flex; flex-direction:column; gap:6px; }
.form__label{ font-size:12px; color:var(--c-muted); }
.form__label .req{ color:var(--c-red); font-style:normal; }
.form input,.form select,.form textarea{ width:100%; padding:10px 12px; border-radius:10px; background:rgba(4,7,15,0.6);
  border:1px solid var(--c-stroke); color:var(--c-text); font-family:var(--font); font-size:14px; outline:none; transition:.15s; }
.form input:focus,.form select:focus,.form textarea:focus{ border-color:var(--c-stroke-2); box-shadow:0 0 0 3px rgba(56,224,255,0.08); }
.form input.invalid{ border-color:var(--c-red); }
.form textarea{ resize:vertical; }
.form input[type="date"],.form input[type="time"]{ color-scheme:dark; }
.form__actions{ display:flex; justify-content:flex-end; gap:10px; }
.btn--danger{ background:linear-gradient(135deg,var(--c-red),#ff8aa0); color:#04070f; }

.toast-wrap{ position:fixed; bottom:20px; right:20px; z-index:300; display:flex; flex-direction:column; gap:10px; }
.toast{ padding:12px 16px; border-radius:11px; background:rgba(18,28,50,0.96); border:1px solid var(--c-stroke-2);
  color:var(--c-text); font-size:13px; box-shadow:0 12px 40px rgba(0,0,0,0.5); border-left:3px solid var(--c-green);
  transform:translateX(120%); transition:transform .3s cubic-bezier(.22,1,.36,1); }
.toast.show{ transform:translateX(0); }
.toast--warn{ border-left-color:var(--c-amber); }

@media (max-width:980px){
  .kanban{ grid-template-columns:1fr; }
  .prog{ grid-template-columns:repeat(2,1fr); }
  .cal-cell{ min-height:64px; }
  .cal-ev{ font-size:9px; }
}

/* ============================================================
   SETTINGS / THEMES / NOTIFICATIONS / TOOLS / PLANNER
   ============================================================ */

/* section header inside a panel */
.section-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin:26px 2px 14px; }
.section-head h2{ font-size:18px; font-weight:600; letter-spacing:.3px; }

/* ---- settings ---- */
.settings{ display:flex; flex-direction:column; gap:6px; min-width:300px; }
.settings__h{ font-family:var(--font-mono); font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--c-muted); margin:14px 0 8px; }
.settings__h:first-child{ margin-top:0; }
.theme-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.theme-tile{ display:flex; flex-direction:column; align-items:center; gap:6px; padding:9px 6px; border-radius:11px;
  background:rgba(6,11,24,0.5); border:1px solid var(--c-stroke); cursor:pointer; transition:.15s; }
.theme-tile:hover{ border-color:var(--c-stroke-2); }
.theme-tile.is-on{ border-color:var(--c-cyan); box-shadow:0 0 0 2px rgba(56,224,255,0.18); }
.theme-tile__sw{ width:100%; height:30px; border-radius:8px; }
.theme-tile small{ font-size:10px; color:var(--c-muted); }
.toggle,.toggle2{ display:flex; align-items:center; gap:10px; padding:10px 0; font-size:13px; }
.toggle__sw{ width:36px; height:20px; border-radius:20px; background:rgba(120,180,255,0.15); position:relative; }
.toggle__sw::after{ content:''; position:absolute; top:2px; left:2px; width:16px; height:16px; border-radius:50%; background:var(--c-dim); }
.toggle.is-off{ opacity:.6; } .toggle__note{ margin-left:auto; color:var(--c-dim); font-family:var(--font-mono); font-size:10px; }
.toggle2 input{ width:auto; }

/* ---- notification centre ---- */
.notif-pop{ position:fixed; top:74px; right:22px; z-index:210; width:min(360px,92vw); max-height:70vh; overflow:auto;
  background:linear-gradient(180deg,rgba(18,28,50,0.98),rgba(8,14,28,0.98)); border:1px solid var(--c-stroke-2);
  border-radius:14px; box-shadow:0 26px 70px rgba(0,0,0,0.6); opacity:0; transform:translateY(-8px); transition:.2s; }
.notif-pop.show{ opacity:1; transform:translateY(0); }
.notif-pop__head{ display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid var(--c-stroke); position:sticky; top:0; background:rgba(12,20,38,0.98); }
.notif-pop__head strong{ font-family:var(--font-display); letter-spacing:1px; font-size:14px; }
.notif-pop__clear{ background:none; border:none; color:var(--c-cyan); font-size:12px; cursor:pointer; }
.notif-pop__body{ padding:6px; }
.notif{ display:flex; align-items:center; gap:11px; padding:11px; border-radius:10px; cursor:pointer; transition:.15s; }
.notif:hover{ background:rgba(56,224,255,0.06); }
.notif.read{ opacity:.45; }
.notif__ic{ width:30px; height:30px; border-radius:9px; display:grid; place-items:center; font-size:13px; flex:none; }
.notif__body{ flex:1; min-width:0; } .notif__body strong{ display:block; font-size:13px; } .notif__body small{ font-size:11px; color:var(--c-muted); }
.notif time{ font-family:var(--font-mono); font-size:10px; color:var(--c-dim); }

/* ---- business tools / calculators ---- */
.tools-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.calc__inputs{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:12px; }
.calc__field{ display:flex; flex-direction:column; gap:5px; }
.calc__field span{ font-size:11px; color:var(--c-muted); }
.calc__inwrap{ position:relative; display:flex; align-items:center; }
.calc__inwrap input{ width:100%; padding:9px 28px 9px 11px; border-radius:9px; background:rgba(4,7,15,0.6);
  border:1px solid var(--c-stroke); color:var(--c-text); font-family:var(--font-mono); font-size:13px; outline:none; }
.calc__inwrap input:focus{ border-color:var(--c-stroke-2); }
.calc__inwrap i{ position:absolute; right:10px; font-style:normal; font-size:11px; color:var(--c-dim); }
.calc__res{ display:flex; flex-direction:column; gap:7px; border-top:1px solid var(--c-stroke); padding-top:11px; }
.calc__line{ display:flex; justify-content:space-between; align-items:center; font-size:12px; color:var(--c-muted); }
.calc__line strong{ font-family:var(--font-mono); color:var(--c-text); }
.calc__line.big{ font-size:14px; color:var(--c-text); }
.calc__line.big strong{ font-family:var(--font-display); font-size:18px; color:var(--c-cyan); }

/* ---- ideas board ---- */
.ideas-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.idea{ background:var(--c-panel); border:1px solid var(--c-stroke); border-radius:12px; padding:14px; }
.idea__top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.idea__tag{ font-size:10px; font-family:var(--font-mono); text-transform:uppercase; letter-spacing:1px; color:var(--c-cyan); background:rgba(56,224,255,0.1); padding:2px 8px; border-radius:8px; }
.idea__x{ width:22px; height:22px; border-radius:6px; border:none; background:transparent; color:var(--c-dim); cursor:pointer; }
.idea__x:hover{ color:var(--c-red); }
.idea strong{ display:block; font-size:14px; margin-bottom:6px; }
.idea p{ font-size:12px; color:var(--c-muted); line-height:1.45; }

/* ---- weekly plan ---- */
.weekplan{ display:grid; grid-template-columns:repeat(7,1fr); gap:8px; }
.wp-day{ background:rgba(8,14,28,0.45); border:1px solid var(--c-stroke); border-radius:11px; padding:10px; cursor:pointer; transition:.15s; min-height:150px; display:flex; flex-direction:column; gap:7px; }
.wp-day:hover{ border-color:var(--c-stroke-2); transform:translateY(-2px); }
.wp-day.today{ border-color:var(--c-cyan); box-shadow:0 0 16px rgba(56,224,255,0.12) inset; }
.wp-day.rest{ opacity:.6; }
.wp-day__head{ display:flex; align-items:center; justify-content:space-between; }
.wp-day__d{ font-family:var(--font-mono); font-size:11px; color:var(--c-muted); letter-spacing:1px; }
.wp-day__type{ font-size:10px; font-weight:600; color:var(--c-cyan); background:rgba(56,224,255,0.12); padding:2px 7px; border-radius:8px; }
.wp-day__rest{ font-size:10px; color:var(--c-dim); font-family:var(--font-mono); }
.wp-day__focus{ font-size:11px; color:var(--c-text); line-height:1.3; }
.wp-day__ex{ list-style:none; display:flex; flex-direction:column; gap:3px; flex:1; }
.wp-day__ex li{ font-size:10px; color:var(--c-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.wp-day__ex li.more{ color:var(--c-cyan); }
.wp-day__meta{ display:flex; flex-wrap:wrap; gap:7px; font-size:10px; color:var(--c-dim); font-family:var(--font-mono); margin-top:auto; }

/* ---- planner modal extras ---- */
.form__grid2{ display:grid; grid-template-columns:1fr 1fr; gap:11px; }
.btn--sm{ padding:6px 11px; font-size:12px; }
.planner__exhead{ display:flex; align-items:center; justify-content:space-between; margin:6px 0 2px; }
.exrows{ display:flex; flex-direction:column; gap:7px; }
.exrow{ display:grid; grid-template-columns:1fr 56px 70px 28px; gap:6px; align-items:center; }
.exrow input{ padding:8px 9px; border-radius:8px; background:rgba(4,7,15,0.6); border:1px solid var(--c-stroke); color:var(--c-text); font-size:13px; outline:none; }
.exrow input:focus{ border-color:var(--c-stroke-2); }
.exrow__x{ width:28px; height:32px; border-radius:7px; border:1px solid transparent; background:transparent; color:var(--c-dim); cursor:pointer; }
.exrow__x:hover{ color:var(--c-red); border-color:var(--c-stroke); }

@media (max-width:1100px){
  .tools-grid,.ideas-grid{ grid-template-columns:repeat(2,1fr); }
  .theme-grid{ grid-template-columns:repeat(4,1fr); }
}
@media (max-width:820px){
  .tools-grid,.ideas-grid{ grid-template-columns:1fr; }
  .weekplan{ grid-template-columns:repeat(2,1fr); }
  .calc__inputs{ grid-template-columns:1fr; }
  .notif-pop{ right:10px; left:10px; width:auto; }
}
