/* ============================================================
   EduZicht — design system
   ============================================================ */
:root{
  /* palette */
  --bg:        #FBF9FF;
  --bg-lilac:  #F2E9FF;
  --bg-tint:   #F4ECFF;
  --ink:       #2A0A4A;
  --ink-2:     #4B3A66;
  --ink-soft:  #6B5B82;
  --violet:    #7C3AED;
  --violet-dp: #6321C4;
  --indigo:    #4A1B96;
  --magenta:   #E5187E;
  --magenta-2: #FF2D8E;
  --mint:      #16B364;
  --mint-soft: #E3F8EC;
  --peach:     #FCE7CB;
  --peach-dp:  #F7D2A6;
  --card:      #FFFFFF;
  --line:      rgba(124,58,237,.14);
  --line-2:    rgba(74,27,150,.10);
  --shadow-sm: 0 1px 2px rgba(42,10,74,.04), 0 8px 24px -16px rgba(42,10,74,.10);
  --shadow:    0 14px 44px -26px rgba(42,10,74,.26);
  --shadow-lg: 0 30px 72px -42px rgba(42,10,74,.38);
  --grad:      linear-gradient(100deg,var(--violet),var(--magenta));
  --grad-soft: linear-gradient(120deg,#8b4af2,#ff3d97);
  --radius:    18px;
  --radius-sm: 12px;
  --wrap:      1180px;
  --ease:      cubic-bezier(.22,.61,.36,1);
  --font-d:    "Bricolage Grotesque", "Hanken Grotesk", sans-serif;
  --font-b:    "Hanken Grotesk", system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:88px;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-b);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.wrap{width:min(var(--wrap),92vw);margin-inline:auto}

/* ---------- canvas ---------- */
/* clean, flat editorial canvas (no decorative gradient blobs) */

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  --py:.95em;--px:1.5em;
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--font-d);font-weight:600;font-size:1rem;
  padding:var(--py) var(--px);border-radius:999px;border:0;cursor:pointer;
  letter-spacing:-.01em;line-height:1;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  white-space:nowrap;
}
.btn-sm{--py:.7em;--px:1.15em;font-size:.95rem}
.btn-block{width:100%;justify-content:center}
.btn-primary{
  color:#fff;background:var(--grad);
  box-shadow:0 6px 16px -10px rgba(229,24,126,.5),inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 24px -12px rgba(229,24,126,.55)}
.btn-ghost{
  color:var(--violet-dp);background:rgba(255,255,255,.7);
  border:1.5px solid var(--line);backdrop-filter:blur(6px);
}
.btn-ghost:hover{transform:translateY(-2px);border-color:var(--violet);background:#fff}

/* ============================================================
   Header
   ============================================================ */
.site-header{position:sticky;top:0;z-index:60;
  backdrop-filter:saturate(140%) blur(12px);
  background:rgba(251,247,255,.72);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.site-header.scrolled{border-bottom-color:var(--line);background:rgba(251,247,255,.9)}
.header-inner{display:flex;align-items:center;gap:1.4rem;height:74px}
.brand{display:flex;align-items:center;gap:.6rem;margin-right:auto}
.brand-mark{width:40px;height:40px;flex:none}
.brand-mark svg{width:100%;height:100%;filter:drop-shadow(0 4px 8px rgba(124,58,237,.28))}
.brand-word{font-family:var(--font-d);font-weight:800;font-size:1.5rem;letter-spacing:-.03em}
.brand-word b{color:var(--violet-dp);font-weight:800}
.brand-word i{font-style:normal;color:var(--magenta)}

.nav{display:flex;gap:.4rem}
.nav a{font-family:var(--font-d);font-weight:600;font-size:.98rem;color:var(--ink-2);
  padding:.5rem .85rem;border-radius:999px;transition:color .2s,background .2s;position:relative}
.nav a:hover{color:var(--violet-dp);background:rgba(124,58,237,.08)}

.header-cta{display:flex}
.hamburger{display:none;flex-direction:column;gap:5px;width:44px;height:44px;
  align-items:center;justify-content:center;background:none;border:0;cursor:pointer}
.hamburger span{width:24px;height:2.4px;border-radius:2px;background:var(--ink);transition:.3s var(--ease)}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7.4px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.4px) rotate(-45deg)}

.mobile-menu{display:none;flex-direction:column;gap:.3rem;padding:1rem 4vw 1.6rem;
  background:rgba(251,247,255,.98);border-bottom:1px solid var(--line)}
.mobile-menu.open{display:flex;animation:menuDrop .3s var(--ease)}
@keyframes menuDrop{from{opacity:0;transform:translateY(-8px)}}
.mobile-menu a{font-family:var(--font-d);font-weight:600;padding:.85rem .4rem;color:var(--ink-2);border-bottom:1px solid var(--line-2)}
.mobile-menu a.btn{margin-top:.8rem;color:#fff;border:0;justify-content:center}

/* ============================================================
   Hero
   ============================================================ */
.hero{padding:clamp(3rem,7vw,6rem) 0 4rem}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--font-d);
  font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--magenta)}
.eyebrow::before{content:"";width:26px;height:2px;border-radius:2px;background:var(--magenta)}

h1{font-family:var(--font-d);font-weight:800;letter-spacing:-.035em;line-height:1.04;
  font-size:clamp(2rem,7vw,4.3rem);margin:1.2rem 0 0;overflow-wrap:break-word}
.grad-text{color:var(--magenta)}
.lede{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--ink-2);max-width:34ch;margin-top:1.3rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}
.hero-points{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem 1.1rem;margin-top:2.2rem;
  padding-top:1.5rem;border-top:1px solid var(--line)}
.hero-points span{font-family:var(--font-d);font-weight:600;font-size:.92rem;color:var(--ink-2);display:inline-flex;align-items:center}
.hero-points span:not(:last-child)::after{content:"";width:4px;height:4px;border-radius:50%;
  background:var(--violet);opacity:.45;margin-left:1.1rem}
.hero-foot{margin-top:3.2rem;font-size:.95rem;color:var(--ink-soft);text-align:center;
  padding-top:1.6rem;border-top:1px dashed var(--line)}

/* product mock */
.hero-visual{position:relative}
.mock{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);
  border:1px solid var(--line);overflow:hidden;transform:rotate(.6deg)}
.mock-bar{display:flex;align-items:center;gap:.5rem;padding:.8rem 1rem;
  background:linear-gradient(90deg,#f6effe,#fdeef6);border-bottom:1px solid var(--line)}
.mock-bar .dot{width:10px;height:10px;border-radius:50%;background:#e6d8fb}
.mock-bar .dot:nth-child(2){background:#f6cbe2}
.mock-bar .dot:nth-child(3){background:#cdeedd}
.mock-bar em{margin-left:auto;font-style:normal;font-family:var(--font-d);font-weight:600;font-size:.78rem;color:var(--ink-soft)}
.mock-body{padding:.8rem .9rem 1.1rem}
.mock-row{display:grid;grid-template-columns:1.6fr .7fr .7fr .7fr;gap:.4rem;align-items:center;
  padding:.5rem .6rem;font-size:.82rem;font-weight:500}
.mock-head{font-family:var(--font-d);font-weight:700;font-size:.7rem;text-transform:uppercase;
  letter-spacing:.04em;color:var(--ink-soft)}
.mock-group{border-radius:12px;margin-top:.5rem;padding:.3rem .25rem;position:relative;border:1px solid transparent}
.grp-tag{display:inline-block;font-family:var(--font-d);font-weight:700;font-size:.68rem;
  padding:.2rem .6rem;border-radius:999px;margin:.2rem 0 .15rem .6rem}
.g-support{background:rgba(229,24,126,.05);border-color:rgba(229,24,126,.16)}
.g-support .grp-tag{background:rgba(229,24,126,.12);color:var(--magenta)}
.g-base{background:rgba(124,58,237,.05);border-color:rgba(124,58,237,.16)}
.g-base .grp-tag{background:rgba(124,58,237,.12);color:var(--violet-dp)}
.g-enrich{background:rgba(22,179,100,.06);border-color:rgba(22,179,100,.18)}
.g-enrich .grp-tag{background:rgba(22,179,100,.14);color:var(--mint)}
.wh{width:34px;height:7px;border-radius:4px;background:#eadcfb;justify-self:start}
.wh-high{background:linear-gradient(90deg,var(--mint),#5fd99b)}
.wh-mid{background:linear-gradient(90deg,#f6b24a,#ffd089);width:24px}
.wh-low{background:linear-gradient(90deg,#ef6aa3,#ffb1d2);width:15px}


/* ============================================================
   Sections shared
   ============================================================ */
.section{padding:clamp(3.5rem,8vw,7rem) 0;position:relative}
.section-tint{background:
  linear-gradient(180deg,transparent,rgba(124,58,237,.04) 12%,rgba(124,58,237,.04) 88%,transparent);
  border-block:1px solid var(--line-2)}
.sec-head{max-width:none;margin-bottom:3rem}
.sec-head.center{text-align:center;margin-inline:auto;max-width:760px}
.sec-head.center .sec-intro{margin-inline:auto}
.kicker{font-family:var(--font-d);font-weight:700;font-size:.82rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--magenta)}
.kicker.light{color:#ffc8e4}
h2{font-family:var(--font-d);font-weight:800;letter-spacing:-.03em;line-height:1.07;
  font-size:clamp(1.7rem,4.6vw,3rem);margin:.7rem 0 0;overflow-wrap:break-word}
.sec-intro{font-size:clamp(1.02rem,1.3vw,1.15rem);color:var(--ink-2);max-width:62ch;margin-top:1.1rem}
h3{font-family:var(--font-d);font-weight:700;letter-spacing:-.02em}

/* ============================================================
   Probleem
   ============================================================ */
.problem-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:1.6rem;align-items:stretch}
.quote-card{position:relative;background:var(--ink);color:#fff;border-radius:var(--radius);
  padding:2.4rem 2.2rem;box-shadow:var(--shadow);overflow:hidden}
.quote-card::before{content:"“";position:absolute;top:-1.4rem;left:1rem;font-family:var(--font-d);
  font-size:9rem;color:rgba(255,255,255,.08);line-height:1}
.q-source{display:inline-block;font-family:var(--font-d);font-weight:700;font-size:.8rem;
  letter-spacing:.04em;text-transform:uppercase;color:#ffb3d8;margin-bottom:1rem;position:relative}
.quote-card blockquote{font-family:var(--font-d);font-weight:500;font-size:clamp(1.15rem,1.7vw,1.45rem);
  line-height:1.35;letter-spacing:-.01em;position:relative}
.stat-stack{display:grid;gap:1rem}
.stat-tile{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:1.3rem 1.4rem;display:flex;gap:1.1rem;align-items:center;box-shadow:var(--shadow-sm)}
.stat-num{font-family:var(--font-d);font-weight:800;font-size:clamp(1.8rem,3vw,2.4rem);
  letter-spacing:-.03em;color:var(--violet-dp);flex:none;min-width:3.4ch}
.stat-num small{font-size:.5em;color:var(--ink-soft)}
.stat-tile p{font-size:.92rem;color:var(--ink-2)}

.shortfall{margin-top:2.4rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:2rem 2.2rem;box-shadow:var(--shadow-sm)}
.shortfall h3{font-size:1.3rem;margin-bottom:1.2rem}
.shortfall-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.shortfall-cols p{font-size:.95rem;color:var(--ink-2);padding-left:1rem;border-left:2.5px solid var(--magenta)}
.shortfall-cols strong{color:var(--ink);font-family:var(--font-d)}

/* ============================================================
   Diagram 80/10/10
   ============================================================ */
.diagram{display:grid;grid-template-columns:1.15fr .85fr;gap:2rem;align-items:center;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(1.6rem,3vw,2.8rem);box-shadow:var(--shadow);margin-bottom:3rem}
.dgr-bars{display:flex;align-items:flex-end;gap:1rem;height:300px}
.dgr-col{flex:1 1 var(--w);display:flex;flex-direction:column;align-items:center;gap:.7rem;height:100%;justify-content:flex-end}
.dgr-pct{font-family:var(--font-d);font-weight:800;font-size:clamp(1.1rem,2vw,1.5rem);letter-spacing:-.02em}
.dgr-bar{width:100%;border-radius:14px 14px 6px 6px;position:relative;overflow:hidden;
  display:flex;align-items:flex-end;height:var(--h,40%);transition:height 1.1s var(--ease)}
.dgr-bar span{position:absolute;inset:0}
.bar-support{background:linear-gradient(180deg,#ff7bb6,var(--magenta))}
.bar-base{background:linear-gradient(180deg,#9a63f3,var(--violet-dp))}
.bar-enrich{background:linear-gradient(180deg,#34d399,var(--mint))}
.dgr-label{font-family:var(--font-d);font-weight:700;font-size:.85rem;color:var(--ink-2);text-align:center}
.in-view .dgr-col:nth-child(1) .dgr-bar{--h:34%}
.in-view .dgr-col:nth-child(2) .dgr-bar{--h:100%}
.in-view .dgr-col:nth-child(3) .dgr-bar{--h:34%}

.convergent-card{position:relative;border:2.5px solid var(--magenta);border-radius:20px;
  padding:1.6rem 1.7rem;background:linear-gradient(180deg,#fff,#fff6fb)}
.cc-badge{display:inline-block;font-family:var(--font-d);font-weight:700;font-size:.78rem;
  letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--magenta);
  padding:.35rem .8rem;border-radius:999px;margin-bottom:.9rem}
.convergent-card p{font-size:.98rem;color:var(--ink-2)}
.convergent-card strong{color:var(--ink)}
.cc-list{display:flex;flex-wrap:wrap;gap:.45rem;margin:1.1rem 0 .8rem}
.cc-list li{font-family:var(--font-d);font-weight:600;font-size:.82rem;color:var(--violet-dp);
  background:rgba(124,58,237,.1);padding:.35rem .7rem;border-radius:999px}
.cc-foot{font-size:.85rem;color:var(--ink-soft);font-style:italic}

.feature-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:1.6rem 1.4rem;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s}
.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.feat-ic{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;
  background:rgba(124,58,237,.09);color:var(--violet-dp);margin-bottom:1.1rem;transition:background .3s,color .3s}
.feat-ic svg{width:23px;height:23px}
.feature:hover .feat-ic{background:var(--violet-dp);color:#fff}
.feature h3{font-size:1.1rem;margin-bottom:.4rem}
.feature p{font-size:.92rem;color:var(--ink-2)}

/* ============================================================
   Steps
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;counter-reset:s}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:1.7rem 1.5rem;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),border-color .3s}
.step:hover{transform:translateY(-4px);border-color:var(--violet)}
.step-n{font-family:var(--font-d);font-weight:800;font-size:1.05rem;letter-spacing:.02em;
  display:inline-grid;place-items:center;width:42px;height:42px;border-radius:12px;
  background:rgba(124,58,237,.1);color:var(--violet-dp);margin-bottom:1rem}
.step h3{font-size:1.12rem;margin-bottom:.45rem}
.step p{font-size:.93rem;color:var(--ink-2)}

.edi-note{margin-top:1.8rem;display:flex;gap:1.4rem;align-items:flex-start;flex-wrap:wrap;
  background:var(--ink);color:#fff;border-radius:var(--radius);padding:1.8rem 2rem;box-shadow:var(--shadow)}
.edi-badge{flex:none;font-family:var(--font-d);font-weight:700;font-size:.78rem;letter-spacing:.05em;
  text-transform:uppercase;color:var(--ink);background:#ffd089;padding:.45rem .9rem;border-radius:999px}
.edi-note p{font-size:1rem;color:rgba(255,255,255,.86);max-width:74ch}
.edi-note strong{color:#fff}
.edi-note em{color:#ffc8e4;font-style:normal}

/* ============================================================
   Compare table
   ============================================================ */
.table-scroll{overflow-x:auto;border-radius:var(--radius);box-shadow:var(--shadow);
  border:1px solid var(--line);background:#fff}
.compare{width:100%;border-collapse:collapse;min-width:640px}
.compare th,.compare td{padding:1.1rem 1rem;text-align:center;border-bottom:1px solid var(--line-2)}
.compare thead th{font-family:var(--font-d);font-weight:700;font-size:1rem;color:var(--ink-2);
  background:var(--peach);border-bottom:0}
.compare thead th:first-child{background:transparent}
.compare .rowhead{text-align:left;font-family:var(--font-d);font-weight:600;color:var(--ink);
  background:#fbf3ff;font-size:.96rem}
.compare .rowhead small{display:block;font-weight:500;color:var(--ink-soft);font-size:.78rem;font-family:var(--font-b)}
.compare tbody tr:last-child td,.compare tbody tr:last-child th{border-bottom:0}
.col-eduzicht{position:relative}
.compare thead th.col-eduzicht{color:#fff;background:var(--grad);border-radius:14px 14px 0 0}
.compare td.col-eduzicht{background:rgba(124,58,237,.06)}
.compare tbody tr:last-child td.col-eduzicht{border-radius:0 0 14px 14px}
.yes::after{content:"";display:inline-block;width:26px;height:26px;border-radius:50%;
  background:var(--mint-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2316B364' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/15px no-repeat}
.col-eduzicht.yes::after{background-color:#d6f5e4}
.no::after{content:"–";color:#c9b8de;font-size:1.4rem;font-weight:700}

/* ============================================================
   Audience
   ============================================================ */
.audience-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.2rem}
.aud-card{grid-column:span 2;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.8rem 1.7rem;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s;position:relative;overflow:hidden}
.aud-card::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--grad);
  transform:scaleY(0);transform-origin:top;transition:transform .35s var(--ease)}
.aud-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.aud-card:hover::after{transform:scaleY(1)}
.aud-card.feature-big{grid-column:span 3;background:linear-gradient(135deg,#fff,#faf4ff)}
.audience-grid .aud-card:nth-child(2){grid-column:span 3}
.aud-tag{display:inline-block;font-family:var(--font-d);font-weight:700;font-size:.72rem;
  letter-spacing:.05em;text-transform:uppercase;color:var(--magenta);background:rgba(229,24,126,.1);
  padding:.3rem .7rem;border-radius:999px;margin-bottom:.7rem}
.aud-card h3{font-size:1.3rem;margin-bottom:.55rem}
.aud-card p{font-size:.95rem;color:var(--ink-2)}
.aud-card em{color:var(--violet-dp);font-style:italic}

/* ============================================================
   Pricing
   ============================================================ */
.pricing{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;max-width:920px;margin-inline:auto}
.price-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:2rem 1.9rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;position:relative}
.price-card.featured{border:2.5px solid var(--violet);box-shadow:var(--shadow-lg);
  background:linear-gradient(180deg,#fff,#faf5ff)}
.price-flag{display:inline-block;font-family:var(--font-d);font-weight:700;font-size:.76rem;
  letter-spacing:.03em;text-transform:uppercase;color:#fff;background:var(--grad);
  padding:.4rem .85rem;border-radius:999px;align-self:flex-start;margin-bottom:1rem}
.price-flag.plain{background:rgba(124,58,237,.1);color:var(--violet-dp)}
.price-card h3{font-size:1.4rem;margin-bottom:.2rem}
.price-when{font-size:.92rem;color:var(--ink-soft);font-weight:600}
.price-amount{font-family:var(--font-d);font-weight:800;font-size:clamp(2.6rem,5vw,3.4rem);
  letter-spacing:-.04em;color:var(--ink);margin:1rem 0 .3rem;display:flex;align-items:baseline;gap:.15rem}
.price-amount .cur{font-size:.5em;color:var(--magenta)}
.price-amount .per{font-size:.32em;font-family:var(--font-b);font-weight:600;color:var(--ink-soft);letter-spacing:0}
.price-feats{display:grid;gap:.7rem;margin:1.2rem 0 1.6rem}
.price-feats li{position:relative;padding-left:1.8rem;font-size:.93rem;color:var(--ink-2)}
.price-feats li::before{content:"";position:absolute;left:0;top:.15rem;width:18px;height:18px;border-radius:50%;
  background:var(--mint-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2316B364' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/11px no-repeat}
.price-feats strong{color:var(--ink)}
.price-card .btn{margin-top:auto}

.price-extras{display:grid;grid-template-columns:1.3fr 1fr;gap:1.4rem;max-width:920px;margin:1.4rem auto 0}
.extra-board{background:var(--ink);color:#fff;border-radius:var(--radius);padding:1.7rem 1.8rem;box-shadow:var(--shadow)}
.extra-board h4{font-family:var(--font-d);font-weight:700;font-size:1.15rem}
.extra-board h4 small{font-weight:500;color:#ffb3d8;font-size:.8rem;display:block;margin-top:.2rem}
.extra-board ul{margin-top:1rem;display:grid;gap:.6rem}
.extra-board li{font-size:.92rem;color:rgba(255,255,255,.85);padding-left:1.3rem;position:relative}
.extra-board li::before{content:"→";position:absolute;left:0;color:#ffc8e4}
.extra-board strong{color:#fff}
.extra-addons{display:grid;gap:1rem;align-content:center}
.addon{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:1rem 1.2rem;
  display:flex;align-items:center;gap:.9rem;box-shadow:var(--shadow-sm)}
.addon-price{font-family:var(--font-d);font-weight:800;font-size:1.3rem;color:var(--violet-dp);flex:none}
.addon span:last-child{font-size:.9rem;color:var(--ink-2)}

/* ============================================================
   CTA / form
   ============================================================ */
.cta-section{background:
  radial-gradient(120% 120% at 0% 0%,#3a0e6b,transparent 55%),
  radial-gradient(120% 120% at 100% 100%,#7a0f49,transparent 55%),
  #2A0A4A;color:#fff;border-radius:0}
.cta-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.cta-copy h2{color:#fff}
.cta-copy p{color:rgba(255,255,255,.82);margin-top:1rem;max-width:42ch}
.cta-list{margin-top:1.6rem;display:grid;gap:.7rem}
.cta-list li{position:relative;padding-left:1.9rem;font-weight:500}
.cta-list li::before{content:"✓";position:absolute;left:0;top:0;display:grid;place-items:center;
  width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.14);color:#7df0b3;font-size:.8rem;font-weight:800}
.cta-form{background:#fff;color:var(--ink);border-radius:var(--radius);padding:2rem 1.9rem;box-shadow:var(--shadow-lg)}
.cta-form h3{font-size:1.4rem;margin-bottom:1.2rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cta-form label{display:block;font-family:var(--font-d);font-weight:600;font-size:.85rem;color:var(--ink-2);margin-bottom:1rem}
.cta-form input,.cta-form textarea{width:100%;margin-top:.4rem;padding:.8rem .9rem;border-radius:12px;
  border:1.5px solid var(--line);background:#fcfaff;font-family:var(--font-b);font-size:.95rem;color:var(--ink);
  transition:border-color .2s,box-shadow .2s}
.cta-form input:focus,.cta-form textarea:focus{outline:0;border-color:var(--violet);box-shadow:0 0 0 4px rgba(124,58,237,.14)}
.cta-form textarea{resize:vertical}
.form-note{margin-top:.9rem;font-size:.88rem;font-weight:600;text-align:center;min-height:1.2em}
.form-note.ok{color:var(--mint)}
.form-note.err{color:var(--magenta)}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{background:#1e0735;color:rgba(255,255,255,.7);padding:3.4rem 0 1.8rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem}
.footer-word{font-size:1.6rem}
.footer-word b{color:#b794ff}.footer-word i{color:#ff63a8}
.foot-brand p{margin-top:.9rem;font-size:.92rem;max-width:34ch}
.foot-col h4{font-family:var(--font-d);font-weight:700;font-size:.82rem;letter-spacing:.08em;
  text-transform:uppercase;color:#fff;margin-bottom:1rem}
.foot-col a{display:block;font-size:.93rem;padding:.32rem 0;color:rgba(255,255,255,.66);transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  margin-top:2.6rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.1);font-size:.84rem}

/* ============================================================
   Reveal animation
   ============================================================ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
  .dgr-bar{transition:none}
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:960px){
  .nav,.header-cta{display:none}
  .hamburger{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:2.4rem}
  .hero-visual{max-width:520px;margin-inline:auto}
  .problem-grid,.diagram,.cta-grid{grid-template-columns:1fr}
  .feature-row{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .shortfall-cols{grid-template-columns:1fr;gap:1rem}
  .audience-grid{grid-template-columns:1fr 1fr}
  .aud-card,.aud-card.feature-big,.audience-grid .aud-card:nth-child(2){grid-column:span 1}
  .price-extras{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .dgr-bars{height:240px}
}
@media (max-width:560px){
  body{font-size:16px}
  .feature-row,.steps,.pricing,.audience-grid,.footer-grid,.field-row{grid-template-columns:1fr}
  .lede{max-width:none}
  .mock{transform:none}
  .stat-tile{flex-direction:column;align-items:flex-start;text-align:left}
  .foot-bottom{flex-direction:column;gap:.4rem}
  .edi-note{flex-direction:column;gap:.9rem}
}

/* ============================================================
   Added: selection, scroll progress, announce, integrations,
   faq, active nav  (eduzicht.nl integration + polish)
   ============================================================ */
::selection{background:rgba(229,24,126,.2);color:var(--ink)}

.skip-link{position:fixed;left:50%;top:-70px;transform:translateX(-50%);z-index:100;
  background:var(--ink);color:#fff;font-family:var(--font-d);font-weight:600;font-size:.9rem;
  padding:.7rem 1.2rem;border-radius:0 0 12px 12px;transition:top .25s var(--ease)}
.skip-link:focus{top:0;outline:2px solid var(--magenta);outline-offset:2px}

.scroll-progress{position:fixed;top:0;left:0;height:3px;width:100%;transform:scaleX(0);
  transform-origin:0 50%;background:var(--grad);z-index:80;transition:transform .08s linear;pointer-events:none}

.nav a.active{color:var(--violet-dp);background:rgba(124,58,237,.1)}

/* announcement bar */
.announce{display:flex;align-items:center;justify-content:center;gap:.55rem;flex-wrap:wrap;
  padding:.6rem 1.1rem;font-family:var(--font-d);font-size:.85rem;font-weight:500;text-align:center;
  color:rgba(255,255,255,.82);background:var(--ink);position:relative;z-index:55;letter-spacing:-.005em}
.announce strong{font-weight:700;color:#fff}
.announce-dot{width:6px;height:6px;border-radius:50%;background:var(--magenta-2)}
.announce-arrow{font-weight:700;transition:transform .25s var(--ease)}
.announce:hover .announce-arrow{transform:translateX(5px)}

/* integrations strip */
.integrations{padding:1.6rem 0 0}
.intg-inner{display:flex;align-items:center;justify-content:center;gap:1.2rem 1.6rem;flex-wrap:wrap;
  padding:1.3rem 1.7rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.intg-label{font-family:var(--font-d);font-weight:700;font-size:.88rem;color:var(--ink-2)}
.intg-logos{display:flex;align-items:center;gap:.5rem 1.1rem;flex-wrap:wrap}
.intg-name{font-family:var(--font-d);font-weight:800;font-size:1.18rem;color:var(--ink);letter-spacing:-.01em}
.intg-divider{width:1px;height:20px;background:var(--line)}
.intg-note{font-size:.86rem;color:var(--ink-soft);max-width:38ch;padding-left:.6rem;border-left:1px solid var(--line);margin-left:.3rem}

/* faq */
.faq-wrap{display:grid;grid-template-columns:.82fr 1.18fr;gap:2.6rem;align-items:start}
.faq-head{margin-bottom:0;position:sticky;top:110px}
.faq-list{display:grid;gap:.8rem}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);
  transition:border-color .25s,box-shadow .25s}
.faq-item[open]{border-color:var(--violet);box-shadow:var(--shadow)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;
  gap:1rem;padding:1.15rem 1.4rem;font-family:var(--font-d);font-weight:700;font-size:1.04rem;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-plus{position:relative;flex:none;width:22px;height:22px}
.faq-plus::before,.faq-plus::after{content:"";position:absolute;background:var(--violet);border-radius:2px;transition:transform .3s var(--ease),opacity .3s,background .3s}
.faq-plus::before{top:9.8px;left:3px;width:16px;height:2.4px}
.faq-plus::after{left:9.8px;top:3px;width:2.4px;height:16px}
.faq-item[open] .faq-plus::after{transform:rotate(90deg);opacity:0}
.faq-item[open] .faq-plus::before{background:var(--magenta)}
.faq-a{padding:0 1.4rem 1.3rem}
.faq-a p{font-size:.96rem;color:var(--ink-2)}
.faq-item[open] .faq-a{animation:faqIn .35s var(--ease)}
@keyframes faqIn{from{opacity:0;transform:translateY(-6px)}}
.inline-link{color:var(--violet-dp);font-weight:600;text-decoration:underline;
  text-decoration-color:rgba(124,58,237,.35);text-underline-offset:3px;transition:text-decoration-color .2s}
.inline-link:hover{text-decoration-color:var(--violet)}
.foot-note{display:block;font-size:.82rem;color:rgba(255,255,255,.5);margin-top:.4rem}

@media (max-width:960px){
  .faq-wrap{grid-template-columns:1fr;gap:1.4rem}
  .faq-head{position:static}
}
@media (max-width:560px){
  .announce{font-size:.8rem;padding:.55rem .8rem}
  .announce-sep,.announce>span:not(.announce-dot):not(.announce-arrow){display:none}
  .intg-note{display:none}
}

/* ============================================================
   Added: onderbouwing, praktijk-quote, veilig & avg, legal
   ============================================================ */
.evidence-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.evidence{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.8rem 1.6rem;box-shadow:var(--shadow-sm)}
.evidence-n{font-family:var(--font-d);font-weight:800;font-size:.85rem;letter-spacing:.06em;color:var(--magenta)}
.evidence h3{font-size:1.18rem;margin:.7rem 0 .55rem}
.evidence p{font-size:.95rem;color:var(--ink-2)}
.evidence-src{display:block;margin-top:1.1rem;padding-top:.9rem;border-top:1px solid var(--line);
  font-size:.8rem;color:var(--ink-soft);font-style:italic}

.quote-band{max-width:880px;margin-inline:auto;text-align:center}
.quote-band .kicker{display:block;margin-bottom:1.4rem}
.big-quote{font-family:var(--font-d);font-weight:600;letter-spacing:-.02em;line-height:1.2;
  font-size:clamp(1.5rem,3.2vw,2.5rem);color:var(--ink)}
.quote-by{display:inline-flex;align-items:center;gap:.9rem;margin-top:2rem;text-align:left}
.qb-mark{width:46px;height:46px;flex:none}
.quote-by strong{display:block;font-family:var(--font-d);font-size:1rem;color:var(--ink)}
.quote-by span{font-size:.9rem;color:var(--ink-soft)}

.secure-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:2.6rem;align-items:center}
.secure-intro h2{margin-bottom:.9rem}
.secure-intro p{color:var(--ink-2)}
.secure-cta{margin-top:1.1rem;font-size:.95rem}
.secure-list{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.secure-list li{display:flex;gap:.9rem;align-items:flex-start;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:1.1rem 1.2rem;box-shadow:var(--shadow-sm)}
.sec-ic{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;
  background:rgba(124,58,237,.09);color:var(--violet-dp);flex:none}
.sec-ic svg{width:20px;height:20px}
.secure-list strong{display:block;font-family:var(--font-d);font-size:.98rem;color:var(--ink);margin-bottom:.15rem}
.secure-list span{font-size:.86rem;color:var(--ink-soft)}

.foot-legal{display:flex;gap:1.2rem}
.foot-legal a{color:rgba(255,255,255,.6);transition:color .2s}
.foot-legal a:hover{color:#fff}

/* legal pages */
.legal-top{position:sticky;top:0;z-index:60;background:rgba(251,249,255,.9);
  backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--line)}
.legal-top .wrap{display:flex;align-items:center;justify-content:space-between;height:70px}
.legal-main{padding:clamp(2.5rem,6vw,5rem) 0}
.legal{max-width:760px;margin-inline:auto}
.legal h1{font-family:var(--font-d);font-weight:800;letter-spacing:-.03em;
  font-size:clamp(2rem,4vw,2.8rem);color:var(--ink);line-height:1.05}
.legal .lead{color:var(--ink-2);font-size:1.05rem;margin-top:.8rem}
.legal .updated{display:inline-block;margin-top:1rem;font-size:.82rem;color:var(--ink-soft);
  background:rgba(124,58,237,.08);padding:.35rem .8rem;border-radius:999px}
.legal h2{font-family:var(--font-d);font-weight:700;font-size:1.3rem;color:var(--ink);margin:2.4rem 0 .7rem}
.legal p,.legal li{color:var(--ink-2);font-size:1rem;line-height:1.65}
.legal p{margin-top:.7rem}
.legal ul{margin:.6rem 0 0;padding-left:1.2rem;list-style:disc}
.legal li{margin-top:.4rem}
.legal a{color:var(--violet-dp);text-decoration:underline;text-underline-offset:3px}

@media (max-width:960px){
  .evidence-grid{grid-template-columns:1fr}
  .secure-grid{grid-template-columns:1fr;gap:1.6rem}
}
@media (max-width:560px){
  .secure-list{grid-template-columns:1fr}
}

/* ============================================================
   Added: real product screenshots (hero + showcase)
   ============================================================ */
.hero-shot{border-radius:16px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow-lg);background:#fff;line-height:0}
.hero-shot img{width:100%;height:auto;display:block}

.showcase{display:grid;gap:clamp(1.8rem,3.5vw,3rem);margin-top:.5rem}
.show-row{display:grid;grid-template-columns:1.32fr .68fr;gap:clamp(1.4rem,3vw,2.6rem);align-items:center}
.show-row.reverse .show-shot{order:2}
.show-shot{border-radius:14px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);background:#fff;line-height:0;transition:transform .35s var(--ease),box-shadow .35s}
.show-shot:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.show-shot img{width:100%;height:auto;display:block}
.show-text h3{font-size:clamp(1.3rem,2vw,1.6rem);margin-bottom:.6rem;letter-spacing:-.02em}
.show-text p{color:var(--ink-2);font-size:1rem}

@media (max-width:860px){
  .show-row,.show-row.reverse{grid-template-columns:1fr;gap:1.1rem}
  .show-row.reverse .show-shot{order:0}
}

/* ============================================================
   Added: interactive subgroep-demo + tariefcalculator
   ============================================================ */
.sgdemo{display:flex;flex-direction:column;gap:1rem}
.sgdemo-head{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}
.sgdemo-klabel{font-family:var(--font-d);font-weight:700;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft)}
.sgdemo-range{flex:1;min-width:110px;accent-color:var(--violet)}
.sgdemo-knum{font-family:var(--font-d);font-size:.92rem;color:var(--ink-2)}
.sgdemo-knum b{color:var(--ink);font-weight:800}
.sgdemo-bins{display:grid;gap:.7rem}
.sgbin{border:1px solid var(--line);border-radius:14px;padding:.7rem .85rem;background:#fff}
.sgbin-0{background:rgba(229,24,126,.045);border-color:rgba(229,24,126,.18)}
.sgbin-1{background:rgba(124,58,237,.045);border-color:rgba(124,58,237,.18)}
.sgbin-2{background:rgba(22,179,100,.05);border-color:rgba(22,179,100,.2)}
.sgbin-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.55rem}
.sgbin-name{font-family:var(--font-d);font-weight:700;font-size:.9rem}
.sgbin-0 .sgbin-name{color:var(--magenta)}.sgbin-1 .sgbin-name{color:var(--violet-dp)}.sgbin-2 .sgbin-name{color:var(--mint)}
.sgbin-stat{font-size:.82rem;color:var(--ink-soft)}.sgbin-stat b{color:var(--ink);font-family:var(--font-d)}
.sgbin-dots{display:flex;flex-wrap:wrap;gap:5px;min-height:18px}
.sgdot{width:18px;height:18px;border-radius:6px;border:0;cursor:pointer;padding:0;
  transition:transform .15s var(--ease);animation:sgPop .3s var(--ease) backwards}
.sgdot:hover{transform:scale(1.18)}
.sgdot:focus-visible{outline:2px solid var(--ink);outline-offset:2px}
.sgdot.g0{background:linear-gradient(150deg,#ff7bb6,var(--magenta))}
.sgdot.g1{background:linear-gradient(150deg,#9a63f3,var(--violet-dp))}
.sgdot.g2{background:linear-gradient(150deg,#34d399,var(--mint))}
@keyframes sgPop{from{opacity:0;transform:scale(.4)}}
.sgdemo-hint{font-size:.84rem;color:var(--ink-soft);font-style:italic}

.calc{background:var(--ink);color:#fff;border-radius:var(--radius);
  padding:clamp(1.5rem,3vw,2.3rem);box-shadow:var(--shadow);margin-bottom:1.6rem}
.calc-top{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(1.4rem,3vw,2.4rem);align-items:center}
.calc-qlabel{display:block;font-family:var(--font-d);font-weight:700;font-size:1.15rem;color:#fff;margin-bottom:1rem}
.calc-input{display:flex;align-items:baseline;gap:.6rem;margin-bottom:1.1rem}
.calc-input input{width:150px;font-family:var(--font-d);font-weight:800;font-size:1.8rem;color:var(--ink);
  background:#fff;border:0;border-radius:12px;padding:.45rem .7rem;text-align:center}
.calc-input input:focus{outline:3px solid var(--magenta-2);outline-offset:1px}
.calc-input span{color:rgba(255,255,255,.7)}
.calc-range{width:100%;accent-color:var(--magenta-2)}
.calc-bestuur{display:inline-block;margin-top:.9rem;font-size:.82rem;font-weight:600;color:#7df0b3;
  background:rgba(125,240,179,.12);padding:.35rem .8rem;border-radius:999px}
.calc-bestuur[hidden]{display:none}
.calc-results{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.calc-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:1.1rem 1.2rem}
.calc-card-now{background:linear-gradient(160deg,rgba(124,58,237,.4),rgba(229,24,126,.28));border-color:rgba(255,255,255,.22)}
.calc-when{font-size:.74rem;font-weight:700;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.03em}
.calc-total{font-family:var(--font-d);font-weight:800;font-size:clamp(1.7rem,3.4vw,2.3rem);letter-spacing:-.03em;margin:.5rem 0 .25rem;color:#fff}
.calc-per{font-size:.88rem;color:rgba(255,255,255,.78)}.calc-per b{color:#fff;font-family:var(--font-d)}
.calc-note{margin-top:1.2rem;font-size:.81rem;color:rgba(255,255,255,.55)}
@media (max-width:760px){.calc-top{grid-template-columns:1fr}.calc-results{grid-template-columns:1fr}}
