/* === Design tokens === */
:root{
  --ink:#0A0A0B; --ink-2:#121216; --ink-3:#1B1B20;
  --paper:#FFFFFF; --paper-2:#F4F4F2;
  --line:#E6E6E2; --line-dk:#24242A;
  --muted:#6C6C74; --muted-dk:#90909C;
  --accent:#2E5BFF; --accent-dk:#1E45D8; --accent-soft:rgba(46,91,255,.10);
  --maxw:1180px;
  --display:"Orbitron",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --body:"Rajdhani",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --mono:"Rajdhani",ui-monospace,monospace;
}
/* === Base, typography & shared helpers === */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);
  font-size:18px;line-height:1.62;font-weight:500;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3{font-family:var(--display);font-weight:700;line-height:1.06;letter-spacing:.002em;margin:0 0 .4em}
h1{font-size:clamp(2.05rem,5.2vw,4rem)}
h2{font-size:clamp(1.7rem,3.1vw,2.65rem)}
h3{font-size:1.16rem;letter-spacing:.01em}
p{margin:0 0 1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px}
.accent{color:var(--accent)}

.eyebrow{font-family:var(--body);text-transform:uppercase;letter-spacing:.32em;font-size:.74rem;
  font-weight:700;color:var(--muted);display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--accent)}
.eyebrow.c{justify-content:center}
.dark .eyebrow{color:var(--muted-dk)}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}.d4{transition-delay:.28s}
#progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--accent);z-index:300}

/* === Header & navigation === */
header{position:fixed;top:0;left:0;right:0;z-index:200;transition:background .3s,border-color .3s}
header.solid{background:rgba(255,255,255,.88);backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid var(--line)}
header.on-dark{border-bottom:1px solid transparent}
header.on-dark.solid{background:rgba(10,10,11,.72);border-bottom:1px solid var(--line-dk)}
.nav{display:flex;align-items:center;justify-content:space-between;height:80px;gap:20px}

.brand{display:flex;align-items:center;gap:13px;color:var(--ink)}
.brand .mark{width:172px;height:44px;flex:0 0 auto;background:currentColor;
  -webkit-mask:url(assets/logo-mask.png) left center/contain no-repeat;mask:url(assets/logo-mask.png) left center/contain no-repeat}
.brand .wordmark{display:none}
header.on-dark .brand{color:#fff}
@media(max-width:520px){.brand .mark{width:140px;height:36px}}

.nav-mid{display:flex;gap:40px;align-items:center}
.nav-mid a{font-family:var(--body);font-weight:600;font-size:.94rem;letter-spacing:.05em;
  text-transform:uppercase;color:var(--muted);transition:color .2s;position:relative;padding:6px 0;white-space:nowrap}
.nav-mid a:hover{color:var(--ink)}
.nav-mid a.active{color:var(--ink)}
.nav-mid a.active::after{content:"";position:absolute;left:0;bottom:-3px;width:16px;height:2px;background:var(--accent)}
header.on-dark .nav-mid a{color:var(--muted-dk)}
header.on-dark .nav-mid a:hover,header.on-dark .nav-mid a.active{color:#fff}
.nav-right{display:flex;align-items:center;gap:16px}
/* Keep the top menu on ONE line between 900–1180px (longer PL labels): fluid gap + font, tighter tracking. >=1180px stays roomy via base rules. */
@media(min-width:901px) and (max-width:1179px){
  .nav{gap:clamp(8px,1.2vw,18px)}
  .nav-mid{gap:clamp(10px,1.5vw,24px)}
  .nav-mid a{font-size:clamp(.78rem,1vw,.9rem);letter-spacing:.02em}
  .nav-right{gap:10px}
}

.lang select{font-family:var(--body);font-weight:700;font-size:.84rem;letter-spacing:.1em;
  padding:9px 30px 9px 13px;border:1px solid var(--line);border-radius:8px;background:transparent;color:var(--ink);
  cursor:pointer;-webkit-appearance:none;appearance:none;outline:none;transition:.2s;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236C6C74' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center}
.lang select:hover{border-color:var(--ink)}
header.on-dark .lang select{border-color:var(--line-dk);color:#fff;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23B6B6C2' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E")}
header.on-dark .lang select:hover{border-color:#fff}
.lang option{color:#111;background:#fff}

.cta{font-family:var(--body);font-weight:700;font-size:.9rem;letter-spacing:.07em;text-transform:uppercase;
  padding:12px 22px;border-radius:9px;background:var(--ink);color:#fff;transition:.2s;white-space:nowrap}
.cta:hover{background:var(--ink-3);transform:translateY(-1px)}
header.on-dark .cta{background:#fff;color:var(--ink)}
header.on-dark .cta:hover{background:var(--paper-2)}
.burger{display:none;background:none;border:0;cursor:pointer;color:var(--ink);width:30px;height:30px}
/* Burger must stay visible in every header state: dark hero (on-dark) -> white; otherwise the light .solid bg keeps the dark burger readable */
header.on-dark .burger{color:#fff}
@media(max-width:900px){.nav-mid{display:none}.burger{display:grid;place-items:center}}
.mobile{position:fixed;inset:80px 0 auto 0;z-index:190;background:var(--ink);color:#fff;
  border-bottom:1px solid var(--line-dk);transform:translateY(-12px);opacity:0;pointer-events:none;transition:.25s}
.mobile.open{transform:none;opacity:1;pointer-events:auto}
.mobile a{display:block;padding:18px 30px;border-top:1px solid var(--line-dk);
  text-transform:uppercase;letter-spacing:.05em;font-weight:600}

.btn{display:inline-flex;align-items:center;gap:11px;font-family:var(--body);font-weight:700;font-size:1rem;
  letter-spacing:.05em;text-transform:uppercase;padding:16px 30px;border-radius:11px;cursor:pointer;
  border:1px solid transparent;transition:.2s}
.btn svg{transition:transform .2s}.btn:hover svg{transform:translateX(4px)}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:var(--paper-2);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--ink-3);transform:translateY(-2px)}
.btn-line{background:transparent;border-color:rgba(255,255,255,.26);color:#fff}
.btn-line:hover{border-color:#fff}

section{padding:110px 0}
.center{text-align:center}
.sec-head{max-width:720px}.sec-head.center{margin:0 auto}
.sec-head h2{margin-top:.34em}
.sec-head p{color:var(--muted);font-size:1.16rem;margin-top:.3em}
.dark{background:var(--ink);color:#fff}
.dark h1,.dark h2,.dark h3{color:#fff}
.dark .sec-head p{color:var(--muted-dk)}
.soft{background:var(--paper-2)}

.phero{background:var(--ink);color:#fff;padding:168px 0 92px;position:relative;overflow:hidden}
.phero::before{content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:64px 64px;-webkit-mask:radial-gradient(circle at 78% 12%,#000,transparent 72%);mask:radial-gradient(circle at 78% 12%,#000,transparent 72%)}
.phero::after{content:"";position:absolute;left:0;right:0;top:120px;height:1px;background:var(--accent);opacity:.28;animation:scan 7s linear infinite}
@keyframes scan{0%{transform:translateY(-90px)}100%{transform:translateY(320px)}}
.phero .wrap{position:relative;z-index:2}
.phero p{color:var(--muted-dk);font-size:1.2rem;max-width:60ch}

.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden;padding:108px 0 60px}
.hero::before{content:"";position:absolute;inset:0;opacity:.55;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:64px 64px;-webkit-mask:radial-gradient(circle at 80% 20%,#000,transparent 70%);mask:radial-gradient(circle at 80% 20%,#000,transparent 70%)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.06fr .94fr;gap:54px;align-items:center}
@media(max-width:940px){.hero-grid{grid-template-columns:1fr;gap:30px}}
.kicker{font-family:var(--body);text-transform:uppercase;letter-spacing:.32em;font-size:.76rem;font-weight:700;
  color:var(--muted-dk);margin-bottom:26px;display:flex;align-items:center;gap:12px}
.kicker::before{content:"";width:30px;height:2px;background:var(--accent)}
.hero h1{margin-bottom:.32em}
.hero p.lead{font-size:1.22rem;color:#c6c6d0;max-width:52ch;margin-bottom:36px;font-weight:500}
.actions{display:flex;flex-wrap:wrap;gap:15px;align-items:center}
.hero-note{margin-top:22px;font-size:.92rem;color:var(--muted-dk);letter-spacing:.02em}

.viz{position:relative;width:100%;max-width:580px;margin-left:auto;aspect-ratio:1/1}
@media(max-width:940px){.viz{max-width:460px;margin:6px auto 0}}
.viz svg{width:100%;height:100%;overflow:visible}

.strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:14px;overflow:hidden}
@media(max-width:760px){.strip{grid-template-columns:1fr}}
.stat{background:var(--paper);padding:40px 34px}
.stat .num{font-family:var(--display);font-size:2.6rem;font-weight:700;line-height:1}
.stat .num .u{color:var(--muted)}
.stat .cap{color:var(--muted);font-size:1rem;margin-top:14px}

.features{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:920px){.features{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.features{grid-template-columns:1fr}}
.feat{border:1px solid var(--line);border-radius:14px;padding:34px 30px;background:var(--paper);transition:.25s}
.feat:hover{border-color:var(--ink);transform:translateY(-4px)}
.feat .ic{width:48px;height:48px;border:1px solid var(--line);border-radius:11px;display:grid;place-items:center;
  margin-bottom:22px;color:var(--ink);transition:.25s}
.feat:hover .ic{background:var(--ink);color:#fff;border-color:var(--ink)}
.feat h3{margin-bottom:.4em}
.feat p{color:var(--muted);font-size:1rem;margin:0}
.feat .no{font-family:var(--display);font-size:.82rem;color:var(--muted);letter-spacing:.1em;margin-bottom:16px}
.dark .feat{background:var(--ink-2);border-color:var(--line-dk)}
.dark .feat h3{color:#fff}.dark .feat p{color:var(--muted-dk)}
.dark .feat .ic{border-color:var(--line-dk);color:#fff}
.dark .feat:hover{border-color:var(--muted-dk)}

.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-dk);transform:translateY(-2px)}

.plans{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;align-items:stretch;margin-top:54px}
@media(max-width:920px){.plans{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.plans{grid-template-columns:1fr}}
.plan{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;
  padding:32px 26px;background:var(--paper);transition:.25s;position:relative}
.plan:hover{border-color:var(--ink);transform:translateY(-4px)}
.plan.popular{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.plan.popular:hover{border-color:var(--accent)}
.plan .badge{position:absolute;top:-12px;left:26px;background:var(--accent);color:#fff;font-family:var(--display);
  font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;border-radius:7px}
.plan .pname{font-family:var(--display);font-size:.92rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.plan .price{font-family:var(--display);font-weight:700;font-size:2.5rem;line-height:1;margin-top:14px;color:var(--ink)}
.plan .price .per{font-family:var(--body);font-size:1rem;font-weight:600;color:var(--muted);letter-spacing:0}
.plan .pdesc{color:var(--muted);font-size:.97rem;margin:12px 0 0}
.plan .terms{margin:22px 0 26px}
.plan .terms li{font-size:.97rem;margin-bottom:13px}
.plan .terms .mk{color:var(--accent)}
.plan .btn{width:100%;justify-content:center;margin-top:auto;padding:14px 22px}
.plan .btn-line{border-color:var(--line);color:var(--ink)}
.plan .btn-line:hover{border-color:var(--ink);background:var(--paper-2)}
.price-note{color:var(--muted);font-size:.92rem;text-align:center;margin-top:30px}
.price-note a{color:var(--accent);text-decoration:underline}
.dark .terms .mk{color:var(--accent)}
a.feat{display:block;color:var(--ink)}
a.feat .feat-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
a.feat .feat-row svg{flex:0 0 auto;color:var(--muted);transition:transform .2s,color .2s}
a.feat:hover .feat-row svg{transform:translateX(4px);color:var(--ink)}

.compare{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:16px;overflow:hidden}
@media(max-width:720px){.compare{grid-template-columns:1fr}}
.compare>div{padding:40px 36px}
.compare .old{background:var(--paper)}
.compare .new{background:var(--ink);color:#fff}
.compare h3{font-size:1.25rem;margin-bottom:18px}
.compare .new h3{color:#fff}
.cmp-li{display:flex;gap:13px;padding:15px 0;border-top:1px solid var(--line);color:var(--muted);font-size:1.02rem;align-items:flex-start}
.compare .new .cmp-li{border-color:var(--line-dk);color:var(--muted-dk)}
.cmp-li .mk{flex:0 0 auto;margin-top:3px;color:var(--muted)}
.compare .new .cmp-li .mk{color:var(--accent)}

.terminal{max-width:780px;margin:50px auto 0;background:var(--ink-2);border:1px solid var(--line-dk);
  border-radius:14px;overflow:hidden;box-shadow:0 30px 60px -40px rgba(0,0,0,.6)}
.term-bar{display:flex;align-items:center;gap:8px;padding:15px 18px;border-bottom:1px solid var(--line-dk)}
.term-bar i{width:11px;height:11px;border-radius:50%;background:#33333c;display:inline-block}
.term-bar span{margin-left:12px;font-family:var(--mono);font-size:.82rem;color:var(--muted-dk);letter-spacing:.06em}
.term-body{padding:26px 28px;font-family:var(--mono);font-size:1.08rem;line-height:1.95;color:#cfd2dd}
.term-prompt{color:var(--accent);font-weight:700}
.term-q{color:#fff}
.type{display:inline-block;overflow:hidden;white-space:nowrap;vertical-align:bottom;
  animation:type 7s steps(40,end) infinite;max-width:42ch}
@keyframes type{0%{width:0}35%{width:42ch}88%{width:42ch}100%{width:0}}
.cursor{display:inline-block;width:9px;height:19px;background:var(--accent);vertical-align:-4px;margin-left:2px;animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.term-a{display:block;margin-top:14px;color:var(--muted-dk);font-size:.98rem}

.offer-card{display:grid;grid-template-columns:.92fr 1.08fr;background:#fff;
  border:1px solid var(--line);border-radius:18px;overflow:hidden}
@media(max-width:900px){.offer-card{grid-template-columns:1fr}}
.offer-l{padding:50px;background:var(--paper-2);border-right:1px solid var(--line)}
@media(max-width:900px){.offer-l{border-right:0;border-bottom:1px solid var(--line)}}
.spec{font-family:var(--mono);font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  display:flex;align-items:center;gap:10px;margin-bottom:26px}
.spec::before{content:"";width:8px;height:8px;background:var(--accent);border-radius:50%}
.bigprice{display:flex;align-items:baseline;gap:14px;font-family:var(--display)}
.bigprice .pct{font-size:3.5rem;font-weight:700}
.bigprice .ctx{color:var(--muted);font-size:1.04rem;font-family:var(--body);font-weight:600}
.terms{list-style:none;padding:0;margin:28px 0 0}
.terms li{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px;font-size:1.02rem}
.terms .mk{flex:0 0 auto;margin-top:4px;color:var(--ink)}
.pbar{height:6px;border-radius:99px;background:var(--line);overflow:hidden;margin-top:34px}
.pbar i{display:block;height:100%;width:15%;border-radius:99px;background:var(--ink)}
.pmeta{display:flex;justify-content:space-between;font-size:.84rem;color:var(--muted);margin-top:12px;
  text-transform:uppercase;letter-spacing:.06em;font-weight:700;font-family:var(--mono)}

.offer-r{padding:50px;background:#fff}
.offer-r h3{font-size:1.5rem;margin-bottom:.2em}
.offer-r .sub{color:var(--muted);font-size:1.02rem;margin-bottom:30px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:520px){.frow{grid-template-columns:1fr}}
.field{margin-bottom:22px}.field.full{grid-column:1/-1}
label{display:block;font-family:var(--mono);font-size:.74rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);margin-bottom:9px}
label .req{color:var(--accent)}
input,select.fld,textarea{width:100%;padding:9px 2px;border:0;border-bottom:1px solid var(--line);border-radius:0;
  background:transparent;color:var(--ink);font-size:1.04rem;font-family:var(--body);font-weight:600;outline:none;transition:border-color .2s}
textarea{resize:vertical;min-height:78px}
select.fld{-webkit-appearance:none;appearance:none;cursor:pointer;padding-right:26px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='13' viewBox='0 0 24 24' fill='none' stroke='%236C6C74' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 2px center}
input::placeholder,textarea::placeholder{color:#b3b3ba}
input:focus,select.fld:focus,textarea:focus{border-bottom-color:var(--accent)}
.btn-submit{width:100%;justify-content:center;background:var(--ink);color:#fff;margin-top:6px;border:0}
.btn-submit:hover{background:var(--ink-3);transform:translateY(-2px)}
.consent{font-size:.84rem;color:var(--muted);margin-top:16px;line-height:1.5;text-transform:none;letter-spacing:0;font-weight:500;font-family:var(--body)}
.consent a{color:var(--ink);text-decoration:underline}
.msg{display:none;margin-top:16px;padding:13px 15px;border-radius:10px;font-size:.96rem}
.msg.ok{display:block;background:var(--accent-soft);color:var(--accent-dk);border:1px solid rgba(46,91,255,.3)}
.msg.err{display:block;background:#fdecec;color:#a32d2d;border:1px solid #f1c4c4}

.faq{max-width:860px;margin:0 auto}
details{border-bottom:1px solid var(--line);padding:4px 2px}
summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:24px 0;font-family:var(--display);font-weight:600;font-size:1.1rem}
summary::-webkit-details-marker{display:none}
.chev{flex:0 0 auto;width:22px;height:22px;transition:.3s;color:var(--muted)}
details[open] .chev{transform:rotate(45deg);color:var(--accent)}
details p{color:var(--muted);margin:0;padding:0 0 26px;font-size:1.04rem;max-width:72ch}

footer{background:var(--ink);color:var(--muted-dk);padding:62px 0 42px}
.foot-top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:30px;align-items:flex-start;
  padding-bottom:36px;border-bottom:1px solid var(--line-dk)}
.foot-brand{color:#fff}
.foot-brand .brand{color:#fff;margin-bottom:16px}
.foot-tag{max-width:36ch;font-size:.98rem}
.foot-nav{display:flex;gap:48px;flex-wrap:wrap}
.foot-nav h4{font-family:var(--body);text-transform:uppercase;letter-spacing:.12em;font-size:.76rem;
  color:#fff;margin:0 0 14px;font-weight:700}
.foot-nav a{display:block;color:var(--muted-dk);font-size:.96rem;margin-bottom:9px;transition:.2s}
.foot-nav a:hover{color:#fff}
.foot-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;margin-top:28px;font-size:.9rem;letter-spacing:.02em}
.foot-bottom a{color:#cfd2dd}

/* --- Mobile/tablet refinements (do not affect >=900px desktop) --- */
/* Mobile menu: never let its items overflow below the viewport */
.mobile{max-height:calc(100vh - 80px);max-height:calc(100dvh - 80px);overflow-y:auto;-webkit-overflow-scrolling:touch}
/* Language switch lives in the burger menu on phones (hidden by default; dark-menu styling) */
.lang-mobile{display:none}
.lang-mobile select{width:auto;color:#fff;border-color:var(--line-dk);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23B6B6C2' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E")}
.lang-mobile select:hover{border-color:#fff}
/* Phones: compact header = full logo lockup + CTA + burger; language moves into the burger */
@media(max-width:560px){
  .nav{height:60px;gap:10px}
  /* Full CERTEMIS lockup on phones, just smaller (logo-mask, ~3.9:1 -> 94x24) */
  .brand .mark{width:94px;height:24px;
    -webkit-mask:url(assets/logo-mask.png) left center/contain no-repeat;
    mask:url(assets/logo-mask.png) left center/contain no-repeat}
  header .lang{display:none}
  /* Trimmed so logo + CTA + burger all fit the 300px nav area at 360px */
  header .cta{padding:8px 12px;font-size:.75rem;letter-spacing:.03em}
  .nav-right{gap:10px}
  /* Mobile menu hangs off the now-shorter 60px header */
  .mobile{top:60px;max-height:calc(100vh - 60px);max-height:calc(100dvh - 60px)}
  .mobile .lang-mobile{display:block;padding:16px 30px}
}
/* Phones: tighten section rhythm and oversized paddings that waste width */
@media(max-width:560px){
  section{padding:74px 0}
  .phero{padding:104px 0 64px}
  .hero{padding:104px 0 80px}
}
/* Phones: roomier form by trimming the large card padding */
@media(max-width:520px){
  .offer-l,.offer-r{padding:32px 24px}
  .term-body{font-size:.94rem;padding:20px 18px;line-height:1.8}
  .term-bar{padding:13px 16px}
}

/* === Use-cases zig-zag (page-scoped, additive — does not touch shared rules) === */
.uc-rows{display:flex;flex-direction:column}
.uc-row{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:60px 0}
.uc-row:first-child{padding-top:0}
.uc-row + .uc-row{border-top:1px solid var(--line)}
/* alternating rows: reverse column order for the zig-zag */
.uc-row.rev .uc-text{order:2}
.uc-row.rev .uc-visual{order:1}
.uc-text .eyebrow{margin-bottom:18px}
.uc-text h2{margin:0 0 .5em}
.uc-text p{color:var(--muted);font-size:1.1rem;margin:0 0 15px;max-width:54ch}
.uc-text .terms{margin-top:24px}

.uc-visual{position:relative}
.uc-panel{position:relative;overflow:hidden;display:grid;place-items:center;
  background:var(--ink-2);border:1px solid var(--line-dk);border-radius:18px;
  aspect-ratio:7/5;color:#fff}
.uc-panel::before{content:"";position:absolute;inset:0;opacity:.55;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:40px 40px;-webkit-mask:radial-gradient(circle at 72% 16%,#000,transparent 74%);mask:radial-gradient(circle at 72% 16%,#000,transparent 74%)}
.uc-panel svg{position:relative;z-index:2;width:80%;height:80%;overflow:visible}
/* large faint chapter index watermark inside each panel */
.uc-idx{position:absolute;top:8px;left:16px;z-index:1;pointer-events:none;
  font-family:var(--display);font-weight:700;line-height:1;letter-spacing:.02em;
  font-size:clamp(2.6rem,7vw,4.4rem);color:rgba(255,255,255,.07)}

/* shared SVG primitives for the panels (echo the hero graph aesthetic) */
.uc-edge{stroke:rgba(255,255,255,.16);stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
.uc-edge.dash{stroke:rgba(255,255,255,.3);stroke-dasharray:5 7}
.uc-line{stroke:var(--accent);stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}
.uc-node{fill:#101015;stroke:rgba(255,255,255,.28);stroke-width:1.5}
.uc-node.accent{fill:var(--accent);stroke:var(--accent)}
.uc-node.ghost{fill:none;stroke:rgba(255,255,255,.2);stroke-dasharray:4 5}
.uc-dot{fill:var(--accent)}

@media(max-width:760px){
  .uc-row{grid-template-columns:1fr;gap:30px;padding:44px 0}
  /* mobile: always text first, visual after — even on reversed rows (matches .rev specificity) */
  .uc-row .uc-text,.uc-row.rev .uc-text{order:1}
  .uc-row .uc-visual,.uc-row.rev .uc-visual{order:2}
  .uc-text p{max-width:none}
  .uc-panel{aspect-ratio:16/9}
  .uc-idx{font-size:clamp(2.1rem,11vw,3.2rem)}
}

/* ===================================================================
   Premium motion layer (additive). Everything here is GPU-only
   (transform/opacity/filter; width only on .pbar i) and gated by
   js-ready + prefers-reduced-motion. Without JS or under reduced
   motion the page is fully static and visible.
   =================================================================== */

/* 4. Reveal: add a focus-in blur on top of the existing translateY/opacity */
@media (prefers-reduced-motion: no-preference){
  .reveal{filter:blur(6px);
    transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1),filter .7s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{filter:blur(0)}
}
/* Reduced motion: show everything statically, no transitions/blur */
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;filter:none;transition:none}
}

/* 6. Page transitions — only with JS active AND motion allowed. Default body stays opaque. */
@media (prefers-reduced-motion: no-preference){
  html.js-ready body{opacity:0}
  html.js-ready body.page-in{opacity:1;transition:opacity .4s ease}
  html.js-ready body.page-out{opacity:0;transition:opacity .25s ease}
}

/* 3. Magnetic buttons — JS sets the transform; here we add a softer hover shadow + scale hint.
   Pointer/hover + motion gated so touch and reduced-motion are unaffected. */
@media (hover:hover) and (pointer:fine) and (prefers-reduced-motion: no-preference){
  .btn,.cta{will-change:transform}
  .btn:hover{box-shadow:0 12px 30px -12px rgba(10,10,11,.38)}
  .btn-dark:hover,.btn-line:hover,.btn-accent:hover,.btn-submit:hover{box-shadow:0 14px 34px -14px rgba(0,0,0,.5)}
  .cta:hover{box-shadow:0 10px 24px -12px rgba(10,10,11,.5)}
}

/* 2. Cursor glow — host class + element are only added by JS in rich mode */
.cg-host{position:relative;overflow:hidden}
.cg-host > .wrap{position:relative;z-index:1}
.cursor-glow{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;opacity:0;transition:opacity .5s ease}
.cursor-glow b{position:absolute;top:0;left:0;width:520px;height:520px;margin:-260px 0 0 -260px;border-radius:50%;
  background:radial-gradient(circle, rgba(46,91,255,.10), rgba(46,91,255,0) 65%);will-change:transform}

/* 1. Hero graph parallax wrapper (JS writes translate3d here) */
.viz{will-change:transform}

/* 5. Progress-bar fill (width is the one allowed layout transition) */
@media (prefers-reduced-motion: no-preference){
  html.js-ready .pbar i{transition:width 1.2s cubic-bezier(.2,.7,.2,1)}
}

/* ===================================================================
   Hero memory visualization (lives inside .viz): source nodes + connecting
   lines + flowing particles + a pulsing accent core with the Certemis
   symbol + orbiting points. Base styles = STATIC state (no JS / reduced
   motion); the loops below are layered on only when motion is allowed.
   =================================================================== */
.hero-anim{position:absolute;inset:0;font-family:var(--body);color:#fff}

/* connecting lines: faint base (.ln) + accent particles flowing node -> core (.fl) */
.ha-lines{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.ha-lines .ln{stroke:rgba(255,255,255,.20);stroke-width:1;fill:none;vector-effect:non-scaling-stroke}
.ha-lines .fl{stroke:var(--accent);stroke-width:1.7;fill:none;stroke-linecap:round;
  stroke-dasharray:2.5 21;stroke-dashoffset:23.5;vector-effect:non-scaling-stroke}

/* source nodes on a ring around the core */
/* anchor = the DOT's centre (so connecting lines meet the node exactly); label hangs below */
.ha-src{position:absolute;width:18px;height:18px;transform:translate(-50%,-50%)}
.ha-dot{display:block;width:18px;height:18px;border-radius:50%;background:#16161c;border:2px solid rgba(255,255,255,.6);box-shadow:0 0 0 5px rgba(255,255,255,.045)}
.ha-lbl{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);font-size:clamp(.66rem,1.45vw,.84rem);font-weight:600;letter-spacing:.03em;color:#dde0ea;white-space:nowrap}
.ha-src.s1{left:50%;top:12%}.ha-src.s2{left:84%;top:31%}.ha-src.s3{left:84%;top:69%}
.ha-src.s4{left:50%;top:88%}.ha-src.s5{left:16%;top:69%}.ha-src.s6{left:16%;top:31%}

/* orbiting accent points */
.ha-orbit{position:absolute;left:50%;top:50%;width:42%;height:42%;transform:translate(-50%,-50%);border-radius:50%}
.ha-orbit i{position:absolute;width:7px;height:7px;border-radius:50%;background:var(--accent);transform:translate(-50%,-50%);opacity:0}
.ha-orbit i:nth-child(1){left:50%;top:0}
.ha-orbit i:nth-child(2){left:93.3%;top:75%}
.ha-orbit i:nth-child(3){left:6.7%;top:75%}

/* core: blue circle + white Certemis symbol (CSS mask, like .brand .mark) + ping rings */
.ha-core{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:clamp(64px,15vw,96px);height:clamp(64px,15vw,96px);border-radius:50%;background:var(--accent);
  display:grid;place-items:center;box-shadow:0 0 0 8px rgba(46,91,255,.12),0 0 34px -8px rgba(46,91,255,.4)}
.ha-sym{width:52%;height:52%;background:#fff;
  -webkit-mask:url(assets/symbol-mask.png) center/contain no-repeat;
  mask:url(assets/symbol-mask.png) center/contain no-repeat}
.ha-ping{position:absolute;inset:0;border-radius:50%;border:1.5px solid var(--accent);opacity:.4}

@keyframes ha-flow{from{stroke-dashoffset:23.5}to{stroke-dashoffset:0}}
@keyframes ha-ping{0%{transform:scale(1);opacity:.55}70%{transform:scale(2.4);opacity:0}100%{opacity:0}}
@keyframes ha-spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes ha-draw{from{stroke-dashoffset:60}to{stroke-dashoffset:0}}
@keyframes ha-src-in{from{opacity:0;transform:translate(-50%,-50%) scale(.5)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
@keyframes ha-core-in{from{opacity:0;transform:translate(-50%,-50%) scale(.3)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
@keyframes ha-core-glow{0%,100%{box-shadow:0 0 0 8px rgba(46,91,255,.12),0 0 34px -8px rgba(46,91,255,.4)}50%{box-shadow:0 0 0 13px rgba(46,91,255,.18),0 0 60px -2px rgba(46,91,255,.7)}}
@keyframes ha-orbit-in{from{opacity:0}to{opacity:.5}}
@keyframes hero-in{from{opacity:0;transform:translateY(16px);filter:blur(7px)}to{opacity:1;transform:none;filter:blur(0)}}

/* Motion ON (pure CSS, no JS needed): one-time entrance + slow ambient loops (~13s) */
@media (prefers-reduced-motion: no-preference){
  .ha-src{animation:ha-src-in 1s cubic-bezier(.2,.7,.2,1) both}
  .ha-src.s2{animation-delay:.12s}.ha-src.s3{animation-delay:.24s}.ha-src.s4{animation-delay:.36s}
  .ha-src.s5{animation-delay:.48s}.ha-src.s6{animation-delay:.60s}

  .ha-lines .ln{stroke-dasharray:60;animation:ha-draw 1.5s ease both}
  .ha-lines .fl{animation:ha-flow 5.5s linear infinite}
  .ha-lines .fl.f2{animation-delay:-.9s}.ha-lines .fl.f3{animation-delay:-1.8s}
  .ha-lines .fl.f4{animation-delay:-2.7s}.ha-lines .fl.f5{animation-delay:-3.6s}.ha-lines .fl.f6{animation-delay:-4.5s}

  .ha-core{animation:ha-core-in 1.1s .4s cubic-bezier(.2,.7,.2,1) both, ha-core-glow 6s ease-in-out 1.6s infinite}
  .ha-ping{opacity:0;animation:ha-ping 4.4s ease-out 1.4s infinite}
  .ha-ping.p2{animation-delay:3.6s}

  .ha-orbit{animation:ha-spin 13s linear infinite}
  .ha-orbit i{animation:ha-orbit-in 1.2s 1.1s both}

  /* Hero text (left column): one-time cascade — fade-up + focus-in (~1s) */
  .hero .kicker,.hero h1,.hero p.lead,.hero .actions,.hero .hero-note{animation:hero-in .8s cubic-bezier(.2,.7,.2,1) both}
  .hero h1{animation-delay:.09s}
  .hero p.lead{animation-delay:.18s}
  .hero .actions{animation-delay:.27s}
  .hero .hero-note{animation-delay:.36s}
}

/* Reduced motion: static memory map — nodes, faint lines, core+symbol; no particles/spin/pulse */
@media (prefers-reduced-motion: reduce){
  .ha-lines .fl{display:none}
  .ha-orbit{display:none}
}

/* Very narrow phones: drop source labels for clarity */
@media (max-width:480px){
  .ha-lbl{display:none}
}

/* ===================================================================
   How-it-works vertical timeline (page-scoped). Single accent rail with
   numbered nodes; line segments draw per-step on reveal (existing IO),
   nodes pulse. Reduced motion / no JS: static line + nodes.
   =================================================================== */
.tl{position:relative;--n:64px;max-width:820px}
.tl-item{position:relative;display:grid;grid-template-columns:var(--n) 1fr;gap:28px;align-items:start;padding:0 0 56px}
.tl-item:last-child{padding-bottom:0}

/* accent connecting line — one segment per step so variable text heights stay connected */
.tl-item::before{content:"";position:absolute;left:calc(var(--n)/2 - 1px);top:0;bottom:0;width:2px;
  background:var(--accent);opacity:.45;z-index:0;
  transform:scaleY(0);transform-origin:top;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.tl-item:first-child::before{top:calc(var(--n)/2)}
.tl-item:last-child::before{bottom:auto;height:calc(var(--n)/2)}
.tl-item.in::before{transform:scaleY(1)}

/* numbered node sitting on the rail */
.tl-node{position:relative;z-index:2;width:var(--n);height:var(--n);border-radius:50%;display:grid;place-items:center;
  background:var(--ink-2);border:2px solid var(--accent);box-shadow:0 0 22px -6px rgba(46,91,255,.6);
  font-family:var(--display);font-weight:700;font-size:1.25rem;color:#fff}
.tl-node span{position:relative;z-index:2}
.tl-node::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:1px solid var(--accent);opacity:0;pointer-events:none}

.tl-body{padding-top:15px}
.tl-body h3{font-size:1.4rem;color:#fff;margin:0 0 .32em}
.tl-body p{color:var(--muted-dk);margin:0;max-width:60ch;font-size:1.06rem}

@keyframes tl-pulse{0%{transform:scale(.92);opacity:.5}70%{transform:scale(1.6);opacity:0}100%{opacity:0}}
@media (prefers-reduced-motion: no-preference){
  .tl-node::after{animation:tl-pulse 3.2s ease-out infinite}
  .tl-item.d1 .tl-node::after{animation-delay:.5s}
  .tl-item.d2 .tl-node::after{animation-delay:1s}
  .tl-item.d3 .tl-node::after{animation-delay:1.5s}
}
/* reduced motion: full static line, no draw/pulse */
@media (prefers-reduced-motion: reduce){
  .tl-item::before{transform:none;transition:none}
}

@media(max-width:560px){
  .tl{--n:52px}
  .tl-item{gap:18px;padding-bottom:42px}
  .tl-node{font-size:1.05rem}
  .tl-body{padding-top:11px}
  .tl-body h3{font-size:1.22rem}
}

/* ===================================================================
   Security bento dashboard (page-scoped): asymmetric grid, one dark
   focal "hero" tile (2x2) + five light tiles. Reuses the .feat look.
   =================================================================== */
.secd{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;grid-auto-rows:minmax(160px,auto)}
.secd-tile{position:relative;display:flex;flex-direction:column;border:1px solid var(--line);border-radius:16px;
  background:var(--paper);padding:28px 26px;transition:.25s}
.secd-tile:hover{border-color:var(--ink);transform:translateY(-4px)}
.secd-ic{flex:0 0 auto;width:46px;height:46px;border:1px solid var(--line);border-radius:11px;display:grid;place-items:center;
  color:var(--ink);margin-bottom:18px;transition:.25s}
.secd-tile:hover .secd-ic{background:var(--ink);color:#fff;border-color:var(--ink)}
.secd-tile h3{font-size:1.14rem;margin:0 0 .4em;color:var(--ink)}
.secd-tile p{color:var(--muted);font-size:1rem;margin:0}

/* focal hero tile — dark, 2x2, subtle HUD grid + accent */
.secd-hero{grid-column:1 / span 2;grid-row:1 / span 2;justify-content:center;overflow:hidden;
  background:var(--ink);border-color:var(--line-dk);color:#fff;padding:40px 38px}
.secd-hero::before{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:46px 46px;-webkit-mask:radial-gradient(circle at 80% 16%,#000,transparent 75%);mask:radial-gradient(circle at 80% 16%,#000,transparent 75%)}
.secd-hero > *{position:relative;z-index:1}
.secd-hero .secd-ic{width:60px;height:60px;border-color:var(--accent);color:#fff;margin-bottom:24px}
.secd-hero .secd-ic svg{width:30px;height:30px}
.secd-hero h3{font-size:clamp(1.5rem,2.4vw,2.05rem);color:#fff;margin-bottom:.42em}
.secd-hero p{color:var(--muted-dk);font-size:1.1rem;max-width:42ch}
.secd-hero:hover{border-color:var(--accent)}
.secd-hero:hover .secd-ic{background:var(--accent);color:#fff;border-color:var(--accent)}

/* tablet: hero full-width banner on top, last tile full-width footer, rest in 2 cols */
@media(max-width:920px){
  .secd{grid-template-columns:repeat(2,1fr)}
  .secd-hero{grid-column:1 / -1;grid-row:auto;justify-content:flex-start}
  .secd > :last-child{grid-column:1 / -1}
}
/* mobile: single column, all full width */
@media(max-width:620px){
  .secd{grid-template-columns:1fr;grid-auto-rows:auto}
  .secd-hero,.secd > :last-child{grid-column:auto}
}

/* ===================================================================
   About — editorial layout (page-scoped): mission statement with an
   accent rule + lead, and values as a numbered vertical axis.
   =================================================================== */
.ab-mission{max-width:980px}
.ab-statement{display:grid;grid-template-columns:4px 1fr;column-gap:34px;margin-top:24px}
.ab-rule{grid-column:1;grid-row:1 / span 2;background:var(--accent);border-radius:2px}
.ab-statement h2{grid-column:2;grid-row:1;margin:0;font-size:clamp(2rem,4.8vw,3.5rem);line-height:1.04;letter-spacing:.004em}
.ab-lead{grid-column:2;grid-row:2;margin:28px 0 0;max-width:54ch;color:var(--muted);
  font-size:clamp(1.1rem,1.5vw,1.3rem);line-height:1.55;font-weight:500}

.ab-values{margin-top:46px;max-width:880px}
.ab-val{display:grid;grid-template-columns:auto 1fr;gap:30px;align-items:start;
  padding:34px 0;border-top:1px solid var(--line)}
.ab-val:last-child{border-bottom:1px solid var(--line)}
.ab-num{font-family:var(--display);font-weight:700;line-height:.9;color:var(--accent);
  font-size:clamp(1.9rem,3.4vw,2.7rem);min-width:2.2ch}
.ab-val-body h3{margin:0 0 .4em;font-size:clamp(1.2rem,2vw,1.5rem)}
.ab-val-body p{margin:0;color:var(--muted);font-size:1.08rem;max-width:60ch}

@media(max-width:560px){
  .ab-statement{column-gap:22px}
  .ab-val{gap:20px;padding:26px 0}
}

/* ===================================================================
   Use-cases — unique animated banner ("knowledge quietly slips away")
   and living scenario panels. Page-scoped; global .phero is untouched.
   =================================================================== */
.uc-hero{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:150px 0 112px}
.uc-hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(circle at 50% 28%,rgba(46,91,255,.12),transparent 60%)}
.uc-hero-inner{position:relative;z-index:2;max-width:880px;margin:0 auto;text-align:center}
.uc-hero .eyebrow{justify-content:center;color:var(--muted-dk)}
.uc-hero h1{font-size:clamp(2.2rem,5.4vw,4rem);line-height:1.04;margin:.32em 0 .34em}
.uc-hero p{color:var(--muted-dk);font-size:clamp(1.05rem,1.6vw,1.32rem);max-width:60ch;margin:0 auto}

/* drifting, fading knowledge particles */
.uc-hero-fx{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.uc-hero-fx span{position:absolute;width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.5);opacity:.22}
.uc-hero-fx span.a{background:var(--accent)}
.uc-hero-fx span.lg{width:7px;height:7px}

/* fading dot trail woven under the copy (theme accent) */
.uc-hero-trail{display:flex;gap:9px;justify-content:center;margin-top:30px}
.uc-hero-trail i{width:7px;height:7px;border-radius:50%;background:var(--accent);opacity:.85}

@keyframes uc-drift{0%{opacity:0;transform:translate3d(0,0,0) scale(.5)}20%{opacity:.5}75%{opacity:.16}100%{opacity:0;transform:translate3d(var(--dx,10px),-46px,0) scale(1.15)}}
@keyframes uc-fadeout{0%,100%{opacity:.85;transform:translateY(0)}60%{opacity:.06;transform:translateY(-4px)}}
@keyframes uc-hero-in{from{opacity:0;transform:translateY(16px);filter:blur(6px)}to{opacity:1;transform:none;filter:blur(0)}}

/* living scenario panels */
@keyframes uc-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.13)}}
@keyframes uc-twinkle{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes uc-ghost{0%,100%{opacity:.5}50%{opacity:.1}}
@keyframes uc-flow{to{stroke-dashoffset:-24}}

@media (prefers-reduced-motion: no-preference){
  .uc-hero-fx span{animation:uc-drift var(--t,9s) ease-in-out var(--d,0s) infinite}
  .uc-hero-trail i{animation:uc-fadeout 3s ease-in-out infinite}
  .uc-hero-trail i:nth-child(2){animation-delay:.4s}
  .uc-hero-trail i:nth-child(3){animation-delay:.8s}

  .uc-hero-inner .eyebrow,.uc-hero-inner h1,.uc-hero-inner p{animation:uc-hero-in .8s cubic-bezier(.2,.7,.2,1) both}
  .uc-hero-inner h1{animation-delay:.1s}
  .uc-hero-inner p{animation-delay:.2s}
  .uc-hero-trail{animation:uc-hero-in .8s cubic-bezier(.2,.7,.2,1) .3s both}

  .uc-panel .uc-node.accent{transform-box:fill-box;transform-origin:center;animation:uc-pulse 3s ease-in-out infinite}
  .uc-panel .uc-node.ghost{animation:uc-ghost 4s ease-in-out infinite}
  .uc-panel .uc-dot{transform-box:fill-box;transform-origin:center;animation:uc-twinkle 3s ease-in-out infinite}
  .uc-panel .uc-dot:nth-of-type(2){animation-delay:.5s}
  .uc-panel .uc-dot:nth-of-type(3){animation-delay:1s}
  .uc-panel .uc-dot:nth-of-type(4){animation-delay:1.5s}
  .uc-panel .uc-dot:nth-of-type(5){animation-delay:2s}
  .uc-panel .uc-line{stroke-dasharray:5 7;animation:uc-flow 2.4s linear infinite}
}

@media(max-width:560px){
  .uc-hero{padding:120px 0 84px}
}

/* ===================================================================
   Product — unique animated banner ("scattered sources -> one layer").
   Left-aligned copy with a memory-layer band beneath: scattered dots
   converge onto one accent line, then disperse, on a loop. Page-scoped;
   global .phero untouched.
   =================================================================== */
.pr-hero{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:148px 0 96px}
.pr-hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(circle at 22% 30%,rgba(46,91,255,.1),transparent 58%)}
.pr-hero-inner{position:relative;z-index:2;max-width:820px}
.pr-hero .eyebrow{color:var(--muted-dk)}
.pr-hero h1{font-size:clamp(2.1rem,4.8vw,3.6rem);line-height:1.05;margin:.3em 0 .34em}
.pr-hero p{color:var(--muted-dk);font-size:clamp(1.05rem,1.55vw,1.28rem);max-width:62ch;margin:0}

/* the forming "memory layer" band */
.pr-hero-layer{position:relative;z-index:1;height:118px;margin-top:50px;overflow:hidden}
.pr-hero-line{position:absolute;left:0;right:0;top:50%;height:2px;border-radius:2px;background:var(--accent);
  opacity:.5;transform-origin:center}
.pr-hero-dot{position:absolute;top:50%;left:var(--x);width:6px;height:6px;margin:-3px 0 0 -3px;border-radius:50%;
  background:rgba(255,255,255,.6);opacity:.55}
.pr-hero-dot.a{background:var(--accent)}

@keyframes pr-converge{0%{transform:translate(var(--sx),var(--sy));opacity:0}16%{opacity:.85}80%{opacity:.85}100%{transform:translate(0,0);opacity:0}}
@keyframes pr-line{0%,100%{opacity:.2;transform:scaleX(.55)}50%{opacity:.7;transform:scaleX(1)}}
@keyframes pr-hero-in{from{opacity:0;transform:translateY(16px);filter:blur(6px)}to{opacity:1;transform:none;filter:blur(0)}}

@media (prefers-reduced-motion: no-preference){
  .pr-hero-dot{animation:pr-converge 8s ease-in-out var(--d,0s) infinite}
  .pr-hero-line{animation:pr-line 8s ease-in-out infinite}
  .pr-hero-inner .eyebrow,.pr-hero-inner h1,.pr-hero-inner p{animation:pr-hero-in .8s cubic-bezier(.2,.7,.2,1) both}
  .pr-hero-inner h1{animation-delay:.1s}
  .pr-hero-inner p{animation-delay:.2s}
}

@media(max-width:560px){
  .pr-hero{padding:120px 0 76px}
  .pr-hero-layer{height:96px;margin-top:40px}
}

/* ===================================================================
   How it works — unique animated banner ("flow / sequence"): a 4-point
   process track with a signal travelling left->right, lighting each node
   in turn (preview of the timeline below). Page-scoped; .phero untouched.
   =================================================================== */
.hw-hero{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:148px 0 92px}
.hw-hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(circle at 18% 28%,rgba(46,91,255,.1),transparent 58%)}
.hw-hero-inner{position:relative;z-index:2;max-width:780px}
.hw-hero .eyebrow{color:var(--muted-dk)}
.hw-hero h1{font-size:clamp(2.1rem,4.8vw,3.6rem);line-height:1.05;margin:.3em 0 .34em}
.hw-hero p{color:var(--muted-dk);font-size:clamp(1.05rem,1.55vw,1.28rem);max-width:60ch;margin:0}

/* the process track */
.hw-hero-track{position:relative;z-index:1;height:74px;margin-top:48px}
.hw-line{position:absolute;left:6%;right:6%;top:30px;height:2px;margin-top:-1px;border-radius:2px;background:rgba(46,91,255,.28)}
.hw-signal{position:absolute;top:30px;left:6%;width:11px;height:11px;margin:-5.5px 0 0 -5.5px;border-radius:50%;
  background:#fff;box-shadow:0 0 16px 3px rgba(46,91,255,.85);opacity:0}
.hw-node{position:absolute;top:30px;width:14px;height:14px;margin:-7px 0 0 -7px;border-radius:50%;
  background:#16161c;border:2px solid var(--accent);opacity:.55}
.hw-num{position:absolute;top:46px;transform:translateX(-50%);font-family:var(--display);font-weight:700;
  font-size:.82rem;letter-spacing:.06em;color:var(--muted-dk);opacity:.7}

@keyframes hw-travel{0%{left:6%;opacity:0}8%{opacity:1}90%{opacity:1}100%{left:94%;opacity:0}}
@keyframes hw-pulse{0%{opacity:.55;transform:scale(1);box-shadow:0 0 0 0 rgba(46,91,255,0)}
  6%{opacity:1;transform:scale(1.32);box-shadow:0 0 20px 2px rgba(46,91,255,.6)}
  26%,100%{opacity:.55;transform:scale(1);box-shadow:0 0 0 0 rgba(46,91,255,0)}}
@keyframes hw-hero-in{from{opacity:0;transform:translateY(16px);filter:blur(6px)}to{opacity:1;transform:none;filter:blur(0)}}

@media (prefers-reduced-motion: no-preference){
  .hw-signal{animation:hw-travel 3.2s linear infinite}
  .hw-node{animation:hw-pulse 3.2s linear infinite}
  .hw-node.n2{animation-delay:1s}
  .hw-node.n3{animation-delay:2s}
  .hw-node.n4{animation-delay:3s}
  .hw-hero-inner .eyebrow,.hw-hero-inner h1,.hw-hero-inner p{animation:hw-hero-in .8s cubic-bezier(.2,.7,.2,1) both}
  .hw-hero-inner h1{animation-delay:.1s}
  .hw-hero-inner p{animation-delay:.2s}
}

@media(max-width:560px){
  .hw-hero{padding:120px 0 72px}
  .hw-hero-track{margin-top:40px}
}

/* ===================================================================
   Security — unique animated banner ("scan / forming protection"): an
   accent scan band sweeps across a faint dot grid, with a discreet
   geometric shield. Page-scoped; global .phero untouched.
   =================================================================== */
.se-hero{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:150px 0 104px}
.se-hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.1) 1.4px,transparent 1.6px);background-size:30px 30px;
  -webkit-mask:radial-gradient(circle at 32% 42%,#000,transparent 80%);mask:radial-gradient(circle at 32% 42%,#000,transparent 80%)}
.se-hero-scan{position:absolute;top:0;bottom:0;left:0;width:170px;z-index:1;pointer-events:none;opacity:0;will-change:transform;
  background:linear-gradient(90deg,transparent 0,rgba(46,91,255,.06) 28%,rgba(46,91,255,.24) 46%,#aec6ff 50%,rgba(46,91,255,.16) 56%,transparent 74%)}
.se-hero-shield{position:absolute;right:-44px;top:50%;transform:translateY(-50%);z-index:0;
  width:min(42vw,420px);opacity:.14;color:var(--accent);pointer-events:none}
.se-hero-shield svg{display:block;width:100%;height:auto}
.se-hero-inner{position:relative;z-index:2;max-width:760px}
.se-hero .eyebrow{color:var(--muted-dk)}
.se-hero h1{font-size:clamp(2.1rem,4.8vw,3.6rem);line-height:1.05;margin:.3em 0 .34em}
.se-hero p{color:var(--muted-dk);font-size:clamp(1.05rem,1.55vw,1.28rem);max-width:60ch;margin:0}

@keyframes se-scan{0%{transform:translateX(-170px)}100%{transform:translateX(calc(100vw + 170px))}}
@keyframes se-hero-in{from{opacity:0;transform:translateY(16px);filter:blur(6px)}to{opacity:1;transform:none;filter:blur(0)}}

@media (prefers-reduced-motion: no-preference){
  .se-hero-scan{opacity:1;animation:se-scan 7s linear infinite}
  .se-hero-inner .eyebrow,.se-hero-inner h1,.se-hero-inner p{animation:se-hero-in .8s cubic-bezier(.2,.7,.2,1) both}
  .se-hero-inner h1{animation-delay:.1s}
  .se-hero-inner p{animation-delay:.2s}
}

@media(max-width:560px){
  .se-hero{padding:120px 0 80px}
  .se-hero-shield{opacity:.1;right:-70px}
}

/* ===================================================================
   About — unique animated banner ("quiet self-building network"): a
   faint constellation whose connection lines slowly draw themselves in
   on a calm, long loop. Page-scoped; global .phero untouched.
   =================================================================== */
.ab-hero{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:166px 0 92px}
/* first content section sits closer to its custom banner (avoids a large empty white band) */
.hero-next{padding-top:56px}
.ab-hero-net{position:absolute;inset:0;z-index:0;pointer-events:none}
.ab-net-lines{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.ab-net-line{stroke:rgba(255,255,255,.3);stroke-width:1;fill:none;vector-effect:non-scaling-stroke;
  stroke-dasharray:1;stroke-dashoffset:0;opacity:.35}
.ab-net-dot{position:absolute;width:6px;height:6px;margin:-3px 0 0 -3px;border-radius:50%;background:rgba(255,255,255,.45);opacity:.5}
.ab-net-dot.a{background:var(--accent);opacity:.7}
.ab-hero-inner{position:relative;z-index:2;max-width:820px}
.ab-hero .eyebrow{color:var(--muted-dk)}
.ab-hero h1{font-size:clamp(2.1rem,4.8vw,3.6rem);line-height:1.05;margin:.3em 0 .36em}
.ab-hero p{color:var(--muted-dk);font-size:clamp(1.05rem,1.55vw,1.3rem);max-width:60ch;margin:0}

@keyframes ab-draw{0%{stroke-dashoffset:1;opacity:0}12%{opacity:.4}45%,82%{stroke-dashoffset:0;opacity:.4}96%{opacity:0}100%{stroke-dashoffset:0;opacity:0}}
@keyframes ab-dot{0%,100%{opacity:.45}50%{opacity:.85}}
@keyframes ab-hero-in{from{opacity:0;transform:translateY(14px);filter:blur(6px)}to{opacity:1;transform:none;filter:blur(0)}}

@media (prefers-reduced-motion: no-preference){
  .ab-net-line{animation:ab-draw 15s ease-in-out infinite}
  .ab-net-line:nth-child(2){animation-delay:.8s}
  .ab-net-line:nth-child(3){animation-delay:1.6s}
  .ab-net-line:nth-child(4){animation-delay:2.4s}
  .ab-net-line:nth-child(5){animation-delay:3.2s}
  .ab-net-line:nth-child(6){animation-delay:4s}
  .ab-net-line:nth-child(7){animation-delay:4.8s}
  .ab-net-line:nth-child(8){animation-delay:5.6s}
  .ab-net-dot{animation:ab-dot 7s ease-in-out infinite}
  .ab-net-dot.a{animation-duration:6s}
  .ab-hero-inner .eyebrow,.ab-hero-inner h1,.ab-hero-inner p{animation:ab-hero-in 1s cubic-bezier(.2,.7,.2,1) both}
  .ab-hero-inner h1{animation-delay:.14s}
  .ab-hero-inner p{animation-delay:.28s}
}

@media(max-width:560px){
  .ab-hero{padding:128px 0 64px}
  .hero-next{padding-top:40px}
}

/* ===================================================================
   Pricing — unique animated banner ("scaling / growth"): accent bars
   rising from a baseline in an ascending staircase, growing in sequence
   then resetting on a loop. Page-scoped; global .phero untouched.
   =================================================================== */
.pc-hero{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:150px 0 96px}
.pc-hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(circle at 20% 30%,rgba(46,91,255,.1),transparent 58%)}
.pc-hero-inner{position:relative;z-index:2;max-width:780px}
.pc-hero .eyebrow{color:var(--muted-dk)}
.pc-hero h1{font-size:clamp(2.1rem,4.8vw,3.6rem);line-height:1.05;margin:.3em 0 .34em}
.pc-hero p{color:var(--muted-dk);font-size:clamp(1.05rem,1.55vw,1.28rem);max-width:62ch;margin:0}

/* the growth chart */
.pc-hero-bars{position:relative;z-index:1;height:120px;margin-top:50px;display:flex;align-items:flex-end;gap:10px}
.pc-hero-bars::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:rgba(255,255,255,.12)}
.pc-bar{flex:1 1 0;height:var(--h,40%);min-width:0;border-radius:3px 3px 0 0;
  background:rgba(46,91,255,.32);transform-origin:bottom;transform:scaleY(1)}
.pc-bar.a{background:var(--accent)}

@keyframes pc-grow{0%{transform:scaleY(0)}30%{transform:scaleY(1)}85%{transform:scaleY(1)}100%{transform:scaleY(0)}}
@keyframes pc-hero-in{from{opacity:0;transform:translateY(16px);filter:blur(6px)}to{opacity:1;transform:none;filter:blur(0)}}

@media (prefers-reduced-motion: no-preference){
  .pc-bar{animation:pc-grow 6.5s cubic-bezier(.2,.7,.2,1) both}
  .pc-bar:nth-child(1){animation-delay:0s}.pc-bar:nth-child(2){animation-delay:.13s}
  .pc-bar:nth-child(3){animation-delay:.26s}.pc-bar:nth-child(4){animation-delay:.39s}
  .pc-bar:nth-child(5){animation-delay:.52s}.pc-bar:nth-child(6){animation-delay:.65s}
  .pc-bar:nth-child(7){animation-delay:.78s}.pc-bar:nth-child(8){animation-delay:.91s}
  .pc-bar:nth-child(9){animation-delay:1.04s}.pc-bar:nth-child(10){animation-delay:1.17s}
  .pc-bar:nth-child(11){animation-delay:1.3s}.pc-bar:nth-child(12){animation-delay:1.43s}
  .pc-hero-inner .eyebrow,.pc-hero-inner h1,.pc-hero-inner p{animation:pc-hero-in .8s cubic-bezier(.2,.7,.2,1) both}
  .pc-hero-inner h1{animation-delay:.1s}
  .pc-hero-inner p{animation-delay:.2s}
}

@media(max-width:560px){
  .pc-hero{padding:120px 0 76px}
  .pc-hero-bars{height:92px;margin-top:40px;gap:6px}
}

/* === Use-cases: per-scenario reality-check stat + "Why it adds up" metrics === */
.uc-stat{margin:24px 0 0;padding:11px 0 11px 18px;border-left:3px solid var(--accent);
  color:var(--muted);font-size:.96rem;line-height:1.5;max-width:60ch}
.uc-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:50px}
.uc-metric-n{font-family:var(--display);font-weight:700;color:var(--accent);line-height:1;font-size:clamp(2rem,4vw,2.9rem)}
.uc-metric-c{color:var(--muted-dk);font-size:1rem;margin-top:12px;max-width:32ch}
.uc-src{margin-top:30px;color:var(--muted-dk);font-size:.86rem;opacity:.85}
.uc-src a{color:#b6b6c2;text-decoration:underline;text-underline-offset:2px;transition:color .2s}
.uc-src a:hover{color:#fff}
@media(max-width:680px){
  .uc-metrics{grid-template-columns:1fr;gap:26px}
}

/* === Scroll-reactive effects (driven by site.js setting --sp / transform) ===
   Without JS or under reduced motion these rest in their natural state. */
/* one bold scroll-progress bar (homepage "the problem" section): fill + a glowing dot
   that travels across as you scroll through the section. Default (no JS / reduced motion)
   rests filled so it reads as an intentional accent rule. */
.sfx-prog{position:relative;width:100%;height:5px;border-radius:99px;background:var(--line)}
.sfx-prog .fill{position:absolute;inset:0;border-radius:99px;background:var(--accent);transform-origin:left;transform:scaleX(var(--sp,1))}
.sfx-prog .dot{position:absolute;top:50%;left:calc(var(--sp,1)*100%);width:16px;height:16px;margin:-8px 0 0 -8px;
  border-radius:50%;background:var(--accent);box-shadow:0 0 16px 4px rgba(46,91,255,.55)}
/* count-up numbers pop in as they enter (scroll-triggered via IntersectionObserver) */
@media (prefers-reduced-motion: no-preference){
  .stat .num{transform-origin:left}
  .stat.sfx-counted .num{animation:sfx-pop .7s cubic-bezier(.2,.7,.2,1)}
}
@keyframes sfx-pop{0%{transform:scale(.6);opacity:.15}55%{opacity:1}100%{transform:scale(1);opacity:1}}

/* ===================================================================
   ROI calculator (pricing.html): controls card (left) + result card (right)
   =================================================================== */
.roi-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:start;margin-top:48px}
@media(max-width:820px){.roi-grid{grid-template-columns:1fr;gap:22px}}

/* left — controls */
.roi-controls{border:1px solid var(--line);border-radius:16px;padding:30px 28px;background:var(--paper)}
.roi-ctrl{margin-bottom:24px}
.roi-ctrl:last-child{margin-bottom:0}
.roi-row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:10px}
.roi-row label{margin:0}

/* range sliders (override the global input rule) */
.roi-controls input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:5px;margin:4px 0 0;padding:0;
  border:0;border-radius:99px;cursor:pointer;background-color:var(--line);
  background-image:linear-gradient(var(--accent),var(--accent));background-repeat:no-repeat;background-size:var(--fp,0%) 100%}
.roi-controls input[type=range]:focus{outline:none}
.roi-controls input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;
  background:var(--accent);border:3px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.22);cursor:pointer}
.roi-controls input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;
  background:var(--accent);border:3px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.22);cursor:pointer}
.roi-controls input[type=range]:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 4px var(--accent-soft)}

/* number field (€ rate) */
.roi-num{display:flex;align-items:center;gap:6px;border-bottom:1px solid var(--line);transition:border-color .2s}
.roi-num:focus-within{border-bottom-color:var(--accent)}
.roi-cur{flex:0 0 auto;font-family:var(--display);font-weight:700;color:var(--muted)}
.roi-num input{flex:1;width:auto;min-width:0;border:0;padding:9px 0;font-family:var(--display);font-weight:700;font-size:1.12rem}
/* manual number field next to each slider */
.roi-numin{flex:0 0 auto;width:76px;text-align:right;border:1px solid var(--line);border-radius:8px;
  padding:5px 8px;font-family:var(--display);font-weight:700;font-size:.98rem;color:var(--ink);background:var(--paper);-moz-appearance:textfield;appearance:textfield}
.roi-numin::-webkit-outer-spin-button,.roi-numin::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.roi-numin:focus{outline:none;border-color:var(--accent)}
.roi-rangenote{margin:10px 0 0;font-size:.82rem;line-height:1.45;color:var(--muted-dk)}

/* right — result card (accent-highlighted, dark) */
.roi-out{position:relative;overflow:hidden;border:1px solid var(--line-dk);border-radius:16px;
  padding:34px 30px;background:var(--ink);color:#fff}
.roi-out::before{content:"";position:absolute;left:0;top:0;right:0;height:4px;background:var(--accent)}
.roi-out .eyebrow{color:var(--muted-dk)}
.roi-big{font-family:var(--display);font-weight:700;line-height:1;color:#fff;margin-top:12px;font-size:clamp(2.5rem,5.5vw,3.6rem)}
.roi-peryear{margin-top:8px;font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-dk)}
.roi-lines{list-style:none;padding:20px 0 0;margin:22px 0 0;border-top:1px solid var(--line-dk)}
.roi-lines li{display:flex;justify-content:space-between;align-items:baseline;gap:14px;margin-bottom:11px;color:var(--muted-dk);font-size:.98rem}
.roi-lines li:last-child{margin-bottom:0}
.roi-n{flex:0 0 auto;font-family:var(--display);font-weight:700;color:#fff;font-size:1.04rem}
.roi-disc{margin-top:20px;font-size:.8rem;line-height:1.5;color:var(--muted-dk);opacity:.85}
.roi-cta{margin-top:22px}

/* ===================================================================
   Integration logos (homepage) — simplified monochrome marks, shown
   honestly as planned connectors (see int.note caption below the grid).
   =================================================================== */
.int-logos{margin-top:46px}
.int-logos-h{display:block;margin-bottom:22px}
.int-logos-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:760px){.int-logos-row{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.int-logos-row{grid-template-columns:repeat(2,1fr)}}
.int-logo{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  padding:22px 12px;border:1px solid var(--line);border-radius:12px;background:var(--paper);
  color:var(--muted);transition:color .25s,border-color .25s,transform .25s}
.int-logo:hover{color:var(--ink);border-color:var(--ink);transform:translateY(-3px)}
.int-logo svg{width:26px;height:26px;flex:0 0 auto}
.int-logo span{font-family:var(--body);font-weight:600;font-size:.92rem;letter-spacing:.01em;text-align:center;line-height:1.2}

.cdemo{max-width:1080px;margin:0 auto;padding:80px 24px}
.cdemo__head{text-align:center;max-width:640px;margin:0 auto 34px}
.cdemo__eyebrow{font-family:'Rajdhani',sans-serif;font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#2E5BFF;margin-bottom:14px}
.cdemo__title{font-family:'Orbitron',sans-serif;font-size:clamp(26px,4vw,40px);margin:0 0 12px}
.cdemo__sub{color:#5b626e;font-size:16px;line-height:1.6;margin:0}
.cdemo__frame{position:relative;border-radius:16px;overflow:hidden;border:1px solid rgba(0,0,0,.12);box-shadow:0 30px 80px rgba(0,0,0,.18);aspect-ratio:16/10;background:#0c0e12}
.cdemo__iframe{position:absolute;top:0;left:0;width:200%;height:200%;transform:scale(.5);transform-origin:top left;border:0;pointer-events:none}
.cdemo__overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-decoration:none;background:radial-gradient(circle at center,rgba(8,10,14,.35),rgba(8,10,14,.72));transition:background .2s;cursor:pointer}
.cdemo__overlay:hover{background:radial-gradient(circle at center,rgba(8,10,14,.22),rgba(8,10,14,.6))}
.cdemo__play{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#2E5BFF;color:#fff;box-shadow:0 8px 30px rgba(46,91,255,.5);transition:transform .2s}
.cdemo__overlay:hover .cdemo__play{transform:scale(1.08)}
.cdemo__btn{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:16px;letter-spacing:.04em;color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.25);padding:12px 22px;border-radius:12px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.cdemo__hint{text-align:center;color:#8a909c;font-size:13px;margin-top:16px}
@media(max-width:640px){.cdemo__frame{aspect-ratio:4/3}}
