*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

body{
  background:#FFF8F0;
  color:#2D2A33;
  font-family:'Work Sans',sans-serif;
  font-weight:400;
  font-size:clamp(1rem,1.2vw,1.15rem);
  line-height:1.72;
  letter-spacing:0.01em;
  overflow-x:hidden;
  position:relative;
}

body::after{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:9999;
  opacity:0.035;
  mix-blend-mode:multiply;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.65' numOctaves='3'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Scroll indicator */
.scroll-indicator{
  position:fixed;
  right:16px;
  top:50%;
  transform:translateY(-50%);
  z-index:100;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.indicator-dot{
  width:10px;
  height:10px;
  border:1.5px solid #C4A0A0;
  border-radius:50%;
  background:transparent;
  cursor:pointer;
  transition:background 0.3s ease;
}
.indicator-dot.active{
  background:#C4A0A0;
}

/* Spreads */
.spread{
  position:relative;
  overflow:hidden;
  padding:0 4vw;
}
.spread-inner{
  display:grid;
  grid-template-columns:1fr 2vw 1fr;
  max-width:1200px;
  margin:0 auto;
  min-height:inherit;
  align-items:center;
}

/* Spread numerals */
.spread-numeral{
  position:absolute;
  font-family:'Syne',sans-serif;
  font-weight:800;
  font-size:15vw;
  color:#B8E6D0;
  opacity:0;
  pointer-events:none;
  z-index:0;
  line-height:1;
}
.spread-numeral.visible{
  opacity:0.15;
  transition:opacity 1.2s linear;
}
.numeral-light{
  color:#F5F0E8;
}

/* Registration marks */
.reg-mark{
  position:absolute;
  width:8px;
  height:8px;
  font-size:10px;
  line-height:1;
  color:#C4A0A0;
  opacity:0.4;
  font-family:'Work Sans',sans-serif;
  z-index:1;
}
.reg-tl{top:12px;left:12px}
.reg-tr{top:12px;right:12px}
.reg-bl{bottom:12px;left:12px}
.reg-br{bottom:12px;right:12px}

/* Gutter shadow */
.gutter-shadow{
  position:absolute;
  top:0;
  bottom:0;
  left:50%;
  width:2vw;
  transform:translateX(-50%);
  background:linear-gradient(90deg,transparent,rgba(0,0,0,0.04),transparent);
  z-index:0;
  pointer-events:none;
}

/* Geometric divider */
.geometric-divider{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding:24px 0;
}
.divider-shape{
  color:#C4A0A0;
  font-size:8px;
}
.divider-line{
  width:40px;
  height:1px;
  background:#C4A0A0;
  display:block;
  transform:scaleX(0);
}
.divider-line.visible{
  transform:scaleX(1);
  transition:transform 0.8s cubic-bezier(0.34,1.56,0.64,1);
}

/* -------- SPREAD 01: COVER -------- */
.spread-cover{
  min-height:100vh;
  display:flex;
  align-items:center;
}
.spread-cover .spread-numeral{
  top:5vh;
  left:3vw;
}
.cover-left{
  padding-right:2vw;
}
.cover-title{
  font-family:'Josefin Sans',sans-serif;
  font-weight:700;
  font-size:clamp(2.8rem,8vw,7rem);
  letter-spacing:0.06em;
  line-height:1.1;
  text-transform:uppercase;
  color:#2D2A33;
}
.cover-rule{
  width:100%;
  height:1px;
  background:#C4A0A0;
  margin:clamp(20px,3vw,40px) 0;
}
.cover-tagline{
  font-family:'Darker Grotesque',sans-serif;
  font-weight:500;
  font-size:clamp(0.9rem,1.5vw,1.2rem);
  letter-spacing:0.04em;
  text-transform:uppercase;
  color:#6B5C7A;
}
.cover-right{
  display:flex;
  align-items:center;
  justify-content:center;
}
.geo-composition{
  position:relative;
  width:clamp(200px,30vw,420px);
  height:clamp(200px,30vw,420px);
}
.geo-shape{
  position:absolute;
  mix-blend-mode:multiply;
  transition:transform 0.4s cubic-bezier(0.34,1.56,0.64,1),fill 0.3s ease;
}
.geo-circle{width:60%;top:0;right:0}
.geo-triangle{width:50%;top:10%;left:5%}
.geo-rect{width:45%;bottom:5%;right:10%}
.geo-circle-sm{width:35%;bottom:15%;left:15%}
.geo-diamond{width:30%;top:35%;left:35%}

/* -------- SPREAD 02: EDITORIAL -------- */
.spread-editorial{
  min-height:80vh;
  padding-top:6vh;
  padding-bottom:4vh;
}
.spread-editorial .spread-numeral{
  top:3vh;
  right:3vw;
}
.editorial-left{
  padding-right:2vw;
}
.drop-cap-container{
  float:left;
  margin-right:12px;
  margin-bottom:4px;
}
.drop-cap{
  font-family:'Syne',sans-serif;
  font-weight:800;
  font-size:4.5em;
  line-height:0.8;
  color:#FFF8F0;
  background:#D4C5E8;
  width:1.2em;
  height:1.2em;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
}
.body-text{
  margin-bottom:1.25em;
  max-width:48ch;
}
.editorial-right{
  display:flex;
  align-items:center;
  justify-content:center;
}
.nature-panel{
  background:#FFF8F0;
  border:1px solid #C4A0A0;
  border-radius:4px;
  padding:16px;
  max-width:320px;
}
.nature-illustration{
  width:100%;
  height:auto;
  display:block;
  mix-blend-mode:multiply;
}

/* -------- SPREAD 03: PORTFOLIO -------- */
.spread-portfolio{
  min-height:90vh;
  padding-top:6vh;
  padding-bottom:6vh;
}
.spread-portfolio .spread-numeral{
  bottom:4vh;
  left:3vw;
}
.spread-portfolio .spread-inner{
  display:block;
}
.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(12px,2vw,20px);
  max-width:1100px;
  margin:0 auto;
}
.portfolio-panel{
  border-radius:4px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:clamp(20px,3vw,40px);
  mix-blend-mode:multiply;
  opacity:0.9;
}
.panel-motif svg{
  width:60px;
  height:60px;
  display:block;
}
.panel-1{background:#B8E6D0;aspect-ratio:1/1}
.panel-2{background:#D4C5E8;aspect-ratio:1/1.618}
.panel-3{background:#F8D4C2;aspect-ratio:1.618/1}
.panel-4{background:#BDD8E8;aspect-ratio:1/1}
.panel-5{background:#F5E6A3;aspect-ratio:1/1.618}
.panel-6{background:#B8E6D0;aspect-ratio:1.618/1}

/* -------- SPREAD 04: FEATURE -------- */
.spread-feature{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}
.spread-feature .spread-numeral{
  top:5vh;
  right:3vw;
}
.feature-composition{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:0;
}
.feature-outer{
  position:absolute;
  width:min(70vw,600px);
  height:min(70vw,600px);
  border:2px solid #F8D4C2;
  transform:rotate(45deg);
  opacity:0.6;
}
.feature-diamond{
  position:absolute;
  width:min(50vw,430px);
  height:min(50vw,430px);
  border:2px solid #D4C5E8;
  border-radius:12px;
  opacity:0.6;
}
.feature-square{
  position:absolute;
  width:min(35vw,300px);
  height:min(35vw,300px);
  border:2px solid #BDD8E8;
  transform:rotate(45deg);
  opacity:0.6;
}
.feature-circle{
  position:absolute;
  width:min(20vw,180px);
  height:min(20vw,180px);
  border:2px solid #B8E6D0;
  border-radius:50%;
  opacity:0.6;
}
.feature-text{
  position:relative;
  z-index:1;
  text-align:center;
  max-width:44ch;
  padding:0 4vw;
}
.feature-heading{
  font-family:'Josefin Sans',sans-serif;
  font-weight:700;
  font-size:clamp(2rem,5vw,4rem);
  letter-spacing:0.03em;
  line-height:1.1;
  margin-bottom:1em;
  color:#2D2A33;
}
.feature-body{
  max-width:44ch;
  margin:0 auto;
}

/* -------- SPREAD 05: DETAIL -------- */
.spread-detail{
  min-height:70vh;
  padding-top:6vh;
  padding-bottom:6vh;
}
.spread-detail .spread-numeral{
  top:3vh;
  left:3vw;
}
.spread-detail .spread-inner{
  display:block;
}
.qa-grid{
  max-width:800px;
  margin:0 auto;
}
.qa-item{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(16px,3vw,32px);
  padding:clamp(16px,3vw,32px) 0;
}
.qa-question{
  font-family:'Josefin Sans',sans-serif;
  font-weight:700;
  font-size:clamp(1rem,1.5vw,1.2rem);
  letter-spacing:0.02em;
  color:#2D2A33;
}
.qa-answer{
  font-family:'Work Sans',sans-serif;
  font-weight:400;
  color:#6B5C7A;
  line-height:1.72;
}
.qa-divider{
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  padding:4px 0;
}
.qa-divider::before,
.qa-divider::after{
  content:'';
  flex:1;
  height:1px;
  background:#C4A0A0;
}
.qa-shape{
  margin:0 12px;
  color:#C4A0A0;
  font-size:8px;
}

/* -------- SPREAD 06: COLOPHON -------- */
.spread-colophon{
  min-height:60vh;
  background:#3A3640;
  color:#F5F0E8;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding-top:6vh;
  padding-bottom:6vh;
}
.spread-colophon .spread-numeral{
  top:4vh;
  left:3vw;
}
.colophon-mark{
  margin-bottom:clamp(24px,4vw,48px);
}
.colophon-mark svg{
  width:clamp(60px,10vw,100px);
  height:clamp(60px,10vw,100px);
  display:block;
}
.colophon-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(20px,4vw,48px);
  max-width:600px;
  width:100%;
  text-align:center;
}
.colophon-heading{
  font-family:'Darker Grotesque',sans-serif;
  font-weight:500;
  font-size:clamp(0.85rem,1.2vw,1rem);
  letter-spacing:0.04em;
  text-transform:uppercase;
  color:#F5F0E8;
  margin-bottom:12px;
}
.colophon-text{
  font-family:'Work Sans',sans-serif;
  font-size:0.8rem;
  line-height:1.8;
  color:#F5F0E8;
  opacity:0.6;
}

/* --- Spring animation states --- */
.spread .geo-shape,
.spread .portfolio-panel,
.spread .feature-outer,
.spread .feature-diamond,
.spread .feature-square,
.spread .feature-circle,
.spread .nature-panel,
.spread .drop-cap-container,
.spread .colophon-mark,
.spread .colophon-grid{
  opacity:0;
  transform:scale(0);
}
.spread .body-text,
.spread .cover-title,
.spread .cover-tagline,
.spread .cover-rule,
.spread .qa-item,
.spread .feature-text{
  opacity:0;
  transform:translateY(30px);
}

.spread.revealed .geo-shape,
.spread.revealed .portfolio-panel,
.spread.revealed .feature-outer,
.spread.revealed .feature-diamond,
.spread.revealed .feature-square,
.spread.revealed .feature-circle,
.spread.revealed .nature-panel,
.spread.revealed .drop-cap-container,
.spread.revealed .colophon-mark,
.spread.revealed .colophon-grid{
  opacity:1;
  transform:scale(1);
  transition:opacity 0.5s cubic-bezier(0.34,1.56,0.64,1),transform 0.5s cubic-bezier(0.34,1.56,0.64,1);
}
.spread.revealed .body-text,
.spread.revealed .cover-title,
.spread.revealed .cover-tagline,
.spread.revealed .cover-rule,
.spread.revealed .qa-item,
.spread.revealed .feature-text{
  opacity:1;
  transform:translateY(0);
  transition:opacity 0.6s cubic-bezier(0.34,1.56,0.64,1),transform 0.6s cubic-bezier(0.34,1.56,0.64,1);
}

/* Stagger delays */
.spread.revealed .geo-shape:nth-child(1){transition-delay:0ms}
.spread.revealed .geo-shape:nth-child(2){transition-delay:80ms}
.spread.revealed .geo-shape:nth-child(3){transition-delay:160ms}
.spread.revealed .geo-shape:nth-child(4){transition-delay:240ms}
.spread.revealed .geo-shape:nth-child(5){transition-delay:320ms}

.spread.revealed .portfolio-panel:nth-child(1){transition-delay:0ms}
.spread.revealed .portfolio-panel:nth-child(2){transition-delay:80ms}
.spread.revealed .portfolio-panel:nth-child(3){transition-delay:160ms}
.spread.revealed .portfolio-panel:nth-child(4){transition-delay:240ms}
.spread.revealed .portfolio-panel:nth-child(5){transition-delay:320ms}
.spread.revealed .portfolio-panel:nth-child(6){transition-delay:400ms}

.spread.revealed .qa-item:nth-child(1){transition-delay:0ms}
.spread.revealed .qa-item:nth-child(3){transition-delay:150ms}
.spread.revealed .qa-item:nth-child(5){transition-delay:300ms}

.spread.revealed .cover-title{transition-delay:0ms}
.spread.revealed .cover-rule{transition-delay:200ms}
.spread.revealed .cover-tagline{transition-delay:350ms}

.divider-line{
  transition:transform 0.8s cubic-bezier(0.34,1.56,0.64,1);
  transform-origin:center;
}

/* Nature elements bloom */
.spread .nature-illustration ellipse,
.spread .nature-illustration circle{
  opacity:0;
  transform:rotate(-15deg) scale(0.8);
  transform-origin:center;
  transition:opacity 0.5s cubic-bezier(0.34,1.56,0.64,1),transform 0.5s cubic-bezier(0.34,1.56,0.64,1);
}
.spread.revealed .nature-illustration ellipse,
.spread.revealed .nature-illustration circle{
  opacity:1;
  transform:rotate(0) scale(1);
}

/* Geo hover */
.geo-shape:hover{
  transform:rotate(4deg) !important;
  cursor:default;
}

/* -------- MOBILE -------- */
@media(max-width:768px){
  .spread-inner{
    grid-template-columns:1fr;
    gap:24px;
  }
  .gutter-shadow{display:none}
  .cover-left{padding-right:0}
  .editorial-left{padding-right:0}
  .spread{padding:0 8vw}
  .spread-numeral{font-size:8vw}
  .qa-item{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr 1fr}
  .colophon-grid{grid-template-columns:1fr}
  .scroll-indicator{right:8px}
}

@media(max-width:480px){
  .portfolio-grid{grid-template-columns:1fr}
  .cover-title{font-size:clamp(2rem,10vw,3.5rem)}
}
