/* ===================================================================
   Din Familie Coach — static rebuild · style.css  (v2, modern)
   Brand: primary #B3012F (logo crimson), secondary #2B7BB9, Nunito Sans.
   Drop-in replacement: same class names as the generator (_build.py),
   so it restyles every page + all blog posts at once.
   Mobile-first, lean, no frameworks.
   =================================================================== */

:root{
  /* Brand (var names kept for _build.py inline styles) */
  --pink:#B3012F;            /* primary — logo crimson */
  --pink-dark-solid:#97012A; /* hover */
  --pink-darker:#7E0123;     /* pressed */
  --pink-tint:#F7E1E6;
  --pink-wash:#FBEEF1;
  --pink-light:#E23B5A;      /* gradient stop */
  --blue:#2B7BB9;
  --blue-dark:#22618F;
  --blue-wash:#EEF5FB;
  --ink:#2b2b2b;             /* body */
  --heading:#1f2733;
  --muted:#757575;
  --bg:#ffffff;
  --band:#f6f6f6;
  --dark:#1d2433;            /* footer */
  --dark-2:#161c28;
  --on-dark:#c4ccdb;
  --border:#e6e6e6;
  --radius:12px;
  --radius-pill:40px;
  --maxw:1140px;
  --shadow:0 8px 30px rgba(0,0,0,.07);
  --shadow-lg:0 18px 48px rgba(0,0,0,.12);
  --grad-hero:linear-gradient(160deg,#fbeef1 0%,#eef5fb 100%);
  --grad-cta:linear-gradient(135deg,#B3012F 0%,#E23B5A 100%);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:"Nunito Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{line-height:1.15;color:var(--heading);font-weight:800;margin:0 0 .5em;letter-spacing:-.015em}
h1{font-size:clamp(30px,6vw,52px);line-height:1.06}
h2{font-size:clamp(24px,4.4vw,34px)}
h3{font-size:1.3rem}
p{margin:0 0 1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.band{background:var(--band)}
.section{padding:56px 0}
.section-sm{padding:36px 0}
.center{text-align:center}
.lead{font-size:1.18rem;color:#3c3c3c;line-height:1.6}
.muted{color:var(--muted)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--pink);color:#fff;font-weight:800;
  padding:14px 28px;border-radius:var(--radius-pill);border:2px solid var(--pink);cursor:pointer;
  transition:background .2s,border-color .2s,color .2s,transform .12s;
  text-align:center;line-height:1.2;font-size:1rem;
}
.btn:hover{background:var(--pink-dark-solid);border-color:var(--pink-dark-solid);text-decoration:none;color:#fff}
.btn:active{transform:translateY(1px)}
.btn-blue{background:var(--blue);border-color:var(--blue)}
.btn-blue:hover{background:var(--blue-dark);border-color:var(--blue-dark)}
.btn-outline{background:transparent;border:2px solid var(--pink);color:var(--pink)}
.btn-outline:hover{background:var(--pink);color:#fff}

/* ---------- Top bar ---------- */
.topbar{background:#fff;border-top:5px solid var(--dark);border-bottom:1px solid var(--border);font-size:.92rem}
.topbar .container{display:flex;flex-wrap:wrap;gap:6px 26px;align-items:center;padding-top:11px;padding-bottom:11px}
.topbar a{color:var(--ink);font-weight:700;display:inline-flex;align-items:center;gap:6px}
.topbar a:hover{color:var(--pink);text-decoration:none}
.topbar a:last-child{margin-left:auto;font-weight:600}   /* address → right */

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.93);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 22px;max-width:var(--maxw);margin:0 auto}
.brand img{height:46px;width:auto}
.nav-links{display:flex;flex-wrap:wrap;gap:2px;align-items:center;list-style:none;margin:0;padding:0}
.nav-links a{color:#33404f;font-weight:700;padding:9px 13px;border-radius:8px;font-size:.97rem}
.nav-links a:hover{background:var(--band);text-decoration:none}
.nav-links a.cta{background:var(--pink);color:#fff;margin-left:6px;border-radius:var(--radius-pill);padding:10px 18px}
.nav-links a.cta:hover{background:var(--pink-dark-solid)}
.nav-toggle{display:none;background:none;border:0;font-size:1.7rem;cursor:pointer;color:#33404f;line-height:1;padding:4px 8px}

/* ---------- Hero ---------- */
.hero{background:var(--grad-hero);padding:72px 0}
.hero h1{margin-bottom:.3em}
.hero .lead{max-width:560px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero-grid img{border-radius:var(--radius);box-shadow:var(--shadow-lg)}

/* ---------- Cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow);transition:box-shadow .2s,transform .2s}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.card h3{color:var(--pink);font-size:1.32rem}
.cards-2{grid-template-columns:repeat(2,1fr)}

/* ---------- Generic content ---------- */
.prose{max-width:780px;margin:0 auto}
.prose h2{margin-top:1.5em}
.prose ul{padding-left:1.2em}
.prose li{margin:.4em 0}
.prose blockquote{margin:1.6em 0;padding:20px 26px;border-left:4px solid var(--pink);background:var(--band);border-radius:0 var(--radius) var(--radius) 0;font-style:italic;font-size:1.15rem;color:var(--heading)}
.case{background:#fff;border:1px solid var(--border);border-left:4px solid var(--blue);border-radius:0 var(--radius) var(--radius) 0;padding:26px 28px;margin:22px 0;box-shadow:var(--shadow)}
.case h3{color:var(--blue)}
.case .scenario{font-style:italic;color:#555}

/* ---------- Pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.price{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px;text-align:center;box-shadow:var(--shadow);transition:box-shadow .2s,transform .2s}
.price:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.price h3{margin-bottom:.2em;font-size:1.18rem}
.price .amount{font-size:2.1rem;font-weight:900;color:var(--pink);margin:.3em 0}
.price .per{color:var(--muted);font-size:.95rem;margin-bottom:1em}
.price .btn{width:100%}

/* ---------- Testimonials ---------- */
.quote{background:#fff;border:1px solid var(--border);border-left:4px solid var(--pink);border-radius:0 var(--radius) var(--radius) 0;padding:28px;box-shadow:var(--shadow);margin-bottom:22px}
.quote h3{font-size:1.2rem;color:var(--heading)}
.quote .who{font-weight:800;color:var(--pink);margin-top:.6em}

/* ---------- Forms ---------- */
.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow);max-width:640px;margin:0 auto}
.form-card label{display:block;font-weight:800;margin:14px 0 6px;font-size:.95rem;color:var(--heading)}
.form-card input,.form-card textarea{
  width:100%;padding:13px 15px;border:1px solid #d8d8d8;border-radius:8px;font:inherit;font-size:1rem;color:var(--ink);
  transition:border-color .2s,box-shadow .2s;
}
.form-card input:focus,.form-card textarea:focus{outline:none;border-color:var(--pink);box-shadow:0 0 0 3px rgba(179,1,47,.2)}
.form-card textarea{min-height:120px;resize:vertical}
.form-note{font-size:.82rem;color:var(--muted);margin-top:14px}

/* ---------- Blog ---------- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.post-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s}
.post-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.post-card img{aspect-ratio:3/2;object-fit:cover;width:100%}
.post-card .body{padding:20px;display:flex;flex-direction:column;gap:10px;flex:1}
.post-card h3{font-size:1.12rem;margin:0;color:var(--heading)}
.post-card .date{font-size:.82rem;color:var(--muted);font-weight:700}
.post-card a.more{margin-top:auto;font-weight:800;color:var(--pink)}
.post-hero img{border-radius:var(--radius);box-shadow:var(--shadow);margin:0 auto 28px;max-height:440px;width:100%;aspect-ratio:1024/600;object-fit:cover}
.post-meta{color:var(--muted);font-size:.95rem;margin-bottom:1.5em;font-weight:600}
.post-nav{display:flex;justify-content:space-between;gap:16px;margin:48px auto 0;max-width:780px;font-weight:800;flex-wrap:wrap}
.post-nav a{color:var(--pink)}

/* ---------- CTA band ---------- */
.cta-band{background:var(--grad-cta);color:#fff;text-align:center}
.cta-band h2{color:#fff}
.cta-band .btn{background:#fff;color:var(--pink);border-color:#fff}
.cta-band .btn:hover{background:#ffe9ef;border-color:#ffe9ef;color:var(--pink)}
.cta-band p{color:#ffe7ee;max-width:680px;margin:0 auto 1.3em;font-size:1.1rem}

/* ---------- Footer ---------- */
.site-footer{background:var(--dark);color:var(--on-dark);padding:56px 0 28px;font-size:.97rem}
.site-footer a{color:var(--on-dark)}
.site-footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:40px}
.site-footer img.logo{height:54px;width:auto;margin-bottom:16px}
.site-footer h4{color:#fff;font-size:1.05rem;margin-bottom:.8em}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:.4em 0}
.footer-bottom{border-top:1px solid #2c3547;margin-top:36px;padding-top:18px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#8a93a6;font-size:.85rem}
.social{display:flex;gap:14px;margin-top:14px}
.social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;font-weight:700;font-size:.85rem}
.social a:hover{background:var(--pink);text-decoration:none}

/* ---------- Header social + hero extras ---------- */
.nav-social{display:inline-flex;align-items:center;gap:12px;margin-left:10px}
.nav-social a{color:var(--pink);display:inline-flex;padding:4px;line-height:0}
.nav-social a:hover{color:var(--pink-dark-solid)}
.topbar a svg{flex-shrink:0}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--pink);color:#fff;font-weight:800;font-size:.86rem;padding:8px 16px;border-radius:999px;margin:6px 0 0}
.hero-figure{display:flex;flex-direction:column;gap:18px}
.kendt{display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:center}
.kendt-label{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}
.kendt img{width:auto;opacity:.95}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media(min-width:901px){
  .section{padding:84px 0}
  body{font-size:18px}
}

@media(max-width:900px){
  .nav-toggle{display:block}
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;background:#fff;
    flex-direction:column;align-items:stretch;gap:2px;padding:10px 16px 18px;
    border-bottom:1px solid var(--border);box-shadow:var(--shadow);
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 12px;border-radius:8px;font-size:1rem}
  .nav-links a:hover{background:var(--band)}
  .nav-links a.cta{margin:8px 0 0;text-align:center;padding:14px 18px}
  .hero{padding:48px 0}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .cards,.cards-2,.price-grid,.post-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .topbar a:last-child{margin-left:0;flex-basis:100%}  /* address wraps below on mobile */
}

@media(max-width:560px){
  .topbar{font-size:.85rem}
  .topbar .container{gap:4px 18px}
  .section{padding:44px 0}
  .btn{width:100%}
  .hero .btn,.cta-band .btn{width:auto}
  .post-nav{flex-direction:column}
}

/* Larger, comfortable tap targets on touch devices */
@media(hover:none){
  .nav-links a{min-height:44px;display:flex;align-items:center}
}

@media print{
  .topbar,.site-header,.cta-band,.form-card,.nav-toggle{display:none}
  body{font-size:12pt}
}

/* ===================================================================
   v2 PAGE ELEMENTS (icons, featured pricing, stars, steps, sub-hero)
   =================================================================== */
.eyebrow{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--pink);margin:0 0 12px}
.page-hero{background:var(--grad-hero);padding:72px 0}
.page-hero .container{max-width:780px}
.page-hero h1{margin:0 0 .3em}
.section-head{text-align:center;max-width:680px;margin:0 auto 40px}
.section-head h2{margin:0}
.section-head .eyebrow{display:block}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}

.tile{width:48px;height:48px;border-radius:12px;background:var(--pink-tint);color:var(--pink);display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px}
.card .tile{margin-bottom:16px}
.card-accent{border-top:3px solid var(--pink)}

.feature-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:15px}
.feature{display:flex;gap:14px;align-items:flex-start;font-size:1.02rem}
.feature .tick{flex:0 0 27px;height:27px;border-radius:50%;background:var(--pink-tint);color:var(--pink);display:inline-flex;align-items:center;justify-content:center;margin-top:2px}

.price.featured{border-top:3px solid var(--pink);box-shadow:var(--shadow-lg)}
.badge-top{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--pink);color:#fff;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;padding:5px 14px;border-radius:999px;white-space:nowrap}

.stars{color:var(--pink);letter-spacing:3px;margin:0 0 12px;font-size:1.05rem}

.steps{display:flex;flex-direction:column;gap:18px;margin:0}
.step{display:flex;gap:18px;align-items:flex-start}
.step-n{flex:0 0 38px;height:38px;border-radius:50%;background:var(--pink);color:#fff;font-weight:800;font-size:1.05rem;display:inline-flex;align-items:center;justify-content:center}
.step p{margin:.35rem 0 0}

/* ===== v2 hero panel + stat + om-band (re-applied over zip base) ===== */
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:4px 0 2px}
.hero-cta .btn{display:inline-flex;align-items:center;gap:8px}
.hero-figure{position:relative}
.hero-photo{position:relative;display:block;background:linear-gradient(155deg,#ffffff 0%,#f4e9ed 100%);
  border-radius:24px;padding:14px 14px 0;box-shadow:var(--shadow-lg)}
.hero-photo>img{display:block;width:100%;height:auto;border-radius:0;box-shadow:none}
.hero-stat{position:absolute;left:-16px;bottom:26px;display:flex;align-items:center;gap:12px;
  background:#fff;border-radius:16px;padding:12px 18px 12px 12px;box-shadow:var(--shadow-lg)}
.hero-stat .ic{width:42px;height:42px;border-radius:50%;background:rgba(179,1,47,.12);
  color:var(--pink);display:grid;place-items:center;flex:0 0 auto}
.hero-stat strong{display:block;font-size:1.2rem;line-height:1;color:#1f2733}
.hero-stat span{font-size:.8rem;color:var(--muted)}
.om-band{display:grid;grid-template-columns:.78fr 1fr;gap:48px;align-items:center}
.om-band .hero-photo{max-width:360px}
.notice{background:rgba(179,1,47,.07);border:1px solid rgba(179,1,47,.18);color:#7a1228;
  border-radius:12px;padding:14px 18px;margin:8px 0;font-size:.95rem}
@media(max-width:820px){.om-band{grid-template-columns:1fr;gap:28px}.hero-stat{left:8px;bottom:12px}}

/* Cookie consent banner */
.consent-banner{position:fixed;left:0;right:0;bottom:0;z-index:60;background:var(--bg);border-top:1px solid var(--border);box-shadow:0 -6px 28px rgba(0,0,0,.13)}
.consent-banner[hidden]{display:none}
.consent-inner{max-width:var(--maxw);margin:0 auto;padding:16px 20px;display:flex;gap:18px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.consent-text{margin:0;flex:1 1 340px;font-size:.93rem;color:var(--ink)}
.consent-actions{display:flex;gap:10px;flex-wrap:wrap}
.consent-actions .btn{min-height:44px;display:inline-flex;align-items:center;justify-content:center}
.footer-links{display:flex;gap:18px;flex-wrap:wrap}
@media(max-width:600px){.consent-inner{flex-direction:column;align-items:stretch}.consent-actions .btn{flex:1 1 auto}}

/* blog category eyebrow on post cards */
.post-cat{font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--pink)}

/* check-styled value lists inside blog post bodies */
.post-body ul{list-style:none;padding:0;margin:0 0 1.3em;display:flex;flex-direction:column;gap:12px}
.post-body ul li{position:relative;padding-left:38px;margin:0;line-height:1.55}
.post-body ul li::before{content:"✓";position:absolute;left:0;top:1px;width:24px;height:24px;border-radius:7px;background:var(--pink-tint);color:var(--pink);font-size:13px;font-weight:900;display:flex;align-items:center;justify-content:center;line-height:1}

/* Self-hosted Nunito Sans (variable) — replaces render-blocking Google Fonts (also a GDPR win: no IP sent to Google) */
@font-face{font-family:"Nunito Sans";font-style:normal;font-weight:400 900;font-display:swap;src:url("/assets/fonts/nunito-sans.woff2") format("woff2")}
@font-face{font-family:"Nunito Sans";font-style:italic;font-weight:400 900;font-display:swap;src:url("/assets/fonts/nunito-sans-italic.woff2") format("woff2")}
