/* Praxis für Osteopathie Nicole Mohl — Calm Clinic */
:root{
  --paper:#F2F4F0;
  --paper-d:#E8ECE5;
  --ink:#1A2620;
  --ink-s:#415048;
  --accent:#7AB8A0;
  --accent-d:#5C9A83;
  --accent-soft:#DDEDE4;
  --muted:#8A9A90;
  --line:#D6DDD4;
  --font-display:'Fraunces', Georgia, serif;
  --font-body:'Inter Tight', system-ui, sans-serif;
  --radius:18px;
}
body{background:var(--paper);color:var(--ink);font-family:var(--font-body);letter-spacing:-0.005em}

/* Masthead */
.masthead{border-bottom:1px solid var(--line);background:var(--paper)}
.masthead .brand{font-family:var(--font-display);font-weight:500;font-size:1.2rem;letter-spacing:-0.02em;display:flex;align-items:center;gap:0.7rem}
.masthead .brand .mark{width:28px;height:28px;flex-shrink:0;color:var(--accent)}
.masthead .brand .brand-sub{font-family:var(--font-body);font-size:0.72rem;color:var(--ink-s);font-weight:400;letter-spacing:0.04em;text-transform:uppercase;margin-top:2px}
.masthead nav a{color:var(--ink);transition:color 0.2s}
.masthead nav a.active{color:var(--accent-d);font-weight:500}

/* Buttons */
.btn{border-radius:100px;padding:0.85rem 1.5rem;font-weight:500}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-d);transform:translateY(-1px)}
.btn-ghost{border:1px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

/* Demo banner */
.demo-banner{background:var(--ink);color:var(--paper)}
.demo-banner a{color:var(--accent-soft)}

/* HERO */
.hero{padding:6rem 2.5rem 5rem;position:relative;overflow:hidden;background:linear-gradient(180deg, var(--paper) 0%, var(--paper-d) 100%)}
.hero::before{content:'';position:absolute;top:-120px;right:-120px;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle, var(--accent-soft) 0%, transparent 70%);pointer-events:none;z-index:0}
.hero::after{content:'';position:absolute;bottom:-200px;left:-160px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle, rgba(122,184,160,0.12) 0%, transparent 70%);pointer-events:none;z-index:0}
.hero-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1.1fr 0.9fr;gap:4rem;align-items:center;position:relative;z-index:1}
.hero-text .eyebrow{font-size:0.72rem;text-transform:uppercase;letter-spacing:0.25em;color:var(--accent-d);margin-bottom:1.25rem;font-weight:500}
.hero-text h1{font-family:var(--font-display);font-weight:400;font-size:clamp(2.8rem,6vw,4.8rem);line-height:1.02;letter-spacing:-0.03em;margin-bottom:1.5rem}
.hero-text h1 em{font-style:italic;color:var(--accent-d)}
.hero-text p.lede{color:var(--ink-s);line-height:1.7;margin-bottom:2rem;font-size:1.1rem;max-width:520px}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}
.rating-tag{display:inline-flex;align-items:center;gap:0.55rem;padding:0.45rem 1rem;background:var(--paper);border:1px solid var(--line);font-size:0.82rem;color:var(--ink-s);border-radius:100px;font-weight:500}
.rating-tag .stars{color:var(--accent)}

.hero-card{aspect-ratio:4/5;background:linear-gradient(155deg, var(--accent-soft) 0%, var(--accent) 85%);border-radius:var(--radius);padding:2.5rem;display:flex;flex-direction:column;justify-content:space-between;color:var(--ink);position:relative;overflow:hidden}
.hero-card::after{content:'';position:absolute;bottom:-60px;left:-60px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,0.18);pointer-events:none}
.hero-card .mark-big{position:absolute;top:1.5rem;right:1.5rem;width:64px;height:64px;color:rgba(255,255,255,0.4)}
.hero-card .quote{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:1.9rem;line-height:1.25;position:relative;z-index:1;color:var(--ink)}
.hero-card .meta{position:relative;z-index:1}
.hero-card .meta .l{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.2em;margin-bottom:0.4rem;opacity:0.75;font-weight:500}
.hero-card .meta .v{font-family:var(--font-display);font-size:1.1rem;line-height:1.4}

/* Sections */
section{padding:6rem 2.5rem}
.section-head{text-align:center;margin-bottom:3.5rem;max-width:680px;margin-left:auto;margin-right:auto}
.section-head .k{font-size:0.72rem;text-transform:uppercase;letter-spacing:0.25em;color:var(--accent-d);margin-bottom:0.75rem;font-weight:500}
.section-head h2{font-family:var(--font-display);font-weight:400;font-size:clamp(1.9rem,3.8vw,2.8rem);letter-spacing:-0.02em;line-height:1.12}
.section-head h2 em{font-style:italic;color:var(--accent-d)}
.section-head p{margin-top:1rem;color:var(--ink-s);line-height:1.7;font-size:1.02rem}

/* Intro */
.intro{background:var(--paper-d);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.intro-inner{max-width:760px;margin:0 auto;text-align:center}
.intro p{color:var(--ink-s);line-height:1.85;font-size:1.06rem}
.intro p+p{margin-top:1.25rem}

/* Leistungen */
.leistungen-grid{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.leistungen-grid.three{grid-template-columns:repeat(3,1fr);max-width:960px}
.lcard{padding:2.25rem 1.6rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);transition:all 0.25s}
.lcard:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 20px 40px -20px rgba(26,38,32,0.12)}
.lcard .ico{width:48px;height:48px;border-radius:50%;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin-bottom:1.35rem}
.lcard .ico svg{width:26px;height:26px;fill:var(--accent-d)}
.lcard h3{font-family:var(--font-display);font-weight:500;font-size:1.25rem;margin-bottom:0.5rem;letter-spacing:-0.01em}
.lcard p{font-size:0.93rem;color:var(--ink-s);line-height:1.65}

/* Team */
.team{background:var(--paper-d);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.team-grid{max-width:620px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:2rem}
.tcard{background:var(--paper);border-radius:var(--radius);padding:2.5rem;border:1px solid var(--line);text-align:center}
.tcard .avatar{width:92px;height:92px;border-radius:50%;background:linear-gradient(135deg, var(--accent-soft), var(--accent));margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center}
.tcard .avatar svg{width:48px;height:48px;fill:rgba(26,38,32,0.55)}
.tcard h3{font-family:var(--font-display);font-weight:500;font-size:1.4rem;margin-bottom:0.4rem;letter-spacing:-0.01em}
.tcard .role{color:var(--accent-d);font-size:0.88rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:0.12em;font-weight:500}
.tcard p{color:var(--ink-s);font-size:0.95rem;line-height:1.7}
.tcard ul{list-style:none;margin-top:1.25rem;text-align:left;display:inline-block}
.tcard ul li{padding:0.4rem 0;font-size:0.88rem;color:var(--ink-s);border-bottom:1px solid var(--line)}
.tcard ul li:last-child{border-bottom:0}
.tcard ul li::before{content:'·';color:var(--accent);margin-right:0.6rem;font-weight:700}

/* Kontakt */
.kontakt{padding:6rem 2.5rem}
.kontakt-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:3rem;align-items:start}
.info-block h2{font-family:var(--font-display);font-weight:500;font-size:1.7rem;margin-bottom:1.5rem;letter-spacing:-0.01em}
.info-block dl{display:grid;grid-template-columns:auto 1fr;gap:1rem 1.5rem;font-size:0.95rem}
.info-block dt{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.18em;color:var(--muted);padding-top:0.2rem;font-weight:500}
.info-block dd{color:var(--ink);line-height:1.55}
.info-block dd a{color:var(--accent-d);border-bottom:1.5px solid var(--accent-soft)}
.map-wrap{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;min-height:440px}
.map-wrap iframe{width:100%;height:100%;min-height:440px;border:none;display:block}

/* Sprechzeiten */
.hours-table{width:100%;border-collapse:collapse;margin-top:1rem;font-size:0.94rem}
.hours-table td{padding:0.7rem 0;border-bottom:1px solid var(--line)}
.hours-table td:first-child{font-weight:500;color:var(--ink)}
.hours-table td:last-child{color:var(--ink-s);text-align:right}
.hours-table tr:last-child td{border-bottom:0}

/* Form */
.form{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:2.25rem}
.form h2{font-family:var(--font-display);font-weight:500;font-size:1.5rem;margin-bottom:1.5rem}
.form .field{margin-bottom:1.1rem}
.form label{display:block;font-size:0.78rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted);margin-bottom:0.4rem;font-weight:500}
.form input,.form textarea,.form select{width:100%;padding:0.9rem 1rem;border:1px solid var(--line);border-radius:12px;background:var(--paper-d);font:inherit;color:var(--ink);transition:border-color 0.2s, background 0.2s}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--accent);background:#fff}
.form textarea{min-height:120px;resize:vertical}
.form .hint{font-size:0.82rem;color:var(--muted);margin-top:0.6rem;line-height:1.6}

/* Banner CTA */
.cta-band{background:var(--accent);color:#fff;text-align:center}
.cta-band .section-head h2{color:#fff}
.cta-band .section-head h2 em{color:var(--accent-soft)}
.cta-band .section-head .k{color:var(--accent-soft)}
.cta-band .btn-primary{background:#fff;color:var(--accent-d)}
.cta-band .btn-primary:hover{background:var(--accent-soft)}

/* Page head */
.page-head{padding:5rem 2.5rem 3rem;text-align:center;border-bottom:1px solid var(--line);background:var(--paper-d);position:relative;overflow:hidden}
.page-head .k{font-size:0.72rem;text-transform:uppercase;letter-spacing:0.25em;color:var(--accent-d);margin-bottom:1rem;font-weight:500}
.page-head h1{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:clamp(2.5rem,5vw,4rem);letter-spacing:-0.02em}

/* Footer */
.footer{background:var(--paper);font-family:var(--font-body)}

/* Note card — sanfter Hinweis */
.note{max-width:760px;margin:0 auto;background:var(--accent-soft);border-radius:var(--radius);padding:1.75rem 2rem;color:var(--ink);font-size:0.98rem;line-height:1.7;border:1px solid var(--line);text-align:center}
.note strong{font-family:var(--font-display);font-weight:500}

@media (max-width:880px){
  .hero{padding:3.5rem 1.25rem 3rem}
  .hero-inner{grid-template-columns:1fr;gap:2.5rem}
  .hero-card{aspect-ratio:3/2}
  section{padding:3.5rem 1.25rem}
  .leistungen-grid,.leistungen-grid.three{grid-template-columns:1fr 1fr;gap:1rem}
  .kontakt{padding:3rem 1.25rem}
  .kontakt-inner{grid-template-columns:1fr;gap:2rem}
  .masthead{flex-direction:column;gap:0.75rem;padding:1rem 1.25rem}
  .masthead nav{gap:1.25rem}
}
@media (max-width:520px){
  .leistungen-grid,.leistungen-grid.three{grid-template-columns:1fr}
  .hero-text h1{font-size:2.4rem}
  .tcard{padding:1.75rem}
}
