/*
Theme Name: KommuneCopilot
Theme URI: https://kommunecopilot.dk
Author: Roar M. Johansen
Author URI: https://kommunecopilot.dk
Description: Et roligt, tillidsvækkende WordPress-tema til KommuneCopilot — socialfaglig og juridisk rådgivning til forældre til børn med særlige behov. Alt indhold, farver, fonts, billeder, menuer og knapper redigeres direkte i Tilpas (Customizer).
Version: 1.1.0
Requires at least: 5.9
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kommunecopilot
Tags: blog, custom-colors, custom-logo, custom-menu, featured-images, full-width-template, theme-options, threaded-comments, translation-ready
*/

/* ==========================================================================
   Design tokens — overskrives af Customizer via CSS-variabler i header.php
   ========================================================================== */
:root{
  --kc-green:#829566;
  --kc-green-dark:#6b7d52;
  --kc-green-soft:#eef1e8;
  --kc-script:#5b5f63;
  --kc-ink:#33373b;
  --kc-muted:#6b7176;
  --kc-bg:#ffffff;
  --kc-bg-alt:#f3f2ee;
  --kc-bg-cool:#e5e8ed;
  --kc-line:#e2e1db;
  --kc-radius:18px;
  --kc-shadow:0 18px 50px -20px rgba(51,55,59,.28);
  --kc-shadow-sm:0 6px 22px -12px rgba(51,55,59,.30);
  --kc-maxw:1180px;
  --kc-font-head:'Poppins',system-ui,sans-serif;
  --kc-font-body:'Source Sans 3','Source Sans Pro',system-ui,sans-serif;
  --kc-font-script:'Dancing Script',cursive;
  --kc-font-accent:'Lora',Georgia,serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--kc-font-body);
  font-size:18px;
  line-height:1.7;
  color:var(--kc-ink);
  background:var(--kc-bg);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--kc-green-dark);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--kc-green)}

h1,h2,h3,h4{font-family:var(--kc-font-head);color:var(--kc-ink);line-height:1.15;font-weight:700;margin:0 0 .5em}
h1{font-size:clamp(2.2rem,5vw,3.5rem);letter-spacing:-.02em}
h2{font-size:clamp(1.8rem,3.6vw,2.6rem);letter-spacing:-.015em}
h3{font-size:1.4rem}
p{margin:0 0 1.2em}

.kc-container{max-width:var(--kc-maxw);margin:0 auto;padding:0 24px}
.kc-script{font-family:var(--kc-font-script);color:var(--kc-script);font-weight:600}
.kc-eyebrow{
  display:inline-block;font-family:var(--kc-font-head);font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;font-size:.74rem;
  color:var(--kc-green-dark);margin-bottom:14px;
}
.kc-eyebrow--badge{
  background:var(--kc-green);color:#fff;padding:3px 7px;border-radius:2px;
  letter-spacing:.12em;box-decoration-break:clone;-webkit-box-decoration-break:clone;
}

/* Buttons */
.kc-btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--kc-font-head);font-weight:600;font-size:1rem;
  padding:15px 30px;border-radius:999px;border:2px solid var(--kc-green);
  background:var(--kc-green);color:#fff;cursor:pointer;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
  box-shadow:var(--kc-shadow-sm);
}
.kc-btn:hover{background:var(--kc-green-dark);border-color:var(--kc-green-dark);color:#fff;transform:translateY(-2px)}
.kc-btn--ghost{background:transparent;color:var(--kc-green-dark);box-shadow:none}
.kc-btn--ghost:hover{background:var(--kc-green-soft);color:var(--kc-green-dark)}

/* ===== Header ===== */
.kc-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--kc-line);
}
.kc-header__inner{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:112px}
.kc-nav{flex:1}
.kc-nav>ul,.kc-nav>div>ul{justify-content:center}
.kc-brand{display:flex;align-items:center;gap:14px;text-decoration:none;flex-shrink:0}
.kc-brand img{max-height:54px;width:auto}
.kc-brand__text{font-family:var(--kc-font-head);font-weight:700;font-size:2.5rem;color:var(--kc-green);line-height:1.05;text-align:center;letter-spacing:0;padding:0 4px;white-space:nowrap}
.kc-brand__text small{display:block;font-family:var(--kc-font-script);font-weight:400;font-size:2.4rem;letter-spacing:0;color:var(--kc-script);margin-top:2px;line-height:.95;text-align:center}
.kc-nav ul{list-style:none;display:flex;gap:22px;margin:0;padding:0;align-items:center}
.kc-nav li{white-space:nowrap}
.kc-nav a{font-family:var(--kc-font-head);font-weight:500;color:var(--kc-ink);font-size:1rem}
.kc-nav a:hover,.kc-nav .current-menu-item>a{color:var(--kc-green-dark)}
.kc-header__cta{white-space:nowrap}
.kc-burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.kc-burger span{display:block;width:26px;height:2px;background:var(--kc-ink);margin:5px 0;transition:.3s}

/* ===== Hero ===== */
.kc-hero{position:relative;overflow:hidden;background:var(--kc-bg-cool)}
.kc-hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(115deg,rgba(243,242,238,.96) 0%,rgba(243,242,238,.78) 42%,rgba(229,232,237,.45) 100%);
  z-index:1;
}
.kc-hero__grid{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;padding:90px 0 100px}
.kc-hero__inner{max-width:620px}
.kc-hero__media{margin:0;display:flex;flex-direction:column;align-items:center;text-align:center}
.kc-hero__portrait{
  display:block;width:340px;height:340px;border-radius:50%;overflow:hidden;
  border:6px solid var(--kc-green);background:var(--kc-green-soft);
  box-shadow:0 12px 30px rgba(51,55,59,.12);
}
.kc-hero__portrait img{width:100%;height:100%;object-fit:cover;display:block}
.kc-hero__caption{margin-top:18px;display:flex;flex-direction:column;gap:3px;max-width:300px;line-height:1.3}
.kc-hero__caption-name{font-family:var(--kc-font-head);font-weight:700;color:var(--kc-ink);font-size:1.08rem}
.kc-hero__caption-title{font-family:var(--kc-font-body);font-weight:400;color:var(--kc-muted);font-size:.98rem}
.kc-hero h1{margin-bottom:.3em;font-size:clamp(1.9rem,3.4vw,2.7rem)}
.kc-hero__lead{font-size:1.25rem;color:var(--kc-muted);max-width:600px;margin-bottom:2em}
.kc-hero__actions{display:flex;gap:16px;flex-wrap:wrap}
/* Discreet pulsing ring on the hero CTA to draw a gentle eye */
.kc-hero__actions .kc-btn{position:relative}
.kc-hero__actions .kc-btn::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  border:2px solid var(--kc-green);opacity:0;pointer-events:none;
  animation:kc-pulse 3s ease-out infinite;
}
@keyframes kc-pulse{
  0%{opacity:.5;inset:0}
  70%{opacity:0;inset:-12px}
  100%{opacity:0;inset:-12px}
}
@media (prefers-reduced-motion:reduce){
  .kc-hero__actions .kc-btn::after{animation:none;display:none}
}
.kc-hero__motto{font-family:var(--kc-font-script);font-weight:700;font-size:2.2rem;color:var(--kc-green-dark);margin-bottom:.05em;line-height:1.1}

/* ===== Nøgletal / stats ===== */
.kc-stats{background:var(--kc-bg-alt);padding:80px 0}
.kc-stats__head{max-width:680px;margin:0 auto 48px;text-align:center}
.kc-stats__head h2{font-size:clamp(1.6rem,3vw,2.3rem)}
.kc-stats__head p{color:var(--kc-muted)}
.kc-stats__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:980px;margin:0 auto}
.kc-stat{
  background:var(--kc-bg);border:1px solid var(--kc-line);border-radius:var(--kc-radius);
  padding:34px 26px;text-align:center;box-shadow:var(--kc-shadow-sm);
  opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease;
}
.kc-stat.is-in{opacity:1;transform:none}
.kc-stat__num{font-family:var(--kc-font-head);font-weight:700;color:var(--kc-green-dark);font-size:clamp(2.6rem,6vw,3.6rem);line-height:1;display:flex;align-items:baseline;justify-content:center;gap:2px}
.kc-stat__suffix{font-size:.6em}
.kc-stat__label{color:var(--kc-muted);margin:14px 0 0;font-size:1rem;line-height:1.5}
.kc-stats__cta{text-align:center;margin-top:48px}
.kc-stats__source{color:var(--kc-muted);font-size:.82rem;margin-top:16px}
/* highlight cycling between the stat cards */
.kc-stat.is-active{border-color:var(--kc-green);box-shadow:0 0 0 3px var(--kc-green-soft),var(--kc-shadow-sm);transform:translateY(-4px)}


/* ===== Sections ===== */
.kc-section{padding:96px 0}
.kc-section--alt{background:var(--kc-bg-alt)}
.kc-section__head{max-width:680px;margin:0 auto 56px;text-align:center}
.kc-section__head p{color:var(--kc-muted)}

/* Pillars / "Sådan hjælper jeg" cards */
.kc-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.kc-card{
  background:var(--kc-bg);border:1px solid var(--kc-line);border-radius:var(--kc-radius);
  padding:34px 30px;box-shadow:var(--kc-shadow-sm);transition:transform .25s ease,box-shadow .25s ease;
}
.kc-card:hover{transform:translateY(-6px);box-shadow:var(--kc-shadow)}
.kc-card__icon{
  width:58px;height:58px;border-radius:16px;display:grid;place-items:center;
  background:var(--kc-green-soft);color:var(--kc-green-dark);margin-bottom:20px;
}
.kc-card__icon svg{width:30px;height:30px}
.kc-card h3{margin-bottom:.4em}
.kc-card p{color:var(--kc-muted);margin:0;font-size:1rem}

/* About / Roar */
.kc-about{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
.kc-about__media{position:relative}
.kc-about__media img{
  border-radius:24px;box-shadow:var(--kc-shadow);width:100%;
  aspect-ratio:4/5;object-fit:cover;
}
.kc-about__badge{
  position:absolute;left:18px;bottom:18px;background:var(--kc-green);border-radius:14px;
  padding:14px 20px;box-shadow:var(--kc-shadow-sm);font-family:var(--kc-font-head);
  font-weight:600;color:#fff;
}
.kc-about__badge span{display:block;font-family:var(--kc-font-body);font-weight:400;color:rgba(255,255,255,.85);font-size:.9rem}

/* Philosophy quote band */
.kc-motto-band{
  background:var(--kc-green);color:#fff;padding:80px 0;text-align:center;
}
.kc-motto-band p{font-family:var(--kc-font-head);font-weight:600;font-size:clamp(1.6rem,3.4vw,2.4rem);margin:0;line-height:1.3;color:#fff;letter-spacing:-.01em}
.kc-motto-band small{display:block;margin-top:18px;font-family:var(--kc-font-head);font-weight:500;letter-spacing:.06em;opacity:.92;font-size:1rem}

/* Opt-in / video CTA card */
.kc-optin{
  background:var(--kc-bg-cool);border-radius:26px;padding:48px 52px;
  max-width:1000px;margin:0 auto;box-shadow:var(--kc-shadow);
}
.kc-optin__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.kc-optin__body .kc-eyebrow{margin-bottom:12px}
.kc-optin h2{margin-bottom:.35em;font-size:clamp(1.7rem,3vw,2.4rem)}
.kc-optin__lead{color:var(--kc-muted);margin-bottom:1.6em}
.kc-optin__btn{justify-content:center;font-size:1.05rem;padding:16px 32px}
.kc-optin__fineprint{font-size:.8rem;color:var(--kc-muted);margin-top:16px;max-width:420px}
.kc-optin__media{margin:0;text-align:center}
.kc-optin__media img{
  width:100%;max-width:320px;margin:0 auto;border-radius:20px;
  background:#fff;box-shadow:var(--kc-shadow-sm);
}
.kc-optin__media figcaption{margin-top:14px;font-family:var(--kc-font-head);color:var(--kc-ink);line-height:1.3}
.kc-optin__media figcaption strong{display:block;font-weight:600}
.kc-optin__media figcaption span{font-size:.9rem;color:var(--kc-muted)}

/* Generic page content */
.kc-page{padding:80px 0}
.kc-page__header{text-align:center;max-width:720px;margin:0 auto 48px}
.kc-content{max-width:780px;margin:0 auto}
.kc-content img{border-radius:14px;margin:1.5em 0}

/* ===== Form styling (Contact Form 7, WPForms, Gutenberg, etc.) ===== */
.kc-content label,
.kc-content .wpcf7-form label{
  display:block;font-family:var(--kc-font-head);font-weight:600;
  color:var(--kc-ink);margin:0 0 6px;font-size:.98rem;
}
.kc-content input[type=text],
.kc-content input[type=email],
.kc-content input[type=tel],
.kc-content input[type=url],
.kc-content input[type=number],
.kc-content input[type=date],
.kc-content select,
.kc-content textarea{
  width:100%;padding:14px 16px;margin:0 0 22px;
  border:1px solid var(--kc-line);border-radius:12px;
  font-family:var(--kc-font-body);font-size:1rem;color:var(--kc-ink);
  background:#fff;transition:border-color .2s ease,box-shadow .2s ease;
}
.kc-content input:focus,
.kc-content select:focus,
.kc-content textarea:focus{
  outline:none;border-color:var(--kc-green);
  box-shadow:0 0 0 3px var(--kc-green-soft);
}
.kc-content textarea{min-height:150px;resize:vertical}
.kc-content input[type=submit],
.kc-content button[type=submit],
.kc-content .wpcf7-submit{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--kc-font-head);font-weight:600;font-size:1rem;
  padding:15px 32px;border-radius:999px;border:2px solid var(--kc-green);
  background:var(--kc-green);color:#fff;cursor:pointer;width:auto;
  box-shadow:var(--kc-shadow-sm);transition:transform .2s ease,background .2s ease;
}
.kc-content input[type=submit]:hover,
.kc-content button[type=submit]:hover,
.kc-content .wpcf7-submit:hover{
  background:var(--kc-green-dark);border-color:var(--kc-green-dark);transform:translateY(-2px);
}
/* CF7 response/validation messages */
.kc-content .wpcf7-not-valid-tip{color:#c0392b;font-size:.85rem;margin:-16px 0 16px}
.kc-content .wpcf7 form .wpcf7-response-output{
  border-radius:10px;padding:12px 16px;margin:8px 0 0;font-size:.92rem;
}

/* ===== Footer ===== */
.kc-footer{background:#fff;color:var(--kc-muted);padding:64px 0 28px;border-top:3px solid var(--kc-green)}
.kc-footer a{color:var(--kc-ink)}
.kc-footer a:hover{color:var(--kc-green-dark)}
.kc-footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px}
.kc-footer h4{color:var(--kc-ink);font-size:1.05rem;margin-bottom:1em}
.kc-footer ul,.kc-footer ul.menu,.kc-footer div>ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.kc-footer__logo{display:inline-block;line-height:0}
.kc-footer__logo img{max-width:240px;width:100%;height:auto}
.kc-footer__brand p{color:var(--kc-muted);font-size:.95rem;max-width:320px}
.kc-footer__note{color:var(--kc-muted);font-size:.88rem;line-height:1.5;margin-top:12px;max-width:280px}
.kc-footer__bottom{border-top:1px solid var(--kc-line);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.85rem;color:var(--kc-muted)}

/* ===== Social media icons ===== */
.kc-social{display:flex;gap:10px;align-items:center}
.kc-social__link{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:50%;
  color:var(--kc-green-dark);background:var(--kc-green-soft);
  transition:transform .2s ease,background .2s ease,color .2s ease;
}
.kc-social__link:hover{background:var(--kc-green);color:#fff;transform:translateY(-2px)}
/* Header variant */
.kc-header__social{display:flex;align-items:center}
/* Footer variant: same look as header (green circle) */
.kc-footer__social{margin-top:18px}
.kc-footer__social .kc-social__link{background:var(--kc-green-soft);color:var(--kc-green-dark)}
.kc-footer__social .kc-social__link:hover{background:var(--kc-green);color:#fff}

/* ===== Responsive ===== */
@media (max-width:960px){
  .kc-cards{grid-template-columns:1fr;max-width:480px;margin:0 auto}
  .kc-about{grid-template-columns:1fr;gap:36px}
  .kc-about__media{max-width:420px;margin:0 auto;text-align:center}
  .kc-footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .kc-header__inner{min-height:88px;padding-top:8px;padding-bottom:8px}
  .kc-brand__text{font-size:1.4rem;white-space:normal}
  .kc-brand__text small{font-size:1.3rem;margin-top:0}
  .kc-nav{
    position:absolute;top:104px;left:0;right:0;flex:none;
    background:#fff;border-bottom:1px solid var(--kc-line);
    max-height:calc(100vh - 104px);overflow-y:auto;
    display:none;
  }
  .kc-nav.is-open{display:block}
  /* Hero on mobile: portrait first, then text */
  .kc-hero__grid{grid-template-columns:1fr;gap:28px;padding:48px 0 56px}
  .kc-hero__media{order:-1}
  .kc-hero__portrait{width:200px;height:200px;border-width:5px}
  .kc-hero__caption{font-size:.96rem}
  .kc-hero__inner{max-width:none}
  .kc-hero::before{
    background:linear-gradient(180deg,rgba(243,242,238,.82) 0%,rgba(243,242,238,.92) 55%,rgba(243,242,238,.99) 100%);
  }
  .kc-nav ul{flex-direction:column;gap:0;padding:10px 24px 18px}
  .kc-nav li{padding:12px 0;border-bottom:1px solid var(--kc-line)}
  .kc-nav li:last-child{border-bottom:0}
  .kc-burger{display:block}
  .kc-header__cta{display:none}
  .kc-header__social{display:none}
  .kc-footer__grid{grid-template-columns:1fr}
  .kc-section{padding:64px 0}
  .kc-optin{padding:28px 20px}
  .kc-optin__grid{grid-template-columns:1fr;gap:16px;text-align:center}
  .kc-optin__body .kc-eyebrow{display:inline-block;margin-bottom:8px;font-size:.66rem}
  .kc-optin h2{font-size:1.35rem;margin-bottom:.4em}
  .kc-optin__lead{margin-bottom:1em;font-size:.98rem}
  .kc-optin__btn{font-size:1rem;padding:14px 22px;width:100%}
  .kc-optin__fineprint{margin-left:auto;margin-right:auto;margin-top:12px}
  .kc-optin__media{order:-1;display:flex;align-items:center;gap:14px;justify-content:center;text-align:left}
  .kc-optin__media img{width:72px;height:72px;object-fit:cover;object-position:top;margin:0;border-radius:50%}
  .kc-optin__media figcaption{margin-top:0}
  .kc-optin__media figcaption strong{font-size:1rem}
  .kc-optin__media figcaption span{font-size:.85rem}
  .kc-stats{padding:56px 0}
  .kc-stats__grid{grid-template-columns:1fr;max-width:360px;gap:16px}
  .kc-about__media img{aspect-ratio:1/1}
  .kc-about__badge{position:static;left:auto;bottom:auto;margin:14px auto 0;display:inline-block;border-radius:999px}
}

/* WordPress core alignment classes */
.alignleft{float:left;margin:0 1.5em 1em 0}
.alignright{float:right;margin:0 0 1em 1.5em}
.aligncenter{margin-left:auto;margin-right:auto}
.screen-reader-text{position:absolute;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}
