/*
Theme Name: Praxis an der Schanze
Theme URI: https://www.praxisanderschanze.at/
Author: Agnes Fletzberger
Description: Landingpage-Theme für die Praxis an der Schanze (Drygalskiweg 59, 1220 Wien). Editorial-Style mit Cormorant Garamond & Inter.
Version: 1.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: praxis-an-der-schanze
*/

:root{
  --bone:#F4EFE6; --cream:#FAF7F1; --paper:#FDFBF6;
  --sand:#E8DFD0; --sand-soft:#EFE8DA;
  --rose:#D9B8A8; --rose-deep:#B0735E; --rose-ink:#7A4A38;
  --clay:#C49B7C; --sage-deep:#6F806B;
  --ink:#26241F; --ink-soft:#54524B; --ink-mute:#8A887F;
  --line:#E0D8C7;
  --serif:"Cormorant Garamond","EB Garamond",Garamond,serif;
  --sans:"Inter",system-ui,sans-serif;
  --maxw:1180px;
  --gutter:clamp(24px,5vw,72px);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;padding-top:118px;background:var(--paper);color:var(--ink);font-family:var(--serif);font-size:19px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-padding-top:128px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
em{font-style:italic;color:var(--rose-deep);font-weight:500}

/* Eyebrow / small caps */
.eyebrow{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--rose-deep)}
.smallcap{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}

/* Masthead */
.mast{padding:32px 0 22px;background:var(--bone);position:fixed;top:0;left:0;right:0;z-index:50;transition:background .25s ease, backdrop-filter .25s ease, padding .25s ease}
.mast.is-scrolled{background:transparent;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:18px 0 14px}
.mast.is-scrolled::before{content:"";position:absolute;inset:0;background:rgba(244,239,230,.55);z-index:-1;pointer-events:none}
.mast .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.mast .logo{font-family:var(--serif);font-weight:500;font-size:48px;letter-spacing:.005em;line-height:1}
.mast .logo .it{font-style:italic;color:var(--rose-deep);font-weight:500;font-size:.4em;letter-spacing:.22em;text-transform:uppercase;margin-left:14px;vertical-align:.4em;display:inline-block}
.mast nav{display:flex;gap:28px;font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.04em}
.mast nav a{color:var(--ink);border-bottom:1px solid transparent;padding-bottom:3px;transition:border-color .15s}
.mast nav a:hover{border-bottom-color:var(--rose-deep)}
.navtoggle{display:none}
.burger{display:none}

/* HERO */
.hero{position:relative;margin-top:-118px;padding:calc(118px + clamp(40px,5vw,80px)) 0 clamp(100px,13vw,180px);overflow:hidden;background:var(--paper);min-height:clamp(620px,82vh,860px)}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:65% center;filter:contrast(1.02) saturate(.95)}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg, rgba(253,251,246,.94) 0%, rgba(253,251,246,.9) 25%, rgba(253,251,246,.58) 48%, rgba(253,251,246,.2) 70%, rgba(253,251,246,0) 92%)}
.hero .wrap{position:relative;z-index:1;display:flex;align-items:flex-end;min-height:clamp(440px,60vh,640px)}
.hero-text{max-width:640px}
.hero .kicker{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--rose-deep);margin-bottom:18px}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(54px,7vw,108px);line-height:.98;letter-spacing:-.018em;margin:0;text-wrap:balance;color:var(--ink)}
.hero h1 .it{font-style:italic;color:var(--rose-deep)}
.hero .lede{margin-top:32px;max-width:46ch;font-family:var(--serif);font-style:italic;font-size:22px;line-height:1.45;color:var(--ink-soft)}
.hero .cta{margin-top:28px;display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;border-bottom:1px solid var(--ink);padding-bottom:6px;color:var(--ink)}
.hero .cta::after{content:"→"}
.hero .cta:hover{color:var(--rose-deep);border-color:var(--rose-deep)}
.hero-caption{position:absolute;right:clamp(24px,5vw,72px);bottom:clamp(24px,4vw,44px);z-index:2;font-family:var(--sans);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);background:rgba(253,251,246,.86);padding:6px 10px}

/* Section frame */
section{padding:clamp(80px,9vw,140px) 0;position:relative}
.section-head{display:grid;grid-template-columns:1fr 2fr;gap:clamp(32px,5vw,80px);align-items:start;margin-bottom:clamp(48px,6vw,80px)}
.section-head .meta{display:flex;flex-direction:column;gap:12px;position:sticky;top:24px}
.section-head .meta .num{font-family:var(--serif);font-style:italic;font-weight:500;font-size:56px;color:var(--rose-deep);line-height:1}
.section-head h2{font-family:var(--serif);font-weight:500;font-size:clamp(38px,4.8vw,68px);line-height:1.02;letter-spacing:-.012em;margin:0;text-wrap:balance}
.section-head h2 em{color:var(--rose-deep)}
.section-head .lede{margin-top:22px;max-width:62ch;font-family:var(--serif);font-size:21px;color:var(--ink-soft);line-height:1.45}

/* DIE PRAXIS */
#praxis{background:var(--paper)}
.feature-list{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line)}
.feature-list>article{padding:30px 28px 30px 0;border-bottom:1px solid var(--line)}
.feature-list>article:nth-child(odd){padding-right:36px;border-right:1px solid var(--line)}
.feature-list>article:nth-child(even){padding-left:28px}
.feature-list h3{font-family:var(--serif);font-weight:500;font-size:24px;margin:0 0 8px;line-height:1.2;color:var(--ink)}
.feature-list p{margin:0;font-family:var(--serif);font-size:17px;color:var(--ink-soft);line-height:1.5}

/* RÄUME — Grundriss */
#raeume{background:var(--cream)}
.plan{margin-top:clamp(40px,5vw,72px);background:var(--paper);padding:clamp(28px,4vw,56px);border:1px solid var(--line)}
.plan .head{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:16px;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:24px}
.plan .head h3{margin:0;font-family:var(--serif);font-size:28px;font-weight:500}
.plan img{background:var(--bone)}

/* STANDORT */
#standort{background:var(--ink);color:var(--cream)}
#standort .section-head h2,#standort .section-head h2 em{color:var(--cream)}
#standort .section-head h2 em{font-style:italic;color:var(--rose)}
#standort .section-head .num{color:var(--rose)}
#standort .section-head .lede{color:rgba(244,239,230,.78)}
#standort .eyebrow{color:var(--rose)}

.pullq{margin-top:clamp(60px,7vw,100px);display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.pullq blockquote{margin:0;font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(26px,2.8vw,38px);line-height:1.3;color:var(--cream);max-width:28ch}
.pullq blockquote::before{content:"„";font-size:1.6em;color:var(--rose);line-height:0;margin-right:6px;vertical-align:-.2em}
.pullq .src{margin-top:18px;font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(244,239,230,.6)}
.pullq .links{display:flex;flex-direction:column;gap:14px;font-family:var(--sans);font-size:14px}
.pullq .links a{color:var(--rose);border-bottom:1px solid rgba(217,184,168,.4);padding-bottom:8px}
.pullq .links a:hover{color:var(--cream);border-color:var(--cream)}

.transit{margin-top:clamp(60px,7vw,100px);display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid rgba(244,239,230,.2);border-bottom:1px solid rgba(244,239,230,.2)}
.transit-head{margin:clamp(60px,7vw,100px) 0 18px;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--cream)}
.transit-head + .transit{margin-top:0}
.transit>div{padding:30px 24px;border-right:1px solid rgba(244,239,230,.14)}
.transit>div:last-child{border-right:0}
.transit .kbd{font-family:var(--serif);font-style:italic;font-weight:500;font-size:26px;color:var(--rose);line-height:1.1;margin-bottom:14px}
.transit p{margin:0;font-family:var(--sans);font-size:13px;color:rgba(244,239,230,.7);line-height:1.55}

/* LAGE */
#lage{background:var(--cream)}
.map-grid{display:grid;grid-template-columns:1fr;gap:clamp(32px,4vw,60px);align-items:stretch}
.map-frame{background:var(--sand-soft);border:1px solid var(--line);min-height:460px;position:relative;overflow:hidden}
.map-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* GEBÄUDE */
#gebaeude{background:var(--paper)}
.build{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.build .ph{background:var(--sand);overflow:hidden;aspect-ratio:4/3}
.build .ph img{width:100%;height:100%;object-fit:cover}
.build .a{grid-column:span 6}
.build .b{grid-column:span 6}

/* AGNES */
#agnes{background:var(--bone);padding-bottom:clamp(40px,4vw,60px)}
.agnes-grid{display:grid;grid-template-columns:1fr 2fr;gap:clamp(20px,2.5vw,40px);align-items:start}
.agnes-side{display:flex;flex-direction:column;gap:28px}
.portrait{aspect-ratio:1/1;background:var(--sand);border:1px solid var(--line);position:relative;overflow:hidden}
.portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 30%}
.agnes-text p{margin:18px 0 0;font-family:var(--serif);font-size:22px;color:var(--ink);line-height:1.55;max-width:60ch}
.agnes-text p:first-child{margin-top:0}
.aquote{margin-top:36px;padding:28px 32px;border-left:3px solid var(--rose-deep);background:var(--cream)}
.aquote blockquote{margin:0;font-family:var(--serif);font-style:italic;font-weight:500;font-size:24px;line-height:1.4;color:var(--ink)}
.aquote .src{margin-top:14px;font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute)}

.schwer{border-top:1px solid var(--line);padding-top:20px}
.schwer .label{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--rose-deep);margin-bottom:14px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{font-family:var(--sans);font-size:13px;padding:8px 14px;border-radius:999px;background:var(--paper);border:1px solid var(--line);color:var(--ink-soft)}
.extlink{display:inline-flex;gap:10px;align-items:center;font-family:var(--sans);font-size:14px;font-weight:500;color:var(--rose-deep);border-bottom:1px solid var(--rose);padding-bottom:4px}
.agnes-side .extlink{align-self:flex-start}
.extlink:hover{color:var(--ink);border-color:var(--ink)}

/* KONTAKT */
#kontakt{background:var(--ink);color:var(--cream);padding-bottom:clamp(36px,4vw,56px)}
#kontakt .section-head h2{color:var(--cream)}
#kontakt .section-head h2 em{color:var(--rose)}
#kontakt .section-head .num{color:var(--rose)}
#kontakt .section-head .lede{color:rgba(244,239,230,.78)}

footer{background:#1F1E1B;color:rgba(244,239,230,.55);padding:40px 0;text-align:center;font-family:var(--sans);font-size:12px;letter-spacing:.04em}

/* Scroll-reveal */
.reveal{opacity:0;transform:translateY(28px) scale(.965);transition:opacity .9s cubic-bezier(.2,.6,.2,1), transform 1.1s cubic-bezier(.2,.6,.2,1)}
.reveal.is-in{opacity:1;transform:translateY(0) scale(1)}
.reveal-img{overflow:hidden}
.reveal-img>img,.reveal-img>iframe{transform:scale(1.08);transition:transform 1.4s cubic-bezier(.2,.6,.2,1)}
.reveal-img.is-in>img,.reveal-img.is-in>iframe{transform:scale(1)}
@media (prefers-reduced-motion:reduce){
  .reveal,.reveal-img>img,.reveal-img>iframe{opacity:1;transform:none;transition:none}
}

@media (max-width:980px){
  .hero .wrap,.section-head,.map-grid,.agnes-grid,.feature-list,.pullq{grid-template-columns:1fr}
  .hero-bg::after{background:linear-gradient(180deg, rgba(253,251,246,0) 0%, rgba(253,251,246,.55) 35%, var(--paper) 65%, var(--paper) 100%)}
  .hero-bg img{object-position:center 25%}
  .hero .wrap{align-items:flex-end;min-height:clamp(520px,82vh,720px)}
  .feature-list>article:nth-child(odd){border-right:0;padding-right:0}
  .feature-list>article:nth-child(even){padding-left:0}
  .transit{grid-template-columns:repeat(2,1fr)}
  .transit>div{border-right:0;border-bottom:1px solid rgba(244,239,230,.14)}
  .build .a,.build .b{grid-column:span 12}
  .mast .logo{font-size:30px}
  .mast .logo .it{font-size:.36em;margin-left:8px}
  .burger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:38px;height:38px;cursor:pointer;padding:8px;background:transparent;border:1px solid var(--ink);border-radius:6px}
  .burger span{display:block;height:2px;background:var(--ink);width:100%;transition:transform .2s, opacity .2s}
  .navtoggle:checked + .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .navtoggle:checked + .burger span:nth-child(2){opacity:0}
  .navtoggle:checked + .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .mast nav{display:none;flex-basis:100%;flex-direction:column;gap:14px;padding-top:14px;border-top:1px solid var(--line);margin-top:14px}
  .navtoggle:checked ~ nav{display:flex}
  .mast nav a{padding:8px 0;font-size:16px}
}
@media (max-width:560px){
  .transit{grid-template-columns:1fr}
  .mast .logo{font-size:24px}
  body{padding-top:96px}
  .hero{margin-top:-96px;padding-top:calc(96px + clamp(40px,5vw,80px))}
}
