*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-tap-highlight-color:transparent}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{color:inherit;font-family:inherit;font-feature-settings:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{color:#9ca3af;opacity:1}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.sr-only{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border-width:0;white-space:nowrap}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.bottom-8{bottom:2rem}.left-1{left:.25rem}.left-1\/2{left:50%}.mx-auto{margin-left:auto;margin-right:auto}.my-3{margin-bottom:.75rem;margin-top:.75rem}.mb-10{margin-bottom:2.5rem}.mb-16{margin-bottom:4rem}.mb-20{margin-bottom:5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-1{margin-top:.25rem}.mt-3{margin-top:.75rem}.mt-6{margin-top:1.5rem}.block{display:block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-screen{height:100vh}.w-16{width:4rem}.w-full{width:100%}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-5xl{max-width:64rem}.max-w-md{max-width:28rem}.flex-shrink{flex-shrink:1}.-translate-x-1{--tw-translate-x:-0.25rem}.-translate-x-1,.-translate-x-1\/2{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-x-1\/2{--tw-translate-x:-50%}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}.animate-bounce{animation:bounce 1s infinite}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-end{align-items:flex-end}.items-center{align-items:center}.items-stretch{align-items:stretch}.justify-center{justify-content:center}.gap-12{gap:3rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-8{gap:2rem}.overflow-hidden{overflow:hidden}.border{border-width:1px}.bg-gradient-to-t{background-image:linear-gradient(to top,var(--tw-gradient-stops))}.from-black{--tw-gradient-from:#000 var(--tw-gradient-from-position);--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-black\/65{--tw-gradient-from:rgba(0,0,0,.65) var(--tw-gradient-from-position);--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-black{--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#000 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-black\/20{--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),rgba(0,0,0,.2) var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-black{--tw-gradient-to:#000 var(--tw-gradient-to-position)}.to-black\/10{--tw-gradient-to:rgba(0,0,0,.1) var(--tw-gradient-to-position)}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-20{padding-bottom:5rem;padding-top:5rem}.py-24{padding-bottom:6rem;padding-top:6rem}.py-4{padding-bottom:1rem;padding-top:1rem}.pb-16{padding-bottom:4rem}.pb-24{padding-bottom:6rem}.pt-4{padding-top:1rem}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-6xl{font-size:3.75rem;line-height:1}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-light{font-weight:300}.uppercase{text-transform:uppercase}.italic{font-style:italic}.leading-relaxed{line-height:1.625}.tracking-\[0\.25em\]{letter-spacing:.25em}.tracking-\[0\.4em\]{letter-spacing:.4em}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-white\/90{color:hsla(0,0%,100%,.9)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.blur{--tw-blur:blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}@media (min-width:640px){.sm\:flex-row{flex-direction:row}}@media (min-width:768px){.md\:col-span-5{grid-column:span 5/span 5}.md\:col-span-7{grid-column:span 7/span 7}.md\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:px-12{padding-left:3rem;padding-right:3rem}.md\:py-28{padding-bottom:7rem;padding-top:7rem}.md\:py-32{padding-top:8rem}.md\:pb-32,.md\:py-32{padding-bottom:8rem}.md\:text-2xl{font-size:1.5rem;line-height:2rem}.md\:text-3xl{font-size:1.875rem;line-height:2.25rem}.md\:text-4xl{font-size:2.25rem;line-height:2.5rem}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-6xl{font-size:3.75rem;line-height:1}.md\:text-8xl{font-size:6rem;line-height:1}.md\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width:1024px){.lg\:text-9xl{font-size:8rem;line-height:1}}@media (min-width:1280px){.xl\:text-6xl{font-size:3.75rem;line-height:1}}

/* ═══ RESET ═══ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; scroll-padding-top: 5rem; }
img { display: block; max-width: 100%; height: auto; }
button, a { font: inherit; color: inherit; text-decoration: none; }
button { cursor: pointer; background: none; border: none; }
ul { list-style: none; }

/* ═══ CUSTOM PROPERTIES ═══ */
:root {
  --cream: #F5F0E8;
  --cream-light: #FAF8F4;
  --cream-dark: #EDE7DB;
  --white: #FDFCFA;
  --brown-900: #2C1810;
  --brown-800: #3D2518;
  --brown-700: #4A3228;
  --brown-600: #5E443A;
  --brown-500: #7A6258;
  --brown-400: #9E8A80;
  --brown-300: #C4B5AB;
  --brown-200: #DDD3CA;
  --brown-100: #EDE7E0;
  --accent: #5A2628;
  --accent-dark: #481E20;
  --accent-light: #835C5D;
  --dark-bg: #1E1B18;
  --dark-card: #2A2622;

  --font-display: 'Cormorant Garamond', 'Georgia', serif;
  --font-body: 'DM Sans', 'Helvetica Neue', sans-serif;

  --text-xs: clamp(0.6875rem, 0.65rem + 0.15vw, 0.75rem);
  --text-sm: clamp(0.8125rem, 0.78rem + 0.15vw, 0.875rem);
  --text-base: clamp(0.9375rem, 0.9rem + 0.2vw, 1rem);
  --text-lg: clamp(1.0625rem, 1rem + 0.4vw, 1.25rem);
  --text-xl: clamp(1.375rem, 1.1rem + 0.8vw, 1.75rem);
  --text-2xl: clamp(1.75rem, 1.3rem + 1.5vw, 2.75rem);
  --text-3xl: clamp(2.25rem, 1.5rem + 2.5vw, 3.75rem);
  --text-hero: clamp(2.75rem, 1rem + 5.5vw, 5.5rem);
  --text-display: clamp(3.5rem, 1.5rem + 6vw, 7rem);

  --radius: 6px;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --transition: 300ms var(--ease-out);
}

/* ═══ BASE ═══ */
body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--brown-600);
  background: var(--cream);
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 400;
  line-height: 1.1;
  color: var(--brown-900);
}

p { max-width: 60ch; }

::selection {
  background: rgba(90, 38, 40, 0.15);
  color: var(--brown-900);
}

/* ═══ NAV ═══ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 1.25rem clamp(1.5rem, 3vw, 3rem);
  display: flex; justify-content: space-between; align-items: center;
  background: rgba(245, 240, 232, 0.88);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(0,0,0,0.04);
  transition: padding var(--transition), background var(--transition);
}
.nav.scrolled { padding: 0.75rem clamp(1.5rem, 3vw, 3rem); }
.nav-logo {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-style: italic;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--brown-900);
}
.nav-links { display: flex; gap: 2.25rem; align-items: center; }
.nav-links a {
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brown-500);
  transition: color var(--transition);
  position: relative;
}
.nav-links a:hover { color: var(--brown-900); }
.nav-links a::after {
  content: ''; position: absolute; bottom: -4px; left: 0;
  width: 0; height: 1px; background: var(--brown-900);
  transition: width var(--transition);
}
.nav-links a:hover::after { width: 100%; }
.nav-links a.active { color: var(--brown-900); }
.nav-links a.active::after { width: 100%; }
.nav-cta {
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.625rem 1.5rem;
  background: var(--accent);
  color: var(--cream-light);
  border-radius: 6px;
  transition: background var(--transition);
  display: inline-block;
}
.nav-cta:hover { background: var(--accent-dark); }

/* Breadcrumb */
.breadcrumb {
  font-size: var(--text-xs);
  font-weight: 400;
  letter-spacing: 0.06em;
  color: var(--brown-400);
}
.breadcrumb a {
  color: var(--brown-500);
  transition: color var(--transition);
}
.breadcrumb a:hover { color: var(--brown-900); }
.breadcrumb span { color: var(--brown-300); margin: 0 0.5rem; }

/* Mobile menu */
.hamburger {
  display: none; flex-direction: column; gap: 5px;
  width: 24px; padding: 0;
}
.hamburger span {
  display: block; height: 1.5px; background: var(--brown-900);
  transition: transform var(--transition), opacity var(--transition);
  transform-origin: center;
}
.hamburger.active span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity: 0; }
.hamburger.active span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

.nav-mobile {
  display: none; position: fixed; inset: 0; z-index: 99;
  background: var(--cream);
  flex-direction: column; justify-content: center; align-items: center; gap: 2rem;
}
.nav-mobile.open { display: flex; }
.nav-mobile a {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-style: italic;
  color: var(--brown-900);
  transition: color var(--transition);
}
.nav-mobile a:hover { color: var(--accent); }
.nav-mobile .mobile-cta {
  margin-top: 1rem;
  font-family: var(--font-body);
  font-style: normal;
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.875rem 2.5rem;
  background: var(--accent);
  color: var(--cream-light);
}

@media (max-width: 900px) {
  .nav-links, .nav-cta { display: none; }
  .hamburger { display: flex; }
}

/* ═══ IMAGE STYLES ═══ */
.img-cover {
  width: 100%;
  height: auto;
  display: block;
}
.absolute .img-cover,
.absolute .photo-frame,
.absolute .photo-frame .img-cover {
  height: 100%;
  object-fit: cover;
}
/* Hero: photo-frame muss den ganzen Container ausfüllen */
section.relative .photo-frame.absolute {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.photo-frame {
  overflow: hidden;
  position: relative;
}
.photo-frame img {
  transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
}
.photo-frame:hover img {
  transform: scale(1.03);
}

/* Chapter label */
.chapter-label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--accent);
}

/* Decorative divider */
.divider-dots {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  padding: 2rem 0;
}
.divider-dots span {
  width: 4px; height: 4px;
  background: var(--brown-300);
  border-radius: 50%;
}

/* Fade-in on scroll */
.fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out);
}
.fade-up.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ═══ CHAPTER SIDEBAR NAV ═══ */
.chapter-sidebar {
  position: fixed;
  left: 2rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 50;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.chapter-sidebar a {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.chapter-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--brown-300);
  transition: all var(--transition);
  flex-shrink: 0;
}
.chapter-dot.active {
  background: var(--accent);
  transform: scale(1.5);
}
.chapter-sidebar a:hover .chapter-dot {
  background: var(--accent-light);
  transform: scale(1.3);
}
.chapter-sidebar-label {
  font-size: 0.625rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--brown-400);
  opacity: 0;
  transition: opacity var(--transition);
  white-space: nowrap;
  font-family: var(--font-body);
  font-weight: 500;
}
.chapter-sidebar a:hover .chapter-sidebar-label {
  opacity: 1;
}

@media (max-width: 1100px) {
  .chapter-sidebar { display: none; }
}

/* ═══ QUOTE BLOCK ═══ */
.quote-block {
  padding: 3rem 2.5rem;
  background: var(--white);
  position: relative;
}
.quote-block::before {
  content: '„';
  font-family: var(--font-display);
  font-size: 5rem;
  font-style: italic;
  color: var(--accent);
  opacity: 0.3;
  position: absolute;
  top: 0.5rem;
  left: 1.5rem;
  line-height: 1;
}
.quote-block.text-center::before {
  content: none;
}
.quote-block p {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-style: italic;
  line-height: 1.6;
  color: var(--brown-700);
  max-width: none;
}

/* Dark quote */
.quote-block-dark {
  background: var(--dark-card);
}
.quote-block-dark::before {
  color: var(--accent-light);
}
.quote-block-dark p {
  color: var(--cream-dark);
}

/* ═══ STICKY TEXT LAYOUT ═══ */
.sticky-text {
  position: sticky;
  top: 8rem;
  align-self: start;
}

/* ═══ BENTO GRID ═══ */
.bento-grid {
  display: grid;
  gap: 0.75rem;
}

/* ═══ DARK SECTION ═══ */
.dark-section {
  background: var(--dark-bg);
  color: var(--cream);
}
.dark-section h2,
.dark-section h3,
.dark-section h4 {
  color: var(--cream);
}
.dark-section p {
  color: var(--brown-300);
}
.dark-section .chapter-label {
  color: var(--accent-light);
}

/* ═══ CTA SECTION ═══ */
.btn-primary {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 1rem 2.5rem;
  background: var(--accent);
  color: var(--cream-light);
  border-radius: var(--radius);
  transition: background var(--transition), transform 0.2s ease;
}
.btn-primary:hover { background: var(--accent-dark); transform: translateY(-1px); }
.btn-ghost {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 1rem 2rem;
  border: 1px solid var(--brown-300);
  color: var(--brown-600);
  border-radius: var(--radius);
  transition: all var(--transition);
}
.btn-ghost:hover { border-color: var(--brown-900); color: var(--brown-900); }

/* ═══ FOOTER ═══ */
.footer {
  background: var(--dark-bg);
  color: var(--brown-400);
  padding: 4rem clamp(1.5rem, 5vw, 6rem) 2rem;
}
.footer-inner {
  max-width: 1240px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 2rem;
}
.footer-brand {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xl);
  color: var(--cream);
  margin-bottom: 0.5rem;
}
.footer-tagline {
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brown-500);
  max-width: 280px;
  line-height: 1.6;
}
.footer-links { display: flex; gap: 3rem; }
.footer-col h4 {
  font-size: var(--text-xs);
  font-family: var(--font-body);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brown-300);
  margin-bottom: 0.75rem;
}
.footer-col a {
  display: block;
  font-size: var(--text-sm);
  color: var(--brown-500);
  margin-bottom: 0.375rem;
  transition: color var(--transition);
}
.footer-col a:hover { color: var(--cream); }
.footer-bottom {
  max-width: 1240px;
  margin: 3rem auto 0;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(255,255,255,0.06);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}
@media (max-width: 768px) {
  .footer-inner { flex-direction: column; }
  .footer-links { flex-wrap: wrap; gap: 1.5rem 2rem; }
  .footer-col { min-width: 120px; }
  .footer-bottom { flex-direction: column; text-align: center; }
}
.footer-copy {
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brown-500);
}
.footer-bottom a {
  font-size: var(--text-xs);
  color: var(--brown-500);
  transition: color var(--transition);
}
.footer-bottom a:hover { color: var(--cream); }

/* ═══ MASONRY ═══ */
.masonry-3 {
  columns: 3;
  column-gap: 0.75rem;
}
.masonry-3 .photo-frame {
  break-inside: avoid;
  margin-bottom: 0.75rem;
}
@media (max-width: 768px) {
  .masonry-3 { columns: 2; }
}
@media (max-width: 480px) {
  .masonry-3 { columns: 1; }
}

/* ═══ RESPONSIVE ═══ */
@media (max-width: 768px) {
  .grid-12-desktop {
    grid-template-columns: 1fr !important;
  }
  .sticky-text {
    position: relative;
    top: auto;
  }
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

@media (max-width: 900px) {
  nav.nav {
    padding: 1rem clamp(1.25rem, 6vw, 1.75rem);
    background: rgba(250, 248, 244, 0.94);
    border-bottom: 1px solid rgba(44, 24, 16, 0.07);
  }

  nav.nav.scrolled {
    padding: 0.875rem clamp(1.25rem, 6vw, 1.75rem);
  }

  nav.nav .nav-logo {
    font-size: clamp(1.45rem, 7vw, 2rem);
    line-height: 1;
  }

  nav.nav .hamburger {
    position: relative;
    width: 2.75rem;
    height: 2.75rem;
    flex-direction: initial;
    align-items: center;
    justify-content: center;
    gap: 0;
    border: 1px solid rgba(44, 24, 16, 0.14);
    border-radius: 50%;
    transition: border-color var(--transition), background var(--transition);
  }

  nav.nav .hamburger span {
    position: absolute;
    left: 50%;
    width: 1.2rem;
    height: 1px;
    background: var(--brown-900);
    transform: translateX(-50%);
  }

  nav.nav .hamburger span:nth-child(1) { top: 0.95rem; }
  nav.nav .hamburger span:nth-child(2) { top: 1.35rem; }
  nav.nav .hamburger span:nth-child(3) { top: 1.75rem; }
  nav.nav .hamburger.active { border-color: rgba(90, 38, 40, 0.22); background: rgba(90, 38, 40, 0.05); }
  nav.nav .hamburger.active span:nth-child(1) { top: 50%; transform: translate(-50%, -50%) rotate(45deg); }
  nav.nav .hamburger.active span:nth-child(2) { opacity: 0; transform: translate(-50%, -50%) scaleX(0.35); }
  nav.nav .hamburger.active span:nth-child(3) { top: 50%; transform: translate(-50%, -50%) rotate(-45deg); }

  body .nav-mobile {
    display: flex;
    position: fixed;
    inset: 0;
    z-index: 99;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    gap: 0;
    padding: clamp(5.75rem, 14vh, 6.85rem) clamp(1.25rem, 7vw, 2rem) max(1.5rem, env(safe-area-inset-bottom));
    overflow-y: auto;
    background: var(--cream-light);
    border-top: 1px solid rgba(44, 24, 16, 0.06);
    counter-reset: mobile-nav;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-0.75rem);
    transition: opacity 260ms var(--ease-out), visibility 260ms var(--ease-out), transform 360ms var(--ease-out);
  }

  body .nav-mobile.open {
    display: flex;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }

  body .nav-mobile a {
    width: min(100%, 34rem);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 2.5rem 1fr;
    align-items: baseline;
    padding: 0.78rem 0;
    border-bottom: 1px solid rgba(122, 98, 88, 0.16);
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 8vw, 2.75rem);
    font-style: normal;
    font-weight: 300;
    line-height: 1;
    color: var(--brown-900);
    letter-spacing: 0;
    text-align: left;
    transition: color var(--transition), transform var(--transition), border-color var(--transition);
  }

  body .nav-mobile a::before {
    counter-increment: mobile-nav;
    content: "0" counter(mobile-nav);
    align-self: start;
    padding-top: 0.22rem;
    font-family: var(--font-body);
    font-size: 0.62rem;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.16em;
    color: var(--brown-400);
  }

  body .nav-mobile a:hover,
  body .nav-mobile a:focus-visible {
    color: var(--accent);
    border-color: rgba(90, 38, 40, 0.26);
    transform: translateX(0.2rem);
  }

  body .nav-mobile .mobile-cta {
    width: min(100%, 21rem);
    grid-template-columns: 1fr;
    justify-items: center;
    margin-top: clamp(1.25rem, 4vh, 2rem);
    padding: 0.95rem 1.5rem;
    border: 1px solid var(--accent);
    border-radius: 4px;
    background: var(--accent);
    color: var(--cream-light);
    font-family: var(--font-body);
    font-size: 0.72rem;
    font-style: normal;
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0.16em;
    text-align: center;
    text-transform: uppercase;
    box-shadow: 0 14px 34px rgba(44, 24, 16, 0.12);
  }

  body .nav-mobile .mobile-cta::before {
    content: none;
  }

  body .nav-mobile .mobile-cta:hover,
  body .nav-mobile .mobile-cta:focus-visible {
    background: var(--accent-dark);
    color: var(--cream-light);
    transform: translateY(-1px);
  }
}

.reportage-ee .photo-frame {
  overflow: hidden;
}

.reportage-ee .photo-frame img,
.reportage-ee .img-cover {
  width: 100%;
  height: auto !important;
  object-fit: contain !important;
  display: block;
  transform: none !important;
  transition: none !important;
}

.reportage-ee .hero-shell {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.reportage-ee .hero-shell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  max-width: none;
  max-height: none;
}

.reportage-ee .hero-copy {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  z-index: 2;
  text-align: center;
}

.reportage-ee .hero-copy-inner {
  max-width: min(92vw, 860px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding: clamp(1.25rem, 2.8vw, 2.25rem) clamp(1.5rem, 4vw, 3rem);
}

.reportage-ee .hero-kicker,
.reportage-ee .hero-meta,
.reportage-ee .hero-title,
.reportage-ee .hero-subtitle {
  text-shadow: 0 2px 18px rgba(0,0,0,0.48);
}

.reportage-ee .hero-kicker {
  font-size: clamp(0.72rem, 0.8vw, 0.9rem);
  letter-spacing: 0.42em;
  text-transform: uppercase;
  color: rgba(250,248,244,0.86);
}

.reportage-ee .hero-title {
  font-size: clamp(4.5rem, 8vw, 7.25rem);
  line-height: 0.88;
  letter-spacing: -0.03em;
  margin: 0;
}

.reportage-ee .hero-subtitle {
  max-width: 24ch;
  font-size: clamp(1.4rem, 2vw, 2.15rem);
  line-height: 1.28;
  color: rgba(255,255,255,0.96);
  margin: 0;
}

.reportage-ee .hero-divider {
  width: 4.5rem;
  height: 1px;
  background: rgba(255,255,255,0.52);
}

.reportage-ee .hero-meta {
  width: 100%;
  max-width: 46rem;
  font-size: clamp(0.72rem, 0.8vw, 0.9rem);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgba(250,248,244,0.76);
  margin: 0;
  text-align: center;
  line-height: 1.5;
  text-wrap: balance;
}

.reportage-ee .section-copy p + p {
  margin-top: 1rem;
}

.reportage-ee .single-photo {
  max-width: 860px;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .reportage-ee .hero-copy {
    padding: 1.25rem;
  }
}

.wa-sticky{position:fixed;bottom:1.25rem;right:1.25rem;z-index:90;width:52px;height:52px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.18);transition:transform .3s,opacity .3s;opacity:0;transform:scale(.8);pointer-events:none}
.wa-sticky.visible{opacity:1;transform:scale(1);pointer-events:auto}
.wa-sticky:hover{transform:scale(1.08)}
.wa-sticky svg{width:26px;height:26px;fill:#fff}
