/* ICWT Google Ads landing pages — shared system
   Tokens locked from owner-approved brand system (trifold/marketing rebuild). */

:root{
  --bg:#F4F1EC;
  --ink:#1E2A3A;
  --navy:#162235;
  --navy-2:#1C2B44;
  --slate:#5F6B78;
  --blue:#6B8FA6;
  --blue-text:#53718A;   /* darker blue for small text on cream (AA) */
  --blue2:#A9C2CF;
  --orange:#FB923C;
  --orange-soft:#FDBA74;
  --bdr:#E1DCD2;
  --card:#FFFFFF;
  --card-2:#F0EDE7;
  --ok:#4F8F6A;
  --err:#A65A5A;
  --radius:14px;
  --shadow:0 18px 50px -18px rgba(22,34,53,.28);
  --shadow-soft:0 10px 30px -14px rgba(22,34,53,.18);
  --wrap:1160px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI','Helvetica Neue',Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
a{color:var(--blue-text)}
strong{font-weight:600}
::selection{background:var(--orange-soft);color:var(--navy)}

.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:.6rem 1rem;z-index:100;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

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

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}

/* ---------- type ---------- */
.eyebrow{
  font-size:.78rem;font-weight:600;letter-spacing:.19em;text-transform:uppercase;
  color:var(--blue-text);
}
.on-navy .eyebrow,.navy .eyebrow{color:var(--blue2)}
h1{
  font-weight:600;letter-spacing:-.022em;line-height:1.06;
  font-size:clamp(2.35rem,5.2vw,4.05rem);
  text-wrap:balance;
}
h1 mark{
  background:var(--orange);color:var(--navy);
  padding:.04em .18em;border-radius:.14em;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;
}
h2{
  font-weight:600;letter-spacing:-.015em;line-height:1.12;
  font-size:clamp(1.7rem,3.1vw,2.5rem);text-wrap:balance;
}
h3{font-weight:600;font-size:1.12rem;letter-spacing:-.01em;line-height:1.25}
.lede{font-size:clamp(1.05rem,1.6vw,1.28rem);line-height:1.55;color:var(--slate);max-width:34em}
.on-navy .lede{color:var(--blue2)}
.section-head{max-width:44em;margin-bottom:2.6rem}
.section-head .eyebrow{display:block;margin-bottom:.9rem}
.section-head p{color:var(--slate);margin-top:.85rem;max-width:38em}

/* ---------- header ---------- */
.lp-header{
  position:relative;z-index:5;
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--wrap);margin:0 auto;padding:20px 24px;
}
.lp-header .logo img{height:34px;width:auto}
.lp-header .head-contact{display:flex;align-items:center;gap:1.2rem;font-size:.92rem}
.lp-header .head-phone{font-weight:600;text-decoration:none;color:inherit;white-space:nowrap}
.lp-header .head-note{color:var(--slate)}
.navy .lp-header .head-note,.on-navy .head-note{color:var(--blue2)}
.navy .lp-header .head-phone{color:#fff}
@media(max-width:640px){.lp-header .head-note{display:none}}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font);font-weight:600;font-size:1.02rem;letter-spacing:.005em;
  padding:.95rem 1.7rem;border-radius:10px;border:0;cursor:pointer;
  text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
}
.btn-primary{background:var(--orange);color:var(--navy);box-shadow:0 10px 26px -10px rgba(251,146,60,.55)}
.btn-primary:hover{background:var(--orange-soft);transform:translateY(-1px)}
.btn-primary:active{transform:translateY(0)}
.btn-ghost{background:transparent;color:inherit;border:1.5px solid var(--bdr)}
.on-navy .btn-ghost,.navy .btn-ghost{border-color:rgba(169,194,207,.4);color:#fff}
.btn-block{width:100%}

/* ---------- hero: variant B (navy face) ---------- */
.hero-b{
  background:
    radial-gradient(1100px 620px at 78% -10%,rgba(107,143,166,.24),transparent 60%),
    radial-gradient(900px 700px at -5% 110%,rgba(107,143,166,.14),transparent 55%),
    var(--navy);
  color:#fff;position:relative;overflow:hidden;
}
.hero-b .rings{
  position:absolute;right:-180px;top:-220px;width:820px;height:820px;
  opacity:.5;pointer-events:none;
}
.hero-b .hero-grid{
  position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:3.4rem;
  max-width:var(--wrap);margin:0 auto;padding:3.2rem 24px 4.4rem;
  align-items:start;
}
.hero-copy .eyebrow{display:block;margin-bottom:1.15rem}
.hero-copy .lede{margin-top:1.3rem}
.hero-points{list-style:none;margin-top:1.7rem;display:grid;gap:.65rem}
.hero-points li{
  display:flex;gap:.65rem;align-items:baseline;color:#E9EDF2;font-size:1.0rem;
}
.hero-points li::before{content:"";flex:0 0 8px;width:8px;height:8px;border-radius:50%;background:var(--blue);transform:translateY(-1px)}
.hero-trust{
  margin-top:2.1rem;padding-top:1.5rem;border-top:1px solid rgba(169,194,207,.22);
  display:flex;flex-wrap:wrap;gap:1.4rem 2.2rem;
}
.hero-trust .t{display:flex;flex-direction:column;gap:.15rem}
.hero-trust .t b{font-size:1.28rem;font-weight:600;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.hero-trust .t span{font-size:.8rem;color:var(--blue2)}

/* ---------- hero: variant A (dossier) ---------- */
.hero-a{border-bottom:1px solid var(--bdr);position:relative;overflow:hidden}
.hero-a .rings{position:absolute;right:-260px;top:-300px;width:900px;height:900px;opacity:.35;pointer-events:none}
.hero-a .hero-grid{
  position:relative;display:grid;grid-template-columns:1.2fr .8fr;gap:3.2rem;
  max-width:var(--wrap);margin:0 auto;padding:3rem 24px 4rem;align-items:start;
}
.hero-a .rule{width:64px;height:4px;background:var(--blue);margin:1.4rem 0 1.5rem;border-radius:2px}

/* ---------- hero: variant C (konsola / split) ---------- */
.hero-c{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.hero-c .rings{position:absolute;left:-260px;bottom:-340px;width:860px;height:860px;opacity:.4;pointer-events:none}
.hero-c .hero-grid{
  position:relative;display:grid;grid-template-columns:1fr minmax(380px,460px);gap:0;
  max-width:var(--wrap);margin:0 auto;align-items:stretch;
}
.hero-c .hero-copy{padding:3.4rem 3rem 3.4rem 24px;align-self:center}
.hero-c .hero-form-col{
  background:rgba(244,241,236,.06);border-left:1px solid rgba(169,194,207,.18);
  padding:2.6rem 24px 2.6rem 2.6rem;display:flex;align-items:center;
}
@media(max-width:960px){
  .hero-b .hero-grid,.hero-a .hero-grid,.hero-c .hero-grid{grid-template-columns:1fr;gap:2.2rem}
  .hero-c .hero-copy{padding:2.6rem 24px 0}
  .hero-c .hero-form-col{border-left:0;padding:0 24px 2.6rem;background:transparent}
}

/* ---------- urgency strip (DDoS emergency) ---------- */
.urgency{
  background:var(--orange);color:var(--navy);
  font-weight:500;font-size:.95rem;
}
.urgency .wrap{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.6rem 24px;flex-wrap:wrap;text-align:center}
.urgency a{color:var(--navy);font-weight:600;white-space:nowrap}

/* ---------- form card ---------- */
.form-card{
  background:var(--card);color:var(--ink);
  border:1px solid var(--bdr);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:1.9rem 1.9rem 1.6rem;
}
.form-card .fc-title{font-size:1.28rem;font-weight:600;letter-spacing:-.01em;line-height:1.25}
.form-card .fc-sub{font-size:.92rem;color:var(--slate);margin-top:.45rem}
.form-card form{margin-top:1.35rem;display:grid;gap:.95rem}
.field label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.35rem}
.field label .opt{color:var(--slate);font-weight:400}
.field input,.field textarea{
  width:100%;font-family:var(--font);font-size:1rem;color:var(--ink);
  background:#FBFAF7;border:1.5px solid var(--bdr);border-radius:9px;
  padding:.78rem .9rem;transition:border-color .15s ease;
}
.field input:focus,.field textarea:focus{border-color:var(--blue);outline:none}
.field input[aria-invalid="true"]{border-color:var(--err)}
.field .ferr{display:none;font-size:.8rem;color:var(--err);margin-top:.3rem}
.field .ferr.show{display:block}
.hp{position:absolute!important;left:-9999px!important;height:0;overflow:hidden}
.form-msg{display:none;font-size:.92rem;border-radius:9px;padding:.75rem .9rem}
.form-msg.ok{display:block;background:#EAF3EE;color:#2F6247;border:1px solid #CFE3D7}
.form-msg.fail{display:block;background:#F6ECEC;color:#7C3B3B;border:1px solid #E4CDCD}
.rodo{font-size:.74rem;color:var(--slate);line-height:1.45;margin-top:.35rem}
.rodo a{color:var(--slate)}
.fc-alt{margin-top:1.1rem;padding-top:1rem;border-top:1px solid var(--bdr);font-size:.88rem;color:var(--slate);text-align:center}
.fc-alt a{font-weight:600;color:var(--ink);text-decoration:none}

/* ---------- sticky rail (variant A) ---------- */
.rail{position:sticky;top:24px}

/* ---------- sections ---------- */
section{padding:4.4rem 0}
@media(max-width:640px){section{padding:3.1rem 0}}
.sec-alt{background:var(--card-2)}
.sec-navy{background:var(--navy);color:#fff}
.sec-navy .section-head p{color:var(--blue2)}

/* clients band */
.clients{padding:1.9rem 0;border-bottom:1px solid var(--bdr);background:var(--card)}
.clients .wrap{display:flex;align-items:center;gap:1.2rem 2.6rem;flex-wrap:wrap;justify-content:center}
.clients .c-label{font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--slate)}
.clients .c-name{font-size:1.02rem;font-weight:600;color:var(--slate);letter-spacing:-.01em;opacity:.85}

/* scope cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:960px){.cards{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.cards{grid-template-columns:1fr}}
.card{
  background:var(--card);border:1px solid var(--bdr);border-radius:var(--radius);
  padding:1.6rem;box-shadow:var(--shadow-soft);
}
.sec-navy .card{background:rgba(244,241,236,.05);border-color:rgba(169,194,207,.18);box-shadow:none}
.card h3{margin-bottom:.55rem}
.card p{font-size:.95rem;color:var(--slate);line-height:1.5}
.sec-navy .card p{color:var(--blue2)}
.card .k{font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-text);display:block;margin-bottom:.7rem}
.sec-navy .card .k{color:var(--blue2)}

/* process (real sequence -> numbers justified) */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
@media(max-width:960px){.process{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.process{grid-template-columns:1fr}}
.step{position:relative;padding:1.5rem 1.4rem;background:var(--card);border:1px solid var(--bdr);border-radius:var(--radius)}
.step .n{font-size:2.1rem;font-weight:600;color:var(--blue);letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1}
.step h3{margin:.8rem 0 .45rem}
.step p{font-size:.92rem;color:var(--slate);line-height:1.5}
.step .d{font-size:.78rem;font-weight:600;color:var(--blue-text);margin-top:.7rem;letter-spacing:.04em}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;text-align:left}
@media(max-width:820px){.stats{grid-template-columns:1fr 1fr}}
.stat b{display:block;font-size:clamp(2.2rem,4vw,3.2rem);font-weight:600;letter-spacing:-.025em;line-height:1;font-variant-numeric:tabular-nums}
.stat b i{font-style:normal;color:var(--blue)}
.stat span{display:block;font-size:.86rem;color:var(--slate);margin-top:.5rem;max-width:16em}
.sec-navy .stat span{color:var(--blue2)}

/* vendor band */
.vendor{display:flex;align-items:center;gap:2.4rem;flex-wrap:wrap}
.vendor .v-logo{background:var(--card);border:1px solid var(--bdr);border-radius:var(--radius);padding:1.4rem 2rem;display:flex;align-items:center;justify-content:center}
.vendor .v-logo img{height:40px;width:auto}
.vendor .v-copy{flex:1;min-width:280px}
.vendor .v-copy p{color:var(--slate);margin-top:.6rem;max-width:44em}
.sec-navy .vendor .v-logo{background:rgba(244,241,236,.95);border-color:transparent}
.sec-navy .vendor .v-copy p{color:var(--blue2)}

/* quote */
.quote{max-width:52rem}
.quote blockquote{
  font-size:clamp(1.25rem,2.2vw,1.7rem);font-weight:500;letter-spacing:-.012em;line-height:1.4;
}
.quote figcaption{margin-top:1.1rem;font-size:.9rem;color:var(--slate)}
.sec-navy .quote figcaption{color:var(--blue2)}

/* comparison table (KnowBe4 alt) */
.compare{width:100%;border-collapse:collapse;background:var(--card);font-size:.95rem}
.compare th,.compare td{padding:.95rem 1.1rem;text-align:left;border-bottom:1px solid var(--bdr);vertical-align:top}
.compare thead th{background:var(--navy);color:#fff;font-weight:600;font-size:.9rem}
.compare tbody th{font-weight:500;color:var(--slate);width:34%}
.compare td.yes{color:var(--ok);font-weight:500}
.compare-scroll{overflow-x:auto;border-radius:var(--radius);box-shadow:var(--shadow-soft);border:1px solid var(--bdr)}

/* FAQ */
.faq{max-width:52rem}
.faq details{border-bottom:1px solid var(--bdr)}
.faq summary{
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.15rem 0;font-weight:600;font-size:1.02rem;letter-spacing:-.005em;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;font-weight:400;color:var(--blue);transition:transform .2s ease;flex:0 0 auto}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .fa{padding:0 0 1.25rem;color:var(--slate);font-size:.97rem;max-width:46em}

/* final CTA band */
.cta-band{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.cta-band .rings{position:absolute;right:-220px;bottom:-320px;width:760px;height:760px;opacity:.4;pointer-events:none}
.cta-band .inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
@media(max-width:900px){.cta-band .inner{grid-template-columns:1fr}}
.cta-band h2{color:#fff}
.cta-band p{color:var(--blue2);margin-top:.9rem;max-width:34em}

/* footer */
.lp-footer{background:var(--navy);color:var(--blue2);border-top:1px solid rgba(169,194,207,.18);font-size:.82rem}
.lp-footer .wrap{display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;padding-top:1.6rem;padding-bottom:1.8rem}
.lp-footer a{color:var(--blue2)}
.lp-footer .f-brand{display:flex;align-items:center;gap:.9rem}
.lp-footer .f-brand img{height:26px;width:auto}

/* sticky mobile CTA */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:50;
  display:none;gap:.6rem;padding:.6rem .8rem calc(.6rem + env(safe-area-inset-bottom));
  background:rgba(22,34,53,.97);backdrop-filter:blur(8px);
  transform:translateY(110%);transition:transform .25s ease;
}
.sticky-cta.show{transform:translateY(0)}
.sticky-cta .btn{flex:1;padding:.8rem .6rem;font-size:.95rem}
.sticky-cta .btn-ghost{border-color:rgba(169,194,207,.4);color:#fff}
@media(max-width:820px){.sticky-cta{display:flex}}

/* consent banner */
.consent{
  position:fixed;z-index:60;left:16px;right:16px;bottom:16px;max-width:560px;margin:0 auto;
  background:var(--card);border:1px solid var(--bdr);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:1.1rem 1.2rem;display:none;
}
.consent.show{display:block}
.consent p{font-size:.84rem;color:var(--slate);line-height:1.45}
.consent .c-actions{display:flex;gap:.6rem;margin-top:.8rem}
.consent .btn{padding:.55rem 1rem;font-size:.88rem}
.consent .btn-ghost{border-color:var(--bdr);color:var(--ink)}

/* ---------- demo video (product proof) ---------- */
.demo-sec .demo-frame{
  background:#0B1220;border:1px solid rgba(169,194,207,.22);border-radius:var(--radius);
  box-shadow:0 30px 70px -30px rgba(0,0,0,.65);overflow:hidden;max-width:960px;
}
.sec-navy .demo-cap{color:var(--blue2)}
.demo-sec .demo-bar{
  display:flex;align-items:center;gap:6px;padding:10px 14px;
  background:#0F1828;border-bottom:1px solid rgba(169,194,207,.14);
}
.demo-sec .demo-bar i{width:10px;height:10px;border-radius:50%;background:rgba(169,194,207,.28)}
.demo-sec .demo-bar span{margin-left:10px;font-size:.75rem;color:var(--blue2);letter-spacing:.04em}
.demo-sec video{display:block;width:100%;height:auto}
.demo-sec .demo-cap{font-size:.8rem;color:var(--slate);margin-top:.9rem}

/* ---------- hero entrance orchestration ---------- */
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.hero-copy>*{animation:rise .65s cubic-bezier(.2,.7,.2,1) both}
.hero-copy>*:nth-child(2){animation-delay:.07s}
.hero-copy>*:nth-child(3){animation-delay:.14s}
.hero-copy>*:nth-child(4){animation-delay:.21s}
.hero-copy>*:nth-child(5){animation-delay:.28s}
.form-card{animation:rise .7s .3s cubic-bezier(.2,.7,.2,1) both}

/* ---------- micro-interactions ---------- */
.card,.step{transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}
.card:hover,.step:hover{transform:translateY(-3px);box-shadow:0 16px 40px -16px rgba(22,34,53,.26);border-color:var(--blue)}
.sec-navy .card:hover{box-shadow:none;border-color:rgba(169,194,207,.45)}

/* ---------- motion (reveal) ---------- */
.js .rv{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.js .rv.in{opacity:1;transform:none}
.js .rv-d1{transition-delay:.08s}
.js .rv-d2{transition-delay:.16s}
.js .rv-d3{transition-delay:.24s}

/* rings drift — cheap, opacity-safe (never transform translated SVG groups) */
@keyframes ringspin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.rings svg{animation:ringspin 160s linear infinite;transform-origin:50% 50%}

@media (prefers-reduced-motion:reduce){
  .js .rv{opacity:1;transform:none;transition:none}
  .rings svg{animation:none}
  .btn,.sticky-cta{transition:none}
  .hero-copy>*,.form-card{animation:none}
  .card,.step{transition:none}
  .card:hover,.step:hover{transform:none}
}
