/* ═══════════════════════════════════════════════════════════════
   smart-office.css — WAIproger Smart Office Pro · COSMIC EDITION
   Standalone — zero dependency on b.css
   ═══════════════════════════════════════════════════════════════ */

/* ── RESET ───────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }

/* ── TOKENS: GREEN (default) ─────────────────────────────────── */
:root {
  --so-accent:   #a8ff3e;
  --so-accent2:  #00ffaa;
  --so-accent3:  #ffcc00;
  --so-bg:       #020704;
  --so-bg2:      #060e07;
  --so-bg3:      #0b1a0c;
  --so-card:     rgba(6,14,7,0.97);
  --so-border:   rgba(168,255,62,0.13);
  --so-border2:  rgba(168,255,62,0.38);
  --so-glow:     rgba(168,255,62,0.40);
  --so-glow-sm:  rgba(168,255,62,0.10);
  --so-text:     #e2f8b0;
  --so-muted:    #547838;
  --so-dim:      #253818;
  --so-ok:       #00ff88;
  --so-warn:     #ffcc00;
  --so-danger:   #ff3355;
  --so-cyan:     #00c8ff;
  --so-purple:   #9966ff;
  --f-head: 'Bebas Neue', sans-serif;
  --f-body: 'DM Sans', sans-serif;
  --f-mono: 'JetBrains Mono', monospace;
  --f-syne: 'Syne', sans-serif;
  --star-color: rgba(168,255,62,0.7);
}

/* ── TOKENS: BLUE ────────────────────────────────────────────── */
[data-theme="blue"] {
  --so-accent:   #00d4ff;
  --so-accent2:  #7b5cff;
  --so-accent3:  #ff6eb4;
  --so-bg:       #010610;
  --so-bg2:      #03091a;
  --so-bg3:      #071428;
  --so-card:     rgba(3,9,26,0.97);
  --so-border:   rgba(0,212,255,0.13);
  --so-border2:  rgba(0,212,255,0.40);
  --so-glow:     rgba(0,212,255,0.40);
  --so-glow-sm:  rgba(0,212,255,0.08);
  --so-text:     #bff0ff;
  --so-muted:    #285570;
  --so-dim:      #0e2a3a;
  --star-color:  rgba(0,212,255,0.7);
}

/* ── TOKENS: COSMIC ──────────────────────────────────────────── */
[data-theme="cosmic"] {
  --so-accent:   #c77dff;
  --so-accent2:  #00f0ff;
  --so-accent3:  #ff79c6;
  --so-bg:       #04010e;
  --so-bg2:      #08031a;
  --so-bg3:      #0f0728;
  --so-card:     rgba(8,3,26,0.97);
  --so-border:   rgba(199,125,255,0.13);
  --so-border2:  rgba(199,125,255,0.40);
  --so-glow:     rgba(199,125,255,0.40);
  --so-glow-sm:  rgba(199,125,255,0.10);
  --so-text:     #f0e0ff;
  --so-muted:    #6a3a8a;
  --so-dim:      #251040;
  --star-color:  rgba(199,125,255,0.8);
}

/* ── BODY ────────────────────────────────────────────────────── */
body {
  background: var(--so-bg);
  color: var(--so-text);
  font-family: var(--f-body);
  overflow-x: hidden;
  min-height: 100vh;
  /* Cosmic starfield via pseudo */
  position: relative;
}
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(1px 1px at 20% 30%, var(--star-color) 0%, transparent 100%),
    radial-gradient(1px 1px at 80% 10%, var(--star-color) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 10% 70%, var(--star-color) 0%, transparent 100%),
    radial-gradient(1px 1px at 50% 50%, rgba(255,255,255,0.3) 0%, transparent 100%),
    radial-gradient(1px 1px at 90% 60%, var(--star-color) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 35% 85%, rgba(255,255,255,0.2) 0%, transparent 100%),
    radial-gradient(1px 1px at 65% 20%, var(--star-color) 0%, transparent 100%),
    radial-gradient(1px 1px at 75% 75%, rgba(255,255,255,0.25) 0%, transparent 100%),
    radial-gradient(1px 1px at 5%  40%, var(--star-color) 0%, transparent 100%),
    radial-gradient(2px 2px at 95% 90%, var(--star-color) 0%, transparent 100%);
  pointer-events: none;
  z-index: 0;
  animation: stars-drift 120s linear infinite;
}
@keyframes stars-drift {
  from { transform: translateY(0); }
  to   { transform: translateY(-20px); }
}

/* ── BG CANVAS ───────────────────────────────────────────────── */
.bg-canvas {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  width: 100%;
  height: 100%;
  opacity: 0.85;
}

/* ── SCROLLBAR ───────────────────────────────────────────────── */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--so-border2); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--so-accent); }

.hidden { display: none !important; }

/* ══════════════════════════════════════════════════════════════
   STYLE PICKER
   ══════════════════════════════════════════════════════════════ */
.sp-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: radial-gradient(ellipse at 50% 100%, #0a1a08 0%, #000 60%);
  display: flex; align-items: center; justify-content: center;
  transition: opacity 0.6s, transform 0.6s;
}
.sp-overlay.gone { opacity: 0; transform: scale(1.06); pointer-events: none; }
.sp-inner {
  text-align: center;
  position: relative;
  z-index: 2;
  padding: 20px;
}
.sp-logo {
  font-family: var(--f-head);
  font-size: clamp(3rem,8vw,5.5rem);
  letter-spacing: 0.14em;
  color: #a8ff3e;
  margin-bottom: 6px;
  text-shadow: 0 0 40px rgba(168,255,62,0.6), 0 0 80px rgba(168,255,62,0.2);
  animation: logo-pulse 3s ease-in-out infinite;
}
@keyframes logo-pulse {
  0%,100% { text-shadow: 0 0 40px rgba(168,255,62,0.6),0 0 80px rgba(168,255,62,0.2); }
  50%      { text-shadow: 0 0 60px rgba(168,255,62,0.9),0 0 120px rgba(168,255,62,0.4); }
}
.sp-logo em { font-style: normal; color: #fff; }
.sp-tagline {
  font-family: var(--f-mono);
  font-size: 0.68rem;
  color: #3a5a28;
  letter-spacing: 0.38em;
  text-transform: uppercase;
  margin-bottom: 56px;
}
.sp-cards { display: flex; gap: 22px; justify-content: center; flex-wrap: wrap; }
.sp-card {
  width: 200px;
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 22px;
  padding: 24px 16px;
  cursor: pointer;
  transition: all 0.38s cubic-bezier(0.34,1.56,0.64,1);
  background: rgba(255,255,255,0.02);
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(10px);
}
.sp-card:hover {
  transform: translateY(-12px) scale(1.04);
  border-color: rgba(255,255,255,0.22);
  box-shadow: 0 40px 90px rgba(0,0,0,0.8);
}
.sp-glow {
  position: absolute; width: 100%; height: 100%;
  top: 0; left: 0;
  background: radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--gc) 18%, transparent), transparent 70%);
  opacity: 0;
  transition: opacity 0.3s;
  pointer-events: none;
}
.sp-card:hover .sp-glow { opacity: 1; }
.sp-prev {
  width: 100px; height: 64px;
  margin: 0 auto 16px;
  border-radius: 10px;
  background: linear-gradient(145deg,#040806,#101a0e);
  border: 1px solid rgba(255,255,255,0.07);
  display: flex; align-items: flex-end;
  padding: 6px; gap: 4px;
  position: relative; overflow: hidden;
}
.sp-bars { display: flex; align-items: flex-end; gap: 4px; flex: 1; height: 100%; }
.sp-bars i { flex: 1; border-radius: 3px; display: block; animation: bar-anim 2s ease-in-out infinite alternate; }
.sp-bars i:nth-child(2) { animation-delay: 0.3s; }
.sp-bars i:nth-child(3) { animation-delay: 0.6s; }
.sp-bars i:nth-child(4) { animation-delay: 0.9s; }
@keyframes bar-anim { from { height: 20%; } to { height: 90%; } }
.sp-circ {
  position: absolute; top: 8px; right: 8px;
  width: 16px; height: 16px;
  border-radius: 50%;
  border: 1.5px solid;
}
.sp-cn { font-family: var(--f-head); font-size: 1.15rem; margin-bottom: 4px; letter-spacing: 0.05em; }
.sp-card[data-theme="green"]  .sp-cn { color: #a8ff3e; }
.sp-card[data-theme="blue"]   .sp-cn { color: #00d4ff; }
.sp-card[data-theme="cosmic"] .sp-cn { color: #c77dff; }
.sp-cd { font-size: 0.68rem; color: #3a3a3a; font-family: var(--f-mono); margin-bottom: 14px; }
.sp-badge {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 20px;
  font-size: 0.62rem;
  font-family: var(--f-mono);
  font-weight: 700;
  border: 1px solid;
  letter-spacing: 0.1em;
}
#sp-particles { position: absolute; inset: 0; pointer-events: none; z-index: 0; }

/* ══════════════════════════════════════════════════════════════
   HEADER
   ══════════════════════════════════════════════════════════════ */
.so-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  height: 62px;
  background: rgba(2,7,4,0.92);
  backdrop-filter: blur(28px) saturate(1.6);
  border-bottom: 1px solid var(--so-border);
  display: flex; align-items: center;
  padding: 0 22px; gap: 18px;
  transition: background 0.3s;
}
[data-theme="blue"]   .so-header { background: rgba(1,6,16,0.92); }
[data-theme="cosmic"] .so-header { background: rgba(4,1,14,0.92); }

/* ── Nav trigger (hamburger) ── */
.nav-trigger-btn {
  width: 36px; height: 36px;
  background: var(--so-glow-sm);
  border: 1px solid var(--so-border);
  border-radius: 10px;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 5px; cursor: pointer;
  flex-shrink: 0;
  transition: all 0.22s;
}
.nav-trigger-btn span {
  display: block; width: 18px; height: 1.5px;
  background: var(--so-accent);
  border-radius: 2px;
  transition: all 0.3s;
}
.nav-trigger-btn:hover { box-shadow: 0 0 14px var(--so-glow-sm); border-color: var(--so-border2); }
.nav-open .nav-trigger-btn span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-open .nav-trigger-btn span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-open .nav-trigger-btn span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ── Brand ── */
.so-brand { display: flex; align-items: center; gap: 11px; flex-shrink: 0; }
.brand-hex {
  width: 36px; height: 36px;
  background: var(--so-glow-sm);
  border: 1px solid var(--so-border2);
  border-radius: 10px;
  display: grid; place-items: center;
  font-family: var(--f-head); font-size: 1.2rem; color: var(--so-accent);
  animation: hex-pulse 3s ease-in-out infinite;
}
@keyframes hex-pulse {
  0%,100% { box-shadow: 0 0 8px var(--so-glow-sm); }
  50%      { box-shadow: 0 0 22px var(--so-glow); }
}
.brand-main {
  font-family: var(--f-head); font-size: 1.3rem;
  color: var(--so-accent); letter-spacing: 0.06em; line-height: 1;
}
.brand-main em { font-style: normal; color: var(--so-text); }
.brand-sub {
  font-family: var(--f-mono); font-size: 0.5rem;
  color: var(--so-muted); letter-spacing: 0.22em;
  text-transform: uppercase; margin-top: 2px;
}

/* ── Nav links ── */
.so-nav { display: flex; gap: 2px; flex: 1; }
.snl {
  padding: 6px 13px; border-radius: 8px;
  font-size: 0.78rem; font-family: var(--f-mono);
  color: var(--so-muted);
  text-decoration: none;
  transition: all 0.2s; cursor: pointer;
  letter-spacing: 0.04em;
}
.snl:hover, .snl.active { color: var(--so-accent); background: var(--so-glow-sm); }

/* ── Right cluster ── */
.so-hdr-right { display: flex; align-items: center; gap: 10px; margin-left: auto; }
.so-clock {
  font-family: var(--f-mono); font-size: 0.76rem;
  color: var(--so-accent);
  padding: 4px 12px;
  border: 1px solid var(--so-border);
  border-radius: 20px;
  min-width: 78px; text-align: center;
  background: var(--so-glow-sm);
  letter-spacing: 0.06em;
}
.hdr-btn {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--so-glow-sm);
  border: 1px solid var(--so-border);
  color: var(--so-accent); cursor: pointer;
  font-size: 0.9rem; transition: all 0.2s;
}
.hdr-btn:hover { box-shadow: 0 0 14px var(--so-glow); }
.hdr-cam-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 14px; border-radius: 20px;
  background: var(--so-glow-sm);
  border: 1px solid var(--so-border2);
  color: var(--so-accent); cursor: pointer;
  font-family: var(--f-mono); font-size: 0.73rem; font-weight: 700;
  letter-spacing: 0.1em; transition: all 0.2s;
}
.hdr-cam-btn:hover { background: var(--so-glow); box-shadow: 0 0 22px var(--so-glow); }
.online-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--so-ok); box-shadow: 0 0 8px var(--so-ok);
  animation: pulse-d 2s ease-in-out infinite;
}
@keyframes pulse-d { 0%,100% { opacity:1; transform:scale(1); } 50% { opacity:0.45; transform:scale(0.65); } }

/* ══════════════════════════════════════════════════════════════
   SIDE NAVIGATION
   ══════════════════════════════════════════════════════════════ */
.nav-overlay {
  position: fixed; inset: 0; z-index: 290;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(6px);
  opacity: 0; pointer-events: none;
  transition: opacity 0.35s;
}
.nav-open .nav-overlay { opacity: 1; pointer-events: auto; }

.side-nav {
  position: fixed; top: 0; left: 0; bottom: 0;
  width: 300px; z-index: 300;
  transform: translateX(-100%);
  transition: transform 0.38s cubic-bezier(0.25,0.46,0.45,0.94);
  display: flex; flex-direction: column;
  overflow-y: auto; overflow-x: hidden;
}
.nav-open .side-nav { transform: translateX(0); }

.side-nav-bg {
  position: absolute; inset: 0;
  background: linear-gradient(160deg, var(--so-bg3) 0%, var(--so-bg) 100%);
  border-right: 1px solid var(--so-border);
  backdrop-filter: blur(30px);
}

.side-nav-header {
  position: relative; z-index: 2;
  padding: 18px 20px 16px;
  border-bottom: 1px solid var(--so-border);
  display: flex; align-items: center; justify-content: space-between;
}
.nav-brand {
  font-family: var(--f-head); font-size: 1.6rem;
  color: var(--so-accent); letter-spacing: 0.06em;
}
.nav-brand em { font-style: normal; color: var(--so-text); }
.nav-close-btn {
  width: 30px; height: 30px; border-radius: 8px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--so-border);
  color: var(--so-muted); cursor: pointer; font-size: 0.85rem;
  transition: all 0.2s;
}
.nav-close-btn:hover { border-color: var(--so-danger); color: var(--so-danger); }

.nav-links {
  position: relative; z-index: 2;
  padding: 12px 12px;
  flex: 1;
  display: flex; flex-direction: column; gap: 3px;
}
.nav-link {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 12px;
  text-decoration: none; color: var(--so-muted);
  transition: all 0.22s; border: 1px solid transparent;
  opacity: 0; transform: translateX(-16px);
}
.nav-link.animate-in { animation: nav-slide-in 0.35s ease forwards; }
@keyframes nav-slide-in { to { opacity: 1; transform: translateX(0); } }
.nav-link:hover, .nav-link--active {
  background: var(--so-glow-sm);
  border-color: var(--so-border);
  color: var(--so-text);
}
.nav-link--active { color: var(--so-accent) !important; }
.nav-link-icon { font-size: 1.1rem; width: 28px; text-align: center; flex-shrink: 0; }
.nav-link-info { flex: 1; min-width: 0; }
.nav-link-title { font-size: 0.83rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.nav-link-sub { font-size: 0.66rem; color: var(--so-dim); font-family: var(--f-mono); margin-top: 1px; }
.nav-link-arrow { font-size: 0.75rem; color: var(--so-dim); transition: transform 0.2s; }
.nav-link:hover .nav-link-arrow { transform: translateX(4px); color: var(--so-accent); }

.nav-footer-social {
  position: relative; z-index: 2;
  padding: 14px 16px 24px;
  border-top: 1px solid var(--so-border);
  display: flex; gap: 8px;
}
.nav-social-btn {
  flex: 1; padding: 8px 4px;
  border-radius: 10px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--so-border);
  color: var(--so-muted);
  font-family: var(--f-mono); font-size: 0.65rem;
  text-align: center; text-decoration: none; cursor: pointer;
  transition: all 0.2s;
}
.nav-social-btn:hover { border-color: var(--so-accent); color: var(--so-accent); background: var(--so-glow-sm); }

/* ══════════════════════════════════════════════════════════════
   HERO
   ══════════════════════════════════════════════════════════════ */
.so-hero {
  min-height: 100vh;
  display: flex; align-items: center;
  padding: 90px 60px 70px;
  position: relative; overflow: hidden;
}

.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--so-border) 1px, transparent 1px),
    linear-gradient(90deg, var(--so-border) 1px, transparent 1px);
  background-size: 72px 72px;
  opacity: 0.45;
  mask-image: radial-gradient(ellipse at center, black 40%, transparent 80%);
}

.hero-orb { position: absolute; border-radius: 50%; filter: blur(100px); pointer-events: none; }
.o1 { width: 700px; height: 700px; top: -200px; right: -150px; background: radial-gradient(circle, var(--so-glow-sm) 0%, transparent 70%); animation: orb-float 14s ease-in-out infinite; }
.o2 { width: 400px; height: 400px; bottom: -80px; left: 80px; background: radial-gradient(circle, rgba(0,255,170,0.05) 0%, transparent 70%); animation: orb-float 18s ease-in-out infinite reverse; }
.o3 { width: 280px; height: 280px; top: 35%; left: 42%; background: radial-gradient(circle, rgba(255,204,0,0.04) 0%, transparent 70%); animation: orb-float 10s ease-in-out infinite 2s; }
.o4 { width: 200px; height: 200px; bottom: 20%; right: 38%; background: radial-gradient(circle, rgba(153,102,255,0.05) 0%, transparent 70%); animation: orb-float 12s ease-in-out infinite 4s; }
@keyframes orb-float {
  0%,100% { transform: translate(0,0) scale(1); }
  33%  { transform: translate(20px,-30px) scale(1.05); }
  66%  { transform: translate(-15px,20px) scale(0.95); }
}

/* ── Hero content — centered ── */
.hero-content {
  position: relative; z-index: 2;
  max-width: 560px;
  text-align: center;
  margin: 0 auto;
  display: flex; flex-direction: column; align-items: center;
}

.hero-eyebrow {
  font-family: var(--f-mono); font-size: 0.68rem;
  color: var(--so-accent); letter-spacing: 0.42em;
  text-transform: uppercase;
  margin-bottom: 28px;
  display: flex; align-items: center; gap: 12px;
}
.eb-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--so-accent); box-shadow: 0 0 12px var(--so-accent);
  animation: pulse-d 1.5s ease-in-out infinite;
}

/* ── BIG TITLE ── */
.hero-title {
  display: flex; flex-direction: column;
  align-items: center; gap: 0;
  margin-bottom: 28px;
  line-height: 0.86;
}
.ht-line { display: block; font-family: var(--f-head); letter-spacing: 0.04em; }
.ht-sm {
  font-size: clamp(2.8rem, 7vw, 5.5rem);
  color: var(--so-text);
}
.ht-lg {
  font-size: clamp(5.5rem, 16vw, 13rem);
  line-height: 0.85;
}
.ht-lg em {
  font-style: normal;
  -webkit-text-stroke: 2.5px var(--so-accent);
  color: transparent;
  filter: drop-shadow(0 0 28px var(--so-glow));
  animation: stroke-glow 3s ease-in-out infinite;
}
@keyframes stroke-glow {
  0%,100% { filter: drop-shadow(0 0 24px var(--so-glow)); }
  50%      { filter: drop-shadow(0 0 52px var(--so-glow)) drop-shadow(0 0 90px var(--so-glow-sm)); }
}

.hero-desc {
  font-size: 0.92rem; color: var(--so-muted);
  line-height: 1.8; margin-bottom: 38px;
  letter-spacing: 0.02em;
}
.hd-tags { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-top: 8px; }
.hd-tags i {
  font-style: normal;
  padding: 3px 12px; border-radius: 20px;
  border: 1px solid var(--so-border);
  font-family: var(--f-mono); font-size: 0.68rem;
  color: var(--so-muted); letter-spacing: 0.08em;
}

.hero-btns { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; margin-bottom: 36px; }
.hb {
  padding: 12px 26px; border-radius: 12px;
  font-family: var(--f-mono); font-size: 0.8rem; font-weight: 700;
  cursor: pointer; transition: all 0.25s;
  display: flex; align-items: center; gap: 8px;
  border: 1px solid var(--so-border);
  background: rgba(255,255,255,0.03);
  color: var(--so-muted);
  letter-spacing: 0.06em;
}
.hb:hover { border-color: var(--so-accent); color: var(--so-accent); background: var(--so-glow-sm); transform: translateY(-2px); }
.hb.primary {
  background: var(--so-glow-sm);
  border-color: var(--so-accent);
  color: var(--so-accent);
  box-shadow: 0 0 20px var(--so-glow-sm);
}
.hb.primary:hover {
  background: var(--so-glow);
  box-shadow: 0 0 38px var(--so-glow);
  transform: translateY(-3px);
}

.hero-stats {
  display: flex; align-items: center; gap: 24px;
  padding: 16px 30px;
  border: 1px solid var(--so-border);
  border-radius: 16px;
  background: rgba(255,255,255,0.02);
  backdrop-filter: blur(10px);
}
.hs-item { text-align: center; }
.hs-val { font-family: var(--f-head); font-size: 1.6rem; color: var(--so-accent); line-height: 1; }
.hs-lbl { font-family: var(--f-mono); font-size: 0.58rem; color: var(--so-muted); letter-spacing: 0.12em; text-transform: uppercase; margin-top: 3px; }
.hs-sep { width: 1px; height: 36px; background: var(--so-border); }

/* ── Hero Visual (ring) ── */
.hero-visual {
  position: absolute;
  right: 60px; top: 50%;
  transform: translateY(-50%);
  width: 320px; height: 320px;
  display: grid; place-items: center;
  pointer-events: none;
}
.hv-ring {
  position: absolute; border-radius: 50%;
  border: 1px solid var(--so-accent);
  top: 50%; left: 50%; transform: translate(-50%,-50%);
}
.hv-ring.r1 { width: 320px; height: 320px; opacity: 0.18; animation: spin-r 14s linear infinite; }
.hv-ring.r2 { width: 260px; height: 260px; opacity: 0.12; animation: spin-r 9s linear infinite reverse; }
.hv-ring.r3 { width: 200px; height: 200px; opacity: 0.08; }
@keyframes spin-r { to { transform: translate(-50%,-50%) rotate(360deg); } }
#hero-ring { position: relative; z-index: 2; }
.hv-center { position: absolute; text-align: center; z-index: 3; }
.hvc-lbl { font-family: var(--f-mono); font-size: 0.58rem; color: var(--so-muted); letter-spacing: 0.22em; text-transform: uppercase; }
.hvc-val { font-family: var(--f-head); font-size: 3.8rem; color: var(--so-accent); line-height: 1; text-shadow: 0 0 30px var(--so-glow); }
.hvc-sub { font-size: 0.68rem; color: var(--so-muted); font-family: var(--f-mono); }
.od {
  position: absolute;
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--dc); box-shadow: 0 0 12px var(--dc);
  top: calc(50% - 7px + var(--dr) * -1);
  left: calc(50% - 7px);
  transform-origin: 7px calc(7px + var(--dr));
  animation: orbit-dot 6s linear infinite;
}
@keyframes orbit-dot { to { transform: rotate(360deg); } }

.hero-scroll {
  position: absolute; bottom: 40px; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  font-family: var(--f-mono); font-size: 0.62rem;
  color: var(--so-muted); letter-spacing: 0.2em;
}
.hero-scroll div {
  width: 1px; height: 44px;
  background: linear-gradient(180deg, var(--so-accent), transparent);
  animation: scroll-line 2s ease-in-out infinite;
}
@keyframes scroll-line { 0%,100% { opacity: 0.25; } 50% { opacity: 1; } }

/* ══════════════════════════════════════════════════════════════
   KPI STRIP
   ══════════════════════════════════════════════════════════════ */
.kpi-strip {
  display: grid;
  grid-template-columns: repeat(6,1fr);
  background: var(--so-border);
  gap: 1px;
  border-top: 1px solid var(--so-border);
  border-bottom: 1px solid var(--so-border);
  position: relative; z-index: 2;
}
@media(max-width:1100px) { .kpi-strip { grid-template-columns: repeat(3,1fr); } }
@media(max-width:600px)  { .kpi-strip { grid-template-columns: repeat(2,1fr); } }

.kc {
  background: var(--so-bg2);
  padding: 18px 18px;
  display: flex; align-items: center; gap: 11px;
  position: relative; overflow: hidden;
  transition: background 0.22s;
}
.kc::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--so-accent), transparent);
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.32s;
}
.kc:hover { background: var(--so-bg3); }
.kc:hover::after { transform: scaleX(1); }
.kc-ico { font-size: 1.15rem; color: var(--so-accent); flex-shrink: 0; }
.kc-body { flex: 1; min-width: 0; }
.kc-val { font-family: var(--f-mono); font-size: 1.3rem; font-weight: 700; color: var(--so-text); white-space: nowrap; }
.kc-lbl { font-size: 0.62rem; color: var(--so-muted); text-transform: uppercase; letter-spacing: 0.08em; margin-top: 2px; }
.sparkline { flex-shrink: 0; opacity: 0.6; }
.kc-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--so-ok); box-shadow: 0 0 7px var(--so-ok); flex-shrink: 0; }
.kc-dot.warn   { background: var(--so-warn);   box-shadow: 0 0 7px var(--so-warn); }
.kc-dot.danger { background: var(--so-danger); box-shadow: 0 0 7px var(--so-danger); }
.kc-cbar { flex: 1; height: 3px; background: rgba(255,255,255,0.05); border-radius: 3px; overflow: hidden; }
.kc-cbar div { height: 100%; background: linear-gradient(90deg, var(--so-danger), var(--so-warn), var(--so-ok)); border-radius: 3px; transition: width 0.5s; }
.kc-pulse { width: 10px; height: 10px; border-radius: 50%; background: var(--so-danger); box-shadow: 0 0 8px var(--so-danger); flex-shrink: 0; animation: pulse-d 2s ease-in-out infinite; }
.kc-android .kc-val { color: var(--so-danger); font-size: 0.88rem; }

/* ══════════════════════════════════════════════════════════════
   SECTION LAYOUT
   ══════════════════════════════════════════════════════════════ */
.so-sec {
  max-width: 1440px;
  margin: 0 auto;
  padding: 90px 44px;
  position: relative; z-index: 2;
}
@media(max-width:768px) { .so-sec { padding: 60px 18px; } }

.sec-hdr {
  display: flex; align-items: center;
  justify-content: space-between;
  margin-bottom: 44px;
}
.sec-hdr-l { display: flex; align-items: center; gap: 16px; }
.sec-ico {
  width: 52px; height: 52px; border-radius: 16px;
  background: var(--so-glow-sm);
  border: 1px solid var(--so-border2);
  display: grid; place-items: center;
  font-size: 1.35rem; color: var(--so-accent);
  box-shadow: 0 0 20px var(--so-glow-sm);
}
.sec-ttl {
  font-family: var(--f-head);
  font-size: 2.2rem;
  color: var(--so-text);
  letter-spacing: 0.03em;
  line-height: 1;
}
.sec-sub { font-size: 0.76rem; color: var(--so-muted); font-family: var(--f-mono); margin-top: 4px; letter-spacing: 0.08em; }
.live-badge {
  padding: 6px 16px; border-radius: 22px;
  font-family: var(--f-mono); font-size: 0.68rem; font-weight: 700;
  background: rgba(0,255,136,0.07); color: var(--so-ok);
  border: 1px solid rgba(0,255,136,0.22);
  display: flex; align-items: center; gap: 8px;
  letter-spacing: 0.14em;
}
.live-badge span {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--so-ok); box-shadow: 0 0 8px var(--so-ok);
  animation: pulse-d 1.5s ease-in-out infinite;
}

/* ══════════════════════════════════════════════════════════════
   SENSOR GRID + CARDS
   ══════════════════════════════════════════════════════════════ */
.sensor-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 18px;
  margin-bottom: 22px;
}
@media(max-width:1100px) { .sensor-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:680px)  { .sensor-grid { grid-template-columns: 1fr; } }

.sc {
  background: var(--so-card);
  border: 1px solid var(--so-border);
  border-radius: 22px;
  padding: 24px;
  position: relative; overflow: hidden;
  transition: all 0.32s;
}
.sc::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--so-accent), transparent);
  opacity: 0; transition: opacity 0.32s;
}
.sc:hover {
  border-color: var(--so-border2);
  transform: translateY(-5px);
  box-shadow: 0 24px 70px rgba(0,0,0,0.55), 0 0 36px var(--so-glow-sm);
}
.sc:hover::before { opacity: 1; }

/* ── Colored stripe ── */
.sc-stripe { position: absolute; top: 0; left: 0; width: 3.5px; height: 100%; border-radius: 0 0 0 22px; }
.temp-stripe    { background: linear-gradient(180deg,#ff6432,#ff9966); }
.co2-stripe     { background: linear-gradient(180deg,#00c8ff,#0055ff); }
.light-stripe   { background: linear-gradient(180deg,#ffcc00,#ff9900); }
.humid-stripe   { background: linear-gradient(180deg,#00c8ff,#00d4ff); }
.ergo-stripe    { background: linear-gradient(180deg,var(--so-accent),var(--so-accent2)); }
.android-stripe { background: linear-gradient(180deg,#9966ff,#ff66cc); }

.sc-hdr { display: flex; align-items: center; gap: 11px; margin-bottom: 18px; }
.sc-ico {
  width: 42px; height: 42px; border-radius: 13px;
  display: grid; place-items: center; font-size: 1.05rem; flex-shrink: 0;
}
.ti { background: rgba(255,100,50,0.11); color: #ff6432; border: 1px solid rgba(255,100,50,0.22); }
.ci { background: rgba(0,200,255,0.09); color: #00c8ff; border: 1px solid rgba(0,200,255,0.2); }
.li { background: rgba(255,204,0,0.09); color: #ffcc00; border: 1px solid rgba(255,204,0,0.2); }
.hi { background: rgba(0,200,255,0.07); color: #44ccff; border: 1px solid rgba(0,200,255,0.18); }
.mi { background: rgba(0,255,136,0.07); color: var(--so-ok); border: 1px solid rgba(0,255,136,0.2); }
.ei { background: var(--so-glow-sm); color: var(--so-accent); border: 1px solid var(--so-border); }
.ai { background: rgba(153,102,255,0.09); color: #9966ff; border: 1px solid rgba(153,102,255,0.2); }

.sc-nm { font-weight: 700; font-size: 0.88rem; color: var(--so-text); }
.sc-src { font-size: 0.62rem; color: var(--so-muted); font-family: var(--f-mono); margin-top: 2px; letter-spacing: 0.06em; }
.sc-bdg {
  padding: 3px 10px; border-radius: 12px;
  font-size: 0.63rem; font-family: var(--f-mono); font-weight: 700;
  background: rgba(0,255,136,0.07); color: var(--so-ok);
  border: 1px solid rgba(0,255,136,0.2);
  margin-left: auto; transition: all 0.3s;
}
.sc-bdg.warn   { background: rgba(255,204,0,0.07);  color: var(--so-warn);   border-color: rgba(255,204,0,0.2); }
.sc-bdg.danger { background: rgba(255,51,85,0.07);   color: var(--so-danger); border-color: rgba(255,51,85,0.2); }

.sc-big {
  font-family: var(--f-mono); font-size: 3.2rem;
  font-weight: 700; color: var(--so-accent);
  line-height: 1; margin-bottom: 16px;
  text-shadow: 0 0 20px var(--so-glow-sm);
}
.sc-big.sm { font-size: 2.2rem; }
.sc-un { font-size: 1.1rem; color: var(--so-muted); margin-left: 4px; }
.sc-arc { display: block; margin: 0 auto 12px; }

.sc-zones-row { display: flex; gap: 7px; margin-bottom: 12px; }
.szr {
  flex: 1; padding: 6px 4px; border-radius: 9px;
  font-size: 0.61rem; text-align: center;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.05);
  color: var(--so-muted);
  transition: all 0.25s;
}
.szr.cold.active  { background: rgba(0,200,255,0.1);  border-color: rgba(0,200,255,0.3);  color: #00c8ff; }
.szr.ok.active    { background: rgba(0,255,136,0.1);  border-color: rgba(0,255,136,0.3);  color: var(--so-ok); }
.szr.hot.active   { background: rgba(255,100,50,0.1); border-color: rgba(255,100,50,0.3); color: #ff6432; }
.sc-tip {
  font-size: 0.7rem; color: var(--so-muted);
  font-family: var(--f-mono);
  border-top: 1px solid var(--so-border);
  padding-top: 11px; margin-top: 10px;
  letter-spacing: 0.04em;
}

/* ── CO2 track ── */
.co2-track {
  height: 9px;
  background: linear-gradient(90deg,rgba(0,255,136,0.28),rgba(255,204,0,0.28),rgba(255,51,85,0.28));
  border-radius: 9px; position: relative; margin-bottom: 7px; overflow: visible;
}
.co2-fill { position: absolute; top:0; left:0; height:100%; background:rgba(0,0,0,0.35); right:0; border-radius:9px; }
.co2-pin {
  position: absolute; top: -5px;
  width: 18px; height: 18px; border-radius: 50%;
  background: #fff; border: 2.5px solid var(--so-accent);
  transform: translateX(-50%);
  transition: left 0.5s ease;
  box-shadow: 0 0 12px var(--so-accent);
}
.co2-zlbls { display: flex; justify-content: space-between; font-size: 0.58rem; color: var(--so-muted); font-family: var(--f-mono); margin-bottom: 9px; }
.co2-zrow  { display: flex; gap: 5px; margin-bottom: 9px; }
.czr { flex:1; padding:5px; border-radius:7px; font-size:0.61rem; text-align:center; font-family:var(--f-mono); }
.czr.g { background:rgba(0,255,136,0.07);  color:var(--so-ok);     border:1px solid rgba(0,255,136,0.2); }
.czr.y { background:rgba(255,204,0,0.07);  color:var(--so-warn);   border:1px solid rgba(255,204,0,0.2); }
.czr.r { background:rgba(255,51,85,0.07);  color:var(--so-danger); border:1px solid rgba(255,51,85,0.2); }

/* ── Light sun ── */
.sun-wrap { position:relative; width:84px; height:84px; margin:10px auto; display:grid; place-items:center; }
.sun-core { width:32px; height:32px; border-radius:50%; background:#ffcc00; box-shadow:0 0 22px #ffcc00,0 0 44px #ff990080; position:relative; z-index:2; transition:all 0.5s; }
.sun-rays  { position:absolute; inset:0; animation:spin-r-normal 8s linear infinite; }
.sun-halo  { position:absolute; width:74px; height:74px; border-radius:50%; border:1px solid rgba(255,204,0,0.2); top:5px; left:5px; animation:pulse-d 3s ease-in-out infinite; }
@keyframes spin-r-normal { to { transform:rotate(360deg); } }
.light-btns { display:flex; gap:7px; margin:11px 0; }
.lb { flex:1; padding:7px 4px; border-radius:9px; font-size:0.68rem; font-family:var(--f-mono); background:rgba(255,255,255,0.02); border:1px solid var(--so-border); color:var(--so-muted); cursor:pointer; transition:all 0.2s; }
.lb.active,.lb:hover { background:var(--so-glow-sm); border-color:var(--so-accent); color:var(--so-accent); }

/* ── Humidity + Motion double ── */
.sc-double { padding:0; }
.scd-l,.scd-r { padding:22px; flex:1; }
.sc.sc-double { display:flex; }
.scd-div { width:1px; background:var(--so-border); flex-shrink:0; }
.drop-wrap { display:flex; gap:8px; align-items:flex-end; justify-content:center; margin:10px 0; }
.drop { width:34px; height:68px; border-radius:0 0 20px 20px; border:1px solid rgba(0,200,255,0.3); background:rgba(0,200,255,0.04); position:relative; overflow:hidden; }
.drop-fill { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(180deg,rgba(0,200,255,0.28),rgba(0,200,255,0.65)); transition:height 0.8s ease; }
.drop-lvls { display:flex; flex-direction:column; justify-content:space-between; font-size:0.54rem; color:var(--so-muted); font-family:var(--f-mono); height:68px; }

.motion-orb { position:relative; width:74px; height:74px; margin:10px auto; display:grid; place-items:center; }
.mo-r { position:absolute; border-radius:50%; border:1px solid rgba(0,255,136,0.18); top:50%;left:50%;transform:translate(-50%,-50%); transition:all 0.3s; }
.mo-r.r1 { width:74px; height:74px; }
.mo-r.r2 { width:52px; height:52px; }
.mo-r.r3 { width:34px; height:34px; }
.mo-c { font-size:1.5rem; z-index:2; position:relative; transition:all 0.3s; }
.motion-active .mo-r { border-color:rgba(0,255,136,0.5); animation:pulse-d 0.8s ease-in-out infinite; }
.motion-lbl { font-family:var(--f-mono); font-size:0.72rem; color:var(--so-muted); text-align:center; margin-top:4px; }
.motion-t   { font-size:0.63rem; color:var(--so-muted); font-family:var(--f-mono); text-align:center; }

/* ── Ergonomics ── */
.ergo-sc { grid-column:span 2; }
.ergo-items { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:16px; }
.ergo-item {
  background:rgba(255,255,255,0.02); border:1px solid var(--so-border);
  border-radius:13px; padding:13px;
  display:flex; flex-direction:column; align-items:center; gap:7px;
  transition:all 0.22s;
}
.ergo-item:hover { border-color:var(--so-accent); box-shadow:0 0 14px var(--so-glow-sm); }
.ergo-ring { width:46px; height:46px; position:relative; display:grid; place-items:center; }
.ergo-ring svg { position:absolute; inset:0; width:100%; height:100%; }
.ergo-ring span { font-size:1.15rem; position:relative; z-index:2; }
.ergo-info { text-align:center; }
.ei-lbl { font-size:0.59rem; color:var(--so-muted); text-transform:uppercase; letter-spacing:0.07em; }
.ei-val { font-family:var(--f-mono); font-size:0.82rem; color:var(--so-accent); font-weight:700; margin-top:3px; }
.ergo-timer-row {
  display:flex; align-items:center; gap:13px;
  background:rgba(255,255,255,0.02);
  border:1px solid var(--so-border); border-radius:13px;
  padding:13px 18px;
}
.ergo-timer-row i { color:var(--so-accent); }
.etr-t { font-family:var(--f-mono); font-size:1.55rem; font-weight:700; color:var(--so-accent); flex:1; text-shadow:0 0 14px var(--so-glow-sm); }
.ergo-timer-row button {
  padding:5px 13px; border-radius:8px;
  background:none; border:1px solid var(--so-border);
  color:var(--so-muted); cursor:pointer;
  font-family:var(--f-mono); font-size:0.75rem;
  transition:all 0.2s;
}
.ergo-timer-row button:hover { border-color:var(--so-accent); color:var(--so-accent); }

/* ── Android ── */
.android-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:13px; }
.ag {
  background:rgba(255,255,255,0.02); border:1px solid var(--so-border);
  border-radius:11px; padding:10px 8px;
  display:flex; flex-direction:column; align-items:center; gap:3px;
  font-size:0.75rem; transition:all 0.22s;
}
.ag:hover { border-color:#9966ff; background:rgba(153,102,255,0.05); }
.ag-l { font-size:0.58rem; color:var(--so-muted); font-family:var(--f-mono); }
.ag-v { font-family:var(--f-mono); font-weight:700; color:var(--so-accent); font-size:0.82rem; }
.android-hint { font-size:0.7rem; color:var(--so-muted); font-family:var(--f-mono); display:flex; align-items:center; gap:8px; padding:10px; border:1px dashed var(--so-border); border-radius:11px; }

/* ── Syslog ── */
.syslog { background:var(--so-card); border:1px solid var(--so-border); border-radius:18px; overflow:hidden; }
.syslog-hdr {
  padding:11px 20px; border-bottom:1px solid var(--so-border);
  font-family:var(--f-mono); font-size:0.75rem;
  color:var(--so-accent);
  display:flex; align-items:center; gap:9px;
  background:rgba(0,0,0,0.3);
}
.syslog-body {
  padding:14px 20px; max-height:190px; overflow-y:auto;
  font-family:var(--f-mono); font-size:0.69rem; color:var(--so-muted);
  display:flex; flex-direction:column; gap:2px;
}
.log-line { padding:2px 0; border-bottom:1px solid rgba(255,255,255,0.025); }
.log-line.ok     { color:var(--so-ok); }
.log-line.warn   { color:var(--so-warn); }
.log-line.danger { color:var(--so-danger); }

/* ══════════════════════════════════════════════════════════════
   WAI-JANDI SECTION
   ══════════════════════════════════════════════════════════════ */
.jandi-sec {
  background: var(--so-bg2);
  border-top: 1px solid var(--so-border);
  border-bottom: 1px solid var(--so-border);
  padding: 90px 44px;
  position: relative; overflow: hidden; z-index: 2;
}
.jandi-orb { position:absolute; border-radius:50%; filter:blur(110px); pointer-events:none; }
.j1 { width:550px; height:550px; top:-120px; left:-120px; background:radial-gradient(circle,var(--so-glow-sm),transparent 70%); }
.j2 { width:440px; height:440px; bottom:-120px; right:-60px; background:radial-gradient(circle,rgba(0,200,255,0.04),transparent 70%); }

.jandi-wrap {
  display:grid; grid-template-columns:310px 1fr;
  gap:44px; max-width:1360px; margin:0 auto;
  position:relative; z-index:2;
}
@media(max-width:900px) { .jandi-wrap { grid-template-columns:1fr; } }

.jandi-left { display:flex; flex-direction:column; align-items:center; }

.jandi-av { position:relative; width:160px; height:160px; margin-bottom:20px; }
.jav-ring {
  position:absolute; border-radius:50%;
  border:1px solid var(--so-accent);
  top:50%;left:50%;transform:translate(-50%,-50%);
}
.jav-ring.r1 { width:160px;height:160px;opacity:0.42;animation:spin-r-normal 10s linear infinite; }
.jav-ring.r2 { width:126px;height:126px;opacity:0.26;animation:spin-r-normal 7s linear infinite reverse; }
.jav-ring.r3 { width:96px;height:96px;opacity:0.14; }
.jav-face {
  position:absolute; top:50%;left:50%;transform:translate(-50%,-50%);
  width:74px; height:74px; border-radius:50%;
  background:radial-gradient(circle,var(--so-glow-sm),rgba(0,0,0,0.85));
  border:2.5px solid var(--so-accent);
  display:grid; place-items:center;
  box-shadow:0 0 36px var(--so-glow);
}
#jandi-viz { position:absolute; inset:0; width:100%; height:100%; border-radius:50%; opacity:0.6; }
.jav-emoji { position:relative; z-index:2; font-size:1.9rem; }

.jandi-nm { font-family:var(--f-head); font-size:1.7rem; color:var(--so-accent); margin-bottom:7px; letter-spacing:0.06em; }
.jandi-st { display:flex; align-items:center; gap:8px; font-size:0.72rem; color:var(--so-muted); font-family:var(--f-mono); margin-bottom:24px; }
.jst-dot { width:7px; height:7px; border-radius:50%; background:var(--so-ok); box-shadow:0 0 9px var(--so-ok); animation:pulse-d 2s ease-in-out infinite; }

.jandi-mic-zone {
  width:100%; cursor:pointer;
  border:1px solid var(--so-border); border-radius:15px;
  padding:18px; text-align:center;
  position:relative; overflow:hidden;
  transition:all 0.3s; margin-bottom:22px;
  background:rgba(255,255,255,0.02);
}
.jandi-mic-zone:hover { border-color:var(--so-accent); background:var(--so-glow-sm); }
.jmz-ico { font-size:1.7rem; color:var(--so-muted); margin-bottom:7px; transition:all 0.3s; }
.jandi-mic-zone:hover .jmz-ico,
.jandi-mic-zone.listening .jmz-ico { color:var(--so-danger); }
.jmz-lbl { font-size:0.72rem; color:var(--so-muted); font-family:var(--f-mono); }
.jmz-r { position:absolute; border-radius:50%; border:1px solid var(--so-accent); top:50%;left:50%;transform:translate(-50%,-50%); opacity:0; }
.jandi-mic-zone.listening .jmz-r { animation:mic-ring 1.5s ease-out infinite; }
.jmz-r.r1 { width:62px; height:62px; }
.jmz-r.r2 { width:96px; height:96px; animation-delay:0.5s !important; }
@keyframes mic-ring { 0% { opacity:0.6; transform:translate(-50%,-50%) scale(0.5); } 100% { opacity:0; transform:translate(-50%,-50%) scale(1.5); } }

.jandi-quick { display:grid; grid-template-columns:1fr 1fr; gap:7px; width:100%; }
.jandi-quick button {
  padding:10px 6px; border-radius:11px;
  font-size:0.7rem; font-family:var(--f-mono);
  background:rgba(255,255,255,0.02); border:1px solid var(--so-border);
  color:var(--so-muted); cursor:pointer; transition:all 0.2s;
}
.jandi-quick button:hover { border-color:var(--so-accent); color:var(--so-accent); background:var(--so-glow-sm); transform:translateY(-2px); }

/* ── Chat ── */
.jandi-chat {
  background:var(--so-card); border:1px solid var(--so-border);
  border-radius:22px; display:flex; flex-direction:column;
  max-height:620px; overflow:hidden;
  box-shadow:0 8px 40px rgba(0,0,0,0.4);
}
.jc-hdr {
  padding:17px 22px; border-bottom:1px solid var(--so-border);
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--f-mono); font-size:0.8rem; color:var(--so-accent);
  background:rgba(0,0,0,0.25);
}
.jc-acts { display:flex; gap:8px; }
.jc-acts button {
  width:32px; height:32px; border-radius:9px;
  background:rgba(255,255,255,0.04); border:1px solid var(--so-border);
  color:var(--so-muted); cursor:pointer; font-size:0.82rem; transition:all 0.2s;
}
.jc-acts button:hover { border-color:var(--so-accent); color:var(--so-accent); }
.jc-msgs { flex:1; overflow-y:auto; padding:22px; display:flex; flex-direction:column; gap:16px; }
.jm { display:flex; gap:10px; align-items:flex-start; }
.jm.user { flex-direction:row-reverse; }
.jm-av {
  width:36px; height:36px; border-radius:50%;
  display:grid; place-items:center; font-size:1rem; flex-shrink:0;
  background:linear-gradient(135deg,var(--so-glow-sm),rgba(0,255,170,0.09));
  border:1px solid var(--so-accent);
}
.jm.user .jm-av { background:rgba(255,255,255,0.05); border-color:var(--so-border); }
.jm-bub {
  max-width:76%; padding:13px 17px; border-radius:16px;
  font-size:0.86rem; line-height:1.75; white-space:pre-wrap;
  background:rgba(255,255,255,0.04); border:1px solid var(--so-border);
  color:var(--so-text);
}
.jm.user .jm-bub { background:var(--so-glow-sm); border-color:var(--so-accent); }
.jc-typing { display:flex; align-items:center; gap:10px; padding:0 22px 12px; }
.jt-dots { display:flex; gap:4px; padding:13px 17px; background:rgba(255,255,255,0.04); border-radius:16px; }
.jt-dots span { width:7px; height:7px; border-radius:50%; background:var(--so-accent); animation:bounce-d 1.2s ease-in-out infinite; }
.jt-dots span:nth-child(2) { animation-delay:0.15s; }
.jt-dots span:nth-child(3) { animation-delay:0.3s; }
@keyframes bounce-d { 0%,60%,100% { transform:translateY(0); } 30% { transform:translateY(-9px); } }
.jc-inp-wrap { padding:14px; border-top:1px solid var(--so-border); display:flex; gap:9px; }
.jc-inp {
  flex:1; padding:12px 15px;
  background:rgba(255,255,255,0.04); border:1px solid var(--so-border);
  border-radius:13px; color:var(--so-text); font-family:var(--f-body); font-size:0.87rem;
  resize:none; min-height:46px; max-height:110px;
  transition:border-color 0.2s;
}
.jc-inp:focus { outline:none; border-color:var(--so-accent); }
.jc-mic,.jc-send {
  width:46px; height:46px; border-radius:13px;
  display:grid; place-items:center;
  cursor:pointer; font-size:1.02rem;
  border:1px solid var(--so-border); transition:all 0.2s;
}
.jc-mic { background:rgba(255,255,255,0.04); color:var(--so-muted); }
.jc-mic:hover,.jc-mic.active { border-color:var(--so-danger); color:var(--so-danger); background:rgba(255,51,85,0.08); }
.jc-send { background:var(--so-accent); color:var(--so-bg); border-color:var(--so-accent); }
.jc-send:hover { box-shadow:0 0 28px var(--so-glow); transform:scale(1.07); }
.jc-send:disabled { opacity:0.45; transform:none; cursor:not-allowed; }

/* ══════════════════════════════════════════════════════════════
   FULLSCREEN CAMERA
   ══════════════════════════════════════════════════════════════ */
.cam-fs { position:fixed; inset:0; z-index:9000; background:#000; display:flex; flex-direction:column; }
.cam-fs.hidden { display:none; }
.cam-vid { width:100%; height:100%; object-fit:cover; transform:scaleX(-1); display:block; }
.cam-cvs { position:absolute; inset:0; width:100%; height:100%; transform:scaleX(-1); pointer-events:none; }
.cam-scanlines {
  position:absolute; inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,255,62,0.014) 3px,rgba(0,255,62,0.014) 4px);
  pointer-events:none; z-index:10;
  animation:scan-move 8s linear infinite;
}
[data-theme="blue"]   .cam-scanlines { background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,212,255,0.014) 3px,rgba(0,212,255,0.014) 4px); }
[data-theme="cosmic"] .cam-scanlines { background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(199,125,255,0.014) 3px,rgba(199,125,255,0.014) 4px); }
@keyframes scan-move { 0% { background-position:0 0; } 100% { background-position:0 100px; } }
.cam-brk { position:absolute; width:30px; height:30px; z-index:20; }
.cam-brk::before,.cam-brk::after { content:''; position:absolute; background:var(--so-accent); box-shadow:0 0 12px var(--so-accent); }
.cam-brk::before { width:100%; height:2px; top:0; left:0; }
.cam-brk::after  { width:2px; height:100%; top:0; left:0; }
.tl { top:16px; left:16px; }
.tr { top:16px; right:16px; transform:scaleX(-1); }
.bl { bottom:70px; left:16px; transform:scaleY(-1); }
.br { bottom:70px; right:16px; transform:scale(-1,-1); }
.cam-hud-top {
  position:absolute; top:0; left:0; right:0; z-index:20;
  padding:15px 22px;
  background:linear-gradient(180deg,rgba(0,0,0,0.82),transparent);
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--f-mono); font-size:0.76rem; color:var(--so-accent);
}
.cht-l { display:flex; align-items:center; gap:17px; }
.cht-logo { font-family:var(--f-head); font-size:1.25rem; }
.cht-logo em { font-style:normal; color:var(--so-text); }
.cht-mode { font-size:0.63rem; color:rgba(168,255,62,0.55); letter-spacing:0.18em; }
.cht-c { display:flex; align-items:center; gap:9px; }
.cam-rec-dot { width:9px; height:9px; border-radius:50%; background:var(--so-danger); box-shadow:0 0 11px var(--so-danger); animation:pulse-d 1s ease-in-out infinite; }
.cht-r { text-align:right; display:flex; flex-direction:column; gap:2px; }
#cam-fps { font-size:0.6rem; color:var(--so-muted); }
.cam-holo { position:absolute; top:72px; right:22px; z-index:20; display:flex; flex-direction:column; gap:9px; transition:all 0.3s; }
.ch-card {
  background:rgba(0,0,0,0.72); border:1px solid var(--so-accent);
  border-radius:13px; padding:11px 15px;
  backdrop-filter:blur(12px); min-width:135px;
  box-shadow:0 0 22px var(--so-glow-sm);
}
.ch-ico { font-size:0.9rem; margin-bottom:2px; }
.ch-val { font-family:var(--f-mono); font-size:1.32rem; font-weight:700; color:var(--so-accent); line-height:1; text-shadow:0 0 12px var(--so-accent); }
.ch-lbl { font-family:var(--f-mono); font-size:0.54rem; color:rgba(168,255,62,0.5); letter-spacing:0.22em; margin-bottom:7px; }
.ch-bar { height:3px; background:rgba(255,255,255,0.1); border-radius:3px; overflow:hidden; }
.ch-bar div { height:100%; background:var(--so-accent); border-radius:3px; transition:width 0.5s ease; box-shadow:0 0 7px var(--so-accent); }
.cam-jandi {
  position:absolute; bottom:72px; left:22px; z-index:20;
  width:286px; background:rgba(0,0,0,0.88);
  border:1px solid var(--so-accent); border-radius:17px;
  backdrop-filter:blur(22px); box-shadow:0 0 32px var(--so-glow-sm); overflow:hidden;
}
.cam-jandi.hidden { display:none; }
.cj-hdr { padding:11px 15px; border-bottom:1px solid rgba(168,255,62,0.18); display:flex; align-items:center; gap:8px; font-family:var(--f-mono); font-size:0.72rem; color:var(--so-accent); }
.cj-dot { width:6px; height:6px; border-radius:50%; background:var(--so-ok); box-shadow:0 0 7px var(--so-ok); animation:pulse-d 1.5s ease-in-out infinite; }
.cj-msgs { padding:11px 15px; max-height:145px; overflow-y:auto; display:flex; flex-direction:column; gap:6px; }
.cj-msg { font-size:0.78rem; color:var(--so-text); line-height:1.5; padding:6px 10px; background:rgba(168,255,62,0.05); border-radius:9px; border:1px solid rgba(168,255,62,0.1); }
.cj-msg.user { background:rgba(255,255,255,0.06); border-color:rgba(255,255,255,0.1); text-align:right; }
.cj-inp-row { padding:9px 11px; border-top:1px solid rgba(168,255,62,0.14); display:flex; gap:6px; }
.cj-inp { flex:1; background:rgba(255,255,255,0.06); border:1px solid rgba(168,255,62,0.18); border-radius:9px; padding:7px 10px; color:var(--so-text); font-size:0.78rem; font-family:var(--f-mono); outline:none; }
.cj-inp-row button { padding:7px 13px; background:var(--so-accent); border:none; border-radius:9px; color:var(--so-bg); cursor:pointer; font-size:0.8rem; transition:all 0.2s; }
.cam-hud-btm {
  position:absolute; bottom:0; left:0; right:0; z-index:25;
  padding:11px 22px;
  background:linear-gradient(0deg,rgba(0,0,0,0.92),transparent);
  display:flex; align-items:center; justify-content:center; gap:18px;
}
.chb {
  display:flex; align-items:center; gap:9px;
  padding:11px 24px; border-radius:26px;
  font-family:var(--f-mono); font-size:0.78rem;
  background:rgba(0,0,0,0.65); border:1px solid var(--so-border);
  color:var(--so-text); cursor:pointer; transition:all 0.22s;
  backdrop-filter:blur(12px);
}
.chb:hover { border-color:var(--so-accent); color:var(--so-accent); background:rgba(0,0,0,0.85); }
.chb.danger { border-color:rgba(255,51,85,0.38); color:var(--so-danger); }
.chb.danger:hover { background:rgba(255,51,85,0.13); border-color:var(--so-danger); }
.cam-voice-ind {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); z-index:30;
  background:rgba(0,0,0,0.82); border:1px solid var(--so-accent);
  border-radius:22px; padding:17px 30px;
  display:flex; align-items:center; gap:13px;
  font-family:var(--f-mono); font-size:0.86rem; color:var(--so-accent);
  backdrop-filter:blur(22px);
}
.cam-voice-ind.hidden { display:none; }
.cvi-ring { width:13px; height:13px; border-radius:50%; background:var(--so-danger); box-shadow:0 0 13px var(--so-danger); animation:pulse-d 0.6s ease-in-out infinite; }

/* ══════════════════════════════════════════════════════════════
   ALERT + TOAST
   ══════════════════════════════════════════════════════════════ */
.so-alert {
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%);
  z-index:800; background:rgba(255,51,85,0.11);
  border:1px solid var(--so-danger); border-radius:16px;
  padding:15px 26px; display:flex; align-items:center; gap:15px;
  font-family:var(--f-mono); font-size:0.82rem; color:var(--so-danger);
  backdrop-filter:blur(12px); animation:shake 0.3s ease;
  box-shadow:0 8px 32px rgba(255,51,85,0.2);
}
.so-alert.hidden { display:none; }
.so-alert button { background:none; border:none; color:var(--so-danger); cursor:pointer; font-size:1.05rem; }
@keyframes shake { 0%,100%{transform:translateX(-50%)} 25%{transform:translateX(calc(-50% - 9px))} 75%{transform:translateX(calc(-50% + 9px))} }
#toast-container { position:fixed; top:80px; right:20px; z-index:9999; display:flex; flex-direction:column; gap:8px; }
.toast { padding:11px 20px; border-radius:13px; font-family:var(--f-mono); font-size:0.78rem; background:var(--so-card); border:1px solid var(--so-border); color:var(--so-text); animation:toast-in 0.3s ease; backdrop-filter:blur(10px); }
.toast.ok     { border-color:rgba(0,255,136,0.4); color:var(--so-ok); }
.toast.warn   { border-color:rgba(255,204,0,0.4);  color:var(--so-warn); }
.toast.danger { border-color:rgba(255,51,85,0.4);  color:var(--so-danger); }
@keyframes toast-in { from { opacity:0; transform:translateX(24px); } to { opacity:1; transform:translateX(0); } }

/* ══════════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════════ */
.site-footer {
  position:relative; z-index:2;
  background:var(--so-bg2);
  border-top:1px solid var(--so-border);
}
.footer-top-wave { display:block; width:100%; height:60px; margin-bottom:-2px; }
.footer-top-wave svg { width:100%; height:100%; display:block; }
.footer-container { max-width:1300px; margin:0 auto; padding:0 40px 40px; }
.footer-main { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; padding:44px 0 36px; border-bottom:1px solid var(--so-border); }
@media(max-width:900px) { .footer-main { grid-template-columns:1fr 1fr; } }
@media(max-width:560px) { .footer-main { grid-template-columns:1fr; } }

.footer-brand {}
.footer-logo-name {
  display:block;
  font-family:var(--f-head); font-size:2.2rem;
  color:var(--so-accent); letter-spacing:0.08em; line-height:1;
  margin-bottom:4px;
  text-shadow:0 0 24px var(--so-glow-sm);
}
.footer-logo-name em { font-style:normal; color:var(--so-text); }
.footer-logo-sub { font-family:var(--f-mono); font-size:0.6rem; color:var(--so-muted); letter-spacing:0.2em; margin-bottom:14px; }
.footer-brand p { font-size:0.83rem; color:var(--so-muted); line-height:1.7; max-width:260px; }
.footer-mini-stats { display:flex; gap:20px; margin-top:20px; }
.fms-item { display:flex; flex-direction:column; gap:2px; }
.fms-num { font-family:var(--f-head); font-size:1.7rem; color:var(--so-accent); line-height:1; }
.fms-item span:last-child { font-size:0.62rem; color:var(--so-muted); font-family:var(--f-mono); letter-spacing:0.08em; }
.footer-col h4 { font-family:var(--f-syne); font-size:0.8rem; color:var(--so-text); font-weight:700; letter-spacing:0.14em; text-transform:uppercase; margin-bottom:18px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col a { font-size:0.82rem; color:var(--so-muted); text-decoration:none; transition:color 0.2s; display:flex; align-items:center; gap:6px; }
.footer-col a::before { content:'→'; font-size:0.7rem; color:var(--so-dim); transition:color 0.2s; }
.footer-col a:hover { color:var(--so-accent); }
.footer-col a:hover::before { color:var(--so-accent); }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; padding:22px 0 0; flex-wrap:wrap; gap:14px; }
.footer-copy { font-size:0.74rem; color:var(--so-muted); font-family:var(--f-mono); }
.footer-badge { display:flex; align-items:center; gap:8px; font-family:var(--f-mono); font-size:0.68rem; color:var(--so-muted); }
.footer-badge-dot { width:7px; height:7px; border-radius:50%; background:var(--so-ok); box-shadow:0 0 8px var(--so-ok); animation:pulse-d 2s ease-in-out infinite; }

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
@media(max-width:1200px) {
  .hero-visual { display:none; }
  .so-hero { justify-content:center; padding:90px 30px 70px; }
}
@media(max-width:768px) {
  .so-nav { display:none; }
  .so-hero { padding:80px 18px 60px; }
  .ergo-sc { grid-column:span 1; }
  .ergo-items { grid-template-columns:repeat(2,1fr); }
  .jandi-sec { padding:60px 18px; }
  .hero-stats { flex-wrap:wrap; gap:14px; }
}
@media(max-width:480px) {
  .hero-btns { flex-direction:column; }
  .hb { justify-content:center; }
  .footer-container { padding:0 16px 30px; }
}

/* ══════════════════════════════════════════════
   FLOATING HOLOGRAM CARDS (camera mode)
   ══════════════════════════════════════════════ */
.holo-card {
  background: rgba(0,0,0,0.78);
  border: 1px solid var(--so-accent);
  border-radius: 14px;
  padding: 12px 16px;
  min-width: 130px;
  backdrop-filter: blur(14px);
  box-shadow: 0 0 20px var(--so-glow-sm), inset 0 0 20px rgba(0,0,0,0.3);
  transition: transform 0.15s, box-shadow 0.15s, opacity 0.3s;
  animation: holo-appear 0.4s cubic-bezier(0.34,1.56,0.64,1);
  pointer-events: auto;
}
@keyframes holo-appear {
  from { opacity:0; transform: scale(0.6) translateY(10px); }
  to   { opacity:1; transform: scale(1) translateY(0); }
}
.holo-card::before {
  content: '';
  position: absolute; top:0; left:0; right:0; height:1px;
  background: linear-gradient(90deg, transparent, var(--so-accent), transparent);
}
.hc-ico { font-size: 0.95rem; margin-bottom: 3px; }
.hc-val {
  font-family: 'JetBrains Mono', monospace;
  font-size: 1.4rem; font-weight: 700;
  color: var(--so-accent);
  text-shadow: 0 0 12px var(--so-accent);
  line-height: 1;
}
.hc-lbl {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.55rem; color: rgba(168,255,62,0.5);
  letter-spacing: 0.22em; margin-bottom: 7px;
}
[data-theme="blue"] .hc-val  { color: #00d4ff; text-shadow: 0 0 12px #00d4ff; }
[data-theme="blue"] .hc-lbl  { color: rgba(0,212,255,0.5); }
.hc-bar {
  height: 3px; background: rgba(255,255,255,0.08);
  border-radius: 3px; overflow: hidden;
}
.hc-fill {
  height: 100%; background: var(--so-accent);
  border-radius: 3px;
  box-shadow: 0 0 6px var(--so-accent);
  transition: width 0.6s ease;
}
[data-theme="blue"] .hc-fill { background: #00d4ff; box-shadow: 0 0 6px #00d4ff; }

/* Gesture feedback badge */
#cam-gesture-fb {
  animation: gesture-pop 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes gesture-pop {
  from { transform: translate(-50%,-50%) scale(0.5); opacity:0; }
  to   { transform: translate(-50%,-50%) scale(1);   opacity:1; }
}

/* Camera video + canvas positioning fix */
.cam-vid {
  position: absolute;
  inset: 0; width: 100%; height: 100%;
  object-fit: cover;
  transform: scaleX(-1);
}
.cam-cvs {
  position: absolute;
  inset: 0; width: 100%; height: 100%;
  pointer-events: none;
  z-index: 10;
}

/* Permission dialog animation */
#cam-perm-dialog > div {
  animation: perm-appear 0.4s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes perm-appear {
  from { opacity:0; transform: scale(0.85) translateY(20px); }
  to   { opacity:1; transform: scale(1)    translateY(0); }
}
#cam-perm-ok:hover {
  filter: brightness(1.15);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
