/* reclamealmelo.com - eigen poster-stijl: magenta accent, display-koppen, speelse kleurvlakken */

:root{
  --magenta:#E6007E;
  --magenta-dk:#B80064;
  --orange:#FF6A13;
  --yellow:#FFC400;
  --teal:#00B3A4;
  --ink:#161221;
  --ink-soft:#5b5470;
  --paper:#FFFDF7;
  --paper-2:#FBF3FF;
  --line:#ECE3F2;
  --white:#ffffff;
  --radius:18px;
  --radius-lg:30px;
  --shadow:0 18px 50px -22px rgba(34,12,42,.35);
  --shadow-sm:0 8px 24px -14px rgba(34,12,42,.4);
  --wrap:1180px;
  --display:'Anton',Impact,sans-serif;
  --head:'Archivo Black',Arial,sans-serif;
  --body:'Archivo','Segoe UI',system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.container{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 1.5rem}
.container-narrow{max-width:780px}

h1,h2,h3,h4{line-height:1.05;letter-spacing:-.01em}
h1{font-family:var(--display);font-weight:400;font-size:clamp(2.7rem,6.2vw,4.7rem);text-transform:uppercase;letter-spacing:.005em}
h2{font-family:var(--display);font-weight:400;font-size:clamp(2rem,4vw,3rem);text-transform:uppercase}
h3{font-family:var(--head);font-weight:400;font-size:1.22rem;line-height:1.18}
h4{font-family:var(--head);font-weight:400;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase}
p{margin:0 0 1rem}
.accent{color:var(--magenta)}
.accent-o{color:var(--orange)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--head);font-size:.92rem;letter-spacing:.01em;
  padding:.95rem 1.6rem;border-radius:999px;border:3px solid var(--ink);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;text-transform:uppercase}
.btn-primary{background:var(--magenta);color:#fff;box-shadow:5px 5px 0 var(--ink)}
.btn-primary:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink)}
.btn-secondary{background:var(--yellow);color:var(--ink);box-shadow:5px 5px 0 var(--ink)}
.btn-secondary:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink)}
.btn-light{background:#fff;color:var(--ink);box-shadow:5px 5px 0 var(--ink)}
.btn-light:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink)}
.link-arrow{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--head);font-size:.9rem;color:var(--magenta);text-transform:uppercase;letter-spacing:.02em}
.link-arrow:hover{gap:.7rem;transition:gap .12s ease}

/* ---------- topbar ---------- */
.topbar{background:var(--ink);color:#fff;font-size:.82rem}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.5rem 1.5rem;max-width:var(--wrap);margin:0 auto;flex-wrap:wrap}
.topbar-left{display:flex;align-items:center;gap:.5rem;font-family:var(--head);letter-spacing:.02em;text-transform:uppercase;font-size:.72rem}
.topbar-dot{width:9px;height:9px;border-radius:50%;background:var(--yellow);display:inline-block;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.topbar-right{display:flex;gap:1.2rem}
.topbar-right a{font-weight:600}
.topbar-right a:hover{color:var(--yellow)}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:3px solid var(--ink)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.5rem;max-width:var(--wrap);margin:0 auto}
.brand{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--display);font-size:1.45rem;text-transform:uppercase;letter-spacing:.01em}
.brand-badge{display:inline-grid;place-items:center;width:38px;height:38px;background:var(--magenta);color:#fff;border-radius:10px;border:3px solid var(--ink);font-family:var(--display);font-size:1.2rem;transform:rotate(-6deg)}
.brand small{display:block;font-family:var(--head);font-size:.6rem;letter-spacing:.22em;color:var(--magenta);margin-top:-4px}
.nav-toggle{display:none;background:var(--yellow);border:3px solid var(--ink);border-radius:10px;font-size:1.3rem;line-height:1;padding:.25rem .55rem;cursor:pointer}
.nav-menu{list-style:none;display:flex;align-items:center;gap:.4rem}
.nav-menu a{font-family:var(--head);font-size:.85rem;padding:.5rem .8rem;border-radius:999px;text-transform:uppercase;letter-spacing:.01em;transition:background .12s,color .12s}
.nav-menu a:hover,.nav-menu a.active{background:var(--paper-2);color:var(--magenta)}
.nav-menu a.nav-cta{background:var(--magenta);color:#fff;border:3px solid var(--ink);box-shadow:3px 3px 0 var(--ink)}
.nav-menu a.nav-cta:hover{background:var(--magenta-dk);color:#fff;transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}

/* ---------- hero ---------- */
.hero{position:relative;background:
  radial-gradient(circle at 12% 18%,rgba(255,196,0,.55),transparent 26%),
  radial-gradient(circle at 88% 12%,rgba(0,179,164,.4),transparent 28%),
  radial-gradient(circle at 78% 92%,rgba(255,106,19,.4),transparent 30%),
  var(--paper-2);
  border-bottom:3px solid var(--ink);overflow:hidden}
.hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(var(--line) 1.5px,transparent 1.5px);background-size:26px 26px;opacity:.5;z-index:0}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center;padding:4.5rem 0 4rem}
.kicker{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--head);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;background:var(--ink);color:#fff;padding:.45rem .9rem;border-radius:999px;transform:rotate(-1.5deg)}
.kicker .star{color:var(--yellow)}
.hero h1{margin:1.4rem 0 0}
.hero h1 .line2{color:var(--magenta);-webkit-text-stroke:0}
.hero-lead{font-size:1.15rem;color:var(--ink-soft);max-width:34rem;margin-top:1.3rem}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.9rem}
.hero-chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.7rem}
.chip{font-family:var(--head);font-size:.72rem;text-transform:uppercase;letter-spacing:.03em;padding:.4rem .8rem;border-radius:999px;border:2px solid var(--ink);background:#fff}
.chip.m{background:var(--magenta);color:#fff;border-color:var(--ink)}
.chip.o{background:var(--orange);color:#fff;border-color:var(--ink)}
.chip.t{background:var(--teal);color:#fff;border-color:var(--ink)}

/* hero poster collage */
.poster{position:relative;display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:minmax(86px,auto);gap:.9rem}
.poster-tile{border:3px solid var(--ink);border-radius:var(--radius);padding:1rem;display:flex;flex-direction:column;justify-content:flex-end;min-height:108px;box-shadow:var(--shadow-sm);font-family:var(--head);text-transform:uppercase;font-size:.78rem;letter-spacing:.02em;line-height:1.2}
.poster-tile .big{font-family:var(--display);font-size:1.9rem;line-height:.95;text-transform:uppercase}
.pt-1{background:var(--magenta);color:#fff;transform:rotate(-2deg)}
.pt-2{background:var(--yellow);color:var(--ink);grid-row:span 2;transform:rotate(1.5deg)}
.pt-3{background:#fff;color:var(--ink);transform:rotate(1deg)}
.pt-4{background:var(--teal);color:#fff;transform:rotate(-1.5deg)}
.pt-5{background:var(--orange);color:#fff;grid-column:span 2;transform:rotate(.6deg)}

/* ---------- marquee band ---------- */
.band{background:var(--ink);color:#fff;border-bottom:3px solid var(--ink);overflow:hidden}
.band-track{display:flex;gap:2.4rem;white-space:nowrap;padding:.7rem 0;animation:marquee 26s linear infinite;font-family:var(--head);text-transform:uppercase;font-size:.82rem;letter-spacing:.05em}
.band-track span{display:inline-flex;align-items:center;gap:2.4rem}
.band-track .sep{color:var(--yellow)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.band-track{animation:none}.topbar-dot{animation:none}}

/* ---------- sections ---------- */
.section{padding:5rem 0}
.section.tight{padding:3.5rem 0}
.section.paper2{background:var(--paper-2)}
.section.ink{background:var(--ink);color:#fff}
.section.ink h2,.section.ink h3{color:#fff}
.section.ink .eyebrow{color:var(--yellow)}
.section.ink p{color:#d9d2e6}
.section-head{max-width:46rem;margin-bottom:2.6rem}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.eyebrow{display:inline-block;font-family:var(--head);font-size:.76rem;text-transform:uppercase;letter-spacing:.12em;color:var(--magenta);margin-bottom:.8rem}
.section-head p{color:var(--ink-soft);font-size:1.06rem;margin-top:.7rem}

/* ---------- services grid ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.svc-tile{position:relative;background:#fff;border:3px solid var(--ink);border-radius:var(--radius);padding:1.5rem;transition:transform .14s ease,box-shadow .14s ease;box-shadow:4px 4px 0 var(--ink)}
.svc-tile:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--ink)}
.svc-num{position:absolute;top:1rem;right:1.2rem;font-family:var(--display);font-size:1.6rem;color:var(--line)}
.svc-ico{width:46px;height:46px;border-radius:12px;border:3px solid var(--ink);display:grid;place-items:center;margin-bottom:1rem;font-size:1.3rem}
.svc-tile h3{margin-bottom:.5rem}
.svc-tile h3 a:hover{color:var(--magenta)}
.svc-tile p{color:var(--ink-soft);font-size:.96rem;margin-bottom:.9rem}
.svc-ico.c1{background:var(--magenta)}.svc-ico.c2{background:var(--orange)}.svc-ico.c3{background:var(--teal)}
.svc-ico.c4{background:var(--yellow)}.svc-ico.c5{background:var(--ink)}.svc-ico.c6{background:#fff}

/* ---------- steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem;counter-reset:step}
.step{position:relative;background:var(--paper-2);border:3px solid var(--ink);border-radius:var(--radius);padding:1.6rem 1.3rem}
.step:before{counter-increment:step;content:counter(step);position:absolute;top:-18px;left:1.2rem;width:40px;height:40px;background:var(--magenta);color:#fff;border:3px solid var(--ink);border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-size:1.2rem}
.step h3{margin:.7rem 0 .4rem}
.step p{color:var(--ink-soft);font-size:.95rem;margin:0}
.section.ink .step{background:#241c33;border-color:#3a3050}
.section.ink .step p{color:#cdc5db}

/* ---------- why / feature rows ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.feat-card{border:3px solid var(--ink);border-radius:var(--radius);padding:1.6rem;background:#fff}
.feat-card .tagline{font-family:var(--head);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--magenta);margin-bottom:.6rem;display:block}
.feat-card h3{margin-bottom:.5rem}
.feat-card p{color:var(--ink-soft);font-size:.97rem;margin:0}
.feat-card.fill1{background:var(--magenta);color:#fff}
.feat-card.fill1 .tagline{color:var(--yellow)}
.feat-card.fill1 p{color:#ffe2f1}

/* ---------- split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.split-media{position:relative}
.portrait{border:3px solid var(--ink);border-radius:var(--radius-lg);overflow:hidden;box-shadow:8px 8px 0 var(--magenta);aspect-ratio:4/5;background:var(--paper-2)}
.portrait img{width:100%;height:100%;object-fit:cover}
.media-sticker{position:absolute;bottom:-18px;right:-12px;background:var(--yellow);border:3px solid var(--ink);border-radius:14px;padding:.7rem 1rem;font-family:var(--head);text-transform:uppercase;font-size:.8rem;transform:rotate(-5deg);box-shadow:var(--shadow-sm)}
.quote{border:3px solid var(--ink);border-radius:var(--radius-lg);background:var(--paper-2);padding:2rem;position:relative}
.quote:before{content:"\201C";position:absolute;top:-.2rem;left:1rem;font-family:var(--display);font-size:4.5rem;color:var(--magenta);line-height:1}
.quote p{font-family:var(--head);font-size:1.25rem;line-height:1.32;margin:1.2rem 0 1rem}
.quote cite{font-style:normal;color:var(--ink-soft);font-size:.92rem}
.quote cite b{color:var(--ink)}

/* ---------- prices ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.price-card{border:3px solid var(--ink);border-radius:var(--radius);background:#fff;padding:1.8rem;display:flex;flex-direction:column}
.price-card.feat{background:var(--ink);color:#fff;position:relative}
.price-card.feat h3,.price-card.feat .price-amt{color:#fff}
.price-flag{align-self:flex-start;font-family:var(--head);font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;background:var(--yellow);color:var(--ink);border:2px solid var(--ink);border-radius:999px;padding:.25rem .7rem;margin-bottom:1rem}
.price-card.feat .price-flag{background:var(--magenta);color:#fff;border-color:#fff}
.price-amt{font-family:var(--display);font-size:2.4rem;margin:.4rem 0 .2rem}
.price-amt .unit{font-family:var(--body);font-size:.85rem;color:var(--ink-soft);font-weight:600}
.price-card.feat .price-amt .unit{color:#bcb2cf}
.price-desc{color:var(--ink-soft);font-size:.95rem;min-height:2.6rem}
.price-card.feat .price-desc{color:#cdc5db}
.price-feats{list-style:none;margin:1.1rem 0 1.4rem;display:grid;gap:.5rem}
.price-feats li{position:relative;padding-left:1.6rem;font-size:.95rem}
.price-feats li:before{content:"\2713";position:absolute;left:0;color:var(--magenta);font-weight:700}
.price-card.feat .price-feats li:before{color:var(--yellow)}
.price-card .btn{margin-top:auto;justify-content:center}

/* ---------- faq ---------- */
.faq{max-width:760px;margin:0 auto;display:grid;gap:.9rem}
.faq-item{border:3px solid var(--ink);border-radius:14px;background:#fff;overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;font-family:var(--head);font-size:1rem;padding:1.1rem 1.3rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-q:after{content:"+";font-family:var(--display);font-size:1.5rem;color:var(--magenta);transition:transform .15s}
.faq-item.open .faq-q:after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease}
.faq-item.open .faq-a{max-height:340px}
.faq-a p{padding:0 1.3rem 1.2rem;color:var(--ink-soft);margin:0}

/* ---------- posts (blog cards) ---------- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.post-card{border:3px solid var(--ink);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:4px 4px 0 var(--ink);transition:transform .14s,box-shadow .14s}
.post-card:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--ink)}
.post-shape{position:relative;height:118px;border-bottom:3px solid var(--ink);background:var(--magenta);
  background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.14) 0 14px,transparent 14px 28px)}
.post-shape.orange{background-color:var(--orange)}
.post-shape.teal{background-color:var(--teal)}
.post-shape.yellow{background-color:var(--yellow)}
.post-shape.ink{background-color:var(--ink)}
.post-shape-tag{position:absolute;left:.9rem;bottom:.9rem;font-family:var(--head);font-size:.68rem;text-transform:uppercase;letter-spacing:.04em;background:#fff;color:var(--ink);border:2px solid var(--ink);border-radius:999px;padding:.25rem .7rem}
.post-card-body{padding:1.2rem}
.post-card-body h3{font-size:1.08rem;line-height:1.2}
.post-card:hover .post-card-body h3{color:var(--magenta)}
.post-card-meta{margin-top:.7rem;font-family:var(--head);font-size:.72rem;text-transform:uppercase;letter-spacing:.03em;color:var(--ink-soft)}

/* ---------- guides (kennisbank cards) ---------- */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.guide-card{border:3px solid var(--ink);border-radius:var(--radius);background:#fff;padding:1.5rem;display:flex;flex-direction:column}
.guide-card-tag{align-self:flex-start;font-family:var(--head);font-size:.68rem;text-transform:uppercase;letter-spacing:.04em;background:var(--paper-2);border:2px solid var(--ink);border-radius:999px;padding:.25rem .7rem;margin-bottom:.9rem}
.guide-card h3{font-size:1.1rem;margin-bottom:.5rem}
.guide-card p{color:var(--ink-soft);font-size:.95rem;margin-bottom:1rem}
.guide-card .link-arrow{margin-top:auto}

/* ---------- stat band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.stat{border:3px solid var(--ink);border-radius:var(--radius);background:#fff;padding:1.3rem;text-align:center}
.stat:nth-child(1){background:var(--magenta);color:#fff}
.stat:nth-child(2){background:var(--yellow)}
.stat:nth-child(3){background:var(--teal);color:#fff}
.stat:nth-child(4){background:var(--orange);color:#fff}
.stat-num{font-family:var(--display);font-size:2.5rem;line-height:1}
.stat-label{font-family:var(--head);font-size:.74rem;text-transform:uppercase;letter-spacing:.02em;margin-top:.4rem}

/* ---------- page head / crumbs ---------- */
.crumbs{background:var(--paper-2);border-bottom:3px solid var(--ink)}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;padding:.7rem 0;font-family:var(--head);font-size:.74rem;text-transform:uppercase;letter-spacing:.02em}
.crumbs li+li:before{content:"/";margin-right:.5rem;color:var(--magenta)}
.crumbs a:hover{color:var(--magenta)}
.crumbs [aria-current]{color:var(--ink-soft)}
.page-head{background:var(--paper-2);border-bottom:3px solid var(--ink);padding:3.2rem 0}
.page-head .lead{font-size:1.14rem;color:var(--ink-soft);max-width:42rem}

/* ---------- prose ---------- */
.prose{font-size:1.05rem}
.prose h2{font-size:clamp(1.6rem,3vw,2.1rem);margin:2.2rem 0 .8rem}
.prose h3{font-size:1.2rem;margin:1.7rem 0 .5rem}
.prose p{margin:0 0 1.1rem;color:#2b2438}
.prose ul,.prose ol{margin:0 0 1.1rem 1.3rem;color:#2b2438}
.prose li{margin-bottom:.45rem}
.prose strong{color:var(--ink)}
.prose a{color:var(--magenta);text-decoration:underline;text-underline-offset:3px}
.prose blockquote{border-left:5px solid var(--magenta);background:var(--paper-2);padding:1rem 1.3rem;margin:1.6rem 0;font-family:var(--head);font-size:1.1rem;line-height:1.35;border-radius:0 12px 12px 0}
.prose hr{border:0;border-top:3px dashed var(--line);margin:2rem 0}
.related{font-size:.97rem;color:var(--ink-soft)}
.related a{color:var(--magenta)}

/* ---------- article ---------- */
.article-head{background:var(--paper-2);border-bottom:3px solid var(--ink);padding:3rem 0 2.4rem}
.article-kicker{display:inline-block;font-family:var(--head);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;background:var(--magenta);color:#fff;border:2px solid var(--ink);border-radius:999px;padding:.3rem .8rem;margin-bottom:1rem}
.article-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.7rem;margin-top:1.1rem;font-family:var(--head);font-size:.76rem;text-transform:uppercase;letter-spacing:.02em;color:var(--ink-soft)}
.article-meta .dot{width:6px;height:6px;border-radius:50%;background:var(--magenta);display:inline-block}
.article-body{padding:2.8rem 0}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:2.6rem;align-items:start}
.contact-info{border:3px solid var(--ink);border-radius:var(--radius);background:var(--paper-2);padding:1.8rem;display:grid;gap:1.2rem}
.contact-line .lab{font-family:var(--head);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--magenta);margin-bottom:.2rem}
.contact-line .val{font-size:1.05rem;font-weight:600}
.contact-line .val a:hover{color:var(--magenta)}
.form{display:grid;gap:1.1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.form label{display:block;font-family:var(--head);font-size:.74rem;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.4rem}
.form input,.form select,.form textarea{width:100%;font-family:var(--body);font-size:1rem;padding:.8rem .9rem;border:3px solid var(--ink);border-radius:12px;background:#fff;color:var(--ink)}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--magenta);box-shadow:3px 3px 0 var(--magenta)}
.fineprint{font-size:.82rem;color:var(--ink-soft)}
.map-wrap{border:3px solid var(--ink);border-radius:var(--radius);overflow:hidden;margin-top:1.5rem}

/* ---------- cta ---------- */
.cta{background:var(--magenta);border-top:3px solid var(--ink);border-bottom:3px solid var(--ink);color:#fff;text-align:center;padding:4.2rem 0;position:relative;overflow:hidden}
.cta:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(-45deg,rgba(255,255,255,.08) 0 18px,transparent 18px 36px)}
.cta>.container{position:relative}
.cta h2{color:#fff}
.cta p{color:#ffe2f1;max-width:34rem;margin:.8rem auto 1.7rem}

/* ---------- footer ---------- */
.footer{background:var(--ink);color:#cfc7dd;padding:3.4rem 0 1.6rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem}
.footer .brand{color:#fff}
.footer .brand small{color:var(--yellow)}
.footer-brand p{font-size:.92rem;margin:1rem 0;max-width:24rem}
.footer-contact{font-size:.92rem;line-height:1.8}
.footer-contact a{color:#fff}
.footer-contact a:hover{color:var(--yellow)}
.footer-col h4{color:#fff;margin-bottom:.9rem}
.footer-col ul{list-style:none;display:grid;gap:.5rem;font-size:.92rem}
.footer-col a:hover{color:var(--yellow)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;margin-top:2.5rem;padding-top:1.4rem;border-top:1px solid #342b48;font-size:.84rem}
.footer-bottom a{color:#fff}
.footer-bottom a:hover{color:var(--yellow)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media (max-width:960px){
  .hero-inner{grid-template-columns:1fr;gap:2.2rem}
  .poster{max-width:440px}
  .split{grid-template-columns:1fr;gap:2rem}
  .svc-grid,.feat-grid,.price-grid,.post-grid,.guide-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr;gap:1.6rem}
  .stats{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:680px){
  body{font-size:16px}
  .nav-toggle{display:block}
  .nav-menu{position:absolute;top:100%;left:0;right:0;background:var(--paper);border-bottom:3px solid var(--ink);flex-direction:column;align-items:stretch;gap:0;padding:.6rem 1.2rem 1rem;display:none}
  .nav-menu.open{display:flex}
  .nav-menu a{padding:.8rem .6rem;border-radius:8px}
  .svc-grid,.feat-grid,.price-grid,.post-grid,.guide-grid,.steps,.stats,.footer-grid,.form-row{grid-template-columns:1fr}
  .topbar-right{display:none}
  .section{padding:3.4rem 0}
}
