/* ============================================================
   EFFICIENT MARKETING — Design System
   ============================================================ */

/* ---- Tokens ---- */
:root{
  --red:#D80000;
  --red-dark:#B00000;
  --red-tint:#FDECEC;
  --red-tint-2:#FFF5F5;
  --ink:#1A1A1A;
  --body:#4A4A4A;
  --muted:#8A8F98;
  --white:#FFFFFF;
  --light:#F6F7F9;
  --border:#E6E8EC;
  --success:#16A34A;
  --gold:#F5A623;

  --radius-card:16px;
  --radius-btn:12px;
  --radius-sm:10px;

  --shadow-sm:0 4px 16px rgba(20,20,20,.05);
  --shadow:0 10px 34px rgba(20,20,20,.07);
  --shadow-lg:0 24px 60px rgba(20,20,20,.10);
  --shadow-red:0 14px 30px rgba(216,0,0,.26);

  --font-head:"Sora",ui-sans-serif,system-ui,sans-serif;
  --font-body:"Inter",ui-sans-serif,system-ui,sans-serif;

  --maxw:1200px;
  --gutter:clamp(20px,5vw,40px);
  --section-y:clamp(64px,9vw,120px);

  --ease:cubic-bezier(.22,.61,.36,1);
}

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

h1,h2,h3,h4{
  font-family:var(--font-head);
  color:var(--ink);
  margin:0;
  line-height:1.08;
  letter-spacing:-.02em;
  font-weight:700;
  text-wrap:balance;
}
h1{font-size:clamp(2.5rem,5.5vw,4rem)}
h2{font-size:clamp(2rem,3.8vw,2.6rem)}
h3{font-size:clamp(1.3rem,2vw,1.65rem)}
p{margin:0 0 1rem;text-wrap:pretty}

/* ---- Layout helpers ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.wrap-wide{max-width:1340px;margin:0 auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-y)}
.band{background:var(--light)}
.tint{background:linear-gradient(180deg,var(--red-tint-2),var(--red-tint))}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-head);
  font-size:.8rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.18em;
  color:var(--red);
  margin-bottom:18px;
}
.eyebrow::before{
  content:"";width:26px;height:2px;border-radius:2px;
  background:var(--red);display:inline-block;
}
.eyebrow.center{justify-content:center}
.lead{font-size:clamp(1.05rem,1.4vw,1.2rem);color:var(--body);max-width:62ch}
.section-head{max-width:720px;margin:0 auto 56px;text-align:center}
.section-head .lead{margin-inline:auto}
.muted{color:var(--muted)}
.text-red{color:var(--red)}

/* gradient ink accent on a single word */
.accent{
  color:var(--red);
  position:relative;
  white-space:nowrap;
}

/* ---- Buttons ---- */
.btn{
  --bg:var(--red);
  position:relative;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--font-head);
  font-weight:600;font-size:.98rem;
  padding:15px 26px;border-radius:var(--radius-btn);
  border:1px solid transparent;cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);
  overflow:hidden;white-space:nowrap;
  isolation:isolate;
}
.btn svg{width:18px;height:18px}
.btn-primary{
  background:linear-gradient(180deg,#E60606,var(--red));
  color:#fff;box-shadow:var(--shadow-red);
}
.btn-primary::after{ /* sheen */
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  transform:translateX(-130%);
  transition:transform .6s var(--ease);
}
.btn-primary:hover{background:linear-gradient(180deg,var(--red),var(--red-dark));transform:translateY(-3px);box-shadow:0 20px 38px rgba(216,0,0,.34)}
.btn-primary:hover::after{transform:translateX(130%)}
.btn-primary:active{transform:translateY(-1px)}

.btn-ghost{
  background:#fff;color:var(--ink);border-color:var(--border);
  box-shadow:var(--shadow-sm);
}
.btn-ghost:hover{color:var(--red);border-color:var(--red);transform:translateY(-3px);box-shadow:var(--shadow)}

.btn-light{background:#fff;color:var(--red);}
.btn-light:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}

.btn-lg{padding:18px 32px;font-size:1.05rem}
.btn-block{width:100%}

/* link with arrow */
.link-arrow{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-head);font-weight:600;color:var(--red);
  font-size:.95rem;
}
.link-arrow svg{width:16px;height:16px;transition:transform .25s var(--ease)}
.link-arrow:hover svg{transform:translateX(4px)}

/* ---- Cards ---- */
.card{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius-card);
  box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:#e0d2d2}
/* .tile is defined in the homepage's inline <style>; promote it to the shared sheet so
   pages without that inline block (e.g. services) get the same service-card styling */
.tile{padding:30px;display:flex;flex-direction:column;gap:16px;align-items:flex-start}

.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:999px;
  background:var(--red-tint);color:var(--red);
  font-family:var(--font-head);font-weight:600;font-size:.82rem;
}

.icon-chip{
  width:58px;height:58px;border-radius:16px;
  display:grid;place-items:center;flex:none;
  background:var(--red-tint);color:var(--red);
  transition:transform .35s var(--ease),background .35s var(--ease),color .35s var(--ease);
}
.icon-chip svg{width:26px;height:26px}
.card:hover .icon-chip{background:var(--red);color:#fff;transform:rotate(-6deg) scale(1.06)}

/* ---- Reveal animation ---- */
[data-reveal]{
  opacity:0;transform:translateY(26px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
  will-change:opacity,transform;
}
[data-reveal].in{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.08s}
[data-reveal-delay="2"]{transition-delay:.16s}
[data-reveal-delay="3"]{transition-delay:.24s}
[data-reveal-delay="4"]{transition-delay:.32s}
[data-reveal-delay="5"]{transition-delay:.40s}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  [data-reveal]{opacity:1;transform:none}
  html{scroll-behavior:auto}
}

/* ============================================================
   HEADER
   ============================================================ */
.utility{
  background:var(--ink);color:#cfd2d8;font-size:.84rem;
}
.utility .wrap-wide{display:flex;align-items:center;justify-content:space-between;height:42px;gap:20px}
.utility a{display:inline-flex;align-items:center;gap:7px;transition:color .2s}
.utility a:hover{color:#fff}
.utility svg{width:15px;height:15px}
.utility .u-left{display:flex;gap:26px;flex-wrap:wrap}
.utility .u-right{display:flex;align-items:center;gap:18px}
.u-social{display:flex;gap:10px}
.u-social a{width:26px;height:26px;border-radius:7px;background:rgba(255,255,255,.1);display:grid;place-items:center}
.u-social a:hover{background:var(--red)}

.site-header{position:sticky;top:0;z-index:80;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:box-shadow .3s,border-color .3s}
.site-header.scrolled{box-shadow:0 6px 24px rgba(20,20,20,.07);border-color:var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;height:74px}
.brand{flex:none;display:inline-flex;align-items:center}
.brand img{height:42px;width:auto;flex:none}
.nav-menu{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0}
.nav-menu>li{position:relative}
.nav-menu>li>a{
  display:inline-flex;align-items:center;gap:5px;
  padding:10px 10px;border-radius:9px;
  font-family:var(--font-head);font-weight:500;font-size:.93rem;color:var(--ink);
  transition:color .2s,background .2s;white-space:nowrap;
}
.nav-menu>li>a:hover{color:var(--red);background:var(--red-tint-2)}
.nav-menu>li>a .caret{width:14px;height:14px;transition:transform .25s}
.nav-menu>li.has-dd:hover>a .caret{transform:rotate(180deg)}
.nav-menu>li>a.active{color:var(--red)}

.dd{
  position:absolute;top:calc(100% + 8px);left:0;min-width:248px;
  background:#fff;border:1px solid var(--border);border-radius:14px;
  box-shadow:var(--shadow-lg);padding:8px;
  opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .22s var(--ease),transform .22s var(--ease),visibility .22s;
  list-style:none;margin:0;
}
.nav-menu>li.has-dd:hover .dd{opacity:1;visibility:visible;transform:none}
.dd a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:9px;font-size:.9rem;font-weight:500;color:var(--body);transition:background .18s,color .18s}
.dd a:hover{background:var(--red-tint-2);color:var(--red)}
.dd a svg{width:16px;height:16px;color:var(--red);flex:none}

.nav-cta{display:flex;align-items:center;gap:14px}

.hamburger{display:none;width:46px;height:46px;border-radius:11px;border:1px solid var(--border);background:#fff;cursor:pointer;align-items:center;justify-content:center}
.hamburger svg{width:22px;height:22px;color:var(--ink)}

/* Mobile panel */
.mobile-panel{position:fixed;inset:0;z-index:90;background:#fff;transform:translateX(100%);transition:transform .4s var(--ease);display:flex;flex-direction:column;visibility:hidden}
.mobile-panel.open{transform:none;visibility:visible}
.mp-head{display:flex;align-items:center;justify-content:space-between;height:74px;padding-inline:var(--gutter);border-bottom:1px solid var(--border)}
.mp-head img{height:38px;width:auto;flex:none}
.mp-close{width:46px;height:46px;border-radius:11px;border:1px solid var(--border);background:#fff;display:grid;place-items:center;cursor:pointer}
.mp-close svg{width:22px;height:22px}
.mp-body{flex:1;overflow-y:auto;padding:18px var(--gutter) 40px}
.mp-link{display:flex;align-items:center;justify-content:space-between;padding:15px 4px;font-family:var(--font-head);font-weight:600;font-size:1.15rem;color:var(--ink);border-bottom:1px solid var(--border);width:100%;background:none;border-left:0;border-right:0;border-top:0;cursor:pointer;text-align:left}
.mp-link svg{width:20px;height:20px;color:var(--muted);transition:transform .25s}
.mp-acc.open .mp-link svg{transform:rotate(180deg);color:var(--red)}
.mp-sub{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.mp-sub a{display:block;padding:12px 16px;color:var(--body);font-size:1rem;border-bottom:1px solid var(--light)}
.mp-sub a:hover{color:var(--red)}
.mp-actions{margin-top:26px;display:flex;flex-direction:column;gap:12px}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--light);border-top:1px solid var(--border);padding-top:clamp(56px,7vw,84px)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1.6fr 1fr;gap:48px}
.footer-brand img{height:46px;margin-bottom:18px}
.footer-brand p{color:var(--body);max-width:34ch}
.f-social{display:flex;gap:10px;margin-top:18px}
.f-social a{width:38px;height:38px;border-radius:10px;background:#fff;border:1px solid var(--border);display:grid;place-items:center;color:var(--ink);transition:.2s}
.f-social a:hover{background:var(--red);color:#fff;border-color:var(--red);transform:translateY(-3px)}
.f-social svg{width:18px;height:18px}
.footer-key{background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);padding:28px;box-shadow:var(--shadow-sm)}
.footer-key h4{display:flex;align-items:center;gap:9px;font-size:1.15rem;margin-bottom:12px}
.footer-key h4 .rk{width:22px;height:22px;color:var(--red)}
.footer-key p{font-size:.95rem}
.footer-contact{display:flex;flex-direction:column;gap:10px;margin-top:16px}
.footer-contact a{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-head);font-weight:600;color:var(--ink);font-size:.95rem}
.footer-contact a svg{width:17px;height:17px;color:var(--red)}
.f-col h5{font-family:var(--font-head);font-size:.82rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink);margin:0 0 18px}
.f-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.f-col ul a{color:var(--body);font-size:.95rem;transition:color .2s,padding .2s}
.f-col ul a:hover{color:var(--red);padding-left:5px}
.footer-bottom{border-top:1px solid var(--border);margin-top:clamp(44px,6vw,64px);padding-block:24px}
.footer-bottom .wrap-wide{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:.86rem;color:var(--muted)}
.footer-bottom a:hover{color:var(--red)}

/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.page-hero{position:relative;background:var(--light);overflow:hidden;padding-block:clamp(60px,8vw,96px);border-bottom:1px solid var(--border)}
.page-hero .deco-grid{position:absolute;inset:0;background-image:radial-gradient(var(--border) 1px,transparent 1px);background-size:26px 26px;mask-image:linear-gradient(180deg,transparent,#000 40%,transparent);opacity:.7}
.page-hero .wrap{position:relative}
.breadcrumb{display:flex;align-items:center;gap:9px;font-size:.9rem;color:var(--muted);margin-bottom:18px;font-family:var(--font-head);font-weight:500}
.breadcrumb a:hover{color:var(--red)}
.breadcrumb svg{width:15px;height:15px}
.breadcrumb .here{color:var(--red)}
.page-hero h1{font-size:clamp(2.4rem,5vw,3.4rem)}
.page-hero .lead{margin-top:16px}
.page-hero .floaty{position:absolute;right:-40px;top:50%;transform:translateY(-50%);width:340px;height:340px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--red-tint),transparent 70%);filter:blur(6px);pointer-events:none}

/* ============================================================
   GRID UTILITIES
   ============================================================ */
.grid{display:grid;gap:26px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

@media (max-width:1080px){
  .g-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:820px){
  .g-3{grid-template-columns:1fr}
  .g-2{grid-template-columns:1fr}
}
@media (max-width:560px){
  .g-4{grid-template-columns:1fr}
}

/* ============================================================
   FORMS
   ============================================================ */
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:18px}
.field label{font-family:var(--font-head);font-weight:600;font-size:.88rem;color:var(--ink)}
.field input,.field textarea,.field select{
  font-family:var(--font-body);font-size:1rem;color:var(--ink);
  padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);
  background:#fff;transition:border-color .2s,box-shadow .2s;width:100%;
}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px var(--red-tint)}

/* ============================================================
   RESPONSIVE NAV BREAKPOINT
   ============================================================ */
@media (max-width:1240px){
  .nav-menu{display:none}
  .hamburger{display:inline-flex}
}
@media (max-width:560px){
  .utility .u-left{gap:16px}
  .utility .hide-sm{display:none}
  /* phones: clean logo + hamburger header (Get a Quote stays in the slide-out menu & hero) */
  .nav-cta .btn{display:none}
}
@media (max-width:920px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media (max-width:600px){
  .footer-grid{grid-template-columns:1fr}
}

/* ============================================================
   REUSABLE INNER-PAGE COMPONENTS
   ============================================================ */
/* Split content / media */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:center}
.split.media-left{grid-template-columns:1fr 1fr}
.feature-img{position:relative;border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--border)}
.feature-img .media{aspect-ratio:4/3.2}
.feature-img.tall .media{aspect-ratio:4/4.6}
.feature-badge{position:absolute;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);padding:15px 19px;display:flex;align-items:center;gap:13px}
.feature-badge .ic{width:46px;height:46px;border-radius:13px;background:var(--red);color:#fff;display:grid;place-items:center;flex:none}
.feature-badge .ic svg{width:22px;height:22px}
.feature-badge .v{font-family:var(--font-head);font-weight:700;color:var(--ink);line-height:1.1}
.feature-badge .l{font-size:.8rem;color:var(--muted)}
@media (max-width:860px){.split{grid-template-columns:1fr;gap:40px}.split .feature-img{max-width:520px}}

/* check list */
.checklist{list-style:none;padding:0;margin:24px 0;display:flex;flex-direction:column;gap:13px}
.checklist li{display:flex;gap:12px;align-items:flex-start;color:var(--ink);font-weight:500}
.checklist li .tick{width:24px;height:24px;border-radius:50%;background:var(--red-tint);color:var(--red);display:grid;place-items:center;flex:none;margin-top:1px}
.checklist li .tick svg{width:14px;height:14px}

/* process stepper */
.stepper{display:grid;grid-template-columns:repeat(6,1fr);gap:18px;position:relative}
.stepper::before{content:"";position:absolute;top:34px;left:8%;right:8%;height:2px;background:linear-gradient(90deg,var(--red-tint),var(--red),var(--red-tint));z-index:0}
.step{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.step .dot{width:68px;height:68px;border-radius:20px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow);display:grid;place-items:center;color:var(--red);position:relative;transition:.3s var(--ease)}
.step .dot svg{width:28px;height:28px}
.step .dot .n{position:absolute;top:-9px;right:-9px;width:26px;height:26px;border-radius:50%;background:var(--red);color:#fff;font-family:var(--font-head);font-weight:700;font-size:.78rem;display:grid;place-items:center;border:2px solid #fff}
.step:hover .dot{transform:translateY(-5px);background:var(--red);color:#fff;border-color:var(--red)}
.step .st-name{font-family:var(--font-head);font-weight:700;color:var(--ink);font-size:1rem}
.step .st-desc{font-size:.84rem;color:var(--muted);max-width:18ch}
@media (max-width:920px){
  .stepper{grid-template-columns:1fr;gap:0}
  .stepper::before{top:0;bottom:0;left:33px;right:auto;width:2px;height:auto}
  .step{flex-direction:row;text-align:left;align-items:center;gap:20px;padding:14px 0}
  .step .st-desc{max-width:none}
}

/* pricing table */
.ptable-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-sm);background:#fff}
.ptable{border-collapse:collapse;width:100%;min-width:820px}
.ptable th,.ptable td{padding:16px 18px;text-align:center;border-bottom:1px solid var(--border)}
.ptable thead th{position:sticky;top:0;background:#fff;z-index:2}
.ptable tbody tr:nth-child(even){background:var(--red-tint-2)}
.ptable td:first-child,.ptable th:first-child{text-align:left;font-family:var(--font-head);font-weight:600;color:var(--ink);position:sticky;left:0;background:inherit}
.ptable thead .pcol{vertical-align:bottom}
.ptable .pcol .pn{font-family:var(--font-head);font-weight:600;color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em}
.ptable .pcol .pp{font-family:var(--font-head);font-weight:800;color:var(--ink);font-size:1.5rem;margin-top:4px}
.ptable .pcol.pop{background:var(--red);color:#fff;border-radius:14px 14px 0 0}
.ptable .pcol.pop .pn,.ptable .pcol.pop .pp{color:#fff}
.ptable .yes{color:var(--success)}
.ptable .yes svg{width:19px;height:19px}
.ptable .no{color:var(--border)}
.ptable .no svg{width:17px;height:17px}

/* info / contact cards */
.info-card{display:flex;gap:16px;align-items:flex-start;padding:24px;border-radius:var(--radius-card);background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:.3s var(--ease)}
.info-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.info-card .ic{width:52px;height:52px;border-radius:14px;background:var(--red-tint);color:var(--red);display:grid;place-items:center;flex:none}
.info-card .ic svg{width:24px;height:24px}
.info-card h4{font-size:1.05rem;margin-bottom:4px}
.info-card a,.info-card p{color:var(--body);font-size:.95rem;margin:0}
.info-card a:hover{color:var(--red)}

/* form card */
.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow);padding:clamp(26px,4vw,40px)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}
.form-note{display:none;align-items:center;gap:10px;background:#eafaf0;border:1px solid #b9e9cd;color:#137a43;border-radius:10px;padding:13px 16px;font-weight:600;font-size:.92rem;margin-top:6px}
.form-note svg{width:18px;height:18px;flex:none}

/* blog cards */
.blog-card{overflow:hidden;display:flex;flex-direction:column}
.blog-card .media{aspect-ratio:16/10}
.blog-card .bc-body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.blog-card .bc-meta{display:flex;gap:14px;font-size:.82rem;color:var(--muted);font-family:var(--font-head);font-weight:500}
.blog-card .bc-meta .cat{color:var(--red)}
.blog-card h3{font-size:1.18rem}
.blog-card p{font-size:.92rem;margin:0}
.blog-card .link-arrow{margin-top:auto;padding-top:8px}

/* faq / accordion */
.acc{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.acc-item{border:1px solid var(--border);border-radius:14px;background:#fff;overflow:hidden;box-shadow:var(--shadow-sm)}
.acc-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;background:none;border:0;cursor:pointer;font-family:var(--font-head);font-weight:600;font-size:1.05rem;color:var(--ink);text-align:left}
.acc-head .pm{width:30px;height:30px;border-radius:50%;background:var(--red-tint);color:var(--red);display:grid;place-items:center;flex:none;transition:.3s var(--ease)}
.acc-head .pm svg{width:16px;height:16px;transition:transform .3s var(--ease)}
.acc-item.open .acc-head .pm{background:var(--red);color:#fff}
.acc-item.open .acc-head .pm svg{transform:rotate(45deg)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.acc-body p{padding:0 24px 22px;margin:0;color:var(--body)}

/* solution / icon list cards */
.teaser{padding:30px;display:flex;flex-direction:column;gap:16px;align-items:flex-start;height:100%}
.teaser .icon-chip{width:54px;height:54px}
.teaser h3{font-size:1.12rem}
.teaser p{font-size:.94rem;margin:0;flex:1}

/* mini stats strip (inner pages) */
.mini-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.mini-stats .num{font-family:var(--font-head);font-weight:800;font-size:clamp(2.2rem,4vw,3rem);color:var(--red);line-height:1}
.mini-stats .lab{margin-top:8px;font-family:var(--font-head);font-weight:600;color:var(--ink);font-size:.92rem}
@media (max-width:680px){.mini-stats{grid-template-columns:repeat(2,1fr);gap:30px 16px}}

/* page-hero with media variant */
.hero-2col{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,60px);align-items:center}
@media (max-width:860px){.hero-2col{grid-template-columns:1fr;gap:36px}}

/* prose */
.prose p{margin-bottom:1.1rem}
.prose h3{margin:32px 0 12px}
.section-tight{padding-block:clamp(48px,7vw,80px)}

/* tag pills row */
.pill-row{display:flex;flex-wrap:wrap;gap:10px}
.pill{display:inline-flex;align-items:center;gap:7px;padding:8px 15px;border-radius:999px;background:#fff;border:1px solid var(--border);font-family:var(--font-head);font-weight:600;font-size:.85rem;color:var(--ink);box-shadow:var(--shadow-sm)}
.pill svg{width:15px;height:15px;color:var(--red)}

/* CTA strip reusable */
.cta-strip{background:linear-gradient(135deg,var(--red-tint-2),var(--red-tint));border-radius:var(--radius-card);padding:clamp(34px,5vw,56px);position:relative;overflow:hidden;text-align:center}
.cta-strip .rk{position:absolute;right:-30px;bottom:-40px;width:240px;height:240px;color:rgba(216,0,0,.06)}
.cta-strip h2{position:relative}
.cta-strip .lead{margin:14px auto 26px}
.cta-strip .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}
