/*
Theme Name: Praxis Mainkur
Theme URI: https://psychotherapie-mainkur.de
Author: Praxis an der Mainkur
Description: Eigenständiges Custom-Theme für die Psychotherapiepraxis an der Mainkur, Frankfurt-Fechenheim. Ruhige, barrierearme Gestaltung, lokal gehostete Schriften, Markengrün #9DAD0D nur als Akzent.
Version: 0.2.0
Requires at least: 6.4
Requires PHP: 8.1
License: GPL-2.0-or-later
Text Domain: praxis-mainkur
*/

/* =========================================================================
   Design-Tokens (echtes Markengrün #9DAD0D)
   ========================================================================= */
:root{
  --pm-green:#9DAD0D;        /* Markengrün: NUR Akzent (Rahmen, Linien, Flächen) */
  --pm-green-text:#727D09;   /* Grüne Schrift auf Weiß (WCAG AA, 4.51:1) */
  --pm-sand:#F7F5F0;         /* Surface */
  --pm-ink:#2A2A2A;          /* Text & Headlines */
  --pm-ink-soft:#55554F;     /* Sekundärtext */
  --pm-line:#E2DFD6;         /* feine Trennlinien */
  --pm-white:#FFFFFF;

  --pm-container:1200px;
  --pm-content:760px;
  --pm-radius:4px;
  --pm-font:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",system-ui,-apple-system,"Segoe UI",sans-serif;
}

/* Lokale Schrift einbinden, sobald die Dateien unter assets/fonts liegen.
   (Bis dahin greift der humanistische System-Fallback oben.)
@font-face{font-family:"Noto Sans JP";font-weight:300;font-style:normal;font-display:swap;
  src:url("assets/fonts/NotoSansJP-Light.woff2") format("woff2");}
@font-face{font-family:"Noto Sans JP";font-weight:400;font-style:normal;font-display:swap;
  src:url("assets/fonts/NotoSansJP-Regular.woff2") format("woff2");}
@font-face{font-family:"Noto Sans JP";font-weight:500;font-style:normal;font-display:swap;
  src:url("assets/fonts/NotoSansJP-Medium.woff2") format("woff2");}
*/

/* =========================================================================
   Reset / Basis
   ========================================================================= */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--pm-font);font-weight:400;font-size:18px;line-height:1.7;
  color:var(--pm-ink);background:var(--pm-white);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--pm-green-text);text-decoration-thickness:1px;text-underline-offset:3px}
a:hover{color:var(--pm-ink)}

h1,h2,h3,h4{line-height:1.2;font-weight:500;color:var(--pm-ink);margin:0 0 .5em}
h1{font-size:clamp(2.1rem,5vw,3.2rem);font-weight:300;letter-spacing:-.01em}
h2{font-size:clamp(1.6rem,3.5vw,2.3rem);font-weight:300}
h3{font-size:1.3rem}
h1 em,h2 em,h3 em,.accent{font-style:normal;color:var(--pm-green-text)} /* Hervorhebung wie "therapie" */
p{margin:0 0 1.1em}
:focus-visible{outline:3px solid var(--pm-green-text);outline-offset:2px}

.container{max-width:var(--pm-container);margin-inline:auto;padding-inline:clamp(1.2rem,4vw,2.5rem)}
.section{padding-block:clamp(3rem,8vw,6rem)}
.section--sand{background:var(--pm-sand)}
.measure{max-width:var(--pm-content)}
.eyebrow{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--pm-ink-soft);margin-bottom:1rem}

/* =========================================================================
   Skip-Link & Header
   ========================================================================= */
.skip-link{position:absolute;left:-999px;top:0;background:var(--pm-ink);color:#fff;padding:.7rem 1rem;z-index:1000}
.skip-link:focus{left:1rem;top:1rem;color:#fff}

.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--pm-line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;min-height:84px}
.logo{display:inline-flex;align-items:center}
.logo img.logo-full{height:54px;width:auto}
.logo img.logo-mark{display:none;height:48px;width:auto}
.nav-main{list-style:none;display:flex;gap:1.6rem;margin:0;padding:0;align-items:center}
.nav-main a{color:var(--pm-ink);text-decoration:none;font-size:1rem}
.nav-main a:hover,.nav-main .current-menu-item>a{color:var(--pm-green-text)}
.nav-main .btn{margin-left:.4rem}
.menu-toggle{display:none;background:none;border:1px solid var(--pm-line);border-radius:var(--pm-radius);
  padding:.55rem .9rem;font:inherit;font-size:.95rem;cursor:pointer;color:var(--pm-ink)}

/* =========================================================================
   Buttons – Markengrün-Fläche mit dunklem Text (5.75:1, AA)
   ========================================================================= */
.btn{display:inline-block;padding:.85rem 1.5rem;border-radius:var(--pm-radius);font-size:1rem;
  text-decoration:none;border:2px solid transparent;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.btn-primary{background:var(--pm-green);color:var(--pm-ink);border-color:var(--pm-green)}
.btn-primary:hover,.btn-primary:focus-visible{background:var(--pm-green-text);color:#fff;border-color:var(--pm-green-text)}
.btn-secondary{background:transparent;color:var(--pm-ink);border-color:var(--pm-ink)}
.btn-secondary:hover,.btn-secondary:focus-visible{background:var(--pm-ink);color:#fff}
.cta-row{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.6rem}

/* =========================================================================
   Hero
   ========================================================================= */
.hero{padding-block:clamp(3rem,9vw,7rem)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hero-sub{font-size:1.15rem;color:var(--pm-ink-soft);max-width:46ch}
.hero-visual{aspect-ratio:1;background:var(--pm-sand);border:2px solid var(--pm-green);
  border-radius:var(--pm-radius);display:grid;place-items:center;padding:2.5rem}
.hero-visual img{width:78%}

/* Trust-Strip */
.trust{border-top:1px solid var(--pm-line);border-bottom:1px solid var(--pm-line)}
.trust-grid{display:flex;flex-wrap:wrap;gap:1.5rem 2.5rem;justify-content:space-between;
  padding-block:1.3rem;font-size:.92rem;color:var(--pm-ink-soft)}
.trust-grid span{display:inline-flex;align-items:center;gap:.5rem}
.trust-grid span::before{content:"";width:8px;height:8px;background:var(--pm-green);border-radius:50%}

/* =========================================================================
   Säulen / Karten
   ========================================================================= */
.section-head{max-width:var(--pm-content);margin-bottom:2.5rem}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.pillar{background:var(--pm-white);border:1px solid var(--pm-line);border-top:3px solid var(--pm-green);
  border-radius:var(--pm-radius);padding:1.8rem 1.6rem}
.pillar .num{font-size:.8rem;letter-spacing:.1em;color:var(--pm-ink-soft)}
.pillar h3{margin:.6rem 0 .5rem}
.pillar a{font-size:.95rem}

/* Liste „Was Sie erwartet" */
.checklist{list-style:none;margin:0;padding:0;display:grid;gap:1.3rem;grid-template-columns:repeat(3,1fr)}
.checklist li{padding-left:0}
.checklist strong{display:block;margin-bottom:.3rem}
.checklist p{color:var(--pm-ink-soft);font-size:.98rem;margin:0}

/* Team-Teaser */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem}
.team-card{text-align:center}
.team-card .ph{aspect-ratio:3/4;background:var(--pm-sand);border:1px solid var(--pm-line);border-radius:var(--pm-radius);margin-bottom:.8rem}
.team-card .role{color:var(--pm-ink-soft);font-size:.9rem}

/* Kontakt-Block */
.contact-box{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;background:var(--pm-sand);
  border-radius:var(--pm-radius);padding:clamp(1.6rem,4vw,2.6rem)}
.contact-box h3{margin-top:0}
.contact-box a{color:var(--pm-ink)}

/* Info-/Notfall-Boxen */
.info-box{border-left:3px solid var(--pm-green);background:var(--pm-sand);padding:1.4rem 1.6rem;border-radius:0 var(--pm-radius) var(--pm-radius) 0;margin:2rem 0}
.emergency{border:2px solid var(--pm-ink);border-radius:var(--pm-radius);padding:1.6rem;margin:2rem 0}
.emergency h3{margin-top:0}
.emergency ul{margin:.5rem 0 0;padding-left:1.1rem}

/* Seiteneinzelansicht */
.page-header{padding-block:clamp(2.5rem,6vw,4.5rem) 1rem}
.entry-content{max-width:var(--pm-content)}
.entry-content :is(h2,h3){margin-top:1.8em}

/* =========================================================================
   Footer
   ========================================================================= */
.site-footer{background:var(--pm-ink);color:#cfd0c6;margin-top:0;padding-block:3rem 1.5rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem}
.site-footer h4{color:#fff;font-weight:500;font-size:1rem;margin:0 0 .8rem}
.site-footer a{color:#cfd0c6;text-decoration:none}
.site-footer a:hover{color:#fff}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.footer-logo{height:46px;width:auto;margin-bottom:1rem;filter:brightness(0) invert(1);opacity:.92}
.footer-bottom{border-top:1px solid #3c3c3a;margin-top:2rem;padding-top:1.2rem;
  display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;font-size:.85rem;color:#9a9a92}

/* =========================================================================
   Mobile
   ========================================================================= */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{max-width:380px}
  .pillars,.checklist{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .contact-box,.footer-grid{grid-template-columns:1fr}
  .menu-toggle{display:inline-block}
  .logo img.logo-full{display:none}
  .logo img.logo-mark{display:block}
  .nav-wrapper{position:absolute;left:0;right:0;top:100%;background:#fff;border-bottom:1px solid var(--pm-line);
    display:none;padding:1rem clamp(1.2rem,4vw,2.5rem) 1.5rem}
  .nav-wrapper.open{display:block}
  .nav-main{flex-direction:column;align-items:flex-start;gap:1.1rem}
}

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