/* ============ Totekko — site styles ============ */

:root{
  --blue: #3D5286;
  --blue-2: #5670AE;
  --lime: #8BC34A;
  --lime-2: #A8E063;
  /* Default: light theme */
  --ink: #F6F7FB;
  --ink-2: #EFF1F7;
  --ink-3: #E6EAF2;
  --panel: rgba(255, 255, 255, 0.72);
  --panel-solid: #FFFFFF;
  --line: rgba(61, 82, 134, 0.10);
  --line-2: rgba(10,14,26,0.07);
  --line-3: rgba(10,14,26,0.14);
  --text: #0E1428;
  --text-dim: #4E566C;
  --text-dimmer: #8A92A8;
  --accent: var(--lime);
  --accent-glow: rgba(139, 195, 74, 0.30);
  --radius: 16px;
  --radius-lg: 22px;
  --mono: "Poppins", system-ui, sans-serif;
  --sans: "Poppins", system-ui, sans-serif;
}

[data-theme="dark"]{
  --ink: #0A0E1A;
  --ink-2: #0F1526;
  --ink-3: #151C32;
  --panel: rgba(19, 26, 46, 0.55);
  --panel-solid: #131A2E;
  --line: rgba(139, 195, 74, 0.10);
  --line-2: rgba(255,255,255,0.06);
  --line-3: rgba(255,255,255,0.12);
  --text: #EAEEF6;
  --text-dim: #96A0B6;
  --text-dimmer: #636C82;
  --accent-glow: rgba(139, 195, 74, 0.40);
}

[data-theme="light"]{
  --ink: #F6F7FB;
  --ink-2: #EFF1F7;
  --ink-3: #E6EAF2;
  --panel: rgba(255, 255, 255, 0.72);
  --panel-solid: #FFFFFF;
  --line: rgba(61, 82, 134, 0.10);
  --line-2: rgba(10,14,26,0.07);
  --line-3: rgba(10,14,26,0.14);
  --text: #0E1428;
  --text-dim: #4E566C;
  --text-dimmer: #8A92A8;
  --accent-glow: rgba(139, 195, 74, 0.30);
}

*,*::before,*::after{ box-sizing:border-box }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; overflow-x: hidden; }
body{
  font-family: var(--sans);
  font-weight: 300;
  background: var(--ink);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
a{ color: inherit; text-decoration:none; }
button{ font-family: inherit; cursor: pointer; }
img{ max-width:100%; display:block; }
::selection{ background: var(--lime); color: var(--ink); }

/* ============ Background fabric ============ */
.bg-fabric{
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(1100px 700px at 85% -10%, rgba(61,82,134,0.28), transparent 60%),
    radial-gradient(800px 600px at -5% 90%, rgba(139,195,74,0.08), transparent 55%),
    var(--ink);
}
[data-theme="light"] .bg-fabric{
  background:
    radial-gradient(1100px 700px at 85% -10%, rgba(61,82,134,0.10), transparent 60%),
    radial-gradient(800px 600px at -5% 90%, rgba(139,195,74,0.06), transparent 55%),
    var(--ink);
}
.bg-grid{ display: none; }
[data-density="fine"] .bg-grid{ display: none; }
[data-density="coarse"] .bg-grid{ display: none; }

.particle-field{
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  width: 100%; height: 100%;
}

.noise{ display: none; }

/* ============ Layout ============ */
.app{ position: relative; z-index: 1; }
main{ position:relative; z-index: 1; }
section{ position: relative; padding: 140px clamp(16px, 5vw, 72px); }
@media (max-width: 600px){ section{ padding-top: 80px; padding-bottom: 80px; } }
section#umbrella{ padding-bottom: 72px; }
.section-inner{ max-width: 1320px; margin: 0 auto; }

.section-eyebrow{
  display: inline-flex; align-items:center; gap:10px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .18em;
  text-transform: uppercase; color: var(--accent);
  padding: 6px 12px; border: 1px solid var(--line);
  border-radius: 999px; background: rgba(139,195,74,0.04);
}
.section-eyebrow::before{
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 12px var(--accent);
}

.section-title{
  font-weight: 600; font-size: clamp(36px, 5vw, 64px);
  line-height: 1.04; letter-spacing: -0.02em;
  margin: 22px 0 18px;
  text-wrap: balance;
}
.section-title .accent{ color: var(--accent); }
.section-title em{
  font-style: italic; font-weight: 400; color: var(--text-dim);
}

.section-lede{
  font-size: clamp(15px, 1.25vw, 18px);
  color: var(--text-dim); max-width: 60ch; line-height: 1.55;
  text-wrap: pretty;
}

/* ============ Top nav ============ */
.topnav{
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px clamp(24px, 5vw, 72px);
  transition: background .3s, border-color .3s, backdrop-filter .3s;
  border-bottom: 1px solid transparent;
}
.topnav.scrolled{
  background: color-mix(in oklab, var(--ink) 72%, transparent);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border-bottom: 1px solid var(--line-2);
}
.topnav .logo{ height: 42px; display: block; }
.topnav .logo img{ height: 100%; width: auto; display:block; }
/* Logo stays in brand colors on both themes — it contains both blue & lime */

.topnav-links{ display: flex; gap: 22px; align-items: center; }
.topnav-sep{
  width: 1px; height: 14px;
  background: var(--line-2);
  display: inline-block;
}
.topnav-links a{
  font-size: 13px; font-weight: 400; color: var(--text-dim);
  position: relative; padding: 6px 0; letter-spacing:.01em;
  transition: color .2s;
}
.topnav-links a:hover, .topnav-links a.active{ color: var(--text); }
.topnav-links a.active::after{
  content:""; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 1px; background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
}
@media (max-width: 1180px){
  .topnav-links{ gap: 16px; }
  .topnav-links a{ font-size: 12.5px; }
}
@media (max-width: 980px){
  .topnav-sep{ display: none; }
  .topnav-links{ gap: 12px; }
}

/* ===== Divisions dropdown ===== */
.nav-dropdown{ position: relative; }
.nav-dropdown .dd-trigger{
  display: inline-flex; align-items: center; gap: 5px;
}
.nav-dropdown .nav-chev{
  color: currentColor;
  transition: transform .2s, color .2s;
  opacity: .6;
}
.nav-dropdown:hover .nav-chev{ opacity: 1; }
.nav-dropdown.open .nav-chev{ transform: rotate(180deg); }

.nav-dd-panel{
  position: absolute;
  top: calc(100% + 16px);
  left: 50%;
  transform: translateX(-50%);
  width: 380px;
  background: var(--panel-solid);
  border: 1px solid var(--line-3);
  border-radius: 14px;
  padding: 6px;
  box-shadow:
    0 28px 56px -20px rgba(10, 14, 26, .35),
    0 0 0 1px rgba(255,255,255,.02) inset;
  z-index: 60;
  animation: ddFade .2s ease-out;
}
[data-theme="light"] .nav-dd-panel{
  box-shadow:
    0 28px 56px -20px rgba(61,82,134,.18),
    0 0 0 1px rgba(0,0,0,.02) inset;
}
@keyframes ddFade{
  from{ opacity: 0; transform: translateX(-50%) translateY(-4px); }
  to{   opacity: 1; transform: translateX(-50%) translateY(0); }
}
.nav-dd-panel::before{
  content: ""; position: absolute;
  top: -6px; left: 50%; transform: translateX(-50%) rotate(45deg);
  width: 10px; height: 10px;
  background: var(--panel-solid);
  border-left: 1px solid var(--line-3);
  border-top: 1px solid var(--line-3);
}

.nav-dd-header{
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--line-2);
  margin-bottom: 6px;
}
.nav-dd-eyebrow{
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 4px;
  font-weight: 600;
}
.nav-dd-title{
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.005em;
}

.nav-dd-list{
  display: flex; flex-direction: column;
  gap: 1px;
  padding: 2px;
}
.nav-dd-row{
  position: relative;
  display: grid;
  grid-template-columns: 1fr 14px;
  grid-template-rows: auto auto;
  column-gap: 10px;
  align-items: center;
  padding: 11px 12px 11px 18px;
  border-radius: 9px;
  transition: background .15s;
}
.nav-dd-row:hover{
  background: color-mix(in oklab, rgb(var(--dd-accent-rgb)) 9%, transparent);
}
.nav-dd-strip{
  position: absolute;
  left: 6px; top: 14px; bottom: 14px;
  width: 2px;
  border-radius: 2px;
  background: var(--dd-accent);
  opacity: .35;
  transition: opacity .15s, top .15s, bottom .15s;
}
.nav-dd-row:hover .nav-dd-strip{
  opacity: 1;
  top: 10px; bottom: 10px;
}
.nav-dd-name{
  grid-row: 1; grid-column: 1;
  font-size: 13.5px; font-weight: 600;
  color: var(--text);
  letter-spacing: -0.005em;
}
.nav-dd-tag{
  grid-row: 2; grid-column: 1;
  font-size: 11.5px;
  color: var(--text-dim);
  letter-spacing: -0.005em;
  margin-top: 2px;
  line-height: 1.35;
}
.nav-dd-arrow{
  grid-row: 1 / -1; grid-column: 2;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-dimmer);
  transition: color .15s, transform .15s;
}
.nav-dd-row:hover .nav-dd-arrow{
  color: var(--dd-accent);
  transform: translateX(2px);
}

.nav-dd-footer{
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 6px;
  padding: 11px 16px;
  border-top: 1px solid var(--line-2);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--text-dim);
  font-weight: 600;
  transition: color .15s;
}
.nav-dd-footer:hover{ color: var(--accent); }

@media (max-width: 980px){
  .nav-dd-panel{ width: 320px; }
}
@media (max-width: 860px){
  .topnav-links{ display:none; }
}

.cta-btn{
  display: inline-flex; align-items:center; gap:10px;
  padding: 11px 18px; border-radius: 999px;
  background: var(--accent); color: var(--ink);
  font-weight: 500; font-size: 13px; letter-spacing: .01em;
  border: 1px solid transparent;
  transition: transform .2s, box-shadow .2s, background .2s;
  box-shadow: 0 0 0 rgba(139,195,74,0);
}
.cta-btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 8px 26px var(--accent-glow);
}
.cta-btn.ghost{
  background: transparent; color: var(--text);
  border-color: var(--line-2);
}
.cta-btn.ghost:hover{
  border-color: var(--accent); color: var(--accent);
  box-shadow: 0 0 0 rgba(0,0,0,0);
}
.cta-btn .arrow{
  width: 14px; height: 14px; transition: transform .2s;
}
.cta-btn:hover .arrow{ transform: translateX(3px); }

/* ============ Side nav (sticky) ============ */
.sidenav{
  position: fixed; left: clamp(16px, 2.5vw, 36px); top: 50%;
  transform: translateY(-50%);
  z-index: 40; display: flex; flex-direction: column; gap: 22px;
  pointer-events: auto;
  padding: 14px 14px 14px 12px;
  background: var(--panel);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid var(--line-3);
  border-radius: 999px;
  box-shadow: 0 20px 40px -20px rgba(0,0,0,.4);
}
.sidenav a{
  display: flex; align-items: center; gap: 12px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .12em; color: var(--text-dim);
  text-transform: uppercase;
  transition: color .2s;
  padding: 2px 4px;
}
.sidenav .dot{
  width: 10px; height: 10px; border-radius: 50%;
  border: 1.5px solid var(--text-dim);
  background: transparent; transition: all .25s;
  flex-shrink: 0;
}
.sidenav a:hover{ color: var(--text); }
.sidenav a:hover .dot{ border-color: var(--text); }
.sidenav a.active{ color: var(--accent); }
.sidenav a.active .dot{
  background: var(--accent); border-color: var(--accent);
  box-shadow: 0 0 12px var(--accent);
  transform: scale(1.2);
}
.sidenav .label{
  opacity: 0; max-width: 0; overflow: hidden; white-space: nowrap;
  transition: opacity .2s, max-width .3s;
}
.sidenav:hover .label, .sidenav a.active .label{ opacity: 1; max-width: 160px; }

@media (max-width: 1100px){ .sidenav{ display:none; } }

/* ============ Hero ============ */
.hero{
  min-height: 100vh; padding-top: 120px; padding-bottom: 80px;
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: 64px; align-items: center;
}
@media (max-width: 980px){
  .hero{ grid-template-columns: 1fr; gap: 40px; padding-top: 100px; }
}
@media (max-width: 600px){
  .hero{ gap: 28px; padding-top: 80px; padding-bottom: 48px; }
  .hero-copy p.lede{ font-size: 15px; max-width: 100%; }
  .hero-meta{ gap: 24px; margin-top: 32px; flex-wrap: wrap; }
  .hero-visual{ max-height: 320px; }
  .hero-carousel{ padding-bottom: 80px; }
  .hero-carousel-controls{ bottom: 18px; gap: 8px; }
}

.hero-copy h1{
  font-size: clamp(42px, 6.2vw, 88px) !important;
  font-weight: 600; line-height: 0.98; letter-spacing: -0.03em;
  margin: 18px 0 28px;
  text-wrap: balance;
  overflow-wrap: break-word; word-break: break-word;
}
@media (max-width: 600px){
  .hero-copy h1{ font-size: clamp(28px, 9vw, 44px) !important; }
  .hero-copy h1 span[style]{ font-size: inherit !important; }
}
.hero-copy h1 .accent{ color: var(--accent); }
.hero-copy h1 em{
  font-style: italic; font-weight: 400; color: var(--text-dim);
  display: block;
}
.hero-copy p.lede{
  font-size: 18px; line-height: 1.55;
  color: var(--text-dim); max-width: 52ch;
  margin: 0 0 36px;
}
.hero-ctas{ display: flex; gap: 14px; flex-wrap: wrap; }

.hero-meta{
  display: flex; gap: 42px; margin-top: 56px;
  padding-top: 26px; border-top: 1px solid var(--line-2);
}
.hero-meta .m-val{
  font-size: 28px; font-weight: 600; color: var(--text);
  font-variant-numeric: tabular-nums;
}
.hero-meta .m-val .accent{ color: var(--accent); }
.hero-meta .m-lbl{
  font-family: var(--mono); font-size: 10px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--text-dimmer);
  margin-top: 4px;
}

/* Hero visual wrapper */
.hero-visual{
  position: relative; aspect-ratio: 1 / 1;
  max-height: 620px; width: 100%;
  border-radius: var(--radius-lg);
  background: var(--panel);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  border: 1px solid var(--line-3);
  overflow: hidden;
  box-shadow:
    0 40px 80px -40px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.05);
}
[data-theme="light"] .hero-visual{
  box-shadow:
    0 30px 60px -30px rgba(61,82,134,.25),
    inset 0 1px 0 rgba(255,255,255,.9);
}
.hero-visual .frame-chrome{
  position: absolute; top: 14px; left: 14px; right: 14px;
  display: flex; align-items:center; gap: 10px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .12em; color: var(--text-dimmer);
  text-transform: uppercase; z-index: 2;
}
.hero-visual .frame-chrome .pulse-dot{
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 10px var(--accent);
  animation: pulse 1.6s infinite;
}
.hero-visual .frame-chrome .live-tag{ color: var(--accent); }
.hero-visual .frame-chrome .rtls-id{ margin-left: auto; color: var(--text-dim); }

@keyframes pulse{
  0%, 100%{ opacity: 1; transform: scale(1); }
  50%{ opacity: .5; transform: scale(.7); }
}

/* Floorplan svg */
.floorplan{ position: absolute; inset: 0; width: 100%; height:100%; }
.fp-room{
  fill: rgba(61,82,134,0.12);
  stroke: rgba(139,195,74,0.22);
  stroke-width: 1;
}
.fp-wall{
  stroke: rgba(139,195,74,0.38);
  stroke-width: 1.4; fill: none;
}
.fp-label{
  font-family: var(--mono); font-size: 8.5px;
  fill: var(--text-dimmer);
  letter-spacing: .08em; text-transform: uppercase;
}
.fp-path-trail{
  stroke: var(--accent); stroke-width: 1.5; fill: none;
  stroke-dasharray: 4 4; opacity: .45;
}
.fp-ping{ transform-origin: center; }
.fp-ping .ring{
  fill: none; stroke: var(--accent); stroke-width: 1.2;
  transform-origin: center; transform-box: fill-box;
  animation: pingRing 2.6s cubic-bezier(0,0,0.2,1) infinite;
}
.fp-ping .ring.delay-2{ animation-delay: .6s; }
.fp-ping .ring.delay-3{ animation-delay: 1.2s; }
.fp-ping .core{
  fill: var(--accent);
  filter: drop-shadow(0 0 6px var(--accent));
}
.fp-ping.alarm .ring{ stroke: #FF5E6C; }
.fp-ping.alarm .core{ fill: #FF5E6C; filter: drop-shadow(0 0 6px #FF5E6C); }

@keyframes pingRing{
  0%{ r: 4; opacity: .9; }
  100%{ r: 42; opacity: 0; }
}

.fp-staff{
  fill: var(--blue-2); stroke: var(--text); stroke-width: 1.2;
}

.hero-hud{
  position: absolute; bottom: 14px; left: 14px; right: 14px;
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  gap: 8px; z-index: 2;
}
.hud-card{
  padding: 10px 12px; border-radius: 10px;
  background: var(--panel);
  border: 1px solid var(--line-3);
  backdrop-filter: blur(8px);
}
.hud-card .lbl{
  font-family: var(--mono); font-size: 9px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--text-dimmer); margin-bottom:4px;
}
.hud-card .val{
  font-size: 16px; font-weight: 600; color: var(--text);
  font-variant-numeric: tabular-nums;
}
.hud-card .val .accent{ color: var(--accent); }
.hud-card.pulse-bg{ animation: pulseBg 2s ease-in-out infinite; }
@keyframes pulseBg{
  0%, 100%{ border-color: var(--line-2); }
  50%{ border-color: var(--accent); }
}

.hub-svg{ position:absolute; inset:0; width:100%; height:100%; }
.hub-cloud path{
  animation: hubBreathe 3.4s ease-in-out infinite;
  transform-origin: center;
}
@keyframes hubBreathe{
  0%, 100%{ opacity: 1; transform: translateY(0); }
  50%{ opacity: .85; transform: translateY(-2px); }
}

/* Alternate hero: constellation */
.constellation{ position:absolute; inset:0; width:100%; height:100%; }
.const-link{ stroke: var(--line); stroke-width: 1; }
.const-link.active{ stroke: var(--accent); stroke-width: 1.4; opacity: .8; }
.const-node circle{
  fill: var(--ink-3); stroke: var(--blue-2); stroke-width: 1.2;
  transition: all .3s;
}
.const-node.active circle{
  fill: var(--accent); stroke: var(--accent);
  filter: drop-shadow(0 0 10px var(--accent));
}
.const-node text{
  font-family: var(--mono); font-size: 8px;
  fill: var(--text-dim); letter-spacing: .06em; text-transform: uppercase;
}

/* Alternate hero: dashboard */
.dash-hero{
  position: absolute; inset: 40px 18px 18px;
  display: grid; grid-template-rows: auto 1fr auto;
  gap: 10px;
}
.dash-row{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.dash-tile{
  background: var(--panel);
  border: 1px solid var(--line-3);
  border-radius: 10px; padding: 12px;
}
.dash-tile h4{
  margin: 0 0 6px; font-family: var(--mono);
  font-size: 9px; text-transform: uppercase; letter-spacing:.14em;
  color: var(--text-dimmer); font-weight: 500;
}
.dash-big{
  font-size: 26px; font-weight: 600;
  font-variant-numeric: tabular-nums; color: var(--text);
}
.dash-big .accent{ color: var(--accent); }
.dash-tile.chart{ grid-column: span 3; }
.spark{ width: 100%; height: 100%; }
.spark path{ stroke: var(--accent); stroke-width: 1.4; fill: none; }
.spark path.fill{
  fill: url(#spark-grad); stroke: none;
}

/* ============ About ============ */
.about-grid{
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
  align-items: start;
}
@media (max-width: 900px){ .about-grid{ grid-template-columns: 1fr; gap: 40px; }}

.about-stats{
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 14px; margin-top: 40px;
}
@media (max-width: 900px){
  .about-stats{ grid-template-columns: 1fr 1fr; }
}
.stat-card{
  padding: 22px 18px;
  background: var(--panel);
  backdrop-filter: blur(12px);
  border: 1px solid var(--line-3);
  border-radius: var(--radius);
  position: relative; overflow: hidden;
}
.stat-card::before{
  content: ""; position:absolute; left: 0; top: 0;
  width: 3px; height: 0; background: var(--accent);
  transition: height .6s cubic-bezier(0.2, 0.7, 0, 1);
}
.stat-card.in-view::before{ height: 100%; }
.stat-val{
  font-size: 40px; font-weight: 600;
  letter-spacing: -0.02em; line-height: 1;
  font-variant-numeric: tabular-nums;
}
.stat-val .accent{ color: var(--accent); }
.stat-val .unit{ font-size: 18px; margin-left: 4px; color: var(--text-dim); }
.stat-lbl{
  margin-top: 10px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-dim);
}

.about-visual{
  aspect-ratio: 4 / 5; border-radius: var(--radius-lg);
  background: var(--panel);
  backdrop-filter: blur(16px) saturate(140%);
  border: 1px solid var(--line-3);
  position: relative; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  box-shadow:
    0 40px 80px -40px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.05);
}
[data-theme="light"] .about-visual{
  box-shadow:
    0 30px 60px -30px rgba(61,82,134,.25),
    inset 0 1px 0 rgba(255,255,255,.9);
}
.about-visual .mark-big{
  width: 56%; height: auto; opacity: 1;
  filter: drop-shadow(0 8px 30px var(--accent-glow));
}
.about-visual .about-photo{
  position: absolute; inset: 0; z-index: 0;
  background-image: url("https://images.unsplash.com/photo-1519494026892-80bbd2d6fd0d?w=1200&q=70&auto=format&fit=crop");
  background-size: cover; background-position: center;
}
.about-visual .about-overlay{
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(180deg, rgba(10,14,26,0.55) 0%, rgba(10,14,26,0.90) 100%);
}
[data-theme="light"] .about-visual .about-overlay{
  background: linear-gradient(180deg, rgba(246,247,251,0.55) 0%, rgba(246,247,251,0.92) 100%);
}

.about-visual .caption{
  position: absolute; bottom: 20px; left: 20px;
  font-family: var(--mono); font-size: 10px;
  color: var(--text-dim); letter-spacing:.12em; text-transform:uppercase;
}
.about-visual .corner{
  position: absolute; width: 22px; height: 22px;
  border: 1px solid var(--accent);
}
.about-visual .corner.tl{ top: 14px; left: 14px; border-right: none; border-bottom: none; }
.about-visual .corner.tr{ top: 14px; right: 14px; border-left: none; border-bottom: none; }
.about-visual .corner.bl{ bottom: 14px; left: 14px; border-right: none; border-top: none; }
.about-visual .corner.br{ bottom: 14px; right: 14px; border-left: none; border-top: none; }

.about-pills{
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 28px;
}
.about-pills > span{
  padding: 7px 13px; border-radius: 999px;
  border: 1px solid var(--line-2);
  font-size: 12px; color: var(--text-dim);
  transition: all .2s;
}
.about-pills > span:hover{
  color: var(--accent); border-color: var(--accent);
}

/* ============ Services ============ */
.services-head{
  display: flex; justify-content: space-between; align-items: end;
  gap: 40px; flex-wrap: wrap; margin-bottom: 56px;
}
.services-grid{
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}
.svc-card{
  grid-column: span 4;
  min-height: 260px;
  padding: 28px;
  border-radius: var(--radius);
  border: 1px solid var(--line-3);
  background: var(--panel);
  backdrop-filter: blur(12px);
  position: relative; overflow: hidden;
  transition: transform .3s cubic-bezier(0.2,0.7,0,1),
              border-color .3s, background .3s, box-shadow .3s;
}
.svc-card:hover{
  border-color: var(--accent);
  transform: translateY(-4px);
  box-shadow: 0 20px 40px -20px var(--accent-glow);
}
.svc-card.wide{ grid-column: span 8; }
.svc-card.tall{ grid-row: span 2; }

@media (max-width: 980px){
  .svc-card, .svc-card.wide{ grid-column: span 6; }
}
@media (max-width: 640px){
  .svc-card, .svc-card.wide{ grid-column: span 12; }
}

.svc-idx{
  font-family: var(--mono); font-size: 10px;
  letter-spacing:.14em; color: var(--text-dimmer);
  text-transform: uppercase;
}
.svc-title{
  font-size: 22px; font-weight: 500; letter-spacing: -0.01em;
  margin: 14px 0 10px; line-height: 1.1;
}
.svc-desc{
  font-size: 13.5px; line-height: 1.55; color: var(--text-dim);
  max-width: 42ch;
}
.svc-icon{
  position: absolute; right: 22px; top: 22px;
  width: 28px; height: 28px; color: var(--accent);
  opacity: .8; transition: transform .3s, opacity .3s;
}
.svc-card:hover .svc-icon{
  opacity: 1; transform: rotate(-8deg) scale(1.08);
}
.svc-card .learn{
  position: absolute; left: 28px; bottom: 22px;
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--text-dim);
  opacity: 0; transform: translateY(4px);
  transition: opacity .3s, transform .3s, color .3s;
}
.svc-card:hover .learn{
  opacity: 1; transform: translateY(0); color: var(--accent);
}
.svc-card .glow-blob{
  position: absolute; width: 200px; height: 200px;
  border-radius: 50%; filter: blur(50px);
  background: var(--accent);
  opacity: 0; transition: opacity .4s;
  right: -50px; bottom: -60px;
  pointer-events: none;
}
.svc-card:hover .glow-blob{ opacity: .18; }

.svc-card .mini-viz{
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 90px; opacity: .6; pointer-events: none;
  transition: opacity .3s;
}
.svc-card:hover .mini-viz{ opacity: 1; }

.svc-card .tags{
  position: absolute; left: 28px; bottom: 22px;
  display: flex; gap: 6px;
  opacity: 1; transition: opacity .3s;
}
.svc-card:hover .tags{ opacity: 0; }
.svc-card .tags span{
  font-family: var(--mono); font-size: 9px;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--text-dimmer);
  padding: 4px 8px; border: 1px solid var(--line-2);
  border-radius: 4px;
}

/* ============ Industries ============ */
.industries-grid{
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 20px; margin-top: 56px;
}
@media (max-width: 820px){ .industries-grid{ grid-template-columns: 1fr; }}

.ind-card{
  position: relative; padding: 36px;
  border-radius: var(--radius); overflow: hidden;
  border: 1px solid var(--line-3);
  background: var(--panel);
  backdrop-filter: blur(12px);
  min-height: 320px;
  display: flex; flex-direction: column; justify-content: space-between;
  transition: border-color .3s, transform .3s, box-shadow .3s;
}
.ind-card:hover{
  border-color: var(--accent);
  transform: translateY(-4px);
  box-shadow: 0 20px 40px -20px var(--accent-glow);
}
.ind-card .placeholder-img{
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(circle at 80% 20%, var(--accent-glow), transparent 50%),
    linear-gradient(135deg, rgba(61,82,134,0.18), transparent 60%);
  opacity: .6;
}
.ind-card .placeholder-img.has-photo{ opacity: 1; }
.ind-card .ind-overlay{
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(180deg, rgba(10,14,26,0.55) 0%, rgba(10,14,26,0.92) 100%);
}
[data-theme="light"] .ind-card .ind-overlay{
  background: linear-gradient(180deg, rgba(246,247,251,0.55) 0%, rgba(246,247,251,0.92) 100%);
}
[data-theme="light"] .ind-card h3{ color: var(--text); }
[data-theme="light"] .ind-card ul li{ color: var(--text); }
.ind-card > *{ position: relative; z-index: 1; }
.ind-card h3{
  font-size: 26px; font-weight: 500;
  letter-spacing: -0.01em; margin: 8px 0 12px;
}
.ind-card p{ color: var(--text-dim); font-size: 14px; line-height: 1.55; margin:0; max-width: 40ch;}
.ind-card .tag{
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--accent);
}
.ind-card .cap{
  font-family: var(--mono); font-size: 10px;
  color: var(--text-dimmer); letter-spacing: .12em;
  text-transform: uppercase; margin-top: 18px;
}
.ind-card ul{
  margin: 18px 0 0; padding: 0; list-style: none;
  display: flex; flex-direction: column; gap: 8px;
}
.ind-card ul li{
  font-size: 13px; color: var(--text); opacity: .85;
  display: flex; align-items: center; gap: 10px;
}
.ind-card ul li::before{
  content: ""; width: 16px; height: 1px; background: var(--accent);
  display: inline-block;
}

/* ============ Contact ============ */
.contact-grid{
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px;
}
@media (max-width: 900px){ .contact-grid{ grid-template-columns: 1fr; gap: 40px; }}

.contact-panel{
  padding: clamp(20px, 5vw, 40px);
  border: 1px solid var(--line-3);
  border-radius: var(--radius-lg);
  background: var(--panel);
  backdrop-filter: blur(16px) saturate(140%);
  position: relative; overflow: hidden;
  box-shadow:
    0 40px 80px -40px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.05);
}
[data-theme="light"] .contact-panel{
  box-shadow:
    0 30px 60px -30px rgba(61,82,134,.25),
    inset 0 1px 0 rgba(255,255,255,.9);
}
.contact-panel::before{
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(400px 260px at 100% 0%, var(--accent-glow), transparent);
  opacity: .18;
  pointer-events: none;
}

.field{
  position: relative; margin-bottom: 20px;
}
.field label{
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-dimmer);
  display: block; margin-bottom: 8px;
}
.field input, .field textarea, .field select{
  width: 100%; padding: 14px 0;
  background: transparent; border: none;
  border-bottom: 1px solid var(--line-2);
  color: var(--text); font-family: inherit;
  font-size: 15px; outline: none;
  transition: border-color .3s;
}
.field textarea{ resize: vertical; min-height: 90px; padding-top: 12px;}
.field input:focus, .field textarea:focus, .field select:focus{
  border-bottom-color: var(--accent);
}

/* ---- Custom dropdown ---- */
.cselect{ position: relative; }
.cselect-trigger{
  width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding: 14px 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--line-2);
  color: var(--text);
  font-family: inherit; font-size: 15px;
  cursor: pointer;
  transition: border-color .25s;
}
.cselect-trigger:hover{ border-bottom-color: var(--line-3); }
.cselect.open .cselect-trigger{ border-bottom-color: var(--accent); }
.cselect-chev{ color: var(--text-dim); transition: transform .25s; }
.cselect.open .cselect-chev{ transform: rotate(180deg); color: var(--accent); }
.cselect-menu{
  position: absolute; left: 0; right: 0; top: calc(100% + 6px);
  z-index: 30;
  background: var(--panel-solid);
  border: 1px solid var(--line-3);
  border-radius: 12px;
  padding: 6px;
  box-shadow:
    0 18px 40px -16px rgba(0,0,0,.45),
    0 0 0 1px rgba(255,255,255,.02) inset;
  max-height: 280px; overflow: auto;
  animation: cselFade .18s ease-out;
}
[data-theme="light"] .cselect-menu{
  box-shadow:
    0 18px 40px -16px rgba(61,82,134,.22),
    0 0 0 1px rgba(0,0,0,.02) inset;
}
@keyframes cselFade{
  from{ opacity: 0; transform: translateY(-4px); }
  to{ opacity: 1; transform: translateY(0); }
}
.cselect-opt{
  width: 100%; text-align: left;
  display: flex; align-items: center; gap: 10px;
  padding: 11px 12px;
  background: transparent; border: 0; border-radius: 8px;
  color: var(--text);
  font-family: inherit; font-size: 14px;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.cselect-opt:hover{ background: color-mix(in oklab, var(--accent) 12%, transparent); color: var(--text); }
.cselect-opt .dot{
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--text-dimmer);
  transition: all .2s;
}
.cselect-opt.sel{ color: var(--accent); }
.cselect-opt.sel .dot{
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
}
.field .err{
  font-size: 11px; color: #FF5E6C; margin-top: 6px;
  font-family: var(--mono); letter-spacing: .1em;
}

.submit-row{
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 26px;
}
.submit-row .help{
  font-family: var(--mono); font-size: 10px;
  color: var(--text-dimmer); letter-spacing: .12em; text-transform: uppercase;
}

.contact-info{
  display: flex; flex-direction: column; gap: 30px;
}
.info-row{
  display: flex; gap: 16px;
}
.info-row .ico{
  width: 40px; height: 40px; border-radius: 10px;
  border: 1px solid var(--line-2);
  display: grid; place-items: center; color: var(--accent);
  flex-shrink: 0;
}
.info-row h4{
  margin: 0 0 4px; font-size: 14px; font-weight: 500;
  color: var(--text);
}
.info-row .val{
  font-size: 18px; color: var(--text); font-weight: 500;
}
.info-row .val.mono{ font-family: var(--mono); letter-spacing: .02em; }
.info-row .sub{
  font-size: 13px; color: var(--text-dim); margin-top: 2px;
}

.sent{
  text-align: center; padding: 40px 10px;
}
.sent .ok{
  width: 60px; height: 60px; border-radius: 50%;
  border: 1.5px solid var(--accent);
  display: grid; place-items:center; margin: 0 auto 18px;
  color: var(--accent);
  animation: popIn .5s cubic-bezier(0.2,0.7,0,1);
}
@keyframes popIn{
  0%{ transform: scale(.4); opacity: 0; }
  100%{ transform: scale(1); opacity: 1; }
}

/* ============ Footer ============ */
footer{
  border-top: 1px solid var(--line-2);
  padding: 60px clamp(24px, 5vw, 72px) 40px;
  position: relative;
}
.foot-inner{
  max-width: 1320px; margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
}
@media (max-width: 800px){ .foot-inner{ grid-template-columns: 1fr 1fr; gap: 28px; } }
@media (max-width: 480px){ .foot-inner{ grid-template-columns: 1fr; gap: 24px; } }
footer h5{
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-dim); font-weight: 500;
  margin: 0 0 16px;
}
footer ul{ list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
footer a{ font-size: 13px; color: var(--text-dim); transition: color .2s;}
footer a:hover{ color: var(--accent); }
footer .brand-col p{
  font-size: 13px; color: var(--text-dim); line-height: 1.6;
  margin: 16px 0 0; max-width: 40ch;
}
footer .foot-logo{ height: 36px; }
footer .foot-logo img{ height: 100%; width: auto; display: block; }

.foot-bottom{
  max-width: 1320px; margin: 40px auto 0;
  padding-top: 24px; border-top: 1px solid var(--line-2);
  display: flex; justify-content: space-between; gap: 20px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--text-dimmer); flex-wrap: wrap;
}

/* ============ Scroll progress ============ */
.scroll-progress{
  position: fixed; top: 0; left: 0; right: 0; height: 2px;
  z-index: 60; pointer-events: none;
  background: linear-gradient(90deg, var(--accent), var(--blue-2));
  transform-origin: left center;
  transform: scaleX(0);
  transition: transform .1s linear;
  box-shadow: 0 0 10px var(--accent-glow);
}

/* ============ Custom cursor ============ */
html[data-cursor="on"]{ cursor: none; }
html[data-cursor="on"] *{ cursor: none !important; }
html[data-cursor="on"] input,
html[data-cursor="on"] textarea{ cursor: text !important; }

.cursor-dot{
  position: fixed; left: 0; top: 0; z-index: 9999;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  pointer-events: none;
  box-shadow: 0 0 12px var(--accent-glow);
  transition: width .18s, height .18s, background .2s, opacity .2s;
  will-change: transform;
}
.cursor-ring{
  position: fixed; left: 0; top: 0; z-index: 9998;
  width: 34px; height: 34px; border-radius: 50%;
  border: 1.4px solid var(--accent);
  pointer-events: none;
  opacity: .65;
  transition: width .25s cubic-bezier(0.2,0.7,0,1),
              height .25s cubic-bezier(0.2,0.7,0,1),
              opacity .25s, border-color .2s, background .2s;
  will-change: transform;
}
.cursor-ring::before,
.cursor-ring::after{
  content: ""; position: absolute; background: var(--accent);
  opacity: .9;
}
.cursor-ring::before{
  left: 50%; top: -4px; width: 1px; height: 5px; transform: translateX(-50%);
}
.cursor-ring::after{
  left: 50%; bottom: -4px; width: 1px; height: 5px; transform: translateX(-50%);
}
.cursor-ring.hover{
  width: 58px; height: 58px;
  background: color-mix(in oklab, var(--accent) 14%, transparent);
  opacity: 1;
}
.cursor-dot.hover{ width: 8px; height: 8px; }
@media (hover: none){
  html[data-cursor="on"]{ cursor: auto; }
  html[data-cursor="on"] *{ cursor: auto !important; }
  .cursor-dot, .cursor-ring{ display: none; }
}

/* ============ Hero carousel ============ */
.hero-carousel{ position: relative; padding-bottom: 120px; }
.hero-carousel .hero-copy h1,
.hero-carousel .hero-copy p.lede,
.hero-carousel .section-eyebrow{ min-height: 1px; }

.hero-anim-in{
  animation: heroSlideIn .55s cubic-bezier(0.2,0.7,0,1) both;
}
@keyframes heroSlideIn{
  from{ opacity: 0; transform: translateY(14px); }
  to{   opacity: 1; transform: translateY(0); }
}

.hero-services{
  display: flex; flex-wrap: wrap; gap: 8px;
  margin: 0 0 32px;
}
.hero-service-chip{
  font-family: var(--mono);
  font-size: 11px; letter-spacing: .06em;
  padding: 8px 13px;
  border-radius: 999px;
  border: 1px solid var(--line-3);
  background: var(--panel);
  color: var(--text);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: border-color .2s, color .2s, background .2s;
}
.hero-service-chip:hover{
  border-color: var(--accent);
  color: var(--accent);
}

.hero-viz-stage{
  position: absolute; inset: 0;
  animation: heroVizFade .6s ease both;
}
@keyframes heroVizFade{
  from{ opacity: 0; transform: scale(.985); }
  to{   opacity: 1; transform: scale(1); }
}

.hero-carousel-controls{
  position: absolute;
  left: clamp(24px, 5vw, 72px);
  right: clamp(24px, 5vw, 72px);
  bottom: 36px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  z-index: 4;
}

.hero-tabs{
  display: inline-flex; gap: 4px;
  padding: 4px;
  border-radius: 999px;
  border: 1px solid var(--line-3);
  background: var(--panel);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  max-width: 100%;
  overflow-x: auto;
  scrollbar-width: none;
}
.hero-tabs::-webkit-scrollbar{ display: none; }

.hero-tab{
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  border-radius: 999px;
  border: 0;
  background: transparent;
  color: var(--text-dim);
  font-family: inherit;
  font-size: 11.5px; font-weight: 500;
  letter-spacing: .02em;
  cursor: pointer;
  white-space: nowrap;
  transition: color .25s, background .25s;
}
.hero-tab:hover{ color: var(--text); }
.hero-tab.active{
  background: color-mix(in oklab, var(--tab-accent, var(--accent)) 18%, transparent);
  color: var(--tab-accent, var(--accent));
}
.hero-tab-idx{
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .14em;
  opacity: .7;
}
.hero-tab.active .hero-tab-idx{ opacity: 1; }

.hero-progress{
  display: none;
}

.hero-nav{ display: flex; gap: 8px; }
.hero-nav-btn{
  width: 34px; height: 34px;
  display: grid; place-items: center;
  border-radius: 999px;
  border: 1px solid var(--line-3);
  background: var(--panel);
  color: var(--text);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  cursor: pointer;
  transition: border-color .2s, color .2s, transform .15s;
}
.hero-nav-btn:hover{
  border-color: var(--accent);
  color: var(--accent);
}
.hero-nav-btn:active{ transform: scale(.95); }

@media (max-width: 980px){
  .hero-carousel{ padding-bottom: 130px; }
  .hero-carousel-controls{
    flex-wrap: wrap;
    gap: 12px;
  }
}

/* ============ Reveal ============ */
.reveal{ opacity: 0; transform: translateY(24px); transition: opacity .8s ease, transform .8s cubic-bezier(0.2,0.7,0,1); }
.reveal.in-view{ opacity: 1; transform: translateY(0); }

/* ============ Slide viz dashboards ============ */
.sv-root{
  position: absolute;
  inset: 44px 14px 14px 14px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-rows: minmax(0, auto);
  gap: 8px;
  font-family: var(--sans);
  color: var(--text);
}

/* Tiles */
.sv-stat-tile{
  background: var(--panel-solid);
  border: 1px solid var(--line-3);
  border-radius: 10px;
  padding: 12px 14px;
  display: flex; flex-direction: column;
  gap: 4px;
  position: relative;
  overflow: hidden;
}
.sv-stat-tile::before{
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  width: 2px; background: var(--accent);
  opacity: .85;
}
.sv-stat-lbl{
  font-family: var(--mono); font-size: 9px;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-dimmer);
}
.sv-stat-val{
  font-size: 22px; font-weight: 700;
  letter-spacing: -0.02em; line-height: 1;
  color: var(--text);
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}
.sv-stat-sub{
  font-size: 10px;
  color: var(--text-dim);
}
.sv-stat-trend{
  font-size: 9.5px; font-weight: 600;
  font-family: var(--mono); letter-spacing: .04em;
  display: inline-flex; align-items: center; gap: 3px;
  margin-top: 2px;
}
.sv-stat-trend.up   { color: color-mix(in oklab, var(--accent) 80%, #4ADE80); }
.sv-stat-trend.down { color: color-mix(in oklab, var(--accent) 60%, #4ADE80); }

/* Cards */
.sv-card{
  background: var(--panel-solid);
  border: 1px solid var(--line-3);
  border-radius: 10px;
  padding: 12px 14px;
  display: flex; flex-direction: column;
  position: relative;
  overflow: hidden;
  min-width: 0;
}
.sv-card-head{
  display: flex; align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.sv-card-title{
  font-family: var(--mono); font-size: 9.5px;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-dim);
  font-weight: 600;
}
.sv-live-dot{
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
  animation: pulse 1.6s infinite;
}
.sv-card-right{ margin-left: auto; }
.sv-card-tag{
  font-family: var(--mono); font-size: 9px;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--accent);
  padding: 3px 8px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--accent) 12%, transparent);
}
.sv-card-body{ flex: 1; display: flex; flex-direction: column; min-height: 0; }

/* Pills */
.sv-pill{
  font-family: var(--mono);
  font-size: 9px; letter-spacing: .12em;
  text-transform: uppercase; font-weight: 600;
  padding: 3px 8px; border-radius: 999px;
  border: 1px solid transparent;
}
.sv-pill-ok{
  color: var(--accent);
  background: color-mix(in oklab, var(--accent) 14%, transparent);
  border-color: color-mix(in oklab, var(--accent) 35%, transparent);
}
.sv-pill-warn{
  color: #E8A33A;
  background: color-mix(in oklab, #E8A33A 14%, transparent);
  border-color: color-mix(in oklab, #E8A33A 35%, transparent);
}
.sv-pill-urgent{
  color: #FF7A85;
  background: color-mix(in oklab, #FF7A85 14%, transparent);
  border-color: color-mix(in oklab, #FF7A85 35%, transparent);
}

/* Status dots */
.sv-status-dot{
  width: 7px; height: 7px; border-radius: 50%;
  flex-shrink: 0;
}
.sv-status-ok       { background: var(--accent); box-shadow: 0 0 6px var(--accent); }
.sv-status-warn     { background: #E8A33A; box-shadow: 0 0 6px #E8A33A; }
.sv-status-crit     { background: #FF7A85; box-shadow: 0 0 6px #FF7A85; }
.sv-status-training { background: var(--accent); box-shadow: 0 0 6px var(--accent); animation: pulse 1s infinite; }

/* Bars */
.sv-bar-row{ display: flex; align-items: center; gap: 8px; }
.sv-bar-lbl{
  font-size: 10px; color: var(--text-dim);
  flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sv-bar-track{
  flex: 2; min-width: 0;
  height: 4px; border-radius: 4px;
  background: color-mix(in oklab, var(--text) 10%, transparent);
  overflow: hidden;
}
.sv-bar-fill{
  height: 100%; border-radius: 4px;
  background: var(--accent);
  transition: width .6s cubic-bezier(0.2,0.7,0,1);
}
.sv-bar-val{
  font-family: var(--mono); font-size: 10px;
  font-weight: 600; color: var(--accent);
  min-width: 32px; text-align: right;
}

/* Sparkline foot */
.sv-trend-foot{
  display: flex; justify-content: space-between;
  font-family: var(--mono); font-size: 9px;
  color: var(--text-dimmer);
  margin-top: 4px;
  letter-spacing: .06em;
}

/* === Simple shared layout: 3 stats + 1 main card === */
.sv-simple{
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: auto 1fr;
  grid-template-areas:
    "stat1 stat2 stat3"
    "main  main  main";
}
@media (max-width: 480px){
  .sv-simple{
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto 1fr;
    grid-template-areas:
      "stat1 stat2"
      "stat3 stat3"
      "main  main";
  }
  /* Compact stat tiles so chat card gets more vertical room */
  .sv-root{ gap: 6px; }
  .sv-stat-tile{ padding: 7px 9px; }
  .sv-stat-val{ font-size: 16px; }
  .sv-stat-lbl{ font-size: 8px; }
  .sv-stat-sub, .sv-stat-trend{ font-size: 9px; }
  /* Chat: hide suggestion chips (no room) and tighten card */
  .sv-card{ padding: 8px 10px; }
  .sv-card-head{ padding-bottom: 6px; margin-bottom: 6px; }
  .sv-chat{ gap: 6px; }
  .sv-chat-suggestions{ display: none; }
  .sv-chat-form{ padding: 3px 3px 3px 10px; }
  .sv-chat-input{ font-size: 11px; }
  .sv-msg-body{ font-size: 11px; padding: 6px 9px; }
  .sv-msg-avatar{ width: 22px; height: 22px; font-size: 8px; }
  .sv-msg{ gap: 6px; grid-template-columns: 22px 1fr; }
}
.sv-simple .sv-stat-tile:nth-of-type(1){ grid-area: stat1; }
.sv-simple .sv-stat-tile:nth-of-type(2){ grid-area: stat2; }
.sv-simple .sv-stat-tile:nth-of-type(3){ grid-area: stat3; }
.sv-area-main{ grid-area: main; }

/* === HEALTH widgets === */

.sv-call-list{ display: flex; flex-direction: column; gap: 6px; }
.sv-call{
  display: grid;
  grid-template-columns: 38px 1fr auto auto 8px;
  align-items: center; gap: 10px;
  padding: 8px 10px;
  border-radius: 8px;
  background: color-mix(in oklab, var(--text) 4%, transparent);
  border: 1px solid color-mix(in oklab, var(--text) 6%, transparent);
}
.sv-call-room{
  font-family: var(--mono); font-weight: 700;
  font-size: 11px; letter-spacing: .04em;
  color: var(--accent);
}
.sv-call-pt{
  font-size: 11.5px; font-weight: 500; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sv-call-type{
  font-family: var(--mono); font-size: 9px;
  letter-spacing: .12em; color: var(--text-dim);
  text-transform: uppercase;
}
.sv-call-time{
  font-family: var(--mono); font-size: 10px;
  color: var(--text-dimmer);
  font-variant-numeric: tabular-nums;
}
.sv-call-dot{
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--text-dim);
}
.sv-call-urgent   { border-color: color-mix(in oklab, #FF7A85 35%, transparent); background: color-mix(in oklab, #FF7A85 7%, transparent); }
.sv-call-urgent .sv-call-dot   { background: #FF7A85; box-shadow: 0 0 8px #FF7A85; animation: pulse 1.4s infinite; }
.sv-call-critical { border-color: color-mix(in oklab, #FF5E6C 50%, transparent); background: color-mix(in oklab, #FF5E6C 10%, transparent); }
.sv-call-critical .sv-call-dot { background: #FF5E6C; box-shadow: 0 0 10px #FF5E6C; animation: pulse 1s infinite; }
.sv-call-normal .sv-call-dot   { background: var(--accent); box-shadow: 0 0 6px var(--accent); }

.sv-floorplan{ width: 100%; height: 100%; min-height: 130px; }

/* === EDUCATION widgets === */

/* Alarm list */
.sv-alarm-list{ display: flex; flex-direction: column; gap: 4px; }
.sv-alarm{
  display: grid;
  grid-template-columns: 60px 64px 64px 1fr 8px;
  align-items: center; gap: 8px;
  padding: 7px 10px;
  border-radius: 7px;
  background: color-mix(in oklab, var(--text) 3%, transparent);
  border-left: 2px solid var(--accent);
  font-size: 11px;
}
.sv-alarm-t{
  font-family: var(--mono); font-size: 9.5px;
  color: var(--text-dimmer);
}
.sv-alarm-cat{
  font-family: var(--mono); font-size: 9.5px;
  letter-spacing: .12em; font-weight: 700;
  color: var(--accent);
}
.sv-alarm-bldg{
  font-family: var(--mono); font-size: 9px;
  letter-spacing: .12em;
  color: var(--text-dim);
}
.sv-alarm-msg{
  font-size: 11px; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sv-alarm-dot{
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent);
}
.sv-alarm-ok{
  border-left-color: color-mix(in oklab, var(--accent) 60%, #4ADE80);
}
.sv-alarm-ok .sv-alarm-cat{
  color: color-mix(in oklab, var(--accent) 60%, #4ADE80);
}
.sv-alarm-ok .sv-alarm-dot{
  background: color-mix(in oklab, var(--accent) 60%, #4ADE80);
}
.sv-alarm-warn{
  border-left-color: #E8A33A;
  background: color-mix(in oklab, #E8A33A 6%, transparent);
}
.sv-alarm-warn .sv-alarm-cat{ color: #E8A33A; }
.sv-alarm-warn .sv-alarm-dot{ background: #E8A33A; box-shadow: 0 0 6px #E8A33A; }
.sv-alarm-crit{
  border-left-color: #FF5E6C;
  background: color-mix(in oklab, #FF5E6C 8%, transparent);
}
.sv-alarm-crit .sv-alarm-cat{ color: #FF5E6C; }
.sv-alarm-crit .sv-alarm-dot{ background: #FF5E6C; box-shadow: 0 0 8px #FF5E6C; animation: pulse 1.1s infinite; }

/* Building status list */
.sv-bldg-list{ display: flex; flex-direction: column; gap: 6px; }
.sv-bldg{
  display: grid;
  grid-template-columns: 32px 1fr auto;
  align-items: center; gap: 10px;
  padding: 9px 10px;
  border-radius: 8px;
  background: color-mix(in oklab, var(--text) 3%, transparent);
  border: 1px solid color-mix(in oklab, var(--text) 6%, transparent);
}
.sv-bldg-id{
  width: 32px; height: 32px; border-radius: 6px;
  display: grid; place-items: center;
  font-family: var(--mono); font-size: 13px; font-weight: 700;
  color: var(--accent);
  background: color-mix(in oklab, var(--accent) 12%, transparent);
  border: 1px solid color-mix(in oklab, var(--accent) 30%, transparent);
}
.sv-bldg-name{
  font-size: 12px; font-weight: 600; color: var(--text);
  letter-spacing: -0.005em;
}
.sv-bldg-note{
  font-size: 10.5px; color: var(--text-dim);
  font-family: var(--mono); letter-spacing: .02em;
  margin-top: 1px;
}
.sv-bldg-alerts{
  font-family: var(--mono); font-size: 13px; font-weight: 700;
  min-width: 22px; height: 22px;
  display: grid; place-items: center;
  border-radius: 5px;
  color: var(--accent);
  background: color-mix(in oklab, var(--accent) 12%, transparent);
}
.sv-bldg-ok .sv-bldg-id,
.sv-bldg-ok .sv-bldg-alerts{
  color: color-mix(in oklab, var(--accent) 70%, #4ADE80);
  background: color-mix(in oklab, var(--accent) 12%, transparent);
  border-color: color-mix(in oklab, var(--accent) 30%, transparent);
}
.sv-bldg-warn{ border-color: color-mix(in oklab, #E8A33A 30%, transparent); }
.sv-bldg-warn .sv-bldg-id{
  color: #E8A33A;
  background: color-mix(in oklab, #E8A33A 12%, transparent);
  border-color: color-mix(in oklab, #E8A33A 30%, transparent);
}
.sv-bldg-warn .sv-bldg-alerts{
  color: #E8A33A;
  background: color-mix(in oklab, #E8A33A 12%, transparent);
}
.sv-bldg-crit{
  border-color: color-mix(in oklab, #FF5E6C 45%, transparent);
  background: color-mix(in oklab, #FF5E6C 6%, transparent);
}
.sv-bldg-crit .sv-bldg-id{
  color: #FF5E6C;
  background: color-mix(in oklab, #FF5E6C 14%, transparent);
  border-color: color-mix(in oklab, #FF5E6C 35%, transparent);
}
.sv-bldg-crit .sv-bldg-alerts{
  color: #FF5E6C;
  background: color-mix(in oklab, #FF5E6C 14%, transparent);
  animation: pulse 1.4s infinite;
}

/* Bell schedule strip */
.sv-bell-strip{
  display: grid; grid-template-columns: repeat(8, 1fr); gap: 4px;
}
.sv-bell-slot{
  padding: 8px 10px;
  border-radius: 7px;
  background: color-mix(in oklab, var(--text) 3%, transparent);
  border: 1px solid color-mix(in oklab, var(--text) 6%, transparent);
  text-align: center;
}
.sv-bell-time{
  font-family: var(--mono); font-size: 10px;
  color: var(--text-dim); letter-spacing: .06em;
  font-weight: 600;
}
.sv-bell-period{
  font-family: var(--mono); font-size: 9px;
  color: var(--text-dimmer); letter-spacing: .14em;
  margin-top: 3px;
}
.sv-bell-slot.now{
  background: color-mix(in oklab, var(--accent) 16%, transparent);
  border-color: color-mix(in oklab, var(--accent) 40%, transparent);
}
.sv-bell-slot.now .sv-bell-time{ color: var(--accent); }
.sv-bell-slot.now .sv-bell-period{
  color: var(--accent); font-weight: 700;
  text-shadow: 0 0 6px color-mix(in oklab, var(--accent) 50%, transparent);
}

/* === AI widgets === */

/* AI chat */
.sv-chat{
  display: flex; flex-direction: column;
  gap: 10px;
  flex: 1;
  min-height: 0;
}
.sv-chat-stream{
  flex: 1; min-height: 0;
  overflow-y: auto;
  display: flex; flex-direction: column;
  gap: 8px;
  padding: 4px 6px 4px 0;
}
.sv-chat-stream::-webkit-scrollbar{ width: 6px; }
.sv-chat-stream::-webkit-scrollbar-thumb{
  background: color-mix(in oklab, var(--text) 14%, transparent);
  border-radius: 3px;
}

.sv-msg{
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 10px;
  align-items: flex-start;
}
.sv-msg-system{ grid-template-columns: 1fr; }
.sv-msg-avatar{
  width: 28px; height: 28px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--mono);
  font-size: 9px; font-weight: 700;
  letter-spacing: .04em;
  background: color-mix(in oklab, var(--text) 8%, transparent);
  color: var(--text-dim);
  flex-shrink: 0;
}
.sv-msg-user .sv-msg-avatar{
  background: color-mix(in oklab, var(--accent) 20%, transparent);
  color: var(--accent);
}
.sv-msg-assistant .sv-msg-avatar{
  background: var(--accent);
  color: var(--ink);
}
.sv-msg-body{
  padding: 9px 13px;
  border-radius: 10px;
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--text);
  background: color-mix(in oklab, var(--text) 5%, transparent);
  max-width: 100%;
  word-wrap: break-word;
}
.sv-msg-system .sv-msg-body{
  background: transparent;
  color: var(--text-dimmer);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 2px 0;
}
.sv-msg-user .sv-msg-body{
  background: color-mix(in oklab, var(--accent) 12%, transparent);
}
.sv-msg-assistant .sv-msg-body{
  background: color-mix(in oklab, var(--text) 4%, transparent);
}

.sv-msg-typing{
  display: inline-flex; gap: 4px;
  align-items: center;
  padding: 4px 6px;
}
.sv-msg-typing span{
  width: 6px; height: 6px; border-radius: 50%;
  background: color-mix(in oklab, var(--text) 35%, transparent);
  animation: typingBounce 1.2s infinite;
}
.sv-msg-typing span:nth-child(2){ animation-delay: .15s; }
.sv-msg-typing span:nth-child(3){ animation-delay: .3s; }
@keyframes typingBounce{
  0%, 60%, 100%{ transform: translateY(0); opacity: .4; }
  30%{ transform: translateY(-4px); opacity: 1; }
}

.sv-chat-suggestions{
  display: flex; gap: 6px; flex-wrap: wrap;
}
.sv-chip{
  padding: 5px 11px;
  border-radius: 999px;
  border: 1px solid var(--line-3);
  background: transparent;
  font-family: var(--sans);
  font-size: 11px;
  color: var(--text-dim);
  cursor: pointer;
  transition: color .15s, border-color .15s, background .15s;
}
.sv-chip:hover{
  color: var(--accent);
  border-color: var(--accent);
  background: color-mix(in oklab, var(--accent) 8%, transparent);
}
.sv-chip:disabled{ opacity: .4; cursor: not-allowed; }

.sv-chat-form{
  display: flex; gap: 6px;
  align-items: center;
  padding: 4px 4px 4px 14px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--text) 4%, transparent);
  border: 1px solid var(--line-3);
}
.sv-chat-form:focus-within{
  border-color: var(--accent);
}
.sv-chat-input{
  flex: 1; min-width: 0;
  border: none; background: transparent;
  outline: none;
  font-family: var(--sans);
  font-size: 12.5px;
  color: var(--text);
  padding: 6px 0;
}
.sv-chat-input::placeholder{ color: var(--text-dimmer); }
.sv-chat-send{
  width: 30px; height: 30px;
  border-radius: 50%;
  border: none;
  background: var(--accent);
  color: var(--ink);
  display: grid; place-items: center;
  cursor: pointer;
  transition: opacity .15s, transform .15s;
  flex-shrink: 0;
}
.sv-chat-send:not(:disabled):hover{ transform: scale(1.05); }
.sv-chat-send:disabled{ opacity: .4; cursor: not-allowed; }
.sv-chat-send svg{ display: block; }

.sv-model-list{ display: flex; flex-direction: column; gap: 8px; }
.sv-model-row{
  display: grid;
  grid-template-columns: 8px 1fr auto 1fr auto auto;
  align-items: center;
  column-gap: 10px;
  padding: 10px 12px;
  border-radius: 8px;
  background: color-mix(in oklab, var(--text) 3%, transparent);
}
.sv-model-row > .sv-status-dot{ grid-row: 1; grid-column: 1; align-self: center; }
.sv-model-name{
  grid-row: 1; grid-column: 2;
  font-family: var(--mono); font-size: 11px;
  font-weight: 600; color: var(--text);
}
.sv-model-acc{
  grid-row: 1; grid-column: 4;
  font-family: var(--mono); font-size: 11px; font-weight: 700;
  color: var(--accent);
  text-align: right; min-width: 44px;
}
.sv-model-type{
  grid-row: 1; grid-column: 3;
  font-size: 9px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--text-dimmer);
}
.sv-model-bar{ grid-row: 1; grid-column: 4; min-width: 80px; }
.sv-model-row .sv-pill{ display: inline-flex; }

.sv-console{
  display: flex; flex-direction: column; gap: 4px;
  padding: 10px;
  border-radius: 8px;
  background: color-mix(in oklab, var(--text) 6%, transparent);
  border: 1px solid color-mix(in oklab, var(--text) 8%, transparent);
  font-family: var(--mono);
  flex: 1;
}
.sv-console-line{
  display: grid;
  grid-template-columns: 60px 1fr 70px 48px;
  align-items: center; gap: 8px;
  font-size: 10.5px;
}
.sv-c-t{ color: var(--accent); letter-spacing: .12em; font-weight: 700; }
.sv-c-k{ color: var(--text); }
.sv-c-bar{
  height: 4px; border-radius: 4px;
  background: color-mix(in oklab, var(--text) 10%, transparent);
  overflow: hidden;
}
.sv-c-fill{
  display: block; height: 100%;
  background: var(--accent);
  transition: width .4s;
}
.sv-c-v{
  text-align: right; font-weight: 600;
  font-size: 10px; letter-spacing: .04em;
}
.sv-c-v.ok { color: var(--accent); }
.sv-c-v.warn { color: #E8A33A; }

/* === SECURITY widgets === */

.sv-cam-grid{
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  flex: 1;
}
.sv-cam-grid-lg{
  grid-template-columns: 1fr 1fr;
  height: 100%;
}
.sv-cam{
  position: relative;
  background: #0a0e1a;
  border: 1px solid color-mix(in oklab, var(--text) 12%, transparent);
  border-radius: 8px;
  overflow: hidden;
  aspect-ratio: 16/10;
  font-family: var(--mono);
}
.sv-cam.hot{ border-color: var(--accent); box-shadow: 0 0 0 1px color-mix(in oklab, var(--accent) 30%, transparent); }
.sv-cam-img{
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  filter: grayscale(.6) contrast(1.05) brightness(.85);
}
.sv-cam-tint{
  position: absolute; inset: 0;
  background: linear-gradient(180deg,
    rgba(10,14,26,.55) 0%,
    rgba(10,14,26,.18) 20%,
    rgba(10,14,26,.18) 80%,
    rgba(10,14,26,.65) 100%);
}
.sv-cam-noise{
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(0deg,
      rgba(255,255,255,.05) 0 1px,
      transparent 1px 3px);
  opacity: .7;
  mix-blend-mode: overlay;
}
.sv-cam-head{
  position: absolute; top: 0; left: 0; right: 0;
  display: flex; align-items: center; gap: 6px;
  padding: 5px 8px;
  font-size: 9px;
  color: #fff;
  letter-spacing: .12em;
  text-shadow: 0 1px 2px rgba(0,0,0,.6);
}
.sv-cam-rec{
  width: 5px; height: 5px; border-radius: 50%;
  background: #FF5E6C; box-shadow: 0 0 6px #FF5E6C;
  animation: pulse 1.2s infinite;
}
.sv-cam-id{ font-weight: 700; }
.sv-cam-time{ margin-left: auto; color: rgba(255,255,255,.75); font-size: 8.5px; }
.sv-cam-box{
  position: absolute;
  width: 40px; height: 50px;
  border: 1.5px dashed var(--accent);
  border-radius: 2px;
  transition: left .9s, top .9s;
}
.sv-cam-box span{
  position: absolute; top: -12px; left: 0;
  font-size: 8.5px; font-weight: 700;
  color: var(--accent);
  background: var(--panel-solid);
  padding: 0 4px; border-radius: 2px;
}
.sv-cam-foot{
  position: absolute; bottom: 5px; left: 8px; right: 8px;
  font-size: 8.5px;
  color: rgba(255,255,255,.8); letter-spacing: .12em;
  display: flex; justify-content: space-between;
  text-shadow: 0 1px 2px rgba(0,0,0,.6);
}

.sv-radar{
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
  max-height: 160px;
  margin: 0 auto;
}
.sv-radar-svg{
  width: 100%; height: 100%;
}
@keyframes radarSpin{ to{ transform: rotate(360deg); } }
.sv-perim-status{ text-align: center; margin-top: 6px; }
.sv-perim-big{
  font-size: 16px; font-weight: 700; color: var(--accent);
  letter-spacing: .04em;
}
.sv-perim-sub{
  font-family: var(--mono); font-size: 9px;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-dimmer); margin-top: 2px;
}

.sv-event-list{ display: flex; flex-direction: column; gap: 4px; }
.sv-event{
  display: grid;
  grid-template-columns: 70px 70px 1fr;
  align-items: center; gap: 10px;
  font-family: var(--mono);
  font-size: 10px;
  padding: 5px 10px;
  border-radius: 6px;
  background: color-mix(in oklab, var(--text) 3%, transparent);
  border-left: 2px solid var(--accent);
}
.sv-event-ok    { border-left-color: var(--accent); }
.sv-event-warn  { border-left-color: #E8A33A; }
.sv-event-crit  { border-left-color: #FF5E6C; background: color-mix(in oklab, #FF5E6C 6%, transparent); }
.sv-e-t   { color: var(--text-dimmer); }
.sv-e-cat { color: var(--accent); font-weight: 700; letter-spacing: .12em; }
.sv-event-warn .sv-e-cat { color: #E8A33A; }
.sv-event-crit .sv-e-cat { color: #FF5E6C; }
.sv-e-msg { color: var(--text); }

/* === IT widgets === */

.sv-svc-grid{
  display: grid; grid-template-columns: repeat(8, 1fr);
  gap: 4px;
}
.sv-svc-grid-lg{
  grid-template-columns: repeat(6, 1fr);
  gap: 8px;
}
.sv-svc-grid-lg .sv-svc{
  padding: 10px 12px;
  font-size: 11px;
}
.sv-svc{
  display: flex; align-items: center; gap: 5px;
  padding: 5px 7px;
  border-radius: 6px;
  background: color-mix(in oklab, var(--text) 4%, transparent);
  border: 1px solid color-mix(in oklab, var(--text) 8%, transparent);
  font-size: 9.5px;
  font-family: var(--mono);
  overflow: hidden;
}
.sv-svc-dot{
  width: 6px; height: 6px; border-radius: 50%;
  flex-shrink: 0;
}
.sv-svc-name{
  color: var(--text-dim);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sv-svc-ok   .sv-svc-dot{ background: var(--accent); box-shadow: 0 0 6px var(--accent); }
.sv-svc-warn .sv-svc-dot{ background: #E8A33A; box-shadow: 0 0 6px #E8A33A; }
.sv-svc-warn { border-color: color-mix(in oklab, #E8A33A 35%, transparent); }
.sv-svc-crit .sv-svc-dot{ background: #FF5E6C; box-shadow: 0 0 8px #FF5E6C; animation: pulse 1s infinite; }
.sv-svc-crit { border-color: color-mix(in oklab, #FF5E6C 45%, transparent); background: color-mix(in oklab, #FF5E6C 6%, transparent); }

.sv-net-stats{
  display: flex; justify-content: space-between;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text-dim);
  letter-spacing: .04em;
  margin-top: 4px;
}
.sv-net-stats b{ color: var(--accent); font-weight: 700; }

.sv-ticket-list{ display: flex; flex-direction: column; gap: 5px; }
.sv-ticket{
  display: grid;
  grid-template-columns: 32px 50px 1fr auto;
  align-items: center; gap: 10px;
  padding: 7px 10px;
  border-radius: 7px;
  background: color-mix(in oklab, var(--text) 3%, transparent);
  font-size: 11px;
}
.sv-pri{
  font-family: var(--mono); font-size: 9px;
  letter-spacing: .12em; font-weight: 700;
  padding: 3px 6px; border-radius: 4px;
  text-align: center;
}
.sv-pri-p1{ color: #FF5E6C; background: color-mix(in oklab, #FF5E6C 14%, transparent); }
.sv-pri-p2{ color: #E8A33A; background: color-mix(in oklab, #E8A33A 14%, transparent); }
.sv-pri-p3{ color: var(--text-dim); background: color-mix(in oklab, var(--text) 8%, transparent); }
.sv-t-id{ font-family: var(--mono); color: var(--accent); font-weight: 600; font-size: 10px; }
.sv-t-msg{ color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sv-t-age{ font-family: var(--mono); font-size: 10px; color: var(--text-dimmer); }

/* Don't ride the old hub-svg sizing for HTML vizes */
.hero-viz-stage > .sv-root{ inset: 44px 14px 14px 14px; }

/* ============ Reveal (delays) ============ */
.reveal.d-1{ transition-delay: .1s;}
.reveal.d-2{ transition-delay: .2s;}
.reveal.d-3{ transition-delay: .3s;}
.reveal.d-4{ transition-delay: .4s;}

/* Accent hue modifiers */
[data-accent="blue"]{
  --accent: #3D5286;
  --accent-glow: rgba(61,82,134,0.45);
}
[data-theme="dark"][data-accent="blue"]{
  /* Lighter brand blue for legibility against dark ink */
  --accent: #7E97D1;
  --accent-glow: rgba(126,151,209,0.50);
}
[data-accent="lime"]{
  --accent: #8BC34A;
  --accent-glow: rgba(139,195,74,0.45);
}
[data-accent="cyan"]{
  --accent: #4AE0D0;
  --accent-glow: rgba(74,224,208,0.45);
}

/* ============ Umbrella overview ============ */
.umbrella-head{ text-align: center; margin-bottom: 64px; max-width: 760px; margin-left: auto; margin-right: auto; }
.umbrella-head .section-eyebrow{ margin: 0 auto; }
.umbrella-head .section-lede{ margin: 0 auto; }

.umbrella-grid{
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 20px;
}
.umb-card{ grid-column: span 2; }
.umb-card:nth-child(4),
.umb-card:nth-child(5){ grid-column: span 3; }

@media (max-width: 1100px){
  .umbrella-grid{ grid-template-columns: repeat(2, 1fr); }
  .umb-card,
  .umb-card:nth-child(4),
  .umb-card:nth-child(5){ grid-column: span 1; }
}
@media (max-width: 640px){
  .umbrella-grid{ grid-template-columns: 1fr; }
}

.umb-card{
  position: relative;
  padding: 18px 18px 16px;
  background: var(--panel);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid var(--line-3);
  border-radius: var(--radius);
  border-top: 3px solid var(--d-accent);
  overflow: hidden;
  transition: transform .35s cubic-bezier(0.2,0.7,0,1),
              border-color .3s, box-shadow .3s;
  display: flex; flex-direction: column;
  min-height: 280px;
}
.umb-card:hover{
  transform: translateY(-6px);
  border-color: var(--d-accent);
  box-shadow: 0 24px 50px -24px rgba(var(--d-accent-rgb), .50);
}
.umb-num{
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .18em; text-transform: uppercase;
  font-weight: 600; color: var(--d-accent);
  display: inline-flex; align-items: center; gap: 8px;
  margin-bottom: 2px;
}
.umb-num::before{
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--d-accent);
  box-shadow: 0 0 10px rgb(var(--d-accent-rgb));
}
.umb-name{
  font-size: 17px; font-weight: 600; line-height: 1.12;
  margin: 4px 0 4px; color: var(--text);
  letter-spacing: -0.01em;
}
.umb-tag{
  font-size: 11.5px; line-height: 1.45; color: var(--text-dim);
  margin: 0 0 10px; max-width: 38ch;
  font-weight: 400;
}
.umb-viz{
  position: relative;
  width: 100%;
  flex: 1;
  min-height: 100px;
  margin-bottom: 10px;
  border-radius: 8px;
  background:
    linear-gradient(180deg,
      rgba(var(--d-accent-rgb), .07),
      rgba(var(--d-accent-rgb), .02));
  border: 1px solid rgba(var(--d-accent-rgb), .14);
  overflow: hidden;
}
.umb-viz svg{ position: absolute; inset: 0; width: 100%; height: 100%; }
.umb-cta{
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: .16em; text-transform: uppercase;
  font-weight: 600; color: var(--d-accent);
  transition: gap .25s;
  margin-top: auto;
}
.umb-card:hover .umb-cta{ gap: 14px; }
.umb-cta::after{
  content: ""; flex: 1; height: 1px;
  background: linear-gradient(90deg, currentColor, transparent);
  opacity: .35;
  margin-left: 8px;
}
.umb-glow{
  position: absolute; right: -80px; top: -80px;
  width: 220px; height: 220px; border-radius: 50%;
  background: rgb(var(--d-accent-rgb));
  filter: blur(70px); opacity: 0;
  transition: opacity .45s;
  pointer-events: none;
}
.umb-card:hover .umb-glow{ opacity: .28; }

/* ===== Division visualizations ===== */
.viz-stroke{ stroke: var(--d-accent); fill: none; }
.viz-fill{ fill: var(--d-accent); }
.viz-dim{ stroke: rgba(var(--d-accent-rgb), .25); fill: none; }
.viz-bg{ fill: rgba(var(--d-accent-rgb), .08); }

/* Health — ECG */
.viz-ecg{
  stroke: var(--d-accent); stroke-width: 1.6; fill: none;
  stroke-linecap: round; stroke-linejoin: round;
  stroke-dasharray: 400;
  stroke-dashoffset: 400;
  animation: ecgFlow 3.2s linear infinite;
  filter: drop-shadow(0 0 6px rgba(var(--d-accent-rgb), .55));
}
@keyframes ecgFlow{
  to { stroke-dashoffset: -400; }
}
.viz-grid line{ stroke: rgba(var(--d-accent-rgb), .12); stroke-width: 1; }
.viz-pulse{
  fill: var(--d-accent);
  filter: drop-shadow(0 0 6px rgb(var(--d-accent-rgb)));
  animation: vizPulse 1.6s ease-in-out infinite;
}
@keyframes vizPulse{
  0%, 100%{ opacity: 1; transform: scale(1); }
  50%{ opacity: .55; transform: scale(.7); }
}

/* Education — campus dots/blocks */
.viz-room{
  fill: rgba(var(--d-accent-rgb), .12);
  stroke: rgba(var(--d-accent-rgb), .4);
  stroke-width: 1;
}
.viz-room.lit{
  animation: roomLit 2.4s ease-in-out infinite;
}
@keyframes roomLit{
  0%, 100%{ fill: rgba(var(--d-accent-rgb), .12); }
  50%{ fill: rgba(var(--d-accent-rgb), .45); }
}
.viz-room.lit.d2{ animation-delay: .4s; }
.viz-room.lit.d3{ animation-delay: .9s; }
.viz-room.lit.d4{ animation-delay: 1.3s; }

/* AI — neural net */
.viz-edge{
  stroke: rgba(var(--d-accent-rgb), .25);
  stroke-width: 1; fill: none;
}
.viz-edge.active{
  stroke: var(--d-accent);
  stroke-width: 1.4;
  stroke-dasharray: 80;
  stroke-dashoffset: 80;
  animation: edgeFlow 2.4s linear infinite;
  filter: drop-shadow(0 0 4px rgb(var(--d-accent-rgb)));
}
@keyframes edgeFlow{
  to{ stroke-dashoffset: -80; }
}
.viz-edge.active.d2{ animation-delay: .6s; }
.viz-edge.active.d3{ animation-delay: 1.2s; }
.viz-edge.active.d4{ animation-delay: 1.8s; }
.viz-node{ fill: var(--panel-solid); stroke: rgba(var(--d-accent-rgb), .5); stroke-width: 1.4; }
.viz-node.hot{
  fill: var(--d-accent);
  filter: drop-shadow(0 0 6px rgb(var(--d-accent-rgb)));
  animation: nodeHot 2.2s ease-in-out infinite;
}
@keyframes nodeHot{
  0%, 100%{ opacity: 1; }
  50%{ opacity: .55; }
}
.viz-node.hot.d2{ animation-delay: .5s; }
.viz-node.hot.d3{ animation-delay: 1s; }

/* Security — radar sweep */
.viz-radar-ring{
  fill: none; stroke: rgba(var(--d-accent-rgb), .30);
  stroke-width: 1;
}
.viz-radar-sweep{
  transform-origin: center;
  animation: radarSpin 4s linear infinite;
}
@keyframes radarSpin{
  to{ transform: rotate(360deg); }
}
.viz-blip{
  fill: var(--d-accent);
  filter: drop-shadow(0 0 5px rgb(var(--d-accent-rgb)));
  animation: blipPulse 2s ease-in-out infinite;
}
@keyframes blipPulse{
  0%, 100%{ opacity: .9; }
  50%{ opacity: .25; }
}
.viz-blip.d2{ animation-delay: .7s; }
.viz-blip.d3{ animation-delay: 1.3s; }

/* IT — server stack + flow */
.viz-rack{
  fill: rgba(var(--d-accent-rgb), .06);
  stroke: rgba(var(--d-accent-rgb), .35);
  stroke-width: 1;
}
.viz-led{
  fill: var(--d-accent);
  filter: drop-shadow(0 0 3px rgb(var(--d-accent-rgb)));
  animation: ledBlink 1.6s ease-in-out infinite;
}
@keyframes ledBlink{
  0%, 100%{ opacity: 1; }
  50%{ opacity: .25; }
}
.viz-led.d2{ animation-delay: .2s; }
.viz-led.d3{ animation-delay: .5s; }
.viz-led.d4{ animation-delay: .8s; }
.viz-led.d5{ animation-delay: 1.1s; }
.viz-flow{
  stroke: var(--d-accent); stroke-width: 1.4; fill: none;
  stroke-dasharray: 4 4;
  animation: flowDash 1.4s linear infinite;
  filter: drop-shadow(0 0 4px rgb(var(--d-accent-rgb)));
}
@keyframes flowDash{
  to{ stroke-dashoffset: -16; }
}

/* ============ Division deep-dive sections ============ */
.division-section{
  padding: 0; margin: 0;
  position: relative;
}

.div-banner{
  position: relative; overflow: hidden;
  min-height: 460px;
  display: flex; align-items: center;
  padding: 64px clamp(24px, 5vw, 72px) 64px;
}
.div-banner-photo{
  position: absolute; inset: 0; z-index: 0;
  background-size: cover; background-position: center;
  filter: blur(2px) brightness(.45) saturate(.9);
  transform: scale(1.06);
  transition: filter .5s, transform 4s ease-out;
}
.division-section:hover .div-banner-photo{
  filter: blur(1px) brightness(.5) saturate(1);
  transform: scale(1.08);
}
.div-banner-overlay{
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(135deg,
      rgba(var(--d-accent-rgb), .35) 0%,
      rgba(10, 14, 26, .85) 60%,
      rgba(10, 14, 26, .92) 100%);
}
[data-theme="light"] .div-banner-overlay{
  background:
    linear-gradient(135deg,
      rgba(var(--d-accent-rgb), .35) 0%,
      rgba(15, 21, 38, .85) 60%,
      rgba(15, 21, 38, .92) 100%);
}
.div-banner-inner{
  position: relative; z-index: 2;
  width: 100%;
  max-width: 1320px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 56px;
  align-items: center;
}
@media (max-width: 900px){
  .div-banner-inner{ grid-template-columns: 1fr; gap: 36px; }
}
.div-banner-copy{ min-width: 0; }

.div-banner-viz{
  position: relative;
  width: 100%;
  aspect-ratio: 5 / 4;
  max-width: 420px;
  margin-left: auto;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg,
      rgba(var(--d-accent-rgb), .14),
      rgba(var(--d-accent-rgb), .04));
  border: 1px solid rgba(var(--d-accent-rgb), .35);
  overflow: hidden;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow:
    0 30px 60px -30px rgba(var(--d-accent-rgb), .50),
    inset 0 1px 0 rgba(255,255,255,.06);
}
@media (max-width: 900px){
  .div-banner-viz{ margin: 0 auto; max-width: 440px; }
}
.div-banner-viz .viz-chrome{
  position: absolute; top: 14px; left: 16px; right: 16px; z-index: 2;
  display: flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 10px;
  color: rgba(255,255,255,.78); letter-spacing: .14em; text-transform: uppercase;
}
.div-banner-viz .viz-chrome .pulse-dot{
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--d-accent);
  box-shadow: 0 0 10px var(--d-accent);
  animation: pulse 1.6s infinite;
}
.div-banner-viz .viz-chrome .viz-id{
  margin-left: auto; color: rgba(255,255,255,.55);
}
.div-banner-viz .viz-hud{
  position: absolute; left: 16px; right: 16px; bottom: 16px; z-index: 2;
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px;
}
.div-banner-viz .viz-hud .hud{
  padding: 8px 10px;
  border-radius: 8px;
  background: rgba(10,14,26,.55);
  border: 1px solid rgba(var(--d-accent-rgb), .25);
  backdrop-filter: blur(8px);
}
.div-banner-viz .viz-hud .hud .lbl{
  font-family: var(--mono); font-size: 8.5px;
  letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,255,255,.55); margin-bottom: 2px;
}
.div-banner-viz .viz-hud .hud .val{
  font-size: 13px; font-weight: 600; color: #fff;
  font-variant-numeric: tabular-nums;
}
.div-banner-viz .viz-hud .hud .val .accent{ color: var(--d-accent); }
.div-banner-viz .viz-canvas{
  position: absolute; inset: 44px 16px 70px;
}
.div-banner-viz .viz-canvas svg{
  position: absolute; inset: 0; width: 100%; height: 100%;
}
.div-eyebrow{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 14px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,255,255,.92); font-weight: 500;
  backdrop-filter: blur(8px);
}
.div-eyebrow .dot{
  width: 6px; height: 6px; border-radius: 50%;
  box-shadow: 0 0 10px var(--d-accent);
}
.div-title{
  margin: 22px 0 18px;
  font-size: clamp(34px, 4.6vw, 56px);
  font-weight: 600; line-height: 1.04; letter-spacing: -0.02em;
  color: #fff; max-width: 18ch;
  text-wrap: balance;
}
.div-desc{
  font-size: clamp(15px, 1.2vw, 17px);
  line-height: 1.65; color: rgba(255,255,255,.78);
  max-width: 64ch; margin-bottom: 32px;
  text-wrap: pretty;
}
.div-ctas{ display: flex; gap: 14px; flex-wrap: wrap; }

.div-services{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  padding: 48px clamp(24px, 5vw, 72px) 64px;
  max-width: 1320px; margin: 0 auto;
}
@media (max-width: 900px){ .div-services{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .div-services{ grid-template-columns: 1fr; } }

.div-svc{
  background: var(--panel);
  backdrop-filter: blur(12px);
  border: 1px solid var(--line-3);
  border-top: 3px solid var(--d-accent);
  border-radius: var(--radius);
  padding: 26px 24px;
  position: relative; overflow: hidden;
  transition: transform .3s cubic-bezier(0.2,0.7,0,1), box-shadow .3s, border-color .3s;
}
.div-svc:hover{
  transform: translateY(-4px);
  box-shadow: 0 20px 40px -20px rgba(var(--d-accent-rgb), .45);
}
.div-svc-icon{
  width: 44px; height: 44px; border-radius: 10px;
  display: grid; place-items: center;
  background: rgba(var(--d-accent-rgb), .12);
  color: var(--d-accent);
  margin-bottom: 14px;
}
.div-svc h4{
  margin: 0 0 8px;
  font-size: 16px; font-weight: 600; letter-spacing: -0.005em;
  color: var(--text);
}
.div-svc p{
  margin: 0 0 14px;
  font-size: 13.5px; line-height: 1.6; color: var(--text-dim);
}
.div-svc-tags{
  display: flex; flex-wrap: wrap; gap: 6px;
}
.div-svc-tags span{
  padding: 3px 9px; border-radius: 4px;
  background: rgba(var(--d-accent-rgb), .10);
  color: var(--d-accent);
  border: 1px solid rgba(var(--d-accent-rgb), .25);
  font-size: 10px; letter-spacing: .08em; font-weight: 500;
}

/* ============ Helpdesk Support Portal ============ */
.helpdesk{
  padding-top: 80px;
  padding-bottom: 80px;
}
.helpdesk-grid{
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: 64px;
  align-items: center;
}
@media (max-width: 1080px){
  .helpdesk-grid{ grid-template-columns: 1fr; gap: 48px; }
}

.helpdesk-copy h2{ margin-top: 22px; }

.helpdesk-features{
  list-style: none; padding: 0;
  margin: 32px 0 36px;
  display: flex; flex-direction: column;
  gap: 18px;
}
.helpdesk-features li{
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 14px;
  align-items: start;
}
.helpdesk-bullet{
  width: 24px; height: 24px;
  border-radius: 50%;
  display: grid; place-items: center;
  background: color-mix(in oklab, var(--accent) 16%, transparent);
  color: var(--accent);
  border: 1px solid color-mix(in oklab, var(--accent) 40%, transparent);
  flex-shrink: 0;
}
.helpdesk-features h4{
  margin: 0 0 4px;
  font-size: 16px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.005em;
}
.helpdesk-features p{
  margin: 0;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--text-dim);
  max-width: 52ch;
}

.helpdesk-ctas{ display: flex; gap: 12px; flex-wrap: wrap; }

/* ------ Browser window mock ------ */
.hd-window{
  border-radius: 14px;
  background: var(--panel-solid);
  border: 1px solid var(--line-3);
  overflow: hidden;
  box-shadow:
    0 50px 90px -40px rgba(10,14,26,.5),
    inset 0 1px 0 rgba(255,255,255,.05);
}
[data-theme="light"] .hd-window{
  box-shadow:
    0 40px 80px -30px rgba(61,82,134,.18),
    inset 0 1px 0 rgba(255,255,255,.9);
}
.hd-titlebar{
  display: flex; align-items: center; gap: 14px;
  padding: 10px 14px;
  background: color-mix(in oklab, var(--text) 6%, var(--panel-solid));
  border-bottom: 1px solid var(--line-2);
}
.hd-dots{ display: flex; gap: 6px; flex-shrink: 0; }
.hd-dot{ width: 10px; height: 10px; border-radius: 50%; }
.hd-dot.r{ background: #FF5E6C; }
.hd-dot.y{ background: #F5A524; }
.hd-dot.g{ background: #34D2C7; }
.hd-url{
  flex: 1;
  display: flex; align-items: center; gap: 6px;
  padding: 6px 12px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--text) 4%, transparent);
  border: 1px solid var(--line-2);
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text);
  letter-spacing: .01em;
}
.hd-url-lock{
  color: var(--accent);
  display: flex; align-items: center;
}
.hd-url-path{ color: var(--text-dim); }

.hd-body{
  display: grid;
  grid-template-columns: 160px 1fr;
  min-height: 380px;
}
.hd-side{
  background: color-mix(in oklab, var(--text) 3%, var(--panel-solid));
  border-right: 1px solid var(--line-2);
  padding: 14px 10px;
  display: flex; flex-direction: column;
  gap: 4px;
}
.hd-side-head{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--text-dimmer);
  padding: 6px 10px 10px;
  font-weight: 600;
}
.hd-side-item{
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px;
  border-radius: 7px;
  font-size: 12.5px;
  color: var(--text-dim);
  cursor: pointer;
  transition: background .15s, color .15s;
}
.hd-side-item:hover{
  background: color-mix(in oklab, var(--accent) 8%, transparent);
  color: var(--text);
}
.hd-side-item.active{
  background: color-mix(in oklab, var(--accent) 14%, transparent);
  color: var(--accent);
  font-weight: 500;
}
.hd-side-ico{
  font-size: 11px;
  width: 14px; text-align: center;
  color: inherit;
  opacity: .85;
}
.hd-side-badge{
  margin-left: auto;
  font-family: var(--mono);
  font-size: 10px;
  background: var(--accent);
  color: var(--ink);
  padding: 1px 7px;
  border-radius: 999px;
  font-weight: 700;
}
.hd-side-foot{
  margin-top: auto;
  padding: 10px;
  border-top: 1px solid var(--line-2);
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .04em;
}
.hd-sla{ color: var(--text-dimmer); text-transform: uppercase; letter-spacing: .12em; }
.hd-sla-val{ color: var(--accent); font-weight: 700; }

.hd-main{
  display: flex; flex-direction: column;
  min-height: 0;
}
.hd-toolbar{
  display: flex; align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line-2);
  gap: 12px;
}
.hd-tabs{ display: flex; gap: 4px; }
.hd-tab{
  border: 0; background: transparent;
  font-family: var(--sans);
  font-size: 12px;
  color: var(--text-dim);
  padding: 6px 12px;
  border-radius: 7px;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.hd-tab:hover{ color: var(--text); background: color-mix(in oklab, var(--text) 4%, transparent); }
.hd-tab.active{
  background: color-mix(in oklab, var(--accent) 12%, transparent);
  color: var(--accent);
  font-weight: 500;
}
.hd-new{
  margin-left: auto;
  border: 0;
  background: var(--accent);
  color: var(--ink);
  padding: 7px 14px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  transition: transform .15s;
}
.hd-new:hover{ transform: translateY(-1px); }
.hd-new-plus{
  width: 14px; height: 14px; border-radius: 50%;
  background: rgba(255,255,255,.25);
  display: grid; place-items: center;
  font-size: 14px; line-height: 1;
}

.hd-table{
  flex: 1; min-height: 0;
  overflow: hidden;
}
.hd-table-head, .hd-row{
  display: grid;
  grid-template-columns: 120px 1.2fr 1.8fr 90px 50px 110px;
  gap: 10px;
  align-items: center;
  padding: 10px 16px;
}
.hd-table-head{
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--text-dimmer);
  font-weight: 600;
  border-bottom: 1px solid var(--line-2);
}
.hd-row{
  font-size: 11.5px;
  color: var(--text);
  border-bottom: 1px solid var(--line-2);
}
.hd-row:last-child{ border-bottom: 0; }

.hd-id{ display: flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 11px; }
.hd-pri{
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .1em;
  font-weight: 700;
  padding: 2px 5px;
  border-radius: 3px;
  text-align: center;
}
.hd-pri-p1{ color: #FF5E6C; background: color-mix(in oklab, #FF5E6C 12%, transparent); }
.hd-pri-p2{ color: #E8A33A; background: color-mix(in oklab, #E8A33A 12%, transparent); }
.hd-pri-p3{ color: var(--text-dim); background: color-mix(in oklab, var(--text) 6%, transparent); }
.hd-site{ display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.hd-cat{ font-family: var(--mono); font-size: 9.5px; color: var(--accent); letter-spacing: .08em; text-transform: uppercase; font-weight: 600; }
.hd-loc{ font-size: 11.5px; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hd-msg{ color: var(--text-dim); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hd-owner, .hd-age{ font-family: var(--mono); font-size: 10.5px; color: var(--text-dim); }
.hd-status{
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .14em;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 999px;
  text-align: center;
  white-space: nowrap;
}
.hd-status-in-progress{ color: var(--accent); background: color-mix(in oklab, var(--accent) 14%, transparent); }
.hd-status-assigned{ color: var(--text); background: color-mix(in oklab, var(--text) 8%, transparent); }
.hd-status-queued{ color: var(--text-dim); background: color-mix(in oklab, var(--text) 6%, transparent); }
.hd-status-on-site{ color: #E8A33A; background: color-mix(in oklab, #E8A33A 12%, transparent); }

.hd-foot{
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 16px;
  border-top: 1px solid var(--line-2);
  background: color-mix(in oklab, var(--text) 3%, var(--panel-solid));
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text-dimmer);
  letter-spacing: .08em;
}
.hd-foot-live{ display: inline-flex; align-items: center; gap: 6px; color: var(--accent); }
.hd-live-dot{
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 6px var(--accent);
  animation: pulse 1.6s infinite;
}

/* Helpdesk mock: mobile */
@media (max-width: 640px){
  /* Drop sidebar, single column */
  .hd-body{ grid-template-columns: 1fr; }
  .hd-side{ display: none; }
  /* Toolbar: wrap tabs + hide new-ticket btn */
  .hd-toolbar{ flex-wrap: wrap; gap: 8px; padding: 8px 12px; }
  .hd-new{ display: none; }
  /* Table: show only Ticket / Issue / Status (hide Site, Owner, Age) */
  .hd-table-head, .hd-row{
    grid-template-columns: 86px 1fr 76px;
    gap: 6px;
    padding: 8px 12px;
  }
  .hd-table-head span:nth-child(2),
  .hd-table-head span:nth-child(4),
  .hd-table-head span:nth-child(5){ display: none; }
  .hd-row .hd-site,
  .hd-row .hd-owner,
  .hd-row .hd-age{ display: none; }
  .hd-row .hd-msg{
    white-space: normal;
    overflow: visible;
    font-size: 11px;
  }
}

/* ============ Final CTA strip ============ */
.final-cta{
  padding: 80px clamp(24px, 5vw, 72px);
}
.final-cta-inner{
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px;
  align-items: center;
  padding: 56px;
  border-radius: var(--radius-lg);
  background: var(--panel);
  backdrop-filter: blur(16px);
  border: 1px solid var(--line-3);
  position: relative; overflow: hidden;
  box-shadow:
    0 40px 80px -40px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.05);
}
[data-theme="light"] .final-cta-inner{
  box-shadow:
    0 30px 60px -30px rgba(61,82,134,.25),
    inset 0 1px 0 rgba(255,255,255,.9);
}
.final-cta-inner::before{
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(500px 300px at 100% 0%, var(--accent-glow), transparent);
  opacity: .25;
}
.final-cta-inner .section-eyebrow{ margin-bottom: 8px; }
.final-cta-inner .section-title{
  font-size: clamp(28px, 3vw, 42px);
  margin: 0 0 14px;
}
.final-cta-inner .section-lede{ margin: 0; }
.final-cta-actions{
  display: flex; flex-direction: column; gap: 12px;
  position: relative; z-index: 1;
}
.final-cta-actions .cta-btn{ justify-content: center; padding: 14px 22px; }
@media (max-width: 760px){
  .final-cta-inner{ grid-template-columns: 1fr; padding: 36px; gap: 28px; }
}

/* ============================================================
   Zoho Sites integration overrides
   ============================================================ */

/* Hide ALL Zoho native elements on homepage (React SPA takes over entirely) */
body.totekko-home-page [data-headercontainer],
body.totekko-home-page .theme-footer-area,
body.totekko-home-page .theme-content-area,
body.totekko-home-page [data-theme-content-container],
body.totekko-home-page [data-themebanner],
body.totekko-home-page .theme-skip-to-needed-content,
body.totekko-home-page [data-zs-mobile-content-wrap],
body.totekko-home-page [data-megamenu-content-container],
body.totekko-home-page .theme-breadcrumbs,
body.totekko-home-page .zpmm-backdrop,
body.totekko-home-page .zpmm-backdrop-enabled,
body.totekko-home-page [data-zs-home="false"] { display: none !important; }

/* Zoho nav: reset list styles injected by navi() */
.topnav-links ul { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; gap: 4px; }
.topnav-links li { margin: 0; padding: 0; }
.topnav-links .theme-sub-li-menu > svg,
.topnav-links [class*="theme-submenu"] > svg { display: none; }

/* Scroll-progress bar */
.scroll-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 2px; z-index: 9999;
  background: var(--accent); transform: scaleX(0); transform-origin: left;
  transition: transform .1s linear;
}
