/* ===== Jochen Schuh · Mobiler Friseur ===== */
:root{
  --bg:#f4f8fc;
  --bg-soft:#e7f0fa;
  --card:#ffffff;
  --line:#d5e3f1;
  --cream:#1d2b3a;
  --muted:#5d7183;
  --gold:#2f6fb0;
  --gold-soft:#235a93;
  --gold-hover:#3a85cf;
  --wa:#25d366;
  --wa-dark:#1da851;
  --text:#1d2b3a;
  --radius:16px;
  --maxw:1140px;
  --shadow:0 16px 44px rgba(30,60,95,.13);
  --font-head:'Poppins','Inter',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3{font-family:var(--font-head);line-height:1.14;font-weight:700;letter-spacing:-.02em}
h2{font-size:clamp(1.8rem,3.4vw,2.6rem);margin-bottom:.4em}
section{padding:clamp(56px,8vw,110px) 0}
a{color:inherit;text-decoration:none}
img{max-width:100%}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:9px;justify-content:center;
  border:none;cursor:pointer;font-family:var(--font-body);font-weight:600;
  font-size:.95rem;padding:13px 22px;border-radius:999px;transition:.2s ease;
  white-space:nowrap;text-align:center;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn .ico{width:18px;height:18px;fill:currentColor}
.btn-sm{padding:9px 16px;font-size:.85rem}
.btn-lg{padding:16px 30px;font-size:1.05rem}
.btn-block{width:100%}
.btn-wa{background:var(--wa);color:#fff}
.btn-wa:hover{background:var(--wa-dark);color:#fff}
.btn-primary{background:var(--gold);color:#fff}
.btn-primary:hover{background:var(--gold-hover);color:#3a2a08}
.btn-ghost{background:#fff;color:var(--cream);border:1px solid var(--line)}
.btn-ghost:hover{background:var(--bg-soft)}
.btn-outline{background:transparent;color:var(--gold);border:1px solid var(--gold)}
.btn-outline:hover{background:rgba(47,111,176,.10)}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(244,248,252,.9);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;gap:24px;height:72px}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.brand-mark{
  width:42px;height:42px;border-radius:50%;object-fit:cover;flex-shrink:0;
  background:linear-gradient(135deg,var(--gold),var(--gold-soft));
  box-shadow:0 0 0 1px var(--line);
}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-text strong{font-size:1.05rem;letter-spacing:.2px}
.brand-text small{color:var(--muted);font-size:.74rem}
.nav{display:flex;gap:26px}
.nav a{color:var(--muted);font-size:.92rem;font-weight:500;transition:.15s}
.nav a:hover{color:var(--cream)}
.header-actions{display:flex;align-items:center;gap:14px}
.lang-toggle{
  background:none;border:1px solid var(--line);color:var(--muted);
  padding:7px 12px;border-radius:999px;font-size:.78rem;font-weight:600;cursor:pointer;transition:.15s;
}
.lang-toggle:hover{color:var(--cream);border-color:var(--gold)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--cream);border-radius:2px;transition:.25s}

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden;padding:clamp(70px,12vw,150px) 0 clamp(60px,9vw,110px)}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(1100px 520px at 78% -8%,rgba(47,111,176,.16),transparent 60%),
    radial-gradient(800px 500px at 8% 110%,rgba(47,111,176,.08),transparent 55%),
    var(--bg);
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(30,60,95,.06) 1px,transparent 1px);
  background-size:22px 22px;mask:radial-gradient(700px 400px at 70% 10%,#000,transparent 75%);
}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.hero-text{max-width:640px}
.hero-photo{position:relative}
.hero-photo img{
  width:100%;aspect-ratio:4/5;object-fit:cover;object-position:75% 30%;
  border-radius:20px;border:1px solid var(--line);box-shadow:var(--shadow);
}
.hero-photo::after{
  content:"";position:absolute;inset:0;border-radius:20px;pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.04);
}
.eyebrow{
  text-transform:uppercase;letter-spacing:.22em;font-size:.78rem;font-weight:600;
  color:var(--gold);margin-bottom:18px;
}
.hero h1{font-size:clamp(2.4rem,5.6vw,4.2rem);font-weight:700;letter-spacing:-.03em}
.hero-lead{font-size:clamp(1.05rem,2vw,1.3rem);color:var(--muted);margin:22px 0 30px;max-width:560px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-badges{
  list-style:none;display:flex;gap:14px;flex-wrap:wrap;margin-top:48px;
}
.hero-badges li{
  background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:14px 18px;display:flex;flex-direction:column;min-width:120px;box-shadow:0 6px 18px rgba(30,60,95,.06);
}
.hero-badges strong{font-size:1.35rem;color:var(--gold-soft);font-family:var(--font-head)}
.hero-badges span{font-size:.8rem;color:var(--muted)}

/* ===== About ===== */
.about{background:var(--bg-soft)}
.about-inner{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}
.about-text p{color:var(--muted);margin-bottom:16px;max-width:60ch}
.checklist{list-style:none;margin-top:24px;display:grid;gap:12px}
.checklist li{position:relative;padding-left:34px;color:var(--cream)}
.checklist li::before{
  content:"✓";position:absolute;left:0;top:-1px;width:22px;height:22px;border-radius:50%;
  background:rgba(47,111,176,.18);color:var(--gold-soft);display:grid;place-items:center;
  font-size:.8rem;font-weight:700;
}
.about-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;box-shadow:var(--shadow);position:sticky;top:96px;
}
.about-card h3{font-size:1.6rem;margin-bottom:16px;color:var(--gold-soft)}
.hours{width:100%;border-collapse:collapse}
.hours td{padding:10px 0;border-bottom:1px solid var(--line);font-size:.95rem}
.hours td:last-child{text-align:right;color:var(--cream);font-weight:600}
.hours td:first-child{color:var(--muted)}
.about-card-foot{margin-top:22px;display:grid;gap:10px}
.contact-line{color:var(--cream);font-weight:500;font-size:.95rem}
.contact-line:hover{color:var(--gold-soft)}

/* ===== Services ===== */
.section-head{max-width:680px;margin-bottom:38px}
.section-head p{color:var(--muted);font-size:1.05rem}
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.tab{
  background:var(--card);border:1px solid var(--line);color:var(--muted);
  padding:10px 18px;border-radius:999px;cursor:pointer;font-weight:600;font-size:.9rem;transition:.18s;
  font-family:var(--font-body);
}
.tab:hover{color:var(--cream)}
.tab.active{background:var(--gold);color:#241c0a;border-color:var(--gold)}
.services-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:32px;align-items:start}
.service-list{display:grid;gap:10px}
.service-item{
  display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);
  border-radius:12px;padding:14px 18px;cursor:pointer;transition:.16s;
}
.service-item:hover{border-color:var(--gold);transform:translateX(3px)}
.service-item.selected{border-color:var(--gold);background:rgba(47,111,176,.10)}
.service-check{
  width:22px;height:22px;border-radius:6px;border:1.5px solid var(--line);flex-shrink:0;
  display:grid;place-items:center;font-size:.8rem;color:transparent;transition:.16s;
}
.service-item.selected .service-check{background:var(--gold);border-color:var(--gold);color:#241c0a}
.service-name{flex:1;font-weight:500}
.service-price{color:var(--gold-soft);font-weight:600;white-space:nowrap}

.calc{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;position:sticky;top:96px;box-shadow:var(--shadow);
}
.calc h3{font-size:1.5rem;color:var(--gold-soft);margin-bottom:16px}
.calc-items{list-style:none;display:grid;gap:8px;min-height:60px;margin-bottom:16px}
.calc-items li{display:flex;justify-content:space-between;gap:12px;font-size:.92rem}
.calc-items li button{
  background:none;border:none;color:var(--muted);cursor:pointer;font-size:1rem;line-height:1;padding:0 0 0 8px;
}
.calc-items li button:hover{color:#e06b5a}
.calc-empty{color:var(--muted);font-style:italic;font-size:.88rem!important}
.calc-foot{border-top:1px solid var(--line);padding-top:16px}
.calc-row{display:flex;justify-content:space-between;font-size:.92rem;color:var(--muted);margin-bottom:8px}
.calc-total{font-size:1.15rem;color:var(--cream);font-weight:700}
.calc-total span:last-child{color:var(--gold-soft)}
.calc-note{font-size:.76rem;color:var(--muted);margin:14px 0 16px;line-height:1.5}

/* ===== Area ===== */
.area{background:var(--bg-soft)}
.area-inner{display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:center}
.area-text p{color:var(--muted);margin-bottom:22px;max-width:54ch}
.area-form{display:flex;gap:10px;flex-wrap:wrap}
.area-form input{
  flex:1;min-width:200px;background:var(--card);border:1px solid var(--line);color:var(--cream);
  padding:14px 16px;border-radius:12px;font-size:1rem;font-family:var(--font-body);
}
.area-form input:focus{outline:none;border-color:var(--gold)}
.area-result{margin-top:18px;font-size:1rem;min-height:1.4em}
.area-result.ok{color:var(--wa)}
.area-result.maybe{color:var(--gold-soft)}
.area-result.no{color:#e08a7a}
.area-result strong{font-weight:700}
.area-visual{display:grid;place-items:center;position:relative;height:280px}
.radius-ring{
  width:240px;height:240px;border-radius:50%;border:1px dashed rgba(47,111,176,.4);
  display:grid;place-items:center;background:radial-gradient(circle,rgba(47,111,176,.10),transparent 70%);
}
.radius-ring.inner{width:150px;height:150px;border-color:rgba(47,111,176,.6)}
.radius-dot{width:16px;height:16px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 6px rgba(47,111,176,.25)}
.radius-label{position:absolute;bottom:24px;color:var(--muted);font-size:.85rem}

/* ===== Wizard ===== */
.wizard{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(24px,4vw,42px);max-width:760px;margin:0 auto;box-shadow:var(--shadow);
}
.wizard-steps{list-style:none;display:flex;gap:8px;margin-bottom:32px}
.wizard-steps li{flex:1;display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.85rem}
.wizard-steps li span{
  width:30px;height:30px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  background:var(--bg-soft);border:1px solid var(--line);font-weight:700;transition:.2s;
}
.wizard-steps li.active{color:var(--cream)}
.wizard-steps li.active span{background:var(--gold);color:#241c0a;border-color:var(--gold)}
.wizard-steps li em{font-style:normal;font-weight:500}
.wizard-pane{display:none;animation:fade .3s ease}
.wizard-pane.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.field{display:block;margin-bottom:18px}
.field>span{display:block;font-size:.85rem;color:var(--muted);margin-bottom:7px;font-weight:500}
.field input,.field textarea{
  width:100%;background:var(--bg-soft);border:1px solid var(--line);color:var(--cream);
  padding:13px 15px;border-radius:11px;font-size:1rem;font-family:var(--font-body);resize:vertical;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hint{font-size:.82rem;color:var(--muted);margin:-6px 0 18px}
.wizard-nav{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:24px;flex-wrap:wrap}
.finish-actions{display:flex;gap:12px;flex-wrap:wrap}
.summary{
  background:var(--bg-soft);border:1px dashed var(--line);border-radius:12px;padding:16px 18px;
  margin:6px 0 4px;font-size:.92rem;color:var(--muted);white-space:pre-line;
}
.summary strong{color:var(--cream)}

/* ===== Voucher ===== */
.voucher-inner{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center}
.voucher-text p{color:var(--muted);margin-bottom:24px;max-width:54ch}
.voucher-form .field-row{margin-bottom:16px}
.voucher-card{
  aspect-ratio:1.6/1;border-radius:18px;padding:26px;display:flex;flex-direction:column;
  justify-content:space-between;background:linear-gradient(135deg,#1f4068,#0f2236);
  border:1px solid var(--gold);box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.voucher-card::before{
  content:"";position:absolute;inset:0;background:radial-gradient(400px 200px at 90% -20%,rgba(47,111,176,.25),transparent 60%);
}
.vc-label{text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;color:#9fc6ec;position:relative}
.vc-body{position:relative;flex:1;display:flex;flex-direction:column;justify-content:center;gap:6px;padding:10px 0;min-width:0}
.vc-amount{font-family:var(--font-head);font-weight:700;font-size:2.5rem;line-height:1.05;color:#fff;word-break:break-word}
.vc-for{font-size:1.05rem;color:#9fc6ec;word-break:break-word}
.vc-brand{font-family:var(--font-head);font-size:1.05rem;color:#eef5fc;position:relative}

/* ===== Contact ===== */
.contact{background:var(--bg-soft)}
.contact-sub{color:var(--muted)}
.contact .section-head,.contact p{color:var(--muted)}
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:28px}
.contact-tile{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;display:flex;flex-direction:column;gap:6px;align-items:flex-start;transition:.18s;
}
.contact-tile:hover{border-color:var(--gold);transform:translateY(-3px)}
.ct-ico{font-size:1.8rem}
.contact-tile strong{font-size:1.1rem;color:var(--cream)}
.contact-tile small{color:var(--muted)}

/* ===== Mobile / Auto ===== */
.mobile-sec{background:var(--bg-soft)}
.mobile-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.mobile-photo img{
  width:100%;border-radius:var(--radius);border:1px solid var(--line);
  box-shadow:var(--shadow);display:block;
}
.mobile-text p{color:var(--muted);margin-bottom:16px;max-width:52ch}
.mobile-text strong{color:var(--gold-soft)}

/* ===== Qualifikation / Zertifikate ===== */
.cert-grid{
  list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:8px;
}
.cert-grid li{
  background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:20px 18px 20px 50px;position:relative;font-weight:500;
}
.cert-grid li::before{
  content:"🏅";position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:1.2rem;
}

/* ===== Pricelist-Button ===== */
.pricelist-btn{margin-top:18px}

/* ===== Footer ===== */
.site-footer{background:var(--bg);border-top:1px solid var(--line);padding:36px 0}
.footer-inner{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;font-size:.88rem;color:var(--muted)}
.footer-brand{display:flex;align-items:center;gap:14px}
.footer-brand img{border-radius:50%;box-shadow:0 0 0 1px var(--line)}
.footer-brand strong{color:var(--cream)}
.footer-legal{display:flex;flex-direction:column;gap:8px;text-align:right;align-items:flex-end}
.footer-nav{display:flex;gap:18px}
.footer-legal a{color:var(--muted)}
.footer-legal a:hover{color:var(--gold-soft)}

/* ===== Modal ===== */
.modal{
  position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);
  display:none;place-items:center;padding:24px;
}
.modal.open{display:grid}
.modal-box{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:34px;max-width:480px;position:relative;box-shadow:var(--shadow);
}
.modal-box h3{font-size:1.6rem;margin-bottom:16px;color:var(--gold-soft)}
.modal-box p{color:var(--muted);font-size:.92rem;margin-bottom:12px}
.modal-box strong{color:var(--cream)}
.modal-close{
  position:absolute;top:16px;right:18px;background:none;border:none;color:var(--muted);
  font-size:1.8rem;cursor:pointer;line-height:1;
}
.modal-close:hover{color:var(--cream)}

/* ===== Legal-Seiten (Impressum / Datenschutz) ===== */
.legal-wrap{max-width:820px;margin:0 auto;padding:clamp(40px,7vw,80px) 24px}
.legal-back{display:inline-flex;align-items:center;gap:8px;color:var(--muted);margin-bottom:28px;font-size:.92rem}
.legal-back:hover{color:var(--gold-soft)}
.legal h1{font-size:clamp(2.2rem,5vw,3rem);margin-bottom:8px}
.legal>.lead{color:var(--muted);margin-bottom:32px}
.legal h2{font-size:1.5rem;margin:34px 0 12px;color:var(--gold-soft)}
.legal h3{font-size:1.15rem;margin:22px 0 8px}
.legal p,.legal li{color:var(--muted);margin-bottom:12px;line-height:1.7}
.legal ul{padding-left:22px;margin-bottom:14px}
.legal a{color:var(--gold-soft);text-decoration:underline}
.legal .card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 26px;margin:8px 0 8px;
}
.legal .card p{color:var(--cream);margin-bottom:6px}
.legal strong{color:var(--cream)}

/* ===== Floating WhatsApp ===== */
.fab-wa{
  position:fixed;bottom:22px;right:22px;z-index:60;width:50px;height:50px;border-radius:50%;
  background:var(--wa);display:grid;place-items:center;box-shadow:0 8px 24px rgba(37,211,102,.40);
  transition:.2s;
}
.fab-wa:hover{transform:scale(1.08)}
.fab-wa svg{width:26px;height:26px;fill:#fff}

/* ===== Responsive ===== */
@media(max-width:920px){
  .about-inner,.services-grid,.area-inner,.voucher-inner,.mobile-inner{grid-template-columns:1fr}
  .hero-inner{grid-template-columns:1fr}
  .hero-photo{max-width:420px;order:-1}
  .hero-photo img{aspect-ratio:16/9;object-position:75% 25%}
  .cert-grid{grid-template-columns:1fr 1fr}
  .about-card,.calc{position:static}
  .contact-grid{grid-template-columns:1fr}
  .nav{
    position:absolute;top:72px;left:0;right:0;background:var(--bg-soft);flex-direction:column;
    padding:18px 24px;gap:14px;border-bottom:1px solid var(--line);display:none;
  }
  .nav.open{display:flex}
  .burger{display:flex}
  #headerWa span{display:none}
}
@media(max-width:560px){
  .field-row{grid-template-columns:1fr}
  .wizard-steps li em{display:none}
  .header-actions .lang-toggle{display:inline-block}
  .footer-inner{flex-direction:column}
  .footer-legal{text-align:left;align-items:flex-start}
  .cert-grid{grid-template-columns:1fr}
  .hero-badges li{min-width:calc(50% - 7px)}
}
