/* Reclamebureau Almelo - editorial studio
   Zwart-wit basis, vermiljoenrood accent, Fraunces display + Space Grotesk
   Eigen ontwerp, los van iedere zustersite. */

:root{
  --paper:#f6f4ef;          /* warm off-white papier */
  --paper-2:#efece4;
  --ink:#111110;            /* bijna-zwart */
  --ink-soft:#56544d;
  --line:#d9d4c8;           /* fijne lijnen */
  --red:#e5231b;            /* vermiljoen accent */
  --red-dk:#b8160f;
  --white:#ffffff;
  --black:#0c0c0b;
  --display:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Space Grotesk","Segoe UI",system-ui,sans-serif;
  --maxw:1220px;
  --r:2px;                  /* hoeken bijna recht, editorial */
}

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

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

/* ---------- Typografie ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:500;line-height:1.06;letter-spacing:-.015em;color:var(--ink)}
h1{font-size:clamp(2.6rem,7vw,5.4rem)}
h2{font-size:clamp(1.9rem,4vw,3.1rem)}
h3{font-size:1.5rem}
p{margin:0 0 1.1rem}
.lead{font-size:1.22rem;line-height:1.6;color:var(--ink-soft);font-family:var(--sans)}
.accent{color:var(--red)}
.italic{font-style:italic}
em,.serif-it{font-family:var(--display);font-style:italic}

/* labels / kickers */
.kicker{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--sans);font-size:.72rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.22em;color:var(--red);
}
.kicker::before{content:"";width:26px;height:1px;background:var(--red);display:inline-block}
.eyebrow{
  display:block;font-size:.72rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.22em;color:var(--ink-soft);margin-bottom:1rem;
}

/* ---------- Masthead / topbalk ---------- */
.masthead{
  background:var(--ink);color:var(--paper);
  font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;
}
.masthead-inner{
  max-width:var(--maxw);margin:0 auto;padding:.55rem 28px;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
}
.masthead a{color:var(--paper);border-bottom:1px solid transparent;transition:border-color .2s}
.masthead a:hover{border-color:var(--red)}
.masthead-dot{color:var(--red)}

/* ---------- Navigatie ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(246,244,239,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:1.05rem 28px;display:flex;align-items:center;justify-content:space-between}
.brand{font-family:var(--display);font-weight:600;font-size:1.42rem;letter-spacing:-.02em;display:flex;align-items:baseline;gap:.1rem;line-height:1}
.brand .mark{color:var(--red)}
.brand small{font-family:var(--sans);font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.24em;color:var(--ink-soft);margin-left:.5rem}
.nav-menu{list-style:none;display:flex;align-items:center;gap:2.1rem}
.nav-menu a{font-size:.84rem;font-weight:500;letter-spacing:.02em;color:var(--ink);position:relative;padding:.2rem 0}
.nav-menu a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--red);transition:width .25s}
.nav-menu a:not(.nav-cta):hover::after,.nav-menu a.active:not(.nav-cta)::after{width:100%}
.nav-cta{background:var(--ink);color:var(--paper)!important;padding:.62rem 1.2rem;font-weight:600;border-radius:var(--r);transition:background .2s}
.nav-cta:hover{background:var(--red)}
.nav-toggle{display:none;background:none;border:0;font-size:1.4rem;cursor:pointer;color:var(--ink)}

@media(max-width:860px){
  .nav-toggle{display:block}
  .nav-menu{position:absolute;top:100%;left:0;right:0;background:var(--paper);flex-direction:column;align-items:flex-start;gap:0;padding:0;max-height:0;overflow:hidden;transition:max-height .3s ease;border-bottom:1px solid var(--line)}
  .nav-menu.open{max-height:420px;padding:.5rem 0}
  .nav-menu li{width:100%}
  .nav-menu a{display:block;padding:.85rem 28px;width:100%}
  .nav-cta{margin:.6rem 28px;display:inline-block!important;width:auto}
}

/* ---------- Knoppen ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-weight:600;font-size:.92rem;padding:.92rem 1.7rem;border-radius:var(--r);cursor:pointer;border:1.5px solid transparent;transition:all .2s;letter-spacing:.01em}
.btn-primary{background:var(--red);color:#fff;border-color:var(--red)}
.btn-primary:hover{background:var(--red-dk);border-color:var(--red-dk)}
.btn-dark{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-dark:hover{background:var(--red);border-color:var(--red)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--paper)}
.btn-light{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn-light:hover{background:transparent;color:var(--paper);border-color:var(--paper)}
.link-arrow{font-weight:600;color:var(--ink);border-bottom:1.5px solid var(--red);padding-bottom:2px;display:inline-flex;gap:.4rem;align-items:center;transition:gap .2s}
.link-arrow:hover{gap:.7rem;color:var(--red)}

/* ---------- Hero (asymmetrisch, magazine) ---------- */
.hero{padding:4.5rem 0 3rem;border-bottom:1px solid var(--line)}
.hero-top{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:2.5rem}
.hero-edition{font-family:var(--sans);font-size:.74rem;text-transform:uppercase;letter-spacing:.2em;color:var(--ink-soft);text-align:right;line-height:1.8}
.hero h1{max-width:14ch}
.hero h1 .ofidee{display:block}
.hero-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:3.5rem;align-items:end;margin-top:2.4rem}
.hero-side{border-left:2px solid var(--ink);padding-left:1.5rem}
.hero-side p{font-size:1rem;color:var(--ink-soft)}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.8rem}
.hero-rule{height:1px;background:var(--line);margin:3rem 0 0}

/* tickerregel onderaan hero */
.marquee{background:var(--ink);color:var(--paper);overflow:hidden;white-space:nowrap;padding:.7rem 0;font-family:var(--display);font-style:italic;font-size:1.15rem}
.marquee span{display:inline-block;padding:0 1.5rem}
.marquee .sep{color:var(--red);font-style:normal}

/* ---------- Generieke sectie ---------- */
.section{padding:5rem 0}
.section.tight{padding:3.5rem 0}
.section.ink{background:var(--ink);color:var(--paper)}
.section.ink h1,.section.ink h2,.section.ink h3{color:var(--paper)}
.section.ink .eyebrow{color:#9c988c}
.section.ink p{color:#cfcabd}
.section.paper2{background:var(--paper-2)}
.section-head{max-width:640px;margin-bottom:3rem}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head p{color:var(--ink-soft);font-size:1.08rem;margin-top:.8rem}

/* ---------- Diensten als genummerde index ---------- */
.index-list{border-top:1px solid var(--ink)}
.index-row{display:grid;grid-template-columns:auto 1fr auto;gap:2rem;align-items:center;padding:1.9rem 0;border-bottom:1px solid var(--line);transition:padding-left .25s,background .25s;position:relative}
.index-row:hover{padding-left:1.2rem;background:linear-gradient(90deg,rgba(229,35,27,.05),transparent)}
.index-no{font-family:var(--display);font-size:1.05rem;color:var(--red);font-weight:600;min-width:2.6rem}
.index-main h3{font-size:1.65rem;margin-bottom:.25rem;transition:color .2s}
.index-row:hover .index-main h3{color:var(--red)}
.index-main p{margin:0;color:var(--ink-soft);font-size:.96rem;max-width:62ch}
.index-arrow{font-size:1.5rem;color:var(--ink);transition:transform .25s,color .2s}
.index-row:hover .index-arrow{transform:translateX(6px);color:var(--red)}
@media(max-width:680px){
  .index-row{grid-template-columns:auto 1fr;gap:1rem}
  .index-arrow{display:none}
}

/* ---------- Dienst-kaarten (overzicht) ---------- */
.deck{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:0;border:1px solid var(--line)}
.deck-card{padding:2rem 1.9rem;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper);transition:background .25s}
.deck-card:hover{background:var(--white)}
.deck-card .dc-no{font-family:var(--display);font-size:.85rem;color:var(--red);font-weight:600;letter-spacing:.05em}
.deck-card h3{font-size:1.32rem;margin:.7rem 0 .55rem}
.deck-card p{font-size:.94rem;color:var(--ink-soft);margin-bottom:1.1rem}

/* ---------- Cijferband ---------- */
.figband{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.fig{padding:2.4rem 1.5rem;border-right:1px solid var(--line);text-align:left}
.fig:last-child{border-right:0}
.fig-num{font-family:var(--display);font-size:2.9rem;font-weight:500;line-height:1;color:var(--ink)}
.fig-num .accent{color:var(--red)}
.fig-lab{font-size:.82rem;color:var(--ink-soft);margin-top:.7rem;letter-spacing:.02em}
@media(max-width:760px){.figband{grid-template-columns:repeat(2,1fr)}.fig:nth-child(2){border-right:0}}

/* ---------- Aanpak / stappen ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;counter-reset:st}
.step{padding:0 1.6rem 0 0;border-left:1px solid var(--line);padding-left:1.6rem;counter-increment:st}
.step::before{content:"0" counter(st);font-family:var(--display);color:var(--red);font-size:1.1rem;font-weight:600;display:block;margin-bottom:.9rem}
.step h3{font-size:1.2rem;margin-bottom:.5rem}
.step p{font-size:.93rem;color:var(--ink-soft)}
.section.ink .step{border-color:#33322e}
.section.ink .step p{color:#b6b1a4}
@media(max-width:760px){.steps{grid-template-columns:1fr;gap:1.8rem}}

/* ---------- Split met portret/quote ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:2.2rem}}
.portret{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--r);filter:grayscale(15%);box-shadow:14px 14px 0 var(--red)}
.bigquote{font-family:var(--display);font-size:clamp(1.6rem,2.6vw,2.2rem);line-height:1.25;font-style:italic;color:var(--ink);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);padding:2rem 0}
.bigquote cite{display:block;font-family:var(--sans);font-style:normal;font-size:.85rem;letter-spacing:.04em;color:var(--ink-soft);margin-top:1.3rem;text-transform:uppercase}

/* ---------- Waarom / kolommen ---------- */
.cols3{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.col-item{padding:2rem 1.8rem 2rem 0;border-right:1px solid var(--line)}
.col-item:last-child{border-right:0;padding-right:0}
.col-item .ci-no{font-family:var(--sans);font-size:.74rem;text-transform:uppercase;letter-spacing:.18em;color:var(--red);font-weight:600}
.col-item h3{font-size:1.28rem;margin:.6rem 0 .5rem}
.col-item p{font-size:.95rem;color:var(--ink-soft);margin:0}
@media(max-width:760px){.cols3{grid-template-columns:1fr}.col-item{border-right:0;border-bottom:1px solid var(--line);padding:1.6rem 0}.col-item:last-child{border-bottom:0}}

/* ---------- Prijzen ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--ink)}
.price-card{padding:2.2rem 2rem;border-right:1px solid var(--line);display:flex;flex-direction:column}
.price-card:last-child{border-right:0}
.price-card.feat{background:var(--ink);color:var(--paper)}
.price-card.feat h3,.price-card.feat .price-amt{color:var(--paper)}
.price-tier{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:var(--red);font-weight:600}
.price-card.feat .price-tier{color:#ff6b62}
.price-card h3{font-size:1.5rem;margin:.6rem 0 .4rem}
.price-desc{font-size:.92rem;color:var(--ink-soft);margin-bottom:1.1rem}
.price-card.feat .price-desc{color:#c9c4b7}
.price-amt{font-family:var(--display);font-size:1.9rem;font-weight:500;margin-bottom:1.2rem}
.price-amt .unit{font-family:var(--sans);font-size:.8rem;color:var(--ink-soft);font-weight:500}
.price-card.feat .price-amt .unit{color:#c9c4b7}
.price-feats{list-style:none;margin:0 0 1.5rem;padding:0;flex-grow:1}
.price-feats li{font-size:.92rem;padding:.45rem 0 .45rem 1.4rem;position:relative;border-bottom:1px solid var(--line)}
.price-card.feat .price-feats li{border-color:#33322e}
.price-feats li::before{content:"/";color:var(--red);position:absolute;left:0;font-weight:700}
@media(max-width:820px){.price-grid{grid-template-columns:1fr}.price-card{border-right:0;border-bottom:1px solid var(--line)}.price-card:last-child{border-bottom:0}}

/* ---------- FAQ ---------- */
.faq{border-top:1px solid var(--ink)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;font-family:var(--display);font-size:1.22rem;font-weight:500;color:var(--ink);padding:1.4rem 2.5rem 1.4rem 0;position:relative}
.faq-q::after{content:"+";position:absolute;right:0;top:1.3rem;font-size:1.5rem;color:var(--red);transition:transform .25s;font-family:var(--sans)}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-item.open .faq-a{max-height:340px}
.faq-a p{padding:0 0 1.4rem;color:var(--ink-soft);font-size:1rem;margin:0;max-width:70ch}

/* ---------- Blog / kennisbank kaarten ---------- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--ink);border-left:1px solid var(--line)}
.post-card{border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper);transition:background .25s;display:flex;flex-direction:column}
.post-card:hover{background:var(--white)}
.post-cover{aspect-ratio:16/10;background:var(--ink);position:relative;overflow:hidden}
.post-cover::after{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(45deg,transparent,transparent 13px,rgba(255,255,255,.05) 13px,rgba(255,255,255,.05) 14px);}
.post-cover.red{background:var(--red)}
.post-cover.paper{background:var(--paper-2)}
.post-cover.paper::after{background:repeating-linear-gradient(45deg,transparent,transparent 13px,rgba(0,0,0,.04) 13px,rgba(0,0,0,.04) 14px)}
.post-cover-tag{position:absolute;left:14px;top:14px;font-family:var(--sans);font-size:.66rem;text-transform:uppercase;letter-spacing:.16em;font-weight:600;color:#fff;background:rgba(0,0,0,.45);padding:.3rem .6rem;border-radius:var(--r)}
.post-cover.paper .post-cover-tag{color:var(--ink);background:rgba(255,255,255,.6)}
.post-body{padding:1.6rem 1.5rem 1.7rem;display:flex;flex-direction:column;flex-grow:1}
.post-kicker{font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;color:var(--red);font-weight:600;margin-bottom:.6rem}
.post-body h3{font-size:1.28rem;line-height:1.18;margin-bottom:.8rem}
.post-body h3 a:hover{color:var(--red)}
.post-meta{font-size:.78rem;color:var(--ink-soft);letter-spacing:.04em;margin-top:auto;text-transform:uppercase}
@media(max-width:860px){.post-grid{grid-template-columns:1fr}}

/* kennisbank lijst-stijl gids */
.guide-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--ink);border-left:1px solid var(--line)}
.guide-card{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:2rem 1.9rem;background:var(--paper);transition:background .25s}
.guide-card:hover{background:var(--white)}
.guide-card .gc-tag{font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;color:var(--red);font-weight:600}
.guide-card h3{font-size:1.42rem;margin:.6rem 0 .55rem;line-height:1.15}
.guide-card p{font-size:.94rem;color:var(--ink-soft);margin-bottom:1.1rem}
@media(max-width:760px){.guide-grid{grid-template-columns:1fr}}

/* ---------- Page head (binnenpagina's) ---------- */
.page-head{padding:3.5rem 0 2.5rem;border-bottom:1px solid var(--line)}
.page-head h1{max-width:18ch}
.crumbs{border-bottom:1px solid var(--line);font-size:.78rem;background:var(--paper)}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;padding:.85rem 0;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em}
.crumbs li:not(:last-child)::after{content:"/";margin-left:.5rem;color:var(--line)}
.crumbs a:hover{color:var(--red)}

/* ---------- Prose (artikel/dienst) ---------- */
.prose{font-size:1.07rem;line-height:1.78;color:var(--ink)}
.prose h2{font-size:1.95rem;margin:2.6rem 0 1rem;line-height:1.12}
.prose h3{font-size:1.32rem;margin:1.9rem 0 .7rem;font-weight:600}
.prose p{margin:0 0 1.2rem;color:#2c2b27}
.prose ul,.prose ol{margin:0 0 1.3rem 0;padding-left:0;list-style:none}
.prose ul li{position:relative;padding:.18rem 0 .18rem 1.6rem;color:#2c2b27}
.prose ul li::before{content:"/";color:var(--red);position:absolute;left:0;font-weight:700}
.prose ol{counter-reset:pp}
.prose ol li{position:relative;padding:.18rem 0 .18rem 2rem;counter-increment:pp;color:#2c2b27}
.prose ol li::before{content:counter(pp);position:absolute;left:0;font-family:var(--display);color:var(--red);font-weight:600}
.prose a{color:var(--red);border-bottom:1px solid rgba(229,35,27,.35)}
.prose a:hover{border-color:var(--red)}
.prose strong{font-weight:700;color:var(--ink)}
.prose blockquote{font-family:var(--display);font-style:italic;font-size:1.5rem;line-height:1.3;color:var(--ink);border-left:3px solid var(--red);padding:.4rem 0 .4rem 1.6rem;margin:2rem 0}
.prose hr{border:0;border-top:1px solid var(--line);margin:2.5rem 0}
.prose .related{font-size:.95rem;color:var(--ink-soft)}
.prose figure{margin:2rem 0}

/* artikelkop */
.article-head{padding:3.5rem 0 2.5rem;border-bottom:1px solid var(--ink)}
.article-head h1{font-size:clamp(2.2rem,5vw,3.8rem);max-width:20ch;margin:.8rem 0}
.article-kicker{font-size:.74rem;text-transform:uppercase;letter-spacing:.2em;color:var(--red);font-weight:600}
.article-meta{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center;font-size:.82rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;margin-top:1rem}
.article-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--red)}
.article-body{padding:3rem 0}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:3.5rem}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:2.5rem}}
.contact-line{padding:1.2rem 0;border-bottom:1px solid var(--line)}
.contact-line .lab{font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-soft);margin-bottom:.3rem}
.contact-line .val{font-family:var(--display);font-size:1.3rem}
.contact-line .val a:hover{color:var(--red)}
.form label{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);margin-bottom:.4rem;font-weight:600}
.form input,.form select,.form textarea{width:100%;padding:.85rem .9rem;border:1px solid var(--line);border-radius:var(--r);background:var(--white);font-family:var(--sans);font-size:.98rem;color:var(--ink);margin-bottom:1.1rem;transition:border-color .2s}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--red)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}
.fineprint{font-size:.8rem;color:var(--ink-soft);margin-top:.6rem}
.map-wrap{border:1px solid var(--line)}

/* ---------- CTA-blok ---------- */
.cta{background:var(--red);color:#fff;padding:4.5rem 0;position:relative;overflow:hidden}
.cta .container{position:relative;z-index:1;text-align:center}
.cta h2{color:#fff;max-width:18ch;margin:0 auto}
.cta p{color:rgba(255,255,255,.9);max-width:52ch;margin:1rem auto 2rem;font-size:1.1rem}
.cta .btn-light{background:#fff;color:var(--red);border-color:#fff}
.cta .btn-light:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.cta::before{content:"\201D";position:absolute;font-family:var(--display);font-size:24rem;line-height:1;color:rgba(255,255,255,.08);top:-4rem;right:2rem}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#cfcabd;padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}
.footer .brand{color:var(--paper)}
.footer .brand small{color:#8a867a}
.footer-brand p{font-size:.92rem;margin:1.1rem 0;color:#a8a397;max-width:38ch}
.footer-contact{font-size:.92rem;line-height:1.8;color:#cfcabd}
.footer-contact a:hover{color:var(--red)}
.footer-col h4{font-family:var(--sans);font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:#8a867a;margin-bottom:1rem;font-weight:600}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:.55rem;font-size:.92rem}
.footer-col a:hover{color:var(--red)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;border-top:1px solid #33322e;margin-top:3rem;padding-top:1.6rem;font-size:.82rem;color:#8a867a}
.footer-bottom a:hover{color:var(--red)}

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

/* ---------- Tag pill ---------- */
.tag{display:inline-flex;align-items:center;gap:.5rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.18em;color:var(--red);border:1px solid var(--red);padding:.4rem .85rem;border-radius:100px}
