/* ================================================================
   THINK'UP — DESIGN SYSTEM v2  ·  LIGHT EDITION
   Palette logo : pink #E535E0 → purple #8B5CF6 → cyan #00C8E8
   Fond : blanc + lavande très clair · Texte : marine foncé
   ================================================================ */

/* 1 · VARIABLES ────────────────────────────────────────────── */
:root {
  --bg:       #FFFFFF;
  --bg-2:     #F8F6FF;   /* lavande ultra-clair */
  --bg-3:     #EFF0FF;   /* lavande clair */
  --surface:  #FFFFFF;
  --surface-2:#F8F6FF;
  --border:   #E5E1F5;
  --border-l: #C8BEF0;

  --pink:     #D020CC;   /* rose logo adapté fond clair */
  --cyan:     #0096B8;   /* cyan logo adapté fond clair */
  --purple:   #7B46E8;   /* violet logo */

  --pink-l:   #F040EC;   /* version lumineuse (déco) */
  --cyan-l:   #00C8E8;
  --purple-l: #9B6AF7;

  --pink-dim:   rgba(208,32,204,.08);
  --cyan-dim:   rgba(0,150,184,.08);
  --purple-dim: rgba(123,70,232,.08);
  --pink-glow:  rgba(208,32,204,.18);
  --cyan-glow:  rgba(0,150,184,.18);

  --grad:    linear-gradient(135deg,#D020CC 0%,#7B46E8 50%,#0096B8 100%);
  --grad-r:  linear-gradient(135deg,#0096B8 0%,#7B46E8 50%,#D020CC 100%);
  --grad-90: linear-gradient(90deg,#D020CC,#7B46E8,#0096B8);
  --grad-bg: linear-gradient(135deg,rgba(208,32,204,.05) 0%,rgba(123,70,232,.04) 50%,rgba(0,150,184,.05) 100%);
  --grad-soft:linear-gradient(135deg,rgba(208,32,204,.04) 0%,rgba(123,70,232,.03) 100%);

  --text:     #18143A;   /* marine très foncé */
  --text-dim: #4A4672;   /* marine moyen */
  --text-mu:  #8882A8;   /* gris-violet muted */
  --white:    #18143A;   /* alias "white" = texte sombre sur fond clair */
  --white-inv:#FFFFFF;   /* vrai blanc pour texte sur gradient */

  --ff-d: 'Cormorant Garamond', Georgia, serif;
  --ff-b: 'DM Sans', system-ui, sans-serif;
  --ff-m: 'DM Mono', 'Courier New', monospace;

  --r:    6px;
  --rl:   14px;
  --maxw: 1180px;
  --navh: 72px;
  --ease: cubic-bezier(.25,.46,.45,.94);
  --sp:   cubic-bezier(.34,1.56,.64,1);
  --sh:   0 2px 24px rgba(24,20,58,.07);
  --sh-l: 0 8px 40px rgba(24,20,58,.10);
}

/* 2 · RESET ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  background:var(--bg);color:var(--text);
  font-family:var(--ff-b);line-height:1.7;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
}

/* 3 · TYPOGRAPHY ─────────────────────────────────────────── */
h1,h2,h3,h4{font-family:var(--ff-d);line-height:1.1;color:var(--text)}
h1{font-size:clamp(2.4rem,5.5vw,4.2rem);font-weight:300;letter-spacing:-.02em}
h2{font-size:clamp(1.7rem,3.5vw,2.9rem);font-weight:300;letter-spacing:-.015em}
h3{font-size:clamp(1.1rem,2.2vw,1.5rem);font-weight:400}
h4{font-size:.95rem;font-weight:600;font-family:var(--ff-b);color:var(--text)}
p{color:var(--text-dim);max-width:65ch;line-height:1.75}
strong{color:var(--text);font-weight:600}
a{color:var(--purple);text-decoration:none;transition:opacity .2s}
a:hover{opacity:.75}

.grad-text{
  background:var(--grad);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.label{
  display:inline-block;
  font-family:var(--ff-m);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:1rem;
}

/* 4 · LAYOUT ─────────────────────────────────────────────── */
.container{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.25rem,5vw,3.5rem)}
section{position:relative}
.section-gap{padding:6rem 0}
.section-gap-sm{padding:3.5rem 0}
.bg-2{background:var(--bg-2)}
.bg-3{background:var(--bg-3)}

/* 5 · NAV ────────────────────────────────────────────────── */
nav#nav{
  position:fixed;top:0;left:0;right:0;z-index:200;height:var(--navh);
  background:rgba(255,255,255,.95);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  transition:box-shadow .3s;
}
nav#nav.scrolled{box-shadow:var(--sh)}
.nav-in{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--navh);
}
.nav-logo{display:flex;align-items:center;height:46px}
.nav-logo img{height:42px;width:auto;display:block}
.nav-logo:hover{opacity:1}

.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{
  color:var(--text-dim);font-size:.875rem;letter-spacing:.02em;
  position:relative;padding-bottom:3px;transition:color .2s;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;
  background:var(--grad);border-radius:1px;
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);
}
.nav-links a:hover,.nav-links a.active{color:var(--text);opacity:1}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}

.nav-cta{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.55rem 1.3rem;
  background:var(--grad);color:var(--white-inv)!important;
  font-weight:600;font-size:.85rem;border-radius:var(--r);
  transition:transform .25s var(--sp),box-shadow .25s;opacity:1!important;
  box-shadow:0 3px 16px var(--pink-glow);
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 6px 24px var(--pink-glow)}

/* burger mobile */
.nav-burger{
  display:none;flex-direction:column;gap:5px;cursor:pointer;
  background:none;border:none;padding:4px;
}
.nav-burger span{display:block;width:22px;height:2px;background:var(--text);border-radius:1px;transition:all .3s}

/* 6 · BUTTONS ────────────────────────────────────────────── */
.btn-p{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.85rem 1.9rem;
  background:var(--grad);color:var(--white-inv);
  font-weight:600;font-size:.925rem;border-radius:var(--r);
  border:none;cursor:pointer;font-family:var(--ff-b);
  box-shadow:0 4px 20px var(--pink-glow);
  transition:transform .25s var(--sp),box-shadow .25s;
}
.btn-p:hover{transform:translateY(-3px);box-shadow:0 10px 32px var(--pink-glow);color:var(--white-inv);opacity:1}

.btn-g{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.85rem 1.9rem;
  border:1.5px solid var(--border-l);color:var(--text);
  font-size:.925rem;border-radius:var(--r);background:transparent;
  transition:all .25s;cursor:pointer;font-family:var(--ff-b);
}
.btn-g:hover{border-color:var(--purple);background:var(--purple-dim);color:var(--purple);opacity:1}

.btn-row{display:flex;gap:.85rem;flex-wrap:wrap;align-items:center}

/* 7 · REVEAL ─────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* 8 · PAGE HERO (inner pages) ────────────────────────────── */
.page-hero{
  padding:calc(var(--navh)+4.5rem) 0 4rem;
  background:var(--bg-2);
  border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;
  top:-120px;right:-120px;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(123,70,232,.07) 0%,transparent 70%);
  pointer-events:none;
}
.page-hero-in{position:relative;z-index:1;max-width:760px}
.page-hero h1{margin-bottom:1.1rem}
.page-hero p{font-size:1.05rem;max-width:58ch}

/* 9 · STAT BAR ───────────────────────────────────────────── */
.stats-bar{padding:2.25rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat-n{
  font-family:var(--ff-d);font-size:clamp(1.7rem,3vw,2.6rem);font-weight:300;line-height:1;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.stat-l{font-size:.77rem;color:var(--text-mu);letter-spacing:.03em;margin-top:.3rem}

/* 10 · CARDS ─────────────────────────────────────────────── */
.card{
  padding:2rem;background:var(--surface);
  border:1.5px solid var(--border);border-radius:var(--rl);
  box-shadow:var(--sh);transition:border-color .3s,transform .3s,box-shadow .3s;
}
.card:hover{border-color:var(--border-l);transform:translateY(-5px);box-shadow:var(--sh-l)}

.card-feat{
  padding:2rem;background:var(--surface);border-radius:var(--rl);
  position:relative;box-shadow:var(--sh);transition:transform .3s,box-shadow .3s;
}
.card-feat::before{
  content:'';position:absolute;inset:0;border-radius:var(--rl);
  padding:2px;background:var(--grad);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;
}
.card-feat:hover{transform:translateY(-5px);box-shadow:var(--sh-l)}

/* 11 · OFFER CARDS ───────────────────────────────────────── */
.off-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.off-step{
  font-family:var(--ff-m);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:.5rem;
}
.off-title{font-family:var(--ff-d);font-size:1.4rem;font-weight:600;color:var(--text);margin-bottom:.2rem}
.off-fmt{font-size:.77rem;color:var(--text-mu);margin-bottom:1.25rem}
.off-desc{font-size:.875rem;color:var(--text-dim);margin-bottom:1.5rem;flex-grow:1;max-width:none;line-height:1.65}
.off-list{list-style:none;display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.5rem}
.off-list li{
  font-size:.84rem;color:var(--text-dim);
  display:flex;align-items:flex-start;gap:.55rem;line-height:1.5;
}
.off-list li::before{
  content:'→';flex-shrink:0;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.off-link{
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.65rem 1.3rem;border:1.5px solid var(--border-l);
  color:var(--text-dim);font-size:.875rem;border-radius:var(--r);
  transition:all .2s;
}
.off-link:hover{border-color:var(--purple);color:var(--purple);background:var(--purple-dim);opacity:1}
.card-feat .off-link{background:var(--grad);border:none;color:var(--white-inv);font-weight:600;box-shadow:0 4px 18px var(--pink-glow)}
.card-feat .off-link:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--pink-glow);opacity:1}

/* 12 · CAS CLIENTS ───────────────────────────────────────── */
.cas-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.cas-meta{display:flex;align-items:center;gap:.85rem;margin-bottom:1rem}
.cas-tag{
  font-family:var(--ff-m);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;
  padding:.25rem .7rem;border-radius:2px;
  background:var(--purple-dim);color:var(--purple);
}
.cas-res{
  font-family:var(--ff-d);font-size:1.75rem;font-weight:300;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.cas-insight{margin-top:1.1rem;padding-top:1.1rem;border-top:1px solid var(--border);font-size:.8rem;color:var(--text-mu);line-height:1.6}
.cas-insight strong{color:var(--text-dim)}

/* 13 · FAQ ───────────────────────────────────────────────── */
.faq-item{border-bottom:1.5px solid var(--border)}
.faq-q{
  width:100%;background:none;border:none;color:var(--text);
  font-family:var(--ff-d);font-size:1.1rem;font-weight:400;
  text-align:left;padding:1.25rem 0;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  transition:color .2s;
}
.faq-q:hover{color:var(--purple)}
.faq-ico{
  width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border-l);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-size:1rem;color:var(--purple);transition:transform .3s,background .3s,border-color .3s;
}
.faq-item.open .faq-ico{transform:rotate(45deg);background:var(--purple-dim);border-color:var(--purple)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a-in{padding-bottom:1.35rem;font-size:.875rem;color:var(--text-dim);line-height:1.75}

/* 14 · FORM ──────────────────────────────────────────────── */
.form{display:flex;flex-direction:column;gap:.85rem}
.fg{display:flex;flex-direction:column;gap:.3rem}
.fg label{font-size:.68rem;color:var(--text-mu);font-family:var(--ff-m);letter-spacing:.12em;text-transform:uppercase}
.fg input,.fg textarea,.fg select{
  background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--r);
  color:var(--text);font-family:var(--ff-b);font-size:.9rem;
  padding:.75rem 1rem;transition:border-color .25s,box-shadow .25s;outline:none;width:100%;
}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--purple);box-shadow:0 0 0 3px rgba(123,70,232,.1)}
.fg textarea{min-height:110px;resize:vertical}
.fg select option{background:var(--bg)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}

/* 15 · CONTACT INFO ──────────────────────────────────────── */
.c-item{display:flex;align-items:center;gap:.85rem;margin-bottom:.85rem}
.c-ico{
  width:38px;height:38px;border-radius:var(--r);
  background:var(--purple-dim);border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0;
}
.c-lbl{font-size:.67rem;color:var(--text-mu);font-family:var(--ff-m);letter-spacing:.1em;text-transform:uppercase}
.c-val{color:var(--text);font-size:.9rem}

/* 16 · FAIL LIST ─────────────────────────────────────────── */
.fail-list{list-style:none;display:flex;flex-direction:column;gap:.85rem}
.fail-item{
  display:flex;align-items:flex-start;gap:1rem;
  padding:1.25rem 1.5rem;
  background:var(--surface);border:1.5px solid var(--border);border-radius:var(--rl);
  box-shadow:var(--sh);transition:border-color .3s;
}
.fail-item:hover{border-color:rgba(208,32,204,.3)}
.fail-x{
  width:28px;height:28px;border-radius:50%;flex-shrink:0;
  background:rgba(208,32,204,.08);
  display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--pink);
}
.fail-txt strong{display:block;color:var(--text);margin-bottom:.15rem;font-size:.9rem}
.fail-txt{font-size:.875rem;color:var(--text-dim);line-height:1.55}

/* 17 · GRAD DIVIDER ──────────────────────────────────────── */
.grad-hr{
  height:1.5px;border:none;
  background:linear-gradient(90deg,transparent,var(--pink) 25%,var(--purple) 50%,var(--cyan) 75%,transparent);
  margin:3rem 0;opacity:.35;
}

/* 18 · BADGE ─────────────────────────────────────────────── */
.badge-award{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:.7rem 1.1rem;border-radius:var(--r);
  background:var(--grad-bg);border:1.5px solid var(--border-l);
}
.badge-award-icon{font-size:1rem}
.badge-award-text{font-size:.8rem;color:var(--text-dim);line-height:1.4}
.badge-award-text strong{color:var(--text);display:block}

/* 19 · GRIDS ─────────────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.grid-2-asym{display:grid;grid-template-columns:1fr 2fr;gap:5rem;align-items:start}

/* 20 · SECTION HEAD ──────────────────────────────────────── */
.sec-hd{text-align:center;max-width:660px;margin:0 auto 3.5rem}
.sec-hd p{margin:.85rem auto 0;text-align:center}

/* 21 · CTA STRIP ─────────────────────────────────────────── */
.cta-strip{
  text-align:center;padding:5rem 3rem;
  background:var(--grad-bg);border:1.5px solid var(--border-l);border-radius:var(--rl);
  position:relative;overflow:hidden;box-shadow:var(--sh);
}
.cta-strip::before{
  content:'';position:absolute;top:-60px;left:50%;transform:translateX(-50%);
  width:400px;height:250px;border-radius:50%;
  background:radial-gradient(circle,rgba(123,70,232,.07) 0%,transparent 70%);
}
.cta-strip>*{position:relative;z-index:1}
.cta-strip h2{margin-bottom:.9rem}
.cta-strip p{margin:0 auto 1.75rem;text-align:center}

/* 22 · ICEBERG ZONES ─────────────────────────────────────── */
.ice-split{
  border-radius:var(--rl);overflow:hidden;margin-bottom:3rem;
  border:1.5px solid var(--border);box-shadow:var(--sh);
}
.ice-above{
  background:linear-gradient(135deg,rgba(208,32,204,.06) 0%,rgba(208,32,204,.02) 100%);
  padding:2rem;border-bottom:3px solid var(--pink);
}
.ice-below{
  background:var(--bg-2);padding:2rem;
}
.zone-lbl{
  font-family:var(--ff-m);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;
  margin-bottom:1rem;display:flex;align-items:center;gap:.45rem;
}
.zone-lbl.v{color:var(--pink)}.zone-lbl.h{color:var(--cyan)}
.zone-items{list-style:none;display:flex;flex-direction:column;gap:.45rem}
.zone-items li{font-size:.875rem;color:var(--text-dim);display:flex;align-items:center;gap:.55rem}
.zone-items li::before{content:'';width:4px;height:4px;border-radius:50%;flex-shrink:0;background:var(--pink)}
.zone-items.dim li::before{background:var(--cyan)}

/* 23 · STEPS ─────────────────────────────────────────────── */
.steps-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.step-card{
  padding:1.75rem 1.5rem;background:var(--surface);
  border:1.5px solid var(--border);border-radius:var(--rl);
  position:relative;box-shadow:var(--sh);transition:border-color .3s,transform .3s;
}
.step-card:hover{border-color:var(--purple);transform:translateY(-4px)}
.step-n-big{
  font-family:var(--ff-d);font-size:3rem;font-weight:300;line-height:1;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:.65rem;
}

/* 24 · TIMELINE ──────────────────────────────────────────── */
.timeline{position:relative;padding-left:2rem}
.timeline::before{content:'';position:absolute;left:0;top:.5rem;bottom:.5rem;width:1.5px;background:var(--border)}
.tl-item{position:relative;margin-bottom:2.25rem}
.tl-item::before{
  content:'';position:absolute;left:-2.45rem;top:.4rem;
  width:9px;height:9px;border-radius:50%;
  background:var(--surface);border:1.5px solid var(--border-l);
}
.tl-item.hl::before{
  background:var(--grad);border:none;width:11px;height:11px;left:-2.55rem;
  box-shadow:0 0 10px var(--pink-glow);
}
.tl-period{font-family:var(--ff-m);font-size:.67rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-mu);margin-bottom:.2rem}
.tl-item.hl .tl-period{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.tl-role{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:.15rem}
.tl-company{font-size:.84rem;color:var(--purple);margin-bottom:.35rem}
.tl-desc{font-size:.84rem;color:var(--text-dim);max-width:none;line-height:1.65}

/* 25 · BLOG ──────────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.blog-card{
  background:var(--surface);border:1.5px solid var(--border);border-radius:var(--rl);
  box-shadow:var(--sh);overflow:hidden;transition:transform .3s,box-shadow .3s;
  display:flex;flex-direction:column;
}
.blog-card:hover{transform:translateY(-5px);box-shadow:var(--sh-l)}
.blog-card-img{
  height:180px;
  background:var(--grad-bg);border-bottom:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.blog-card-img::before{
  content:'';position:absolute;inset:0;
  background:var(--grad);opacity:.08;
}
.blog-card-cat{
  position:absolute;bottom:.85rem;left:.85rem;
  font-family:var(--ff-m);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  padding:.22rem .65rem;background:var(--purple-dim);color:var(--purple);border-radius:2px;
}
.blog-card-ico{font-size:2.5rem;position:relative;z-index:1}
.blog-card-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.blog-card-body h3{font-family:var(--ff-d);font-size:1.15rem;font-weight:600;color:var(--text);margin-bottom:.5rem;line-height:1.3}
.blog-card-body p{font-size:.85rem;max-width:none;flex:1;margin-bottom:1rem}
.blog-card-meta{
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--ff-m);font-size:.67rem;color:var(--text-mu);
  padding-top:.85rem;border-top:1.5px solid var(--border);
}
.blog-read-link{color:var(--purple);font-weight:500;font-size:.8rem;display:inline-flex;align-items:center;gap:.3rem}
.blog-read-link:hover{opacity:.75}

/* Article */
.article-hero{
  padding:calc(var(--navh)+5rem) 0 4rem;
  background:var(--bg-2);border-bottom:1.5px solid var(--border);
}
.article-body{max-width:760px;margin:0 auto;padding:4rem 0 5rem}
.article-body h2{margin:2.5rem 0 .85rem;font-size:clamp(1.3rem,2.5vw,1.85rem)}
.article-body h3{margin:2rem 0 .65rem;color:var(--text)}
.article-body p{margin-bottom:1.25rem;max-width:none}
.article-body ul,.article-body ol{margin:1rem 0 1.5rem 1.5rem;color:var(--text-dim);font-size:.95rem;line-height:1.8}
.article-body li{margin-bottom:.35rem}
.article-cta-box{
  margin:2.5rem 0;padding:2rem 2.5rem;
  background:var(--grad-bg);border:1.5px solid var(--border-l);border-radius:var(--rl);
  text-align:center;
}
.article-cta-box p{max-width:none;text-align:center;margin-bottom:1.25rem}
.article-tag{
  display:inline-block;
  font-family:var(--ff-m);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;
  padding:.22rem .65rem;background:var(--purple-dim);color:var(--purple);border-radius:2px;
  margin-right:.4rem;margin-bottom:.4rem;
}

/* 26 · FOOTER ────────────────────────────────────────────── */
footer{background:var(--bg-2);border-top:1.5px solid var(--border);padding:4rem 0 2.5rem}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:2.5rem}
.foot-logo{display:inline-flex;align-items:center;margin-bottom:.75rem}
.foot-logo img{height:40px;width:auto}
.foot-brand p{font-size:.84rem;color:var(--text-mu);max-width:26ch}
.foot-col h5{
  font-family:var(--ff-m);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-mu);margin-bottom:1rem;
}
.foot-links{list-style:none;display:flex;flex-direction:column;gap:.45rem}
.foot-links a{font-size:.875rem;color:var(--text-dim);transition:color .2s}
.foot-links a:hover{color:var(--purple);opacity:1}
.foot-bottom{
  padding-top:1.75rem;border-top:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  font-size:.78rem;color:var(--text-mu);
}
.foot-legal{display:flex;gap:1.5rem}
.foot-legal a{color:var(--text-mu);font-size:.78rem}
.foot-legal a:hover{color:var(--text-dim);opacity:1}

/* 27 · RESPONSIVE ────────────────────────────────────────── */
@media(max-width:1024px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .steps-4{grid-template-columns:1fr 1fr}
  .off-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr;gap:2.5rem}
  .grid-2-asym{grid-template-columns:1fr;gap:3rem}
  .cas-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-links{display:none}
  .nav-burger{display:flex}
  .ice-split .ice-above,.ice-split .ice-below{padding:1.5rem}
  .form-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column;gap:.75rem;text-align:center}
  .blog-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .steps-4{grid-template-columns:1fr}
  .btn-row{flex-direction:column;align-items:flex-start}
  .cta-strip{padding:3rem 1.5rem}
}

/* 28 · ANIMATIONS ────────────────────────────────────────── */
@keyframes gpulse{0%,100%{opacity:1}50%{opacity:.35}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes gradshift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
