/* ICG International — shared styles for inner pages
   Mirrors the design system in index.html (Work Sans · cobalt #0066CC · ink #18181D). */

:root{
  --blue:#0066CC;
  --blue-dk:#0052A6;
  --blue-lt:#4D94EA;
  --blue-soft:#E7F0FB;
  --ink:#18181D;
  --ink-2:#23252E;
  --paper:#FFFFFF;
  --mist:#FAFAFA;
  --text:#23262C;
  --muted:#6B7785;
  --muted-dk:#9AA6B2;
  --line:#EBEDEE;
  --line-dk:#2E313B;
  --maxw:1160px;
  --r:4px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:'Work Sans',system-ui,sans-serif;
  color:var(--text);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

h1,h2,h3{font-family:'Work Sans',sans-serif;font-weight:600;line-height:1.12;letter-spacing:-0.02em;color:var(--ink)}

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

.eyebrow{font-weight:600;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);display:inline-block}
.eyebrow.on-dark{color:var(--blue-lt)}

a{color:inherit;text-decoration:none}

.btn{
  font-family:'Work Sans',sans-serif;font-weight:600;font-size:.92rem;letter-spacing:.01em;
  display:inline-flex;align-items:center;gap:.5em;
  padding:.9em 1.6em;border-radius:var(--r);
  border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-dk);transform:translateY(-1px)}
.btn-ghost{border-color:var(--line-dk);color:#fff}
.btn-ghost:hover{border-color:var(--blue-lt);color:var(--blue-lt)}
a:focus-visible,.btn:focus-visible{outline:2px solid var(--blue);outline-offset:3px}

/* ---------- logo / header ---------- */
.logo-mark{width:34px;height:34px;display:block;flex:none}
.brand{display:flex;align-items:center;gap:.7em}
.brand .wordmark{font-weight:600;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:#fff}
header{
  position:sticky;top:0;z-index:50;
  background:rgba(24,24,29,.94);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line-dk);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{color:#D7DBE0;font-size:.92rem;font-weight:500;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--blue-lt)}
.nav-cta{display:flex;align-items:center;gap:18px}
@media(max-width:860px){.nav-links{display:none}}
.nav-book .bk-short{display:none}
@media(max-width:600px){
  .brand .wordmark{font-size:.64rem;letter-spacing:.14em}
  .nav-book .bk-full{display:none}
  .nav-book .bk-short{display:inline}
  .nav-book{padding:.58em .95em;font-size:.82rem;white-space:nowrap}
}

/* ---------- hero ---------- */
.hero{background:var(--ink);color:#fff;position:relative;overflow:hidden;padding:84px 0 90px}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 440px at 80% -10%, rgba(0,102,204,.28), transparent 62%),
    radial-gradient(600px 300px at 10% 110%, rgba(0,102,204,.10), transparent 60%);
  pointer-events:none;
}
.hero .wrap{position:relative}
.hero-eyebrow{opacity:0;animation:fade .7s ease forwards}
.hero h1{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:700;margin:.5em 0 .35em;max-width:18ch;color:#fff;opacity:0;animation:rise .8s ease .08s forwards}
.hero p.lead{font-size:clamp(1.05rem,1.7vw,1.24rem);color:#C3C9D0;max-width:56ch;line-height:1.55;opacity:0;animation:rise .8s ease .18s forwards}
.hero-price{margin-top:20px;font-weight:600;color:#fff;font-size:1.02rem;opacity:0;animation:fade .8s ease .4s forwards}
.hero-price span{color:var(--muted-dk);font-weight:500;font-size:.85rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px;opacity:0;animation:rise .8s ease .28s forwards}
.horizon{margin-top:56px;height:2px;background:linear-gradient(90deg,transparent,var(--line-dk) 10%,var(--blue) 50%,var(--line-dk) 90%,transparent);opacity:.8;transform:scaleX(0);transform-origin:center;animation:grow 1.1s ease .5s forwards}

@keyframes fade{to{opacity:1}}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes grow{to{transform:scaleX(1)}}
@media(prefers-reduced-motion:reduce){
  .hero-eyebrow,.hero h1,.hero p.lead,.hero-price,.hero-actions,.horizon{animation:none;opacity:1;transform:none}
}

/* ---------- sections ---------- */
section{padding:88px 0}
.section-head{max-width:62ch;margin-bottom:48px}
.section-head h2{font-size:clamp(1.8rem,3.4vw,2.7rem);margin:.4em 0 .35em}
.section-head p{color:var(--muted);font-size:1.08rem}

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

/* ---------- who it's for ---------- */
.who{background:var(--mist)}
.who .cols{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:start;margin-top:6px}
@media(max-width:780px){.who .cols{grid-template-columns:1fr;gap:24px}}
.who h2{font-size:clamp(1.8rem,3.4vw,2.6rem);max-width:18ch}
.who .body p{color:var(--muted);font-size:1.08rem;margin-bottom:1.1em;max-width:48ch}
.who .body p:last-child{margin-bottom:0}
.who .body p strong{color:var(--text);font-weight:600}

/* ---------- what the role owns ---------- */
.owns-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px 44px}
@media(max-width:720px){.owns-grid{grid-template-columns:1fr;gap:20px}}
.owns-item{position:relative;padding-left:1.6em}
.owns-item::before{content:"";position:absolute;left:0;top:.5em;width:8px;height:8px;border-radius:50%;background:var(--blue)}
.owns-item b{display:block;font-weight:600;font-size:1.06rem;color:var(--ink);margin-bottom:.15em}
.owns-item span{color:var(--muted);font-size:.96rem}

/* ---------- how it works ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:820px){.steps{grid-template-columns:1fr}}
.step{border-top:2px solid var(--line);padding-top:22px}
.step .num{font-weight:600;font-size:.78rem;color:var(--blue);letter-spacing:.1em;text-transform:uppercase}
.step h3{font-size:1.3rem;margin:.5em 0 .35em;font-weight:600}
.step p{color:var(--muted);font-size:.98rem}

/* ---------- credibility ---------- */
.cred{background:var(--ink-2);color:#fff}
.cred .inner{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
@media(max-width:820px){.cred .inner{grid-template-columns:1fr;gap:28px}}
.cred h2{font-size:clamp(1.9rem,3.6vw,2.6rem);color:#fff;max-width:16ch}
.cred p{color:#C3C9D0;font-size:1.06rem;margin-top:1.1em;max-width:54ch}
.cred .net{border-left:2px solid var(--blue);padding-left:24px}
.cred .net p{margin-top:0}

/* ---------- CTA ---------- */
.cta{text-align:center;padding:104px 0}
.cta h2{font-size:clamp(2rem,4vw,2.9rem);max-width:20ch;margin:0 auto .35em}
.cta p{color:var(--muted);font-size:1.1rem;max-width:52ch;margin:0 auto 32px;text-wrap:balance}

/* ---------- footer ---------- */
footer{background:var(--ink);color:#9AA6B2;padding:54px 0 40px;border-top:1px solid var(--line-dk)}
.foot{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px}
.foot p{font-size:.85rem;margin-top:14px}
.foot a{color:#C3C9D0;font-size:.9rem}
.foot a:hover{color:var(--blue-lt)}
.foot-links{display:flex;gap:24px;flex-wrap:wrap}
