/* =========================================================
   Lektorat Weitblick — Marie Merkel
   Editorial-literarisch · Petrol + Cremepapier + Messing
   ========================================================= */

:root{
  --petrol:        #2d606a;   /* Logo-Teal */
  --petrol-deep:   #1d434b;
  --petrol-darker: #163239;
  --teal-soft:     #5d8a8f;
  --pastel:        #cfe2e4;
  --pastel-soft:   #e4eff0;
  --mist:          #eef4f4;
  --cream:         #fbf8f1;   /* warmes Papier */
  --cream-deep:    #f4eee2;
  --ink:           #1f2d2e;
  --ink-soft:      #51635f;
  --gold:          #b3873f;   /* Messing-Akzent */
  --gold-soft:     #d8bd86;
  --line:          rgba(45,96,106,.16);

  --ff-display: "Fraunces", Georgia, "Times New Roman", serif;
  --ff-body:    "Hanken Grotesk", system-ui, sans-serif;

  --maxw: 1180px;
  --gutter: clamp(1.2rem, 4vw, 3rem);
  --radius: 18px;
  --radius-lg: 32px;
  --shadow: 0 24px 60px -28px rgba(22,50,57,.35);
  --shadow-soft: 0 14px 40px -24px rgba(22,50,57,.4);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:92px; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:clamp(1rem,.96rem + .25vw,1.08rem);
  font-weight:400;
  letter-spacing:.005em;
  overflow-x:hidden;
}
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *{ animation:none !important; transition:none !important; }
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* grain overlay */
.grain{
  position:fixed; inset:0; z-index:9999; pointer-events:none; opacity:.04; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ---------- Typo ---------- */
h1,h2,h3{ font-family:var(--ff-display); font-weight:400; line-height:1.08; letter-spacing:-.01em; color:var(--petrol-deep); margin:0; font-optical-sizing:auto; }
h1{ font-size:clamp(2.6rem,2rem + 4.4vw,5rem); }
h1 em, h2 em{ font-style:italic; font-weight:300; color:var(--petrol); }
h2{ font-size:clamp(1.9rem,1.5rem + 2.4vw,3.1rem); }
h3{ font-size:clamp(1.25rem,1.1rem + .7vw,1.55rem); color:var(--petrol-deep); }
p{ margin:0 0 1rem; }
strong{ font-weight:600; color:var(--petrol-deep); }

.eyebrow{
  display:inline-block; font-family:var(--ff-body); font-weight:600;
  font-size:.74rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold); margin-bottom:1rem; position:relative; padding-left:2.4rem;
}
.eyebrow::before{ content:""; position:absolute; left:0; top:.55em; width:1.8rem; height:1px; background:var(--gold); }
.eyebrow--center{ padding-left:0; }
.eyebrow--center::before{ display:none; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.container--narrow{ max-width:820px; }

.section{ padding:clamp(4rem,3rem + 6vw,7.5rem) 0; position:relative; }
.section__head{ max-width:720px; margin:0 auto clamp(2.4rem,5vw,3.6rem); text-align:center; }
.section__head .eyebrow{ display:block; }
.section__intro{ color:var(--ink-soft); font-size:1.1rem; margin-top:.6rem; }
.section--mist{ background:linear-gradient(180deg,var(--mist),var(--cream)); }
.section--petrol{ background:radial-gradient(120% 140% at 80% 0%, var(--petrol) 0%, var(--petrol-deep) 55%, var(--petrol-darker) 100%); color:#eaf2f1; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--petrol); --fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  background:var(--bg); color:var(--fg); font-family:var(--ff-body); font-weight:600;
  font-size:.95rem; letter-spacing:.01em; padding:.95rem 1.7rem; border-radius:100px;
  border:1px solid transparent; cursor:pointer; transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s;
  box-shadow:0 10px 26px -14px rgba(45,96,106,.7); white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 16px 34px -14px rgba(45,96,106,.8); background:var(--petrol-deep); }
.btn--ghost{ background:transparent; color:var(--petrol-deep); border-color:var(--line); box-shadow:none; }
.btn--ghost:hover{ background:rgba(45,96,106,.06); border-color:var(--petrol); }
.btn--light{ background:#fff; color:var(--petrol-deep); box-shadow:none; }
.btn--light:hover{ background:var(--cream); }
.btn--small{ padding:.6rem 1.15rem; font-size:.86rem; }
.btn--full{ width:100%; padding:1.05rem; }

/* ---------- NAV ---------- */
.nav{ position:fixed; inset:0 0 auto 0; z-index:100; transition:background .4s var(--ease), box-shadow .4s, padding .4s; padding:.55rem 0; }
.nav__inner{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.nav.is-scrolled{ background:rgba(251,248,241,.88); backdrop-filter:blur(14px) saturate(1.2); box-shadow:0 1px 0 var(--line); }

.brand{ display:flex; align-items:center; gap:.6rem; }
.brand__mark{ height:30px; width:auto; }
.brand__text{ font-family:var(--ff-display); font-size:1.18rem; color:var(--petrol-deep); letter-spacing:-.01em; }
.brand__text em{ font-style:italic; font-weight:300; color:var(--petrol); }

.nav__links{ display:flex; align-items:center; gap:.4rem; }
.nav__link{ font-weight:500; font-size:.93rem; color:var(--petrol-deep); padding:.5rem .8rem; border-radius:10px; position:relative; display:inline-flex; align-items:center; gap:.3rem; transition:color .25s, background .25s; }
.nav__link:hover{ color:var(--petrol); background:rgba(45,96,106,.06); }
.nav__link .caret{ transition:transform .3s var(--ease); }
.nav__item{ position:relative; }
.nav__item--has-sub:hover .caret{ transform:rotate(180deg); }
.nav__sub{
  position:absolute; top:calc(100% + .4rem); left:0; min-width:240px;
  background:#fff; border:1px solid var(--line); border-radius:14px; padding:.5rem;
  box-shadow:var(--shadow-soft); display:flex; flex-direction:column;
  opacity:0; visibility:hidden; transform:translateY(8px); transition:all .3s var(--ease);
}
.nav__item--has-sub:hover .nav__sub, .nav__item--has-sub:focus-within .nav__sub{ opacity:1; visibility:visible; transform:translateY(0); }
.nav__sub a{ padding:.6rem .8rem; border-radius:9px; font-size:.9rem; font-weight:500; color:var(--ink-soft); transition:.2s; }
.nav__sub a:hover{ background:var(--mist); color:var(--petrol-deep); }

.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.nav__burger span{ width:24px; height:2px; background:var(--petrol-deep); border-radius:2px; transition:.35s var(--ease); }
.nav__burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile drawer */
.drawer{ position:fixed; inset:0; z-index:99; background:var(--cream); padding:6rem var(--gutter) 2rem; transform:translateX(100%); transition:transform .45s var(--ease); }
.drawer.is-open{ transform:translateX(0); }
.drawer__links{ display:flex; flex-direction:column; gap:.2rem; }
.drawer__links a{ font-family:var(--ff-display); font-size:1.5rem; color:var(--petrol-deep); padding:.7rem 0; border-bottom:1px solid var(--line); }
.drawer__links a.drawer__sub{ font-family:var(--ff-body); font-size:1rem; color:var(--ink-soft); padding:.4rem 0 .4rem 1rem; border:0; }
.drawer__links .btn{ margin-top:1.5rem; align-self:flex-start; font-family:var(--ff-body); }

/* ---------- HERO ---------- */
.hero{ position:relative; padding:clamp(7rem,7rem + 4vw,9.5rem) 0 clamp(3rem,5vw,5rem); overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.hero__bg::before{ content:""; position:absolute; top:-20%; right:-10%; width:60vw; height:60vw; max-width:760px; max-height:760px; border-radius:50%;
  background:radial-gradient(circle at 50% 50%, var(--pastel) 0%, var(--pastel-soft) 45%, transparent 70%); opacity:.7; }
.hero__bg::after{ content:""; position:absolute; bottom:8%; left:-12%; width:40vw; height:40vw; max-width:460px; border-radius:50%;
  background:radial-gradient(circle, var(--cream-deep), transparent 70%); }
.ridge{ position:absolute; width:140%; left:-20%; height:auto; }
.ridge path{ fill:none; stroke:var(--petrol); stroke-width:1.4; opacity:.18; }
.ridge .ridge--faint{ stroke:var(--gold); opacity:.16; }
.ridge--hero{ top:18%; }

.hero__inner{ position:relative; z-index:1; width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter);
  display:grid; grid-template-columns:1.05fr .9fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.hero__text{ max-width:600px; }
.hero__lead{ font-size:1.18rem; color:var(--ink-soft); margin:1.4rem 0 2rem; max-width:36em; }
.hero__cta{ display:flex; gap:.8rem; flex-wrap:wrap; }
.hero__chips{ list-style:none; padding:0; margin:2.4rem 0 0; display:flex; flex-wrap:wrap; gap:.5rem .7rem; }
.hero__chips li{ font-size:.82rem; font-weight:500; color:var(--petrol-deep); background:rgba(255,255,255,.6); border:1px solid var(--line); padding:.4rem .85rem; border-radius:100px; backdrop-filter:blur(4px); }

.hero__media{ position:relative; justify-self:center; }
.hero__frame{
  position:relative; width:min(86vw,420px); aspect-ratio:3/4; overflow:hidden;
  border-radius:48% 48% 46% 46% / 46% 46% 50% 50%;
  box-shadow:var(--shadow); border:8px solid #fff;
}
.hero__frame img{ width:100%; height:100%; object-fit:cover; object-position:50% 25%; }
.hero__media::before{ content:""; position:absolute; inset:-14px -14px auto auto; width:120px; height:120px; border:1.5px solid var(--gold-soft); border-radius:50%; opacity:.5; z-index:-1; }

.hero__seal{ position:absolute; bottom:-6px; left:-26px; width:118px; height:118px; color:var(--petrol); animation:spin 36s linear infinite; }
.hero__seal svg{ width:100%; height:100%; }
.hero__seal text{ font-family:var(--ff-body); font-size:8.4px; font-weight:600; letter-spacing:.12em; fill:var(--petrol); text-transform:uppercase; }
.hero__seal-mark{ position:absolute; inset:0; margin:auto; width:34px; height:34px; background:url("/assets/logo-mark.png") center/contain no-repeat; }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ---------- CARDS / LEISTUNGEN ---------- */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.2rem,2.5vw,1.8rem); align-items:start; }
.card{
  position:relative; background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:2.2rem 1.9rem; transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s;
  box-shadow:0 1px 0 rgba(45,96,106,.04);
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-soft); border-color:transparent; }
.card--feature{ background:linear-gradient(180deg,#fff,var(--pastel-soft)); border-color:rgba(45,96,106,.22); }
.card__tag{ position:absolute; top:1.3rem; right:1.3rem; font-size:.68rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); background:rgba(179,135,63,.1); padding:.3rem .7rem; border-radius:100px; }
.card__icon{ width:52px; height:52px; display:grid; place-items:center; border-radius:14px; background:var(--mist); color:var(--petrol); margin-bottom:1.3rem; }
.card__icon svg{ width:26px; height:26px; }
.card h3{ margin-bottom:.7rem; }
.card p{ color:var(--ink-soft); font-size:.98rem; }
.card__note{ font-size:.86rem; font-style:italic; color:var(--teal-soft); margin-top:1rem; padding-top:1rem; border-top:1px solid var(--line); }
.ticks{ list-style:none; padding:0; margin:1rem 0 0; display:flex; flex-wrap:wrap; gap:.45rem; }
.ticks li{ font-size:.85rem; font-weight:500; color:var(--petrol-deep); background:var(--mist); padding:.32rem .75rem; border-radius:8px; display:flex; align-items:center; }
.card--feature .ticks li{ background:rgba(255,255,255,.7); }

/* ---------- COMPARE ---------- */
.compare{ display:grid; grid-template-columns:1fr auto 1fr; gap:0; align-items:center; background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-soft); }
.compare__col{ padding:clamp(1.8rem,4vw,2.8rem); }
.compare__col h3{ margin-bottom:.6rem; }
.compare__col p{ color:var(--ink-soft); margin:0; }
.compare__divider{ align-self:stretch; display:grid; place-items:center; padding:0 .4rem; background:var(--mist); }
.compare__divider span{ font-family:var(--ff-display); font-style:italic; color:var(--teal-soft); font-size:1.1rem; }
.compare__foot{ text-align:center; color:var(--ink-soft); max-width:62ch; margin:1.8rem auto 0; font-size:.98rem; }

/* ---------- ABLAUF / TRAIL ---------- */
.trail{ list-style:none; counter-reset:s; padding:0; margin:0 auto; max-width:760px; position:relative; }
.trail::before{ content:""; position:absolute; left:24px; top:18px; bottom:40px; width:2px; background:linear-gradient(var(--pastel),var(--gold-soft)); }
.trail__step{ position:relative; display:grid; grid-template-columns:54px 1fr; gap:1.3rem; padding:0 0 2.2rem; }
.trail__num{ position:relative; z-index:1; width:50px; height:50px; border-radius:50%; background:#fff; border:2px solid var(--pastel); color:var(--petrol); display:grid; place-items:center; font-family:var(--ff-display); font-size:1.25rem; box-shadow:0 6px 18px -10px rgba(45,96,106,.5); }
.trail__num svg{ width:24px; height:24px; }
.trail__step--peak .trail__num{ background:var(--petrol); border-color:var(--petrol); color:#fff; }
.trail__step h3{ margin:.55rem 0 .35rem; }
.trail__step p{ color:var(--ink-soft); margin:0; }
.trail__step--peak h3{ color:var(--gold); }

/* ---------- PREISE ---------- */
.section--petrol h2{ color:#fff; }
.section--petrol h2 em{ color:var(--gold-soft); }
.section--petrol strong{ color:#fff; }
.section__head--light .eyebrow{ color:var(--gold-soft); }
.price{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(1.5rem,3vw,2.5rem); align-items:start; }
.price__body p{ color:rgba(234,242,241,.88); font-size:1.06rem; margin:0; }
.price__card{ background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.18); border-radius:var(--radius); padding:2rem; backdrop-filter:blur(6px); display:flex; flex-direction:column; }
.price__label{ font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-soft); font-weight:600; }
.price__amount{ font-family:var(--ff-display); font-size:3.4rem; line-height:1; color:#fff; margin:.4rem 0 .2rem; }
.price__unit{ font-size:.9rem; color:rgba(234,242,241,.7); }
.price__card p{ color:rgba(234,242,241,.85); font-size:.94rem; margin:1.1rem 0 1.5rem; }
.price__card .btn{ margin-top:auto; }

/* ---------- ÜBER MICH ---------- */
.about{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.about__frame{ position:relative; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); border:8px solid #fff; aspect-ratio:4/5; }
.about__frame img{ width:100%; height:100%; object-fit:cover; }
.about__media{ position:relative; }
.about__media::after{ content:""; position:absolute; inset:auto -18px -18px auto; width:60%; height:60%; border:1.5px solid var(--gold-soft); border-radius:var(--radius-lg); z-index:-1; opacity:.45; }
.about__text p{ color:var(--ink-soft); }
.about__sign{ font-family:var(--ff-display); font-style:italic; font-size:1.4rem; color:var(--petrol); margin-top:1.2rem; }

/* ---------- KONTAKT ---------- */
.contact{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.contact__intro p{ color:var(--ink-soft); }
.contact__details{ list-style:none; padding:0; margin:2rem 0 0; display:flex; flex-direction:column; gap:1rem; }
.contact__details li{ display:flex; flex-direction:column; gap:.1rem; }
.contact__details span{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); font-weight:600; }
.contact__details a{ color:var(--petrol-deep); font-weight:500; font-size:1.05rem; transition:color .2s; }
.contact__details a:hover{ color:var(--petrol); }

.form{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(1.6rem,3vw,2.4rem); box-shadow:var(--shadow-soft); }
.field{ margin-bottom:1.2rem; }
.field label{ display:block; font-size:.82rem; font-weight:600; letter-spacing:.04em; color:var(--petrol-deep); margin-bottom:.4rem; }
.field input, .field textarea{ width:100%; font-family:var(--ff-body); font-size:1rem; color:var(--ink); background:var(--cream); border:1.5px solid var(--line); border-radius:12px; padding:.85rem 1rem; transition:border-color .25s, box-shadow .25s, background .25s; resize:vertical; }
.field input::placeholder, .field textarea::placeholder{ color:#9aa9a6; }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--petrol); background:#fff; box-shadow:0 0 0 4px rgba(45,96,106,.1); }
.form__hint{ font-size:.78rem; color:var(--teal-soft); margin:.9rem 0 0; }
.form__success{ margin:1.1rem 0 0; padding:1rem 1.1rem; background:var(--pastel-soft); border:1px solid var(--pastel); border-radius:12px; color:var(--petrol-deep); font-weight:500; }

/* ---------- FOOTER ---------- */
.footer{ background:var(--petrol-darker); color:rgba(234,242,241,.78); padding:clamp(3rem,5vw,4.5rem) 0 2rem; }
.footer__inner{ display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:2.5rem; align-items:start; }
.footer__logo{ height:54px; width:auto; filter:brightness(0) invert(1); opacity:.92; margin-bottom:1rem; }
.footer__claim{ font-family:var(--ff-display); font-style:italic; font-size:1.15rem; color:var(--pastel); margin:0; max-width:24ch; }
.footer__contact{ font-style:normal; line-height:1.9; font-size:.95rem; }
.footer__contact strong{ color:#fff; }
.footer__contact a{ color:rgba(234,242,241,.78); transition:color .2s; }
.footer__contact a:hover{ color:var(--gold-soft); }
.footer__nav{ display:flex; flex-direction:column; gap:.6rem; }
.footer__nav a{ font-size:.95rem; transition:color .2s; width:fit-content; }
.footer__nav a:hover{ color:var(--gold-soft); }
.footer__base{ max-width:var(--maxw); margin:2.5rem auto 0; padding:1.5rem var(--gutter) 0; border-top:1px solid rgba(255,255,255,.12); display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem; font-size:.84rem; color:rgba(234,242,241,.55); }

/* ---------- REVEAL ANIMATION ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease) var(--d,0s), transform .9s var(--ease) var(--d,0s); }
.reveal.is-in{ opacity:1; transform:none; }

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .nav__links{ display:none; }
  .nav__burger{ display:flex; }
  .hero__inner{ grid-template-columns:1fr; text-align:center; }
  .hero__text{ max-width:none; margin-inline:auto; }
  .hero .eyebrow{ padding-left:0; } .hero .eyebrow::before{ display:none; }
  .hero__cta, .hero__chips{ justify-content:center; }
  .hero__media{ margin-top:2.6rem; }
  .cards{ grid-template-columns:1fr; max-width:520px; margin-inline:auto; }
  .price, .about, .contact{ grid-template-columns:1fr; }
  .about__media{ max-width:420px; margin-inline:auto; }
  .footer__inner{ grid-template-columns:1fr 1fr; }
}
@media (max-width:600px){
  .compare{ grid-template-columns:1fr; }
  .compare__divider{ padding:.5rem; }
  .footer__inner{ grid-template-columns:1fr; gap:2rem; }
  .footer__base{ flex-direction:column; }
  .hero__seal{ width:92px; height:92px; left:-10px; }
}
