/* maxmaxi.de — Hochzeit Maxine & Maximilian · Layout & Komponenten */
/* maxmaxi.de — Hochzeit Maxine & Maximilian · hi-fi, elegant-klassisch */
:root{
  --bg:#f7f4ee;          /* warmes Creme */
  --bg-2:#f0ebe1;        /* etwas tiefer */
  --paper:#fffefb;
  --ink:#1c2740;         /* tiefes Navy für Text */
  --navy:#22304f;        /* Akzent (Bräutigam) */
  --navy-soft:#3a4a6b;
  --blue:#a9c6e2;        /* Hellblau (Gäste) */
  --blue-deep:#5f86ad;
  --muted:#7a8194;
  --line:#ddd6c9;
  --gold:#b89a5e;        /* dezente Linie, sparsam */
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Mulish',system-ui,sans-serif;
  --shadow:0 18px 50px -28px rgba(28,39,64,.45);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-weight:400;line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
section{scroll-margin-top:84px}
.wrap{max-width:1120px;margin:0 auto;padding:0 32px}
.eyebrow{font-family:var(--sans);font-weight:600;font-size:12px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--blue-deep)}
h2.title{font-family:var(--serif);font-weight:500;font-size:clamp(34px,5vw,56px);
  line-height:1.05;margin:.18em 0 0;color:var(--ink)}
.lead{font-size:17px;color:var(--muted);max-width:54ch;margin:14px auto 0}
.center{text-align:center}

/* ornament divider */
.orn{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--blue-deep)}
.orn::before,.orn::after{content:"";height:1px;width:54px;background:var(--line)}
.orn i{width:7px;height:7px;background:var(--blue);transform:rotate(45deg);display:block}
body.no-orn .orn{display:none}

/* ---------------- nav ---------------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:.35s ease;
  padding:20px 0;}
.nav .wrap{display:flex;align-items:center;gap:24px}
.nav.scrolled{background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--line);padding:13px 0}
.mono{font-family:var(--serif);font-size:24px;font-weight:600;letter-spacing:.04em;color:var(--ink);
  text-decoration:none;display:flex;align-items:center;gap:7px}
.mono .amp{color:var(--blue-deep);font-style:normal}
.nav .links{margin-left:auto;display:flex;gap:30px}
.nav .links a{font-size:13.5px;letter-spacing:.06em;color:var(--muted);text-decoration:none;
  position:relative;transition:.2s;text-transform:uppercase;font-weight:600}
.nav .links a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:1.5px;
  background:var(--navy);transition:right .25s ease}
.nav .links a:hover,.nav .links a.active{color:var(--ink)}
.nav .links a.active::after{right:0}
.nav .datepill{font-size:12px;letter-spacing:.08em;color:var(--navy);border:1px solid var(--line);
  border-radius:30px;padding:6px 14px;white-space:nowrap}
@media(max-width:760px){.nav .links{display:none}.nav .datepill{margin-left:auto}}

/* ---------------- hero ---------------- */
.hero{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;
  align-items:center;padding:120px 0 70px}
.hero .wrap{display:contents}
.hero-text{padding-left:32px}
.hero-text .names{font-family:var(--serif);font-weight:500;color:var(--ink);
  font-size:clamp(52px,8.5vw,104px);line-height:.92;margin:18px 0 6px;letter-spacing:.005em}
.hero-text .names .amp{display:block;font-style:normal;color:var(--blue-deep);
  font-size:.62em;margin:2px 0;font-weight:500}
.hero-text .sub{font-family:var(--serif);font-size:clamp(20px,2.4vw,27px);color:var(--navy-soft);
  font-style:italic;margin-top:6px}
.hero-text .meta{margin-top:22px;display:flex;flex-direction:column;gap:4px;color:var(--muted);font-size:15px}
.hero-text .meta b{color:var(--ink);font-weight:600;letter-spacing:.04em}
.scrollcue{margin-top:40px;display:inline-flex;align-items:center;gap:10px;color:var(--blue-deep);
  font-size:11px;letter-spacing:.25em;text-transform:uppercase}
.scrollcue span{width:38px;height:1px;background:var(--blue-deep);position:relative;overflow:hidden}
.scrollcue span::after{content:"";position:absolute;inset:0;left:-100%;background:var(--ink);
  animation:slide 2.4s ease-in-out infinite}
@keyframes slide{0%{left:-100%}55%,100%{left:100%}}

/* arch photo */
.hero-photo{padding-right:32px}
.arch{position:relative;margin:0 auto;max-width:430px}
.arch .frame{border-radius:50% 50% 6px 6px/32% 32% 6px 6px;overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow);background:var(--bg-2)}
.arch .imgph{width:100%;aspect-ratio:7/9}
.arch::after{content:"";position:absolute;inset:14px 14px 14px;
  border:1px solid color-mix(in srgb,var(--blue) 60%,transparent);
  border-radius:50% 50% 4px 4px/32% 32% 4px 4px;pointer-events:none}
@media(max-width:880px){
  .hero{grid-template-columns:1fr;text-align:center;gap:36px;padding-top:120px}
  .hero-text{padding:0 24px}.hero-photo{padding:0 24px}
  .hero-text .meta{align-items:center}.scrollcue{display:none}
}

/* ---------------- countdown band ---------------- */
.cd-band{background:var(--navy);color:#fff;padding:46px 0}
.cd{display:flex;justify-content:center;gap:0;flex-wrap:wrap}
.cd .u{flex:1;min-width:120px;text-align:center;padding:6px 10px;position:relative}
.cd .u + .u::before{content:"";position:absolute;left:0;top:18%;bottom:18%;width:1px;
  background:color-mix(in srgb,#fff 22%,transparent)}
.cd .n{font-family:var(--serif);font-size:clamp(44px,6.5vw,72px);line-height:1;
  font-weight:500;color:#fff;font-variant-numeric:tabular-nums}
.cd .l{font-size:11px;letter-spacing:.28em;text-transform:uppercase;margin-top:10px;
  color:var(--blue)}
.cd-cap{text-align:center;color:var(--blue);font-family:var(--serif);font-style:italic;
  font-size:20px;margin-bottom:26px}

/* ---------------- story / übersicht ---------------- */
.story{padding:96px 0}
.stats{display:flex;justify-content:center;gap:0;margin-top:46px;flex-wrap:wrap}
.stat{flex:1;min-width:180px;text-align:center;padding:6px 24px;position:relative}
.stat + .stat::before{content:"";position:absolute;left:0;top:10%;bottom:10%;width:1px;background:var(--line)}
.stat .big{font-family:var(--serif);font-size:clamp(34px,4.6vw,50px);color:var(--navy);
  font-weight:500;line-height:1;font-variant-numeric:tabular-nums}
.stat .cap{margin-top:10px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
@media(max-width:680px){.stat + .stat::before{display:none}.stat{flex-basis:100%;padding:18px 0;
  border-top:1px solid var(--line)}.stats{margin-top:30px}}

/* ---------------- section header ---------------- */
.sec{padding:92px 0}
.sec.alt{background:var(--bg-2)}
.sechead{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;
  margin-bottom:42px}
.sechead .l .title{margin-top:6px}
.sechead .sub{color:var(--muted);font-size:15px;margin-top:8px;max-width:46ch}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:600;
  font-size:13px;letter-spacing:.06em;padding:11px 22px;border-radius:30px;cursor:pointer;
  border:1px solid var(--navy);background:var(--navy);color:#fff;text-decoration:none;transition:.2s}
.btn:hover{background:var(--navy-soft);border-color:var(--navy-soft)}
.btn.ghost{background:transparent;color:var(--navy)}
.btn.ghost:hover{background:color-mix(in srgb,var(--blue) 24%,transparent);color:var(--ink)}
.btn .plus{font-size:17px;line-height:0}

/* chips */
.chips{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:30px}
.chip{font-size:12.5px;letter-spacing:.05em;padding:7px 16px;border-radius:30px;cursor:pointer;
  border:1px solid var(--line);background:var(--paper);color:var(--muted);transition:.18s;font-weight:600}
.chip:hover{border-color:var(--blue-deep);color:var(--ink)}
.chip.on{background:var(--navy);border-color:var(--navy);color:#fff}

/* idea cards */
.ideas{columns:3;column-gap:24px}
@media(max-width:900px){.ideas{columns:2}}
@media(max-width:600px){.ideas{columns:1}}
.idea{break-inside:avoid;margin-bottom:24px;background:var(--paper);border:1px solid var(--line);
  border-radius:14px;padding:22px 22px 20px;box-shadow:0 10px 30px -24px rgba(28,39,64,.5);
  position:relative;transition:.25s}
.idea:hover{transform:translateY(-3px);box-shadow:0 22px 44px -26px rgba(28,39,64,.55)}
.idea::before{content:"";position:absolute;top:16px;right:18px;width:7px;height:7px;border-radius:50%;
  background:var(--blue)}
.idea .cat{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-deep);font-weight:700}
.idea h3{font-family:var(--serif);font-weight:600;font-size:25px;margin:8px 0 6px;color:var(--ink);line-height:1.12}
.idea p{margin:0;font-size:14.5px;color:var(--muted)}
.idea .imgph{width:100%;aspect-ratio:4/3;margin-bottom:14px;border-radius:9px}
.idea.add{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  border-style:dashed;background:transparent;box-shadow:none;min-height:140px;color:var(--muted)}
.idea.add::before{display:none}
.idea.add:hover{transform:none;border-color:var(--blue-deep);color:var(--ink)}
.idea.add .pl{font-family:var(--serif);font-size:30px;color:var(--blue-deep);line-height:1}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;grid-auto-flow:dense}
.gal .imgph{width:100%;height:100%;border-radius:12px;border:1px solid var(--line);
  box-shadow:0 12px 30px -26px rgba(28,39,64,.5);min-height:150px}
.gal .s-2{grid-column:span 2}.gal .s-2r{grid-row:span 2}
@media(max-width:760px){.gal{grid-template-columns:repeat(2,1fr)}.gal .s-2r{grid-row:span 1}}
.gal-note{text-align:center;margin-top:26px;color:var(--muted);font-family:var(--serif);
  font-style:italic;font-size:19px}

/* notes */
.notes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:820px){.notes{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.notes{grid-template-columns:1fr}}
.note-c{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:20px 22px;
  box-shadow:0 10px 30px -26px rgba(28,39,64,.5)}
.note-c .nh{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue-deep);
  font-weight:700;margin-bottom:14px}
.todo{display:flex;align-items:flex-start;gap:11px;padding:9px 0;border-top:1px solid var(--line);font-size:15px}
.todo:first-of-type{border-top:0}
.todo .box{flex:0 0 18px;height:18px;border:1.6px solid var(--blue-deep);border-radius:50%;margin-top:2px;
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.18s}
.todo.done .box{background:var(--navy);border-color:var(--navy);color:#fff;font-size:11px}
.todo.done span{color:var(--muted);text-decoration:line-through}
.note-c.free{font-family:var(--serif);font-size:21px;line-height:1.4;color:var(--ink);font-style:italic;
  display:flex;align-items:center;background:color-mix(in srgb,var(--blue) 16%,var(--paper))}

/* footer */
.foot{background:var(--navy);color:#fff;text-align:center;padding:80px 24px 56px}
.foot .mono{justify-content:center;color:#fff;font-size:30px}
.foot .mono .amp{color:var(--blue)}
.foot .fd{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--blue);margin:16px 0 6px}
.foot .fd .amp{font-style:normal}
.foot .url{letter-spacing:.3em;text-transform:uppercase;font-size:12px;color:color-mix(in srgb,#fff 70%,transparent);margin-top:22px}
.foot .heart{margin-top:10px;font-size:12px;color:color-mix(in srgb,#fff 55%,transparent);letter-spacing:.08em}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------------- bild-platzhalter ---------------- */
/* Knüpft an das Rauten-Ornament (.orn i) an: ein blaues, rotiertes Quadrat
   mit weichem Hof, darunter eine kursive Serif-Bildunterschrift. So wirken
   leere Foto-Felder als bewusst gesetzte Rahmen, nicht als fehlende Bilder. */
.imgph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  text-align:center;padding:22px;overflow:hidden;
  background:radial-gradient(circle at 50% 40%,color-mix(in srgb,var(--blue) 16%,transparent),transparent 62%),
    var(--bg-2)}
.imgph::before{content:"";flex:0 0 auto;width:9px;height:9px;background:var(--blue);
  transform:rotate(45deg);box-shadow:0 0 0 6px color-mix(in srgb,var(--blue) 20%,transparent)}
.imgph span{font-family:var(--serif);font-style:italic;font-size:15.5px;line-height:1.3;
  letter-spacing:.01em;color:var(--muted);max-width:24ch}
@media (prefers-reduced-motion:no-preference){
  .imgph{transition:background .3s ease}
}
