/* ============================================================
   iOmniWatch — marketing site
   Enterprise dark security-ops aesthetic
   ============================================================ */

:root{
  --bg:#0a0e14;
  --bg-2:#0c121b;
  --panel:#121821;
  --panel-2:#161e2a;
  --border:#1f2a37;
  --border-2:#27384a;
  --text:#e6edf3;
  --muted:#8a99aa;
  --muted-2:#647183;
  --cyan:#22d3ee;
  --teal:#2dd4bf;
  --accent-grad:linear-gradient(135deg,#22d3ee,#2dd4bf);
  --glow:0 0 0 1px rgba(34,211,238,.18), 0 18px 50px -18px rgba(34,211,238,.35);
  --radius:14px;
  --radius-sm:10px;
  --maxw:1180px;
  --ease:cubic-bezier(.16,.84,.32,1);
  --font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

h1,h2,h3{line-height:1.15;letter-spacing:-.02em;margin:0 0 .5em;font-weight:700}
h1{font-size:clamp(2.4rem,6vw,4rem)}
h2{font-size:clamp(1.7rem,3.6vw,2.6rem)}
h3{font-size:1.15rem}
p{margin:0 0 1rem}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%}
ul,ol{margin:0;padding:0;list-style:none}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

.grad-text{
  background:var(--accent-grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}

.skip-link{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--cyan);color:#04121a;padding:.6rem 1rem;border-radius:0 0 8px 0;font-weight:600;
}
.skip-link:focus{left:0}

:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:4px}

/* ---------------- Buttons ---------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:inherit;font-size:.95rem;font-weight:600;
  padding:.7rem 1.25rem;border-radius:10px;border:1px solid transparent;
  cursor:pointer;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s,border-color .2s,color .2s;
  white-space:nowrap;
}
.btn--primary{background:var(--accent-grad);color:#04121a;box-shadow:0 8px 24px -10px rgba(34,211,238,.6)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(34,211,238,.75)}
.btn--ghost{background:rgba(255,255,255,.02);color:var(--text);border-color:var(--border-2)}
.btn--ghost:hover{border-color:var(--cyan);color:#fff;transform:translateY(-2px);box-shadow:0 0 0 1px rgba(34,211,238,.25)}
.btn--lg{padding:.9rem 1.6rem;font-size:1rem}
.btn--block{width:100%}

/* ---------------- Nav ---------------- */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(10,14,20,.72);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,background .3s;
}
.nav.is-scrolled{border-bottom-color:var(--border);background:rgba(10,14,20,.92)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:68px}

.brand{display:inline-flex;align-items:center;gap:.6rem;font-size:1.2rem;letter-spacing:-.02em}
.brand__text{font-weight:500;color:var(--text)}
.brand__text strong{font-weight:800}
.brand__mark{flex:none}
.brand__ring{transform-origin:center}
.brand__sweep{transform-origin:20px 20px;animation:sweep 4s linear infinite}
@keyframes sweep{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.brand__sweep{animation:none}}

.nav__links{display:flex;align-items:center;gap:1.6rem}
.nav__links a{color:var(--muted);font-size:.95rem;font-weight:500;transition:color .2s}
.nav__links a:hover{color:var(--text)}
.nav__links .nav__cta{color:#04121a}
.nav__links .nav__cta:hover{color:#04121a}

.nav__toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;background:none;border:1px solid var(--border);border-radius:10px;cursor:pointer}
.nav__toggle span{display:block;height:2px;width:20px;margin:0 auto;background:var(--text);transition:transform .3s var(--ease),opacity .2s}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------------- Hero ---------------- */
.hero{position:relative;padding:clamp(3.5rem,9vw,7rem) 0 clamp(3rem,7vw,5.5rem);overflow:hidden}
.hero__glow{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(60% 50% at 75% 5%,rgba(34,211,238,.16),transparent 60%),
    radial-gradient(50% 40% at 10% 85%,rgba(45,212,191,.12),transparent 60%);
}
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.4;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(70% 60% at 50% 30%,#000,transparent 80%);
  mask-image:radial-gradient(70% 60% at 50% 30%,#000,transparent 80%);
}
.hero__inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:3.5rem;align-items:center}

.eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-size:.82rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:1.1rem}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px rgba(45,212,191,.18);animation:pulse 2.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.hero__title{margin-bottom:1.25rem}
.hero__sub{font-size:clamp(1.05rem,1.5vw,1.2rem);color:var(--muted);max-width:38ch;margin-bottom:2rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2.5rem}

.hero__stats{display:flex;gap:2.2rem;flex-wrap:wrap}
.hero__stats li{display:flex;flex-direction:column}
.hero__stats strong{font-size:1.6rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.hero__stats span{font-size:.85rem;color:var(--muted-2)}

/* Hero visual: camera grid */
.hero__visual{position:relative}
.cam-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
  padding:16px;border:1px solid var(--border);border-radius:18px;
  background:linear-gradient(180deg,var(--panel),var(--bg-2));
  box-shadow:var(--glow);
}
.cam-tile{
  position:relative;aspect-ratio:4/3;border-radius:10px;
  background:radial-gradient(120% 120% at 30% 0%,#1a2533,#0c1119);
  border:1px solid var(--border);overflow:hidden;
}
.cam-tile .cam-id{position:absolute;left:8px;bottom:6px;font-size:.62rem;letter-spacing:.1em;color:var(--muted-2);font-weight:600}
.cam-tile--live{border-color:rgba(34,211,238,.4)}
.cam-tile .rec{position:absolute;right:8px;top:6px;font-size:.6rem;font-weight:700;color:#ff5b6e;letter-spacing:.08em;animation:pulse 1.6s infinite}
.cam-tile .scan{position:absolute;left:0;right:0;top:0;height:30%;background:linear-gradient(180deg,rgba(34,211,238,.22),transparent);animation:scan 3s ease-in-out infinite}
@keyframes scan{0%,100%{transform:translateY(-30%)}50%{transform:translateY(330%)}}
.cam-tile .box{position:absolute;border:1.5px solid var(--teal);border-radius:4px;box-shadow:0 0 12px rgba(45,212,191,.45)}
.cam-tile .box--person{width:26%;height:46%;left:30%;top:34%;border-color:var(--cyan)}
.cam-tile .box--vehicle{width:48%;height:34%;left:26%;top:44%}
.cam-tile .box::after{content:"";position:absolute;top:-7px;left:-1px;width:9px;height:5px;background:inherit;border-radius:2px;background:var(--teal)}

.cam-tile--radar{display:grid;place-items:center;background:radial-gradient(closest-side,#0e1722,#0a0e14)}
.radar{width:84%;height:84%}
.radar__circle{fill:none;stroke:rgba(34,211,238,.22);stroke-width:1}
.radar__sweep{stroke:var(--cyan);stroke-width:1.5;transform-origin:60px 60px;animation:sweep 3.4s linear infinite;filter:drop-shadow(0 0 4px rgba(34,211,238,.7))}
.radar__blip{fill:var(--teal);animation:pulse 2.4s infinite}
.radar__blip--2{animation-delay:1.2s}
@media (prefers-reduced-motion:reduce){.cam-tile .scan,.radar__sweep,.cam-tile .rec,.eyebrow .dot{animation:none}}

/* ---------------- Trust strip ---------------- */
.trust{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-2)}
.trust__inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding:1.4rem 24px}
.trust__label{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-2);font-weight:600}
.trust__brands{display:flex;flex-wrap:wrap;gap:1.4rem 2rem}
.trust__brands li{font-weight:700;font-size:1.02rem;color:var(--muted);letter-spacing:.01em;transition:color .2s,text-shadow .2s}
.trust__brands li:hover{color:var(--text);text-shadow:0 0 18px rgba(34,211,238,.35)}

/* ---------------- Sections ---------------- */
.section{padding:clamp(4rem,8vw,7rem) 0;position:relative}
.section--alt{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.section__head{max-width:680px;margin:0 auto clamp(2.5rem,5vw,3.5rem);text-align:center}
.kicker{font-size:.8rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:.7rem}
.lede{color:var(--muted);font-size:1.08rem}

/* ---------------- Architecture diagram ---------------- */
.arch{
  display:grid;grid-template-columns:1fr auto 1fr;gap:1.5rem;align-items:stretch;
  max-width:980px;margin:0 auto;
}
.arch__col{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);position:relative}
.arch__col--lan{background:linear-gradient(180deg,var(--panel),#0e141d)}
.arch__col--cloud{background:linear-gradient(180deg,rgba(34,211,238,.04),var(--panel))}
.arch__tag{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted-2);font-weight:700}
.arch__node{border:1px solid var(--border-2);border-radius:10px;padding:1rem;background:rgba(255,255,255,.015);display:flex;flex-direction:column;gap:.2rem}
.arch__node small{color:var(--muted-2);font-size:.78rem}
.arch__node .ico{width:30px;height:30px;color:var(--cyan);margin-bottom:.3rem}
.arch__node strong{font-size:1rem}
.arch__node ul{margin-top:.5rem;display:grid;gap:.3rem}
.arch__node ul li{font-size:.82rem;color:var(--muted);padding-left:1rem;position:relative}
.arch__node ul li::before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--teal)}
.arch__node--edge{border-color:rgba(34,211,238,.35);box-shadow:inset 0 0 30px -20px rgba(34,211,238,.6)}
.arch__node--control{border-color:rgba(45,212,191,.35);box-shadow:inset 0 0 30px -20px rgba(45,212,191,.6)}
.arch__flow{display:flex;justify-content:center;padding:.1rem 0}
.arch__flow span{width:1px;height:22px;background:linear-gradient(180deg,var(--cyan),transparent);position:relative}
.arch__flow span::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--cyan)}
.arch__link{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem}
.arch__link-label{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);font-weight:700}
.arch__link-line{width:90px;height:2px;background:repeating-linear-gradient(90deg,var(--cyan) 0 8px,transparent 8px 16px);opacity:.6}

/* ---------------- Grids / cards ---------------- */
.grid{display:grid;gap:1.25rem}
.grid--features{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.card{
  padding:1.6rem;border:1px solid var(--border);border-radius:var(--radius);
  background:var(--panel);transition:transform .25s var(--ease),border-color .25s,box-shadow .25s,background .25s;
}
.card:hover{transform:translateY(-4px);border-color:var(--border-2);background:var(--panel-2);box-shadow:0 20px 40px -24px rgba(0,0,0,.8),0 0 0 1px rgba(34,211,238,.12)}
.card__icon{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:12px;background:rgba(34,211,238,.1);border:1px solid rgba(34,211,238,.25);margin-bottom:1rem}
.card__icon svg{width:24px;height:24px;fill:none;stroke:var(--cyan);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.card h3{margin-bottom:.4rem}
.card p{color:var(--muted);font-size:.93rem;margin:0}

/* ---------------- Steps ---------------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;counter-reset:step;position:relative}
.step{position:relative;padding:1.5rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel)}
.step__num{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;font-weight:800;font-size:1.1rem;color:#04121a;background:var(--accent-grad);margin-bottom:1rem;box-shadow:0 8px 20px -8px rgba(34,211,238,.6)}
.step h3{margin-bottom:.4rem}
.step p{color:var(--muted);font-size:.92rem;margin:0}

/* ---------------- Pricing ---------------- */
.billing-toggle{display:inline-flex;align-items:center;gap:.9rem;margin-top:1.6rem}
.billing-toggle__opt{font-size:.92rem;color:var(--muted);font-weight:600;transition:color .2s}
.billing-toggle__opt.is-active{color:var(--text)}
.billing-toggle__opt em{font-style:normal;font-size:.72rem;color:var(--teal);background:rgba(45,212,191,.12);padding:.1rem .45rem;border-radius:99px;margin-left:.3rem}
.switch{position:relative;width:52px;height:28px;border-radius:99px;border:1px solid var(--border-2);background:var(--panel);cursor:pointer;padding:0;transition:background .2s,border-color .2s}
.switch[aria-checked="true"]{background:rgba(34,211,238,.18);border-color:var(--cyan)}
.switch__thumb{position:absolute;top:2px;left:2px;width:22px;height:22px;border-radius:50%;background:var(--accent-grad);transition:transform .25s var(--ease)}
.switch[aria-checked="true"] .switch__thumb{transform:translateX(24px)}

.grid--pricing{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));align-items:start}
.plan{position:relative;padding:2rem 1.6rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);display:flex;flex-direction:column;transition:transform .25s var(--ease),border-color .25s,box-shadow .25s}
.plan:hover{transform:translateY(-4px);border-color:var(--border-2)}
.plan--featured{border-color:rgba(34,211,238,.45);background:linear-gradient(180deg,rgba(34,211,238,.06),var(--panel));box-shadow:var(--glow)}
.plan__badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent-grad);color:#04121a;font-size:.7rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:.3rem .8rem;border-radius:99px;white-space:nowrap}
.plan__name{font-size:1.3rem;margin-bottom:.1rem}
.plan__cams{color:var(--muted);font-size:.85rem;margin-bottom:1rem}
.plan__price{display:flex;align-items:flex-start;gap:.1rem;margin:0 0 .2rem;line-height:1}
.plan__cur{font-size:1.3rem;font-weight:700;margin-top:.45rem;color:var(--muted)}
.plan__amount{font-size:3rem;font-weight:800;letter-spacing:-.03em;color:#fff}
.plan__price--custom .plan__amount{font-size:2.4rem;background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.plan__per{font-size:.95rem;color:var(--muted);align-self:flex-end;margin-bottom:.55rem}
.plan__billed{font-size:.8rem;color:var(--muted-2);margin-bottom:1.3rem;min-height:1.1em}
.plan__cta{margin-bottom:1.4rem}
.plan__feats{display:grid;gap:.6rem}
.plan__feats li{position:relative;padding-left:1.6rem;font-size:.9rem;color:var(--muted)}
.plan__feats li::before{content:"";position:absolute;left:0;top:.15em;width:16px;height:16px;border-radius:50%;background:rgba(45,212,191,.14);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M4 8l2.5 2.5L12 5' fill='none' stroke='%232dd4bf' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.pricing__note{text-align:center;color:var(--muted-2);font-size:.85rem;margin:2rem auto 0;max-width:60ch}

/* ---------------- Security band ---------------- */
.section--security{background:radial-gradient(80% 120% at 90% 0%,rgba(34,211,238,.07),transparent 60%),var(--bg)}
.security__grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.security__copy{position:sticky;top:90px}
.security__copy .section__head{text-align:left;margin:0}
.security__copy h2,.security__copy .lede{text-align:left}
.security__legal{margin-top:1.3rem;padding:1rem 1.2rem;border-left:2px solid var(--teal);background:rgba(45,212,191,.05);border-radius:0 8px 8px 0;font-size:.9rem;color:var(--muted)}
.security__legal a{color:var(--cyan);text-decoration:underline;text-underline-offset:2px}
.security__list{display:grid;gap:1rem}
.security__list li{display:flex;gap:1rem;align-items:flex-start;padding:1.1rem 1.2rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel)}
.security__list svg{flex:none;width:26px;height:26px;fill:none;stroke:var(--cyan);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;margin-top:2px}
.security__list strong{display:block;font-size:1rem;margin-bottom:.15rem}
.security__list span{color:var(--muted);font-size:.88rem}

/* ---------------- Final CTA ---------------- */
.cta{padding:clamp(4rem,8vw,6rem) 0;position:relative;overflow:hidden}
.cta__inner{
  text-align:center;max-width:760px;margin:0 auto;padding:clamp(2.5rem,6vw,4rem) 2rem;
  border:1px solid rgba(34,211,238,.3);border-radius:24px;
  background:radial-gradient(120% 140% at 50% 0%,rgba(34,211,238,.12),transparent 60%),var(--panel);
  box-shadow:var(--glow);
}
.cta__inner p{color:var(--muted);font-size:1.1rem;margin-bottom:2rem}
.cta__buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---------------- Footer ---------------- */
.footer{border-top:1px solid var(--border);background:var(--bg-2);padding-top:3rem}
.footer__inner{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding-bottom:2.5rem}
.footer__tag{color:var(--muted);margin:.8rem 0 .3rem;font-size:.95rem}
.footer__oss{color:var(--muted-2);font-size:.82rem;margin:0}
.footer__links{display:flex;gap:1.6rem;flex-wrap:wrap;align-items:flex-start}
.footer__links a{color:var(--muted);font-size:.92rem;transition:color .2s}
.footer__links a:hover{color:var(--cyan)}
.footer__bar{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:1.3rem 24px;border-top:1px solid var(--border);margin-top:0}
.footer__bar p{margin:0;color:var(--muted-2);font-size:.84rem}

/* ---------------- Modal ---------------- */
.modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:1.5rem}
.modal[hidden]{display:none}
.modal__overlay{position:absolute;inset:0;background:rgba(4,8,13,.78);backdrop-filter:blur(4px);animation:fade .25s var(--ease)}
.modal__panel{
  position:relative;width:100%;max-width:460px;max-height:92vh;overflow:auto;
  background:var(--panel);border:1px solid var(--border-2);border-radius:18px;padding:2.2rem;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.8),var(--glow);
  animation:pop .3s var(--ease);
}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:none}}
.modal__close{position:absolute;top:1rem;right:1.1rem;width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:1.4rem;line-height:1;cursor:pointer;transition:color .2s,border-color .2s}
.modal__close:hover{color:#fff;border-color:var(--border-2)}
.modal__intro{color:var(--muted);font-size:.95rem;margin-bottom:1.5rem}
.modal__fineprint{font-size:.78rem;color:var(--muted-2);text-align:center;margin:.9rem 0 0}

.field{margin-bottom:1rem}
.field label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.35rem;color:var(--text)}
.field input,.field select{
  width:100%;padding:.7rem .85rem;font-family:inherit;font-size:.95rem;color:var(--text);
  background:var(--bg);border:1px solid var(--border-2);border-radius:10px;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field select:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(34,211,238,.15)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' fill='none' stroke='%238a99aa' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .85rem center;padding-right:2.2rem}
.field--invalid input,.field--invalid select{border-color:#ff5b6e}
.field__error{color:#ff8a96;font-size:.85rem;margin:0 0 .8rem}

.modal__success{text-align:center;padding:1rem 0}
.modal__check{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:rgba(45,212,191,.14);border:1px solid rgba(45,212,191,.4);margin-bottom:1.2rem}
.modal__check svg{width:30px;height:30px;fill:none;stroke:var(--teal);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:30;stroke-dashoffset:30;animation:draw .5s .15s var(--ease) forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.modal__success p{color:var(--muted);margin-bottom:1.5rem}

/* ---------------- Scroll reveal ---------------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------------- Body scroll lock ---------------- */
body.no-scroll{overflow:hidden}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:900px){
  .hero__inner{grid-template-columns:1fr;gap:2.5rem}
  .hero__visual{order:-1;max-width:460px}
  .hero__sub{max-width:none}
  .arch{grid-template-columns:1fr;gap:1.2rem}
  .arch__link{flex-direction:row;padding:.2rem 0}
  .arch__link-line{width:60%;height:2px;background:repeating-linear-gradient(90deg,var(--cyan) 0 8px,transparent 8px 16px)}
  .security__grid{grid-template-columns:1fr;gap:2rem}
  .security__copy{position:static}
}

@media (max-width:720px){
  .nav__toggle{display:flex}
  .nav__links{
    position:fixed;top:68px;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:.4rem;
    background:rgba(10,14,20,.98);backdrop-filter:blur(14px);
    border-bottom:1px solid var(--border);
    padding:1rem 24px 1.5rem;
    transform:translateY(-12px);opacity:0;pointer-events:none;visibility:hidden;
    transition:opacity .25s var(--ease),transform .25s var(--ease),visibility .25s;
  }
  .nav__links.is-open{transform:none;opacity:1;pointer-events:auto;visibility:visible}
  .nav__links a{padding:.7rem .25rem;font-size:1.05rem;border-bottom:1px solid var(--border)}
  .nav__links a:last-child{border-bottom:none}
  .nav__cta{margin-top:.5rem;justify-content:center}
  .trust__inner{justify-content:center;text-align:center}
  .footer__bar{justify-content:center;text-align:center}
}

@media (max-width:480px){
  .container{padding:0 18px}
  .hero__stats{gap:1.4rem}
  .modal__panel{padding:1.7rem}
  .btn--lg{width:100%}
  .hero__cta .btn,.cta__buttons .btn{flex:1 1 auto}
}
