
/* =================================================================
   ARCHIV3 — Swiss Precision, light edition
   Design language: cool paper canvas · hairline structure ·
   one restrained petrol accent · security-first · SaaS-ready
   ================================================================= */
:root{
  /* ---- Surfaces (cool paper, deliberate L-staircase: page→band→card) ---- */
  --bg:        #F4F7FA;   /* page — cool near-white, L≈97 */
  --bg-2:      #FAFCFE;   /* raised page / nav glass base */
  --bg-alt:    #E8EEF4;   /* alternating band — bluish cool gray, L≈93.5, hue ~213 */
  --paper:     #FFFFFF;   /* cards — pure white, top plane */
  --paper-2:   #EDF1F6;   /* sunken / fills */
  --paper-3:   #E2E9F0;   /* deepest fill */

  /* ---- Hairlines (cool slate, +1 step so rules hold on the band) ---- */
  --line:   rgba(15,30,55,0.10);
  --line-2: rgba(15,30,55,0.15);
  --line-3: rgba(15,30,55,0.26);

  /* ---- Ink ---- */
  --ink:   #0E1A2B;   /* near-black slate */
  --ink-2: #41505F;
  --ink-3: #6C7A89;
  --ink-4: #9AA7B4;

  /* ---- Brand (deep petrol / seal — the single premium accent) ---- */
  --brand:        #0B6B63;
  --brand-strong: #075952;
  --brand-2:      #128b7f;
  --brand-soft:   #E7F1EF;
  --brand-tint:   rgba(11,107,99,0.07);
  --brand-line:   rgba(11,107,99,0.32);
  --brand-glow:   rgba(18,139,127,0.18);
  --brand-2-rgb:  18,139,127;

  /* ---- Risk tone (ransomware viz only — muted rust, never neon) ---- */
  --risk:      #B4502E;
  --risk-soft: #F3E3DC;
  --risk-line: rgba(180,80,46,0.40);

  /* ---- Swiss cue ---- */
  --swiss: #D8232A;

  /* ---- Adaptive surfaces (glass) ---- */
  --nav-bg:    rgba(251,252,253,0.82);
  --drawer-bg: rgba(246,248,250,0.98);
  --glass-bg:  rgba(255,255,255,0.74);
  color-scheme: light;

  /* ---- Type ---- */
  --f-display: 'Archivo', system-ui, sans-serif;
  --f-body:    'IBM Plex Sans', system-ui, sans-serif;
  --f-mono:    'IBM Plex Mono', ui-monospace, monospace;

  /* ---- Rhythm ---- */
  --maxw: 1240px;
  --gut: clamp(20px, 5vw, 88px);
  --sp: clamp(72px, 11vw, 156px);
  --radius: 7px;
  --radius-sm: 4px;
  --radius-lg: 12px;

  /* ---- Elevation (soft, premium — resting card now genuinely lifts) ---- */
  --sh-1: 0 1px 2px rgba(15,30,55,0.06), 0 4px 10px -4px rgba(15,30,55,0.07);
  --sh-2: 0 14px 30px -18px rgba(15,30,55,0.24), 0 3px 10px -4px rgba(15,30,55,0.10);
  --sh-3: 0 36px 70px -34px rgba(15,30,55,0.32), 0 10px 26px -12px rgba(15,30,55,0.14);

  /* ---- Motion ---- */
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-2: cubic-bezier(0.65, 0, 0.35, 1);
}

/* =========================== DARK MODE (opt-in; light stays default) =========================== */
html[data-theme="dark"]{
  --bg:#0B0F14; --bg-2:#0F141B; --bg-alt:#0F141B; --paper:#141B23; --paper-2:#1B2530; --paper-3:#24303C;
  --line:rgba(230,237,243,0.10); --line-2:rgba(230,237,243,0.16); --line-3:rgba(230,237,243,0.30);
  --ink:#E6EDF3; --ink-2:#AEBAC6; --ink-3:#7E8A98; --ink-4:#586677;
  --brand:#22C58E; --brand-strong:#19A877; --brand-2:#4DE3AE; --brand-soft:rgba(34,197,142,0.15);
  --brand-tint:rgba(34,197,142,0.13); --brand-line:rgba(34,197,142,0.42); --brand-glow:rgba(77,227,174,0.30); --brand-2-rgb:77,227,174;
  --risk:#E0764A; --risk-soft:rgba(224,118,74,0.16); --risk-line:rgba(224,118,74,0.46);
  --swiss:#E5484D;
  --nav-bg:rgba(11,15,20,0.82); --drawer-bg:rgba(13,17,23,0.98); --glass-bg:rgba(20,27,35,0.70);
  --sh-1:0 1px 2px rgba(0,0,0,0.5), 0 1px 1px rgba(0,0,0,0.35);
  --sh-2:0 16px 32px -18px rgba(0,0,0,0.75), 0 2px 8px -4px rgba(0,0,0,0.55);
  --sh-3:0 40px 72px -34px rgba(0,0,0,0.85), 0 8px 22px -12px rgba(0,0,0,0.65);
  color-scheme:dark;
}
html[data-theme="dark"] .btn--brand{ color:#04231A; }
.ic-sun,.ic-moon{ width:16px; height:16px; }
html[data-theme="dark"] .ic-moon{ display:none; }
html:not([data-theme="dark"]) .ic-sun{ display:none; }
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--f-body);
  font-weight:400;
  font-size:clamp(15px,1.02vw,16.5px);
  line-height:1.65;
  letter-spacing:0.003em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* ---- Atmospheric base (very faint engraved grid, fixed) ---- */
.ambient{ position:fixed; inset:0; z-index:0; pointer-events:none; }
.ambient::before{
  content:""; position:absolute; inset:-2px;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:72px 72px;
  -webkit-mask-image:radial-gradient(125% 80% at 50% -4%, #000 18%, transparent 70%);
          mask-image:radial-gradient(125% 80% at 50% -4%, #000 18%, transparent 70%);
  opacity:.7;
}
.ambient::after{ /* subtle warm/cool wash for depth */
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(60% 50% at 82% -6%, var(--brand-tint), transparent 60%),
    radial-gradient(50% 40% at 0% 8%, rgba(15,23,42,0.035), transparent 60%);
}

.skip{
  position:absolute; left:-999px; top:0; z-index:300;
  background:var(--ink); color:var(--bg); padding:12px 18px;
  font-family:var(--f-mono); font-size:13px; border-radius:0 0 var(--radius) 0;
}
.skip:focus{ left:0; }

/* =========================== LAYOUT =========================== */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
main{ position:relative; z-index:1; }
section{ position:relative; }
.sp{ padding-block:var(--sp); }

/* ---- Kicker / eyebrow ---- */
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--f-mono); font-size:11.5px; font-weight:500;
  letter-spacing:0.22em; text-transform:uppercase; color:var(--brand);
  margin:0 0 20px;
}
.kicker::before{ content:""; width:24px; height:1px; background:var(--brand-line); }
.kicker.ink{ color:var(--ink-3); }
.kicker.ink::before{ background:var(--line-3); }
.kicker.risk{ color:var(--risk); }
.kicker.risk::before{ background:var(--risk-line); }

/* ---- Headlines ---- */
h1,h2,h3,h4{ font-family:var(--f-display); font-weight:800; margin:0; letter-spacing:-0.02em; line-height:1.04; color:var(--ink); }
.h-xl{ font-size:clamp(2.5rem, 6.4vw, 5.2rem); font-weight:900; letter-spacing:-0.035em; line-height:1.0; }
.h-lg{ font-size:clamp(1.95rem, 4.2vw, 3.4rem); letter-spacing:-0.028em; }
.h-md{ font-size:clamp(1.45rem, 2.5vw, 2.05rem); letter-spacing:-0.02em; }
.lede{ font-size:clamp(1.05rem, 1.55vw, 1.26rem); line-height:1.58; color:var(--ink-2); max-width:62ch; }
.muted{ color:var(--ink-2); } .dim{ color:var(--ink-3); }
.sig{ color:var(--brand); }
em.k{ font-style:normal; color:var(--ink); font-weight:600; }
.section-head{ max-width:880px; }
.section-head .lede{ margin-top:18px; }

/* =========================== BUTTONS =========================== */
.btn{
  --bd:var(--line-2);
  position:relative; display:inline-flex; align-items:center; gap:10px;
  font-family:var(--f-mono); font-size:13px; font-weight:500; letter-spacing:0.03em;
  padding:13px 20px; border:1px solid var(--bd); border-radius:var(--radius);
  color:var(--ink); text-decoration:none; cursor:pointer; background:var(--paper);
  overflow:hidden; transition:color .4s var(--ease), border-color .4s var(--ease), background .35s var(--ease), transform .2s var(--ease), box-shadow .35s var(--ease);
  isolation:isolate; white-space:nowrap;
}
.btn .ar{ transition:transform .4s var(--ease); }
.btn:hover{ transform:translateY(-1px); }
.btn:hover .ar{ transform:translate(3px,-3px); }
.btn:focus-visible{ outline:2px solid var(--brand); outline-offset:3px; }

.btn--primary{ background:var(--ink); color:var(--bg); --bd:var(--ink); box-shadow:var(--sh-1); }
.btn--primary:hover{ background:#16263d; box-shadow:var(--sh-2); }

.btn--brand{ background:var(--brand); color:#fff; --bd:var(--brand); box-shadow:0 10px 24px -14px var(--brand-glow); }
.btn--brand:hover{ background:var(--brand-strong); box-shadow:0 14px 28px -12px var(--brand-glow); }

.btn--ghost{ background:transparent; color:var(--ink); }
.btn--soon{ opacity:0.55; pointer-events:none; }
.btn--ghost:hover{ border-color:var(--line-3); background:var(--paper); }

.btn--light{ background:var(--paper); color:var(--ink); border-color:var(--line-2); }
.btn--light:hover{ border-color:var(--brand-line); color:var(--brand-strong); }

.btn--sm{ padding:10px 15px; font-size:12.5px; }
.btn--block{ width:100%; justify-content:center; }

/* corner ticks helper */
.ticks::before,.ticks::after{
  content:""; position:absolute; width:9px; height:9px; pointer-events:none;
  border-color:var(--brand-line); border-style:solid; opacity:0; transition:opacity .4s var(--ease);
}
.ticks::before{ top:-1px; left:-1px; border-width:1px 0 0 1px; }
.ticks::after{ bottom:-1px; right:-1px; border-width:0 1px 1px 0; }
.ticks:hover::before,.ticks:hover::after{ opacity:1; }

/* =========================== NAV =========================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:120;
  transition:background .4s var(--ease), border-color .4s var(--ease), backdrop-filter .4s, box-shadow .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:var(--nav-bg);
  -webkit-backdrop-filter:blur(16px) saturate(150%);
          backdrop-filter:blur(16px) saturate(150%);
  border-bottom-color:var(--line);
  box-shadow:0 1px 0 rgba(15,23,42,0.02), 0 8px 24px -22px rgba(15,23,42,0.4);
}
.nav__row{ display:flex; align-items:center; justify-content:space-between; height:70px; gap:18px; }
.brand{ display:inline-flex; align-items:center; gap:11px; text-decoration:none; color:var(--ink); }
.brand__mark{ width:30px; height:30px; flex:none; }
.brand__name{ font-family:var(--f-display); font-weight:800; font-size:23px; letter-spacing:0.004em; line-height:1; display:inline-flex; align-items:center; color:var(--ink); }
.brand__chip{ display:inline-flex; align-items:center; justify-content:center; min-width:21px; height:21px; padding:0 4px; margin-left:3px; border-radius:6px; background:var(--brand); color:#04231A; font-size:15px; font-weight:800; line-height:1; }
.brand__sub{ font-family:var(--f-mono); font-size:9px; letter-spacing:0.34em; color:var(--ink-3); display:block; margin-top:2px; }

.nav__links{ display:flex; align-items:center; gap:26px; list-style:none; margin:0; padding:0; }
.nav__links a{
  position:relative; font-family:var(--f-mono); font-size:12.5px; letter-spacing:0.03em;
  color:var(--ink-2); text-decoration:none; padding:6px 0; transition:color .3s var(--ease);
}
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-1px; height:1.5px; width:0; background:var(--brand); transition:width .35s var(--ease); }
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after{ width:100%; }

.nav__cta{ display:flex; align-items:center; gap:10px; }
.nav__login{
  display:inline-flex; align-items:center; gap:8px; font-family:var(--f-mono); font-size:12.5px;
  letter-spacing:0.03em; color:var(--ink); text-decoration:none; padding:11px 14px;
  border:1px solid var(--line-2); border-radius:var(--radius); background:var(--paper);
  cursor:pointer; transition:border-color .3s var(--ease), color .3s var(--ease);
}
.nav__login svg{ width:14px; height:14px; }
.nav__login:hover{ border-color:var(--brand-line); color:var(--brand-strong); }

.burger{
  display:none; width:42px; height:42px; border:1px solid var(--line-2); border-radius:var(--radius);
  background:var(--paper); cursor:pointer; padding:0; position:relative;
}
.burger span{ position:absolute; left:11px; right:11px; height:1.6px; background:var(--ink); transition:transform .35s var(--ease), opacity .2s; }
.burger span:nth-child(1){ top:15px; } .burger span:nth-child(2){ top:20px; } .burger span:nth-child(3){ top:25px; }
.burger.is-open span:nth-child(1){ transform:translateY(5px) rotate(45deg); }
.burger.is-open span:nth-child(2){ opacity:0; }
.burger.is-open span:nth-child(3){ transform:translateY(-5px) rotate(-45deg); }

.drawer{
  position:fixed; inset:70px 0 0; z-index:119; background:var(--drawer-bg);
  -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
  transform:translateY(-12px); opacity:0; pointer-events:none;
  transition:opacity .35s var(--ease), transform .35s var(--ease);
  display:flex; flex-direction:column; padding:24px var(--gut) 44px; overflow-y:auto;
}
.drawer.is-open{ opacity:1; transform:none; pointer-events:auto; }
.drawer a.dl{
  font-family:var(--f-display); font-weight:700; font-size:clamp(1.5rem,7vw,2.1rem);
  color:var(--ink); text-decoration:none; padding:15px 0; border-bottom:1px solid var(--line);
  letter-spacing:-0.02em; display:flex; justify-content:space-between; align-items:center;
}
.drawer a.dl .ix{ font-family:var(--f-mono); font-size:12px; color:var(--brand); font-weight:500; letter-spacing:0.1em; }
.drawer .drawer__cta{ display:grid; gap:12px; margin-top:26px; }

/* =========================== LOGIN MODAL =========================== */
.modal{ position:fixed; inset:0; z-index:200; display:grid; place-items:center; padding:24px;
  opacity:0; pointer-events:none; transition:opacity .3s var(--ease); }
.modal.is-open{ opacity:1; pointer-events:auto; }
.modal[hidden]{ display:none !important; }   /* closed: no layout, no stray fields */
.modal__veil{ position:absolute; inset:0; background:rgba(15,23,42,0.42); -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); }
.modal__card{
  position:relative; width:min(440px,100%); background:var(--paper);
  border:1px solid var(--line-2); border-radius:var(--radius-lg); box-shadow:var(--sh-3);
  padding:30px 30px 26px; transform:translateY(14px) scale(.985); transition:transform .35s var(--ease);
}
.modal.is-open .modal__card{ transform:none; }
.modal__head{ display:flex; align-items:flex-start; justify-content:space-between; gap:16px; margin-bottom:4px; }
.modal__title{ font-family:var(--f-display); font-weight:800; font-size:1.35rem; letter-spacing:-0.02em; }
.modal__sub{ color:var(--ink-3); font-size:0.9rem; margin:6px 0 22px; }
.modal__x{ width:34px; height:34px; flex:none; border:1px solid var(--line-2); border-radius:var(--radius-sm);
  background:var(--paper); cursor:pointer; color:var(--ink-2); display:grid; place-items:center; transition:border-color .25s, color .25s; }
.modal__x:hover{ border-color:var(--line-3); color:var(--ink); }
.modal__x svg{ width:15px; height:15px; }
.modal .field{ margin-bottom:14px; }
.modal__sso{ display:grid; gap:10px; margin-top:4px; }
.modal__hr{ display:flex; align-items:center; gap:12px; margin:18px 0; color:var(--ink-4);
  font-family:var(--f-mono); font-size:11px; letter-spacing:0.14em; }
.modal__hr::before,.modal__hr::after{ content:""; height:1px; flex:1; background:var(--line); }
.modal__foot{ margin-top:18px; padding-top:16px; border-top:1px solid var(--line);
  display:flex; flex-wrap:wrap; gap:6px 14px; align-items:center; justify-content:space-between;
  font-family:var(--f-mono); font-size:11px; letter-spacing:0.04em; color:var(--ink-3); }
.modal__foot a{ color:var(--brand-strong); text-decoration:none; }
.modal__foot a:hover{ text-decoration:underline; }
.modal__mfa{ display:inline-flex; align-items:center; gap:7px; }
.modal__mfa::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--brand); box-shadow:0 0 0 3px var(--brand-tint); }
.modal__note{ margin-top:14px; font-size:0.78rem; color:var(--ink-4); line-height:1.5; }

/* =========================== HERO =========================== */
.hero{ position:relative; padding-top:130px; padding-bottom:clamp(56px,8vw,108px); overflow:hidden; }
.hero__grid{
  position:relative; z-index:3;
  display:grid; grid-template-columns:1.04fr 0.96fr; gap:clamp(36px,5vw,76px); align-items:center;
}
.hero__copy{ max-width:620px; min-width:0; }
/* Mobile-Overflow-Fix: Grid-Spalten dürfen unter die Inhalts-Mindestbreite schrumpfen; lange Wörter brechen — sonst rechts abgeschnitten. */
.hero__grid>*{ min-width:0; }
.hero h1, .hero h1 .ln>span{ overflow-wrap:break-word; }
.hero h1{ margin:6px 0 24px; }
.hero h1 .ln{ display:block; overflow:hidden; }
.hero h1 .ln > span{ display:block; }
.hero h1 .ln--accent > span{
  color:transparent;
  background:linear-gradient(96deg,var(--brand-strong),var(--brand-2) 80%);
  -webkit-background-clip:text; background-clip:text;
}
.hero__pills{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:22px; }
.pill{ display:inline-flex; align-items:center; gap:8px; font-family:var(--f-mono); font-size:11.5px;
  letter-spacing:0.04em; color:var(--ink-2); background:var(--paper); border:1px solid var(--line-2);
  border-radius:999px; padding:6px 13px; }
.pill .swiss-cross{ width:13px; height:13px; flex:none; }
.pill b{ color:var(--ink); font-weight:600; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:12px; margin-top:30px; }
.hero__trust{ display:flex; flex-wrap:wrap; gap:9px 22px; margin-top:34px; padding-top:24px; border-top:1px solid var(--line); }
.hero__trust span{ display:inline-flex; align-items:center; gap:8px; font-family:var(--f-mono); font-size:11.5px; letter-spacing:0.08em; color:var(--ink-3); }
.hero__trust span::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--brand); box-shadow:0 0 0 3px var(--brand-tint); }

/* ---- Hero shield instrument ---- */
.shield-wrap{ position:relative; }
.shield-frame{
  position:relative; border:1px solid var(--line-2); border-radius:var(--radius-lg);
  background:
    radial-gradient(120% 80% at 50% 0%, var(--brand-tint), transparent 58%),
    linear-gradient(180deg,var(--paper),var(--bg-2));
  box-shadow:var(--sh-3); overflow:hidden;
}
.shield-frame::before,.shield-frame::after{ content:""; position:absolute; width:13px; height:13px; border-color:var(--brand-line); border-style:solid; z-index:4; pointer-events:none; }
.shield-frame::before{ top:11px; left:11px; border-width:1px 0 0 1px; }
.shield-frame::after{ bottom:11px; right:11px; border-width:0 1px 1px 0; }
.shield-frame__bar{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:13px 17px; border-bottom:1px solid var(--line); position:relative; z-index:4;
  font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.14em; color:var(--ink-3);
}
.shield-frame__bar .live{ display:inline-flex; align-items:center; gap:8px; color:var(--brand-strong); }
.shield-frame__bar .live i{ width:7px; height:7px; border-radius:50%; background:var(--brand); box-shadow:0 0 0 0 var(--brand-line); animation:ping 2.6s var(--ease) infinite; }
@keyframes ping{ 0%{ box-shadow:0 0 0 0 rgba(var(--brand-2-rgb),.45);} 70%{ box-shadow:0 0 0 9px rgba(var(--brand-2-rgb),0);} 100%{ box-shadow:0 0 0 0 rgba(var(--brand-2-rgb),0);} }
.shield-stage{ position:relative; aspect-ratio:1 / 0.92; width:100%; }
.shield-stage canvas{ position:absolute; inset:0; width:100%; height:100%; display:block; }
.shield-verdict{
  position:absolute; left:50%; bottom:13%; transform:translateX(-50%); z-index:3;
  display:inline-flex; align-items:center; gap:8px; padding:7px 14px; border-radius:999px;
  background:var(--glass-bg); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  border:1px solid var(--brand-line); color:var(--brand-strong);
  font-family:var(--f-mono); font-size:11px; letter-spacing:0.12em;
}
.shield-verdict .tk{ width:14px; height:14px; }
.shield-meta{
  display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--line); position:relative; z-index:4;
}
.shield-meta div{ padding:15px 15px; border-right:1px solid var(--line); }
.shield-meta div:last-child{ border-right:0; }
.shield-meta .v{ font-family:var(--f-display); font-weight:800; font-size:1.5rem; letter-spacing:-0.015em; color:var(--ink); line-height:1; }
.shield-meta .v .u{ color:var(--brand); font-size:0.62em; }
.shield-meta .l{ margin-top:8px; font-family:var(--f-mono); font-size:11px; letter-spacing:0.07em; color:var(--ink-3); text-transform:uppercase; }
.shield-coords{ padding:10px 16px; border-top:1px solid var(--line); position:relative; z-index:4;
  font-family:var(--f-mono); font-size:9.5px; letter-spacing:0.16em; color:var(--ink-4); text-align:center; }

/* =========================== TRUST STRIP =========================== */
.strip{ border-block:1px solid var(--line); background:linear-gradient(180deg,var(--paper),var(--bg-2)); }
.strip__row{ display:flex; flex-wrap:wrap; align-items:stretch; gap:0; }
.strip__item{
  flex:1 1 auto; min-width:160px; padding:24px clamp(14px,2.4vw,30px);
  font-family:var(--f-mono); font-size:12.5px; letter-spacing:0.05em; color:var(--ink-2);
  display:flex; align-items:center; gap:10px; border-right:1px solid var(--line);
}
.strip__item:last-child{ border-right:0; }
.strip__item b{ color:var(--ink); font-weight:600; }
.strip__item .dot{ width:6px; height:6px; flex:none; border-radius:50%; background:var(--brand); box-shadow:0 0 0 3px var(--brand-tint); }

/* =========================== PLATFORM (app-shell preview) =========================== */
.platform{ background:linear-gradient(180deg,var(--bg-2),var(--bg)); border-top:1px solid var(--line); }
.app{
  margin-top:48px; border:1px solid var(--line-2); border-radius:var(--radius-lg); overflow:hidden;
  background:var(--paper); box-shadow:var(--sh-3); display:grid; grid-template-columns:236px 1fr; min-height:520px;
}
.app__side{ border-right:1px solid var(--line); background:linear-gradient(180deg,var(--bg-2),var(--paper)); display:flex; flex-direction:column; }
.app__brand{ display:flex; align-items:center; gap:10px; padding:18px 18px; border-bottom:1px solid var(--line); }
.app__brand .m{ width:24px; height:24px; }
.app__brand b{ font-family:var(--f-display); font-weight:800; font-size:15px; letter-spacing:0.04em; }
.app__brand b i{ color:var(--brand); font-style:normal; }
.app__org{ margin-left:auto; font-family:var(--f-mono); font-size:9px; letter-spacing:0.12em; color:var(--ink-3); border:1px solid var(--line-2); border-radius:999px; padding:3px 8px; }
.app__nav{ list-style:none; margin:0; padding:12px 10px; display:grid; gap:2px; }
.app__nav li{ display:flex; align-items:center; gap:11px; padding:10px 12px; border-radius:var(--radius-sm);
  font-family:var(--f-mono); font-size:12.5px; letter-spacing:0.02em; color:var(--ink-2); cursor:default; transition:background .25s, color .25s; }
.app__nav li svg{ width:16px; height:16px; flex:none; color:var(--ink-3); transition:color .25s; }
.app__nav li .ct{ margin-left:auto; font-size:10px; color:var(--ink-4); }
.app__nav li:hover{ background:var(--paper-2); color:var(--ink); }
.app__nav li.is-active{ background:var(--brand-soft); color:var(--brand-strong); }
.app__nav li.is-active svg{ color:var(--brand); }
.app__nav .sep{ height:1px; background:var(--line); margin:10px 12px; padding:0; }
.app__user{ margin-top:auto; padding:14px 16px; border-top:1px solid var(--line); display:flex; align-items:center; gap:11px; }
.app__avatar{ width:30px; height:30px; border-radius:50%; background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff;
  display:grid; place-items:center; font-family:var(--f-display); font-weight:800; font-size:12px; flex:none; }
.app__user .nm{ font-size:12.5px; color:var(--ink); font-weight:600; line-height:1.2; }
.app__user .rl{ font-family:var(--f-mono); font-size:9.5px; letter-spacing:0.06em; color:var(--ink-3); }

.app__main{ display:flex; flex-direction:column; min-width:0; }
.app__top{ display:flex; align-items:center; gap:14px; padding:14px 20px; border-bottom:1px solid var(--line); }
.app__search{ flex:1; min-width:0; display:flex; align-items:center; gap:9px; padding:9px 13px; border:1px solid var(--line-2);
  border-radius:var(--radius); background:var(--paper-2); color:var(--ink-4); font-family:var(--f-mono); font-size:12px; letter-spacing:0.02em; }
.app__search svg{ width:14px; height:14px; flex:none; }
.app__top .tag{ display:inline-flex; align-items:center; gap:7px; font-family:var(--f-mono); font-size:11px; letter-spacing:0.06em;
  color:var(--brand-strong); border:1px solid var(--brand-line); border-radius:999px; padding:6px 12px; white-space:nowrap; }
.app__top .tag i{ width:6px; height:6px; border-radius:50%; background:var(--brand); }
.app__body{ padding:20px; display:grid; gap:16px; }
.app__kpis{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.kpi{ border:1px solid var(--line); border-radius:var(--radius); padding:16px 16px 15px; background:var(--bg-2); position:relative; overflow:hidden; }
.kpi.kpi--ok{ background:linear-gradient(180deg,var(--brand-soft),var(--paper)); border-color:var(--brand-line); }
.kpi__l{ font-family:var(--f-mono); font-size:10px; letter-spacing:0.1em; color:var(--ink-3); text-transform:uppercase; display:flex; align-items:center; gap:7px; }
.kpi__l .d{ width:6px; height:6px; border-radius:50%; background:var(--brand); }
.kpi__v{ font-family:var(--f-display); font-weight:800; font-size:1.6rem; letter-spacing:-0.02em; margin-top:10px; color:var(--ink); line-height:1; }
.kpi__v small{ font-family:var(--f-mono); font-weight:400; font-size:0.5em; letter-spacing:0.04em; color:var(--ink-3); }
.kpi__s{ margin-top:8px; font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.03em; color:var(--ink-3); }
.kpi__bar{ margin-top:11px; height:5px; border-radius:3px; background:var(--paper-3); overflow:hidden; }
.kpi__bar i{ display:block; height:100%; border-radius:3px; background:linear-gradient(90deg,var(--brand),var(--brand-2)); }

.panelcard{ border:1px solid var(--line); border-radius:var(--radius); background:var(--paper); overflow:hidden; }
.panelcard__h{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:13px 16px; border-bottom:1px solid var(--line); }
.panelcard__h h4{ font-family:var(--f-mono); font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-3); font-weight:500; }
.panelcard__h .mini{ font-family:var(--f-mono); font-size:10.5px; color:var(--ink-4); }
.jobs{ list-style:none; margin:0; padding:0; }
.jobs li{ display:grid; grid-template-columns:auto 1fr auto auto; gap:13px; align-items:center; padding:12px 16px; border-bottom:1px solid var(--line); }
.jobs li:last-child{ border-bottom:0; }
.jobs .st{ width:9px; height:9px; border-radius:50%; flex:none; }
.jobs .st.ok{ background:var(--brand); box-shadow:0 0 0 3px var(--brand-tint); }
.jobs .st.run{ background:var(--brand-2); box-shadow:0 0 0 3px var(--brand-tint); animation:ping 2.2s var(--ease) infinite; }
.jobs .st.idle{ background:var(--ink-4); }
.jobs .nm{ font-size:0.92rem; color:var(--ink); font-weight:500; min-width:0; }
.jobs .nm small{ display:block; font-family:var(--f-mono); font-size:10px; letter-spacing:0.04em; color:var(--ink-3); font-weight:400; margin-top:2px; }
.jobs .sz{ font-family:var(--f-mono); font-size:11px; color:var(--ink-3); white-space:nowrap; }
.jobs .tm{ font-family:var(--f-mono); font-size:11px; color:var(--brand-strong); white-space:nowrap; }
.app__cols{ display:grid; grid-template-columns:1.5fr 1fr; gap:16px; }
.restore{ list-style:none; margin:0; padding:6px 0; }
.restore li{ display:flex; align-items:center; gap:11px; padding:9px 16px; }
.restore li .ic{ width:26px; height:26px; flex:none; border-radius:var(--radius-sm); border:1px solid var(--line-2); display:grid; place-items:center; color:var(--brand); background:var(--brand-soft); }
.restore li .ic svg{ width:13px; height:13px; }
.restore li .tx{ font-size:0.86rem; color:var(--ink); line-height:1.3; }
.restore li .tx small{ display:block; font-family:var(--f-mono); font-size:9.5px; letter-spacing:0.04em; color:var(--ink-3); margin-top:1px; }
.restore li .go{ margin-left:auto; font-family:var(--f-mono); font-size:10.5px; color:var(--brand-strong); border:1px solid var(--brand-line); border-radius:var(--radius-sm); padding:4px 9px; }
.app__note{ margin-top:14px; font-family:var(--f-mono); font-size:11px; letter-spacing:0.03em; color:var(--ink-4); display:inline-flex; align-items:center; gap:8px; }
.app__note svg{ width:14px; height:14px; color:var(--ink-3); }

/* =========================== PROBLEM / SOLUTION =========================== */
.ps{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:54px; align-items:stretch; }
.ps__col{ background:var(--paper); padding:clamp(26px,3.4vw,44px); border:1px solid var(--line-2); border-radius:var(--radius-lg); display:flex; flex-direction:column; }
.ps__col--prob{ background:linear-gradient(180deg,var(--risk-soft),var(--paper) 38%); border-color:rgba(186,90,46,0.2); }
.ps__col--sol{ background:linear-gradient(180deg,var(--brand-soft),var(--paper) 38%); border-color:var(--brand-line); }
.ps__col h3{ margin:16px 0 24px; min-height:2.7em; }
.ps__list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:2px; flex:1; }
.ps__list li{ padding:17px 0; border-top:1px solid var(--line); display:grid; grid-template-columns:auto 1fr; gap:13px; align-items:start; flex:1; }
.ps__list li:first-child{ border-top:0; }
.ps__list .mk{ width:22px; height:22px; flex:none; margin-top:2px; }
.ps__list strong{ display:block; font-family:var(--f-display); font-weight:700; font-size:1.04rem; letter-spacing:-0.01em; margin-bottom:3px; color:var(--ink); }
.ps__list p{ margin:0; font-size:0.94rem; color:var(--ink-2); line-height:1.55; }
.ps__list .mk.x{ color:var(--risk); }
.ps__list .mk.c{ color:var(--brand); }

/* =========================== ARCHITECTURE + SCHEMA =========================== */
.arch__grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:clamp(32px,5vw,72px); margin-top:56px; align-items:start; }
.arch__steps{ display:grid; gap:16px; }
.astep{
  position:relative; border:1px solid var(--line-2); border-radius:var(--radius); padding:22px 24px 22px 28px;
  background:var(--paper); transition:border-color .5s var(--ease), background .5s var(--ease), transform .5s var(--ease), box-shadow .5s var(--ease);
}
.astep::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:2px; border-radius:2px 0 0 2px; background:var(--line-2); transition:background .5s var(--ease), box-shadow .5s var(--ease); }
.astep.is-active{ border-color:var(--brand-line); background:linear-gradient(180deg,var(--brand-soft),var(--paper) 60%); box-shadow:var(--sh-2); transform:translateX(2px); }
.astep.is-active::before{ background:var(--brand); box-shadow:0 0 14px var(--brand-line); }
.astep__no{ font-family:var(--f-mono); font-size:11px; letter-spacing:0.14em; color:var(--ink-3); }
.astep.is-active .astep__no{ color:var(--brand-strong); }
.astep h4{ font-size:1.22rem; margin:9px 0 7px; letter-spacing:-0.015em; }
.astep p{ margin:0; color:var(--ink-2); font-size:0.95rem; }
.astep .tag{ display:inline-flex; align-items:center; gap:7px; margin-top:13px; font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.07em; color:var(--ink-3); border:1px solid var(--line-2); border-radius:999px; padding:4px 11px; }
.astep.is-active .tag{ color:var(--brand-strong); border-color:var(--brand-line); }
.astep .tag::before{ content:""; width:5px; height:5px; border-radius:50%; background:currentColor; }

.arch__viz{ position:sticky; top:90px; }
.diagram{
  position:relative; border:1px solid var(--line-2); border-radius:var(--radius-lg); padding:28px 22px;
  background:radial-gradient(120% 85% at 50% 0%, var(--brand-tint), transparent 58%), linear-gradient(180deg,var(--paper),var(--bg-2));
  box-shadow:var(--sh-2); overflow:hidden;
}
.diagram::before{ /* faint depth grid */
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:34px 34px; -webkit-mask-image:radial-gradient(90% 80% at 50% 18%,#000,transparent 80%); mask-image:radial-gradient(90% 80% at 50% 18%,#000,transparent 80%); opacity:.6;
}
.diagram__label{ position:absolute; top:16px; left:18px; z-index:3; font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.16em; color:var(--ink-3); }
.diagram__label .b{ color:var(--brand); }
.diagram__live{ position:absolute; top:16px; right:18px; z-index:3; font-family:var(--f-mono); font-size:10px; letter-spacing:0.1em; color:var(--ink-4); display:inline-flex; align-items:center; gap:7px; }
.diagram__live i{ width:6px; height:6px; border-radius:50%; background:var(--brand-2); animation:ping 2.6s var(--ease) infinite; }
.diagram svg{ position:relative; z-index:2; display:block; }
.dnode-label{ font-family:var(--f-mono); }

/* schema motion */
.flow-base{ stroke:var(--line-3); }
.flow-live{ stroke:var(--brand); stroke-linecap:round; stroke-dasharray:9 320; animation:dash 3.6s linear infinite; }
.flow-live.d2{ stroke:var(--brand-2); animation-duration:5s; animation-delay:-1.2s; opacity:.6; }
@keyframes dash{ from{ stroke-dashoffset:329; } to{ stroke-dashoffset:0; } }
.pkt{ fill:var(--brand); }
.pkt--raw{ fill:var(--risk); }
.seal-ring{ transform-origin:230px 180px; animation:sealpulse 3.4s var(--ease) infinite; }
@keyframes sealpulse{ 0%{ opacity:.0; transform:scale(.7);} 18%{ opacity:.55;} 60%{ opacity:0; transform:scale(1.5);} 100%{ opacity:0; } }
.vault-pulse{ transform-origin:center; animation:vaultpulse 3.6s var(--ease) infinite; }
.vault-pulse.v2{ animation-delay:-1.8s; }
@keyframes vaultpulse{ 0%,55%{ opacity:0; } 62%{ opacity:.6; } 100%{ opacity:0; } }
.shard{ animation:shard 4.4s var(--ease-2) infinite; }
.shard.s2{ animation-delay:-2.2s; }
@keyframes shard{
  0%{ opacity:0; transform:translate(0,0) rotate(0deg);}
  10%{ opacity:.75;}
  46%{ opacity:.75;}
  58%{ opacity:0; transform:translate(var(--dx,30px),var(--dy,-26px)) rotate(140deg);}
  100%{ opacity:0; }
}
@media (prefers-reduced-motion: reduce){
  .flow-live,.seal-ring,.vault-pulse,.shard,.enc-stream,.diagram__live i{ animation:none; }
  .flow-live{ stroke-dashoffset:0; stroke-dasharray:none; opacity:.5; }
  .seal-ring,.vault-pulse,.shard{ opacity:0; }
  .enc-stream{ opacity:.3; }
}

/* =========================== CAPABILITIES =========================== */
.caps{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:54px; }
.cap{ position:relative; background:var(--paper); border:1px solid var(--line-2); border-radius:var(--radius); padding:clamp(24px,2.4vw,34px); min-height:222px; transition:background .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease), transform .4s var(--ease); overflow:hidden; }
.cap:hover{ box-shadow:var(--sh-2); transform:translateY(-2px); border-color:var(--brand-line); }
.cap__no{ font-family:var(--f-mono); font-size:11px; letter-spacing:0.16em; color:var(--ink-4); }
.cap__ico{ width:34px; height:34px; color:var(--brand); margin:20px 0 18px; display:grid; place-items:center; border:1px solid var(--brand-line); border-radius:var(--radius-sm); background:var(--brand-soft); padding:6px; }
.cap h3{ font-size:1.18rem; letter-spacing:-0.018em; margin:0 0 9px; }
.cap p{ margin:0; color:var(--ink-2); font-size:0.93rem; line-height:1.55; }
.cap__edge{ position:absolute; left:0; bottom:0; height:2px; width:0; background:linear-gradient(90deg,var(--brand),var(--brand-2)); transition:width .5s var(--ease); }
.cap:hover .cap__edge{ width:100%; }

/* =========================== COMPARISON =========================== */
.cmp{ margin-top:52px; border:1px solid var(--line-2); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--sh-1); }
.cmp__scroll{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
table.compare{ width:100%; border-collapse:collapse; min-width:680px; background:var(--paper); }
table.compare th, table.compare td{ text-align:left; padding:18px clamp(16px,2vw,28px); border-bottom:1px solid var(--line); vertical-align:top; }
table.compare thead th{ background:var(--bg-2); position:sticky; top:0; font-family:var(--f-mono); font-size:11.5px; letter-spacing:0.08em; color:var(--ink-3); text-transform:uppercase; font-weight:500; }
table.compare thead th.c3{ color:var(--brand-strong); }
table.compare thead th.c3 .badge{ display:block; font-family:var(--f-display); font-size:1.02rem; color:var(--ink); letter-spacing:0; margin-top:4px; text-transform:none; }
table.compare tbody th{ font-family:var(--f-body); font-weight:600; color:var(--ink); width:30%; font-size:0.96rem; }
table.compare td{ color:var(--ink-2); font-size:0.94rem; }
table.compare td.c3{ color:var(--ink); }
table.compare tr:last-child th, table.compare tr:last-child td{ border-bottom:0; }
.cell{ display:flex; gap:10px; align-items:flex-start; }
.cell .mk{ width:18px; height:18px; flex:none; margin-top:2px; }
.cell .mk.x{ color:var(--risk); }
.cell .mk.c{ color:var(--brand); }
.col3-bg{ background:linear-gradient(180deg,var(--brand-soft),transparent 80%); }

/* =========================== PROCESS =========================== */
.flow{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,3vw,38px); margin-top:56px; position:relative; }
.flow::before{ content:""; position:absolute; left:8%; right:8%; top:30px; height:1px; background:linear-gradient(90deg,transparent,var(--line-2) 12%,var(--line-2) 88%,transparent); }
.fstep{ position:relative; }
.fstep__dot{ width:14px; height:14px; border-radius:50%; background:var(--paper); border:1px solid var(--brand-line); position:relative; margin-bottom:26px; box-shadow:0 0 0 4px var(--bg); }
.fstep__dot::after{ content:""; position:absolute; inset:3px; border-radius:50%; background:var(--brand); }
.fstep__no{ font-family:var(--f-mono); font-size:11px; letter-spacing:0.16em; color:var(--ink-3); }
.fstep h3{ font-size:1.26rem; letter-spacing:-0.02em; margin:11px 0 11px; }
.fstep p{ margin:0; color:var(--ink-2); font-size:0.95rem; }
.fstep .meta{ margin-top:15px; font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.06em; color:var(--brand-strong); }

/* =========================== PROMISE =========================== */
.promise{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:54px; }
.pcard{ position:relative; border:1px solid var(--line-2); background:var(--paper); padding:32px 28px 30px; border-radius:var(--radius); box-shadow:var(--sh-1); }
.pcard__no{ font-family:var(--f-mono); font-size:11px; letter-spacing:0.16em; color:var(--ink-4); }
.pcard__ico{ width:34px; height:34px; color:var(--brand); margin:16px 0 16px; display:grid; place-items:center; border:1px solid var(--brand-line); border-radius:var(--radius-sm); background:var(--brand-soft); padding:6px; }
.pcard h3{ font-size:1.22rem; letter-spacing:-0.02em; margin:0 0 11px; }
.pcard p{ margin:0; color:var(--ink-2); font-size:0.94rem; line-height:1.6; }
.pcard--seal{ border-color:var(--brand-line); background:linear-gradient(180deg, var(--brand-soft), var(--paper) 42%); }
.pcard__tag{ display:inline-block; margin-top:17px; font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.08em; color:var(--brand-strong); border:1px solid var(--brand-line); border-radius:var(--radius-sm); padding:5px 9px; }

/* =========================== PRICING =========================== */
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:54px; align-items:stretch; }
.tier{ position:relative; display:flex; flex-direction:column; background:var(--paper); border:1px solid var(--line-2); border-radius:var(--radius-lg); padding:32px 28px; box-shadow:var(--sh-1); transition:transform .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease); }
.tier:hover{ transform:translateY(-3px); box-shadow:var(--sh-2); }
.tier--feat{ background:linear-gradient(180deg,var(--brand-soft),var(--paper) 42%); border-color:var(--brand-line); box-shadow:var(--sh-2); }
.tier__flag{ position:absolute; top:-1px; right:24px; transform:translateY(-50%); font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.1em; color:#fff; background:var(--brand); padding:5px 12px; border-radius:999px; box-shadow:0 8px 18px -10px var(--brand-glow); }
.tier__name{ font-family:var(--f-display); font-weight:800; font-size:1.02rem; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink); }
.tier__for{ color:var(--ink-3); font-size:0.88rem; margin:8px 0 20px; min-height:40px; }
.tier__price{ display:flex; align-items:baseline; gap:7px; padding-bottom:22px; border-bottom:1px solid var(--line); }
.tier__price .amt{ font-family:var(--f-display); font-weight:900; font-size:2.4rem; letter-spacing:-0.03em; color:var(--ink); }
.tier__price .per{ font-family:var(--f-mono); font-size:11.5px; color:var(--ink-3); }
.tier__price .pre{ font-family:var(--f-mono); font-size:11.5px; color:var(--ink-3); align-self:center; }
.tier__price .cur{ font-family:var(--f-mono); font-size:12.5px; color:var(--ink-3); font-weight:500; align-self:flex-start; margin-top:7px; }
.tier__price .dec{ font-family:var(--f-display); font-weight:800; font-size:1.2rem; color:var(--ink-3); align-self:flex-start; margin-top:7px; }
.tier__store{ display:flex; align-items:center; gap:9px; margin-top:14px; font-family:var(--f-mono); font-size:11.5px; letter-spacing:0.04em; color:var(--brand-strong); }
.tier__store svg{ width:15px; height:15px; color:var(--brand); flex:none; }
.tier ul{ list-style:none; margin:22px 0 26px; padding:0; display:grid; gap:12px; flex:1; }
.tier ul li{ display:grid; grid-template-columns:auto 1fr; gap:10px; font-size:0.91rem; color:var(--ink-2); align-items:start; }
.tier ul li svg{ width:16px; height:16px; color:var(--brand); margin-top:3px; flex:none; }
.tier .btn{ justify-content:center; width:100%; }
.tier__base{ margin-top:44px; border:1px solid var(--line-2); border-radius:var(--radius); padding:20px 24px; display:flex; flex-wrap:wrap; gap:8px 26px; align-items:center; background:var(--paper); }
.tier__base .t{ font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.12em; color:var(--ink-3); text-transform:uppercase; }
.tier__base span{ display:inline-flex; align-items:center; gap:9px; font-size:0.9rem; color:var(--ink-2); }
.tier__base span:not(.t)::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--brand); }
.pricing-note{ margin-top:16px; font-family:var(--f-mono); font-size:11px; letter-spacing:0.02em; color:var(--ink-4); }
.addons{ margin-top:30px; border:1px solid var(--line-2); border-radius:var(--radius-lg); background:var(--paper); padding:clamp(22px,3vw,34px); box-shadow:var(--sh-1); }
.addons__head{ margin-bottom:20px; }
.addons__head .h-md{ margin-top:8px; }
.addons__wrap{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
.addons__table{ width:100%; border-collapse:collapse; font-size:0.92rem; min-width:380px; }
.addons__table thead th{ text-align:left; font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-3); font-weight:500; padding:0 16px 12px; border-bottom:1px solid var(--line-2); }
.addons__table thead th:not(:first-child){ text-align:right; }
.addons__table tbody th{ text-align:left; font-family:var(--f-body); font-weight:600; color:var(--ink); padding:14px 16px; border-bottom:1px solid var(--line); }
.addons__table tbody td{ text-align:right; color:var(--ink-2); padding:14px 16px; border-bottom:1px solid var(--line); font-variant-numeric:tabular-nums; white-space:nowrap; }
.addons__table tbody tr:last-child th, .addons__table tbody tr:last-child td{ border-bottom:0; }
.addons__table tbody tr{ transition:background .2s var(--ease); }
.addons__table tbody tr:hover th, .addons__table tbody tr:hover td{ background:var(--paper-2); }
.addons__table .inc{ color:var(--brand-strong); font-family:var(--f-mono); font-size:11.5px; letter-spacing:0.04em; }

/* =========================== PROOF =========================== */
.proof{ border-block:1px solid var(--line); background:linear-gradient(180deg,var(--paper),var(--bg-2)); }
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.stat{ background:var(--paper); border:1px solid var(--line-2); border-radius:var(--radius); padding:clamp(24px,3vw,38px); }
.stat__v{ font-family:var(--f-display); font-weight:900; font-size:clamp(2.1rem,3.6vw,3rem); letter-spacing:-0.03em; color:var(--ink); line-height:1; }
.stat__v .u{ color:var(--brand); font-size:0.5em; }
.stat__l{ margin-top:11px; font-family:var(--f-mono); font-size:11.5px; letter-spacing:0.05em; color:var(--ink-3); }
.proof__statement{ max-width:780px; margin:52px auto 0; text-align:center; }
.proof__statement p{ font-family:var(--f-display); font-weight:700; font-size:clamp(1.35rem,2.6vw,2rem); letter-spacing:-0.02em; line-height:1.28; color:var(--ink); }
.proof__statement .src{ margin-top:16px; font-family:var(--f-mono); font-size:11.5px; letter-spacing:0.1em; color:var(--ink-3); }

/* =========================== FAQ =========================== */
.faq{ margin-top:48px; border-top:1px solid var(--line); }
.qa-item{ border-bottom:1px solid var(--line); }
.qa{
  width:100%; text-align:left; background:transparent; border:0; cursor:pointer;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:24px 4px; color:var(--ink); font-family:var(--f-display); font-weight:600;
  font-size:clamp(1.02rem,1.6vw,1.28rem); letter-spacing:-0.015em;
}
.qa:hover{ color:var(--brand-strong); }
.qa:focus-visible{ outline:2px solid var(--brand); outline-offset:3px; }
.qa__ico{ position:relative; width:18px; height:18px; flex:none; }
.qa__ico::before,.qa__ico::after{ content:""; position:absolute; background:var(--brand); transition:transform .4s var(--ease); }
.qa__ico::before{ left:0; right:0; top:8px; height:2px; }
.qa__ico::after{ top:0; bottom:0; left:8px; width:2px; }
.qa-item[aria-expanded="true"] .qa__ico::after{ transform:scaleY(0); }
.qa__a{ overflow:hidden; max-height:0; transition:max-height .5s var(--ease); }
.qa__a-inner{ padding:0 44px 26px 4px; color:var(--ink-2); max-width:78ch; font-size:0.98rem; line-height:1.62; }

/* =========================== ACCESS (replaces dual contact form) =========================== */
.access{ position:relative; overflow:hidden; }
.access__box{
  position:relative; border:1px solid var(--line-2); border-radius:var(--radius-lg); overflow:hidden;
  background:linear-gradient(180deg,var(--paper),var(--bg-2)); box-shadow:var(--sh-2);
  display:grid; grid-template-columns:1.05fr 0.95fr;
}
.access__intro{ padding:clamp(34px,4.5vw,60px); position:relative; }
.access__intro::before{ content:""; position:absolute; inset:0; pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:40px 40px; -webkit-mask-image:radial-gradient(80% 80% at 14% 0%,#000,transparent 72%); mask-image:radial-gradient(80% 80% at 14% 0%,#000,transparent 72%); opacity:.5; }
.access__intro > *{ position:relative; }
.access__intro h2{ margin:14px 0 0; }
.access__intro .lede{ margin:18px 0 0; }
.access__chips{ display:flex; flex-wrap:wrap; gap:8px 10px; margin-top:26px; }
.access__chips span{ display:inline-flex; align-items:center; gap:8px; font-family:var(--f-mono); font-size:11px; letter-spacing:0.05em; color:var(--ink-3); border:1px solid var(--line-2); border-radius:999px; padding:6px 12px; background:var(--paper); }
.access__chips span::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--brand); }
.access__panel{ border-left:1px solid var(--line); padding:clamp(30px,4vw,52px); display:flex; flex-direction:column; gap:18px; background:var(--bg-2); }
.access__card{ border:1px solid var(--line-2); border-radius:var(--radius); background:var(--paper); padding:22px 22px; box-shadow:var(--sh-1); }
.access__card.primary{ border-color:var(--brand-line); background:linear-gradient(180deg,var(--brand-soft),var(--paper) 50%); }
.access__card h3{ font-size:1.12rem; letter-spacing:-0.01em; margin:0 0 5px; }
.access__card p{ margin:0 0 16px; color:var(--ink-3); font-size:0.9rem; }
.access__login{ display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.access__login .who{ font-family:var(--f-mono); font-size:11px; letter-spacing:0.06em; color:var(--ink-3); }
.access__mail{ font-family:var(--f-mono); font-size:12px; letter-spacing:0.02em; color:var(--ink-3); display:inline-flex; align-items:center; gap:8px; }
.access__mail a{ color:var(--brand-strong); text-decoration:none; }
.access__mail a:hover{ text-decoration:underline; }

/* ---- form fields (shared by modal + access) ---- */
.field{ display:flex; flex-direction:column; gap:7px; margin-bottom:14px; }
.field label{ font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.12em; color:var(--ink-3); text-transform:uppercase; }
.field input, .field textarea{
  font-family:var(--f-body); font-size:0.96rem; color:var(--ink);
  background:var(--paper); border:1px solid var(--line-2); border-radius:var(--radius-sm);
  padding:12px 13px; width:100%; transition:border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.field textarea{ resize:vertical; min-height:96px; }
.field input::placeholder, .field textarea::placeholder{ color:var(--ink-4); }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--brand-line); box-shadow:0 0 0 3px var(--brand-tint); }
.form-note{ margin-top:13px; font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.04em; color:var(--ink-3); display:flex; gap:8px 16px; flex-wrap:wrap; }
.form-note span{ display:inline-flex; align-items:center; gap:7px; }
.form-note span::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--brand); flex:none; }

/* =========================== FOOTER =========================== */
.foot{ border-top:1px solid var(--line); padding-top:clamp(54px,7vw,84px); padding-bottom:38px; margin-top:var(--sp); background:linear-gradient(180deg,var(--bg-2),var(--paper)); }
.foot__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr 1fr; gap:38px 30px; }
.foot__brand .brand{ margin-bottom:16px; }
.foot__brand p{ color:var(--ink-3); font-size:0.9rem; max-width:34ch; margin:0 0 16px; }
.foot__coords{ font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.12em; color:var(--ink-4); }
.foot__imp{ font-family:var(--f-mono); font-size:10.5px; line-height:1.85; letter-spacing:0.02em; color:var(--ink-3); margin:0 0 16px; }
.foot h5{ font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-3); margin:0 0 16px; font-weight:500; }
.foot ul{ list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.foot ul a{ color:var(--ink-2); text-decoration:none; font-size:0.9rem; transition:color .3s var(--ease); cursor:pointer; }
.foot ul a:hover{ color:var(--brand-strong); }
.foot__bar{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:16px; margin-top:clamp(40px,5vw,60px); padding-top:24px; border-top:1px solid var(--line); }
.foot__bar .cp{ font-family:var(--f-mono); font-size:11.5px; color:var(--ink-4); letter-spacing:0.03em; }
.foot__marks{ display:flex; gap:10px 16px; flex-wrap:wrap; }
.foot__marks span{ font-family:var(--f-mono); font-size:10.5px; letter-spacing:0.08em; color:var(--ink-3); border:1px solid var(--line-2); border-radius:999px; padding:5px 12px; }
.foot__lang a{ font-family:var(--f-mono); font-size:11.5px; color:var(--ink-3); text-decoration:none; }
.foot__lang a[aria-current]{ color:var(--brand-strong); }

/* =========================== REVEAL =========================== */
[data-reveal]{ opacity:0; transform:translateY(20px); transition:opacity .8s var(--ease), transform .8s var(--ease); transition-delay:calc(var(--i,0)*65ms); }
[data-reveal].is-in{ opacity:1; transform:none; }
.hero h1 .ln > span{ transform:translateY(108%); transition:transform 1s var(--ease); transition-delay:calc(var(--i,0)*90ms + .1s); }
.hero.ready h1 .ln > span{ transform:none; }
[data-hero]{ opacity:0; transform:translateY(15px); transition:opacity .9s var(--ease), transform .9s var(--ease); transition-delay:calc(var(--i,0)*85ms + .3s); }
.hero.ready [data-hero]{ opacity:1; transform:none; }

/* =========================== RESPONSIVE =========================== */
@media (max-width:1080px){
  .foot__grid{ grid-template-columns:1.4fr 1fr 1fr; }
  .foot__brand{ grid-column:1 / -1; }
}
@media (max-width:980px){
  .nav__links{ display:none; }
  .burger{ display:block; }
  .hero__grid{ grid-template-columns:1fr; }
  .shield-wrap{ max-width:520px; }
  .arch__grid{ grid-template-columns:1fr; }
  .arch__viz{ position:relative; top:0; order:-1; }
  .caps{ grid-template-columns:repeat(2,1fr); }
  .app{ grid-template-columns:1fr; }
  .app__side{ border-right:0; border-bottom:1px solid var(--line); }
  .app__nav{ grid-template-columns:repeat(2,1fr); grid-auto-flow:row; }
  .app__nav .sep{ display:none; }
  .app__user{ border-top:1px solid var(--line); }
  .app__cols{ grid-template-columns:1fr; }
  .access__box{ grid-template-columns:1fr; }
  .access__panel{ border-left:0; border-top:1px solid var(--line); }
  .tiers{ grid-template-columns:1fr; max-width:480px; }
  .tier--feat{ order:-1; }
  .promise{ grid-template-columns:1fr; max-width:520px; }
  .nav__login span.t{ display:none; }
}
@media (max-width:760px){
  .ps{ grid-template-columns:1fr; }
  .flow{ grid-template-columns:1fr; gap:32px; }
  .flow::before{ display:none; }
  .stats{ grid-template-columns:1fr; }
  .app__kpis{ grid-template-columns:1fr; }
  .strip__item{ flex:1 1 50%; border-right:0; border-bottom:1px solid var(--line); }
}
@media (max-width:560px){
  .nav__cta .btn--brand{ display:none; }
  .caps{ grid-template-columns:1fr; }
  .foot__grid{ grid-template-columns:1fr 1fr; }
  .foot__brand{ grid-column:1 / -1; }
  .app__nav{ grid-template-columns:1fr; }
}

/* =========================== REDUCED MOTION =========================== */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation:none !important; transition-duration:.001ms !important; }
  [data-reveal],[data-hero]{ opacity:1 !important; transform:none !important; }
  .hero h1 .ln > span{ transform:none !important; }
}

/* ============================ Polish: gradient keyword, live border, grain ============================ */
.grad{
  background:linear-gradient(100deg, var(--brand), var(--brand-2));
  -webkit-background-clip:text; background-clip:text;
  color:transparent; -webkit-text-fill-color:transparent;
}

/* animated conic gradient border on the recommended plan (progressive enhancement) */
@property --ang{ syntax:"<angle>"; inherits:false; initial-value:0deg; }
@keyframes spinBorder{ to{ --ang:360deg; } }
@supports ((-webkit-mask-composite: xor) or (mask-composite: exclude)){
  .tier--feat::before{
    content:""; position:absolute; inset:0; border-radius:inherit; padding:1.5px;
    background:conic-gradient(from var(--ang,0deg), var(--brand), var(--brand-2), var(--brand-strong), var(--brand));
    -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
            mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none;
  }
  @media (prefers-reduced-motion: no-preference){ .tier--feat::before{ animation:spinBorder 6s linear infinite; } }
}

/* faint film grain — adds tactile depth without muddying the clean Swiss surface */
body::after{
  content:""; position:fixed; inset:0; z-index:9999; pointer-events:none; opacity:0.022;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---- Footer language toggle ---- */
.foot__lang{ display:inline-flex; gap:4px; align-items:center; }
.foot__lang a{ cursor:pointer; color:var(--ink-3); text-decoration:none; font-family:var(--f-mono); font-size:11px; letter-spacing:0.08em; padding:3px 7px; border-radius:6px; transition:color .25s var(--ease), background .25s var(--ease); }
.foot__lang a:hover{ color:var(--ink); }
.foot__lang a.is-active{ color:var(--ink); background:var(--paper-2); }

/* ============================================================
   V2-ENTWURF — zusätzliche Komponenten
   (Demo-Video, Founding 20, Branchen-Karten, Testimonials)
   Nutzt ausschliesslich bestehende Design-Tokens.
   ============================================================ */
.demo__frame{ position:relative; width:100%; max-width:860px; margin:44px auto 0; aspect-ratio:16/9; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line-2); background:linear-gradient(135deg,var(--paper-2),var(--brand-tint)); box-shadow:var(--sh-2); display:grid; place-items:center; }
.demo__play{ width:74px; height:74px; border-radius:50%; background:var(--brand); color:#fff; border:none; display:grid; place-items:center; cursor:pointer; box-shadow:var(--sh-2); transition:transform .3s var(--ease); }
.demo__play:hover{ transform:scale(1.06); }
.demo__play svg{ width:30px; height:30px; margin-left:4px; }
.demo__cap{ text-align:center; margin-top:18px; color:var(--ink-2); font-size:.95rem; }
.demo__note{ text-align:center; margin-top:6px; color:var(--ink-3); font-family:var(--f-mono); font-size:11px; }

.founding{ position:relative; border:1px solid var(--brand-line); border-radius:var(--radius-lg); background:var(--brand-tint); padding:clamp(24px,3.4vw,42px); display:grid; grid-template-columns:1.25fr .9fr; gap:clamp(22px,3vw,40px); align-items:center; margin-top:36px; box-shadow:var(--sh-1); }
.founding__badges{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:18px; }
.founding__badge{ font-family:var(--f-mono); font-size:11px; letter-spacing:.02em; padding:6px 11px; border-radius:999px; border:1px solid var(--brand-line); background:var(--brand-soft); color:var(--brand-strong); }
.founding__price{ font-size:clamp(1.5rem,3.4vw,2.1rem); letter-spacing:-.02em; margin:8px 0 4px; }
.founding__price s{ color:var(--ink-3); font-size:.6em; margin-left:8px; text-decoration-thickness:1px; }
.founding__give{ color:var(--ink-2); font-size:.95rem; margin:14px 0 0; }
.founding__aside{ display:flex; flex-direction:column; gap:12px; }
.founding__aside .btn{ width:100%; }

.vgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:50px; }
.vcard{ position:relative; display:flex; flex-direction:column; background:var(--paper); border:1px solid var(--line-2); border-radius:var(--radius); padding:clamp(22px,2.2vw,30px); text-decoration:none; color:inherit; transition:box-shadow .4s var(--ease), transform .4s var(--ease), border-color .4s var(--ease); }
.vcard:hover{ box-shadow:var(--sh-2); transform:translateY(-2px); border-color:var(--brand-line); }
.vcard__ico{ width:34px; height:34px; color:var(--brand); display:grid; place-items:center; border:1px solid var(--brand-line); border-radius:var(--radius-sm); background:var(--brand-soft); padding:6px; margin-bottom:16px; }
.vcard h3{ font-size:1.16rem; letter-spacing:-.018em; margin:0 0 8px; }
.vcard p{ margin:0 0 16px; color:var(--ink-2); font-size:.93rem; line-height:1.55; }
.vcard .go{ margin-top:auto; font-family:var(--f-mono); font-size:11px; color:var(--brand-strong); }

.tgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:36px; }
.tcard{ background:var(--paper); border:1px dashed var(--line-3); border-radius:var(--radius); padding:26px; color:var(--ink-3); font-size:.93rem; line-height:1.55; display:flex; flex-direction:column; gap:14px; min-height:170px; }
.tcard__who{ display:flex; align-items:center; gap:10px; margin-top:auto; }
.tcard__av{ width:34px; height:34px; border-radius:50%; background:var(--brand); color:#fff; display:grid; place-items:center; font-family:var(--f-mono); font-size:12px; flex:0 0 auto; }

@media (max-width:820px){
  .founding{ grid-template-columns:1fr; }
  .vgrid{ grid-template-columns:1fr; }
  .tgrid{ grid-template-columns:1fr; }
}

/* Early-Access durchgestrichener Regulärpreis (Compliance-Tier) */
.tier__was{ font-family:var(--f-mono); font-size:11.5px; color:var(--ink-3); margin:-2px 0 12px; letter-spacing:.2px; }
.tier__was s{ color:var(--ink-4); }

/* ============================================================
   Abwechselnde Sektions-Hintergründe (klare Kontrast-Rhythmik,
   Hell + Dunkel). Der Brand-Tint-Wash gibt der hellen Seite die
   „grüne" Tiefe, die bisher nur Dark hatte.
   ============================================================ */
.sp--alt{
  background:
    radial-gradient(120% 70% at 50% 0%, var(--brand-tint), transparent 58%),
    var(--bg-alt);
  border-block: 1px solid var(--line-2);
}
/* etwas mehr Hell-Mode-Leben im Hero (subtiler grüner Anflug oben) */
[data-theme="light"] .hero{
  background: radial-gradient(90% 55% at 78% 0%, var(--brand-tint), transparent 60%);
}
