/* ==========================================================
   FAIR PUNCH — Selbstverteidigung & Selbstbehauptung
   Design tokens
   ========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@500;600;700;800&family=Work+Sans:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

:root{
  /* Color */
  --ink:        #1E5A38; /* Waldgrün (Logo-Faust) - Vertrauen, Haltung */
  --punch:      #7CB342; /* Grasgrün (Logo-Schriftzug) - Energie, "Punch" */
  --sun:        #A9D66B; /* Helles Limette - Kinder, Freude */
  --mint:       #5FBE95; /* Mint (Logo-Banner) - Fairness, Wachstum */
  --paper:      #FFF8EC; /* Warmes Creme - Untergrund */
  --paper-dim:  #EEF3E9;
  --ink-soft:   #3E6B52;
  --line:       rgba(30,90,56,0.14);
  --white:      #FFFFFF;

  /* Belt stripe order — signature motif */
  --belt-1: var(--sun);
  --belt-2: var(--punch);
  --belt-3: var(--mint);
  --belt-4: var(--ink);

  /* Type */
  --f-display: 'Baloo 2', system-ui, sans-serif;
  --f-body: 'Work Sans', system-ui, sans-serif;
  --f-mono: 'Space Mono', monospace;

  /* Layout */
  --radius: 22px;
  --radius-sm: 12px;
  --max: 1120px;
  --pad: clamp(20px, 5vw, 64px);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--f-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;}
h1,h2,h3{
  font-family:var(--f-display);
  font-weight:700;
  line-height:1.1;
  margin:0 0 .4em 0;
  letter-spacing:-0.01em;
}
h1{font-weight:800;}
p{margin:0 0 1em 0;}
.container{max-width:var(--max); margin:0 auto; padding:0 var(--pad);}

.eyebrow{
  font-family:var(--f-mono);
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--punch);
  font-weight:700;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.eyebrow::before{
  content:"";
  width:8px;height:8px;border-radius:50%;
  background:var(--punch);
  display:inline-block;
}

/* Belt stripe divider — signature element */
.belt{
  height:10px;
  width:100%;
  display:flex;
  border-radius:6px;
  overflow:hidden;
  box-shadow:0 2px 0 rgba(27,42,74,.08);
}
.belt span{flex:1;}
.belt span:nth-child(1){background:var(--belt-1);}
.belt span:nth-child(2){background:var(--belt-2);}
.belt span:nth-child(3){background:var(--belt-3);}
.belt span:nth-child(4){background:var(--belt-4);}

/* ---------- Header ---------- */
header.site{
  position:sticky; top:0; z-index:50;
  background:rgba(255,248,236,.9);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px var(--pad);
  max-width:var(--max); margin:0 auto;
}
.logo{
  display:flex; align-items:center; gap:10px;
  font-family:var(--f-display); font-weight:800; font-size:22px;
  text-decoration:none; color:var(--ink);
}
.logo .mark{
  width:38px;height:38px;border-radius:50%;
  background:var(--punch);
  display:flex;align-items:center;justify-content:center;
  color:var(--paper); flex-shrink:0;
  transform:rotate(-8deg);
}
.logo .mark svg{width:20px;height:20px;}
.logo img.logo-img{
  width:52px; height:52px; flex-shrink:0;
  object-fit:contain;
}
footer .logo img.logo-img{
  width:56px; height:56px;
}
nav.links{display:flex; gap:6px; align-items:center;}
nav.links a{
  text-decoration:none; font-weight:600; font-size:15px;
  padding:9px 16px; border-radius:999px; color:var(--ink);
  transition:background .15s, color .15s;
}
nav.links a:hover, nav.links a:focus-visible{background:var(--ink); color:var(--paper);}
nav.links a.current{background:var(--punch); color:var(--white);}
nav.links a.cta{background:var(--ink); color:var(--paper);}
nav.links a.cta:hover{background:var(--punch);}
.burger{display:none;}

@media (max-width:760px){
  nav.links{
    position:fixed; inset:64px 16px auto 16px;
    flex-direction:column; align-items:stretch;
    background:var(--white); border-radius:var(--radius);
    padding:10px; box-shadow:0 20px 40px rgba(27,42,74,.18);
    border:1px solid var(--line);
    transform:translateY(-12px); opacity:0; pointer-events:none;
    transition:transform .2s ease, opacity .2s ease;
  }
  nav.links.open{transform:translateY(0); opacity:1; pointer-events:auto;}
  nav.links a{text-align:center;}
  .burger{
    display:flex; width:42px;height:42px; border-radius:50%;
    border:1px solid var(--line); background:var(--white);
    align-items:center; justify-content:center; cursor:pointer;
  }
  .burger svg{width:20px;height:20px;}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--f-body); font-weight:700; font-size:15.5px;
  padding:14px 26px; border-radius:999px;
  text-decoration:none; border:2px solid transparent;
  cursor:pointer; transition:transform .15s ease, box-shadow .15s ease;
}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--punch); color:var(--white); box-shadow:0 8px 0 #5C8A2C;}
.btn-primary:hover{box-shadow:0 10px 0 #5C8A2C;}
.btn-primary:active{transform:translateY(2px); box-shadow:0 4px 0 #5C8A2C;}
.btn-ghost{background:transparent; border-color:var(--ink); color:var(--ink);}
.btn-ghost:hover{background:var(--ink); color:var(--paper);}
.btn-dark{background:var(--ink); color:var(--paper); box-shadow:0 8px 0 #123321;}
.btn-dark:hover{box-shadow:0 10px 0 #123321;}

/* ---------- Hero ---------- */
.hero{
  padding:64px var(--pad) 40px;
  max-width:var(--max); margin:0 auto;
  display:grid; grid-template-columns:1.1fr .9fr; gap:48px;
  align-items:center;
}
.hero h1{font-size:clamp(36px,5.4vw,60px);}
.hero h1 .hl{color:var(--punch);}
.hero .lead{font-size:19px; color:var(--ink-soft); max-width:46ch;}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap; margin-top:26px;}
.hero-badge{
  font-family:var(--f-mono); font-size:12.5px; font-weight:700;
  background:var(--white); border:1px solid var(--line);
  padding:8px 14px; border-radius:999px; display:inline-flex; gap:8px; align-items:center;
  margin-bottom:22px;
}
.hero-badge span.dot{width:7px;height:7px;border-radius:50%;background:var(--mint);}

.hero-art{
  position:relative; aspect-ratio:1/1; border-radius:32px;
  background:var(--white);
  border:1px solid var(--line);
  box-shadow:0 20px 40px rgba(30,90,56,.08);
  overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.hero-art svg{width:78%; height:78%;}
.hero-art .stamp{
  position:absolute; top:16px; right:16px;
  background:var(--sun); color:var(--ink);
  font-family:var(--f-mono); font-weight:700; font-size:12px;
  border-radius:50%; width:78px; height:78px;
  display:flex; align-items:center; justify-content:center; text-align:center;
  transform:rotate(10deg); line-height:1.2; padding:6px;
  box-shadow:0 6px 16px rgba(0,0,0,.2);
}

@media (max-width:820px){
  .hero{grid-template-columns:1fr; padding-top:40px;}
  .hero-art{max-width:360px; margin:0 auto;}
}

/* ---------- Sections ---------- */
section{padding:64px var(--pad);}
section .container-inner{max-width:var(--max); margin:0 auto;}
.section-head{max-width:640px; margin-bottom:40px;}
.section-head h2{font-size:clamp(28px,3.6vw,40px);}
.section-head p{color:var(--ink-soft); font-size:17px;}

.dark{background:var(--ink); color:var(--paper);}
.dark .ink-soft{color:#B9D6C6;}
.dark h2, .dark h3{color:var(--paper);}

/* Cards grid */
.grid{display:grid; gap:22px;}
.grid.cols-3{grid-template-columns:repeat(3,1fr);}
.grid.cols-4{grid-template-columns:repeat(4,1fr);}
@media (max-width:900px){ .grid.cols-3, .grid.cols-4{grid-template-columns:repeat(2,1fr);} }
@media (max-width:600px){ .grid.cols-3, .grid.cols-4{grid-template-columns:1fr;} }

.card{
  background:var(--white); border-radius:var(--radius);
  padding:28px; border:1px solid var(--line);
  position:relative; overflow:hidden;
}
.card .tag{
  font-family:var(--f-mono); font-size:12px; font-weight:700;
  text-transform:uppercase; letter-spacing:.06em;
  background:var(--paper-dim); color:var(--ink);
  display:inline-block; padding:5px 11px; border-radius:999px; margin-bottom:14px;
}
.card h3{font-size:21px; margin-bottom:8px;}
.card p{color:var(--ink-soft); font-size:15.5px; margin-bottom:0;}
.card .icon{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:16px; color:var(--white);
}
.card.recommended{border:2px solid var(--punch);}
.card .stamp-mini{
  position:absolute; top:18px; right:18px;
  font-family:var(--f-mono); font-size:11px; font-weight:700;
  background:var(--sun); color:var(--ink); padding:4px 10px; border-radius:999px;
  transform:rotate(6deg);
}

/* Stats */
.stats{display:flex; gap:0; flex-wrap:wrap; border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.stat{flex:1; min-width:150px; padding:28px var(--pad); text-align:center; border-left:1px solid var(--line);}
.stat:first-child{border-left:none;}
.stat .num{font-family:var(--f-display); font-size:38px; font-weight:800; color:var(--punch);}
.stat .label{font-family:var(--f-mono); font-size:12.5px; color:var(--ink-soft); text-transform:uppercase; letter-spacing:.06em;}

/* Quote / testimonial */
.quote{
  background:var(--paper-dim); border-radius:var(--radius);
  padding:36px; font-family:var(--f-display); font-size:22px;
  color:var(--ink); position:relative;
}
.quote .who{font-family:var(--f-mono); font-size:13px; color:var(--ink-soft); margin-top:16px; font-weight:700;}

/* Timeline (Über mich) */
.timeline{position:relative; padding-left:28px; border-left:3px dashed var(--line);}
.tl-item{position:relative; padding-bottom:36px;}
.tl-item:last-child{padding-bottom:0;}
.tl-item::before{
  content:""; position:absolute; left:-35px; top:2px;
  width:16px;height:16px;border-radius:50%; background:var(--punch);
  border:3px solid var(--paper);
}
.tl-item .yr{font-family:var(--f-mono); color:var(--punch); font-weight:700; font-size:13px;}
.tl-item h3{margin-top:4px; font-size:19px;}
.tl-item p{color:var(--ink-soft);}

/* Values grid icons */
.value-icon{
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--white); margin-bottom:14px;
}

/* CTA band */
.cta-band{
  background:var(--punch); color:var(--white);
  border-radius:32px; padding:52px var(--pad);
  display:flex; justify-content:space-between; align-items:center; gap:24px; flex-wrap:wrap;
  margin:0 var(--pad);
}
.cta-band h2{color:var(--white); font-size:clamp(26px,3.4vw,36px); margin-bottom:6px;}
.cta-band p{color:rgba(255,255,255,.85); margin:0;}

/* Contact page */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:40px;}
@media (max-width:820px){ .contact-grid{grid-template-columns:1fr;} }
.info-block{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:28px; margin-bottom:18px;
}
.info-block .label{font-family:var(--f-mono); font-size:12px; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-soft);}
.info-block .value{font-family:var(--f-display); font-weight:700; font-size:19px; margin-top:4px;}

.form-field{margin-bottom:18px;}
.form-field label{display:block; font-weight:600; font-size:14.5px; margin-bottom:7px;}
.form-field input, .form-field textarea, .form-field select{
  width:100%; padding:13px 16px; border-radius:12px; border:1.5px solid var(--line);
  font-family:var(--f-body); font-size:15.5px; background:var(--white); color:var(--ink);
}
.form-field input:focus, .form-field textarea:focus, .form-field select:focus{
  outline:2px solid var(--punch); outline-offset:1px; border-color:var(--punch);
}
.form-note{
  font-size:13.5px; color:var(--ink-soft); background:var(--paper-dim);
  border-radius:12px; padding:14px 16px; font-family:var(--f-mono); line-height:1.5;
}

/* Footer */
footer.site{background:var(--ink); color:var(--paper); padding:52px var(--pad) 28px;}
.footer-grid{
  max-width:var(--max); margin:0 auto; display:grid;
  grid-template-columns:1.4fr 1fr 1fr; gap:36px; padding-bottom:32px;
}
@media (max-width:700px){ .footer-grid{grid-template-columns:1fr;} }
footer.site h4{
  font-family:var(--f-mono); font-size:12.5px; text-transform:uppercase;
  letter-spacing:.08em; color:#8FB39E; margin-bottom:14px;
}
footer.site a{text-decoration:none; color:var(--paper); opacity:.9; display:block; margin-bottom:9px; font-size:15px;}
footer.site a:hover{opacity:1; color:var(--sun);}
.footer-bottom{
  max-width:var(--max); margin:0 auto; padding-top:22px; border-top:1px solid rgba(255,255,255,.12);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  font-size:13.5px; color:#8FB39E;
}

/* Focus visibility */
a:focus-visible, button:focus-visible{outline:2px solid var(--punch); outline-offset:2px;}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{transition:none !important;}
}
