
:root{
  --paper:#f4efe7;
  --paper-2:#ebe1d4;
  --ink:#171310;
  --muted:#6d6259;
  --espresso:#241b16;
  --wine:#5b2828;
  --copper:#a67654;
  --border:rgba(36,27,22,.16);
  --white:#fffaf2;
}

*{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:Inter, Manrope, Arial, sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
}

a{color:inherit;text-decoration:none}

img{max-width:100%;display:block}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:22px clamp(20px,5vw,76px);
  background:rgba(244,239,231,.88);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}

.logo{
  font-family:Georgia,'Times New Roman',serif;
  font-size:24px;
  letter-spacing:-.04em;
}

.nav{
  display:flex;
  align-items:center;
  gap:22px;
  font-size:14px;
}

.nav a{color:rgba(23,19,16,.78)}

.lang-toggle{
  border:1px solid var(--border);
  background:transparent;
  border-radius:999px;
  padding:8px 11px;
  cursor:pointer;
  color:var(--ink);
}

.section{
  padding:clamp(66px,9vw,122px) clamp(20px,7vw,98px);
}

.hero{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(330px,.78fr);
  gap:clamp(38px,7vw,92px);
  align-items:center;
  min-height:86vh;
  padding:clamp(66px,8vw,112px) clamp(20px,7vw,98px);
}

.eyebrow,.label{
  display:block;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:11px;
  color:var(--wine);
  margin-bottom:18px;
}

h1,h2{
  font-family:Georgia,'Times New Roman',serif;
  font-weight:400;
  letter-spacing:-.058em;
  line-height:1.01;
  margin:0 0 24px;
}

h1{font-size:clamp(50px,8.4vw,108px)}
h2{font-size:clamp(36px,5.8vw,76px);max-width:1020px}
h3{font-size:24px;margin:0 0 10px}

.lead{
  max-width:720px;
  font-size:clamp(18px,2.1vw,25px);
  color:rgba(23,19,16,.72);
  margin:0;
}

.hero-visual{
  position:relative;
  min-height:600px;
}

.hero-visual img,.page-photo{
  width:100%;
  height:100%;
  min-height:520px;
  object-fit:cover;
  border-radius:36px;
  box-shadow:0 34px 92px rgba(36,27,22,.19);
  filter:saturate(.86) contrast(.96) sepia(.08);
}

.editor-note{
  position:absolute;
  left:-34px;
  bottom:32px;
  width:min(350px,88%);
  padding:25px;
  background:rgba(255,250,242,.93);
  backdrop-filter:blur(14px);
  border:1px solid var(--border);
  border-radius:28px;
}

.editor-note p{
  margin:0;
  font-family:Georgia,'Times New Roman',serif;
  font-size:22px;
  line-height:1.25;
}

.cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:32px;
}

.btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  min-height:54px;
  padding:15px 25px;
  border-radius:999px;
  border:1px solid var(--espresso);
  font-weight:650;
  transition:.18s ease;
}

.btn.primary{background:var(--espresso);color:var(--white)}
.btn.secondary{background:transparent;color:var(--espresso)}
.btn:hover{transform:translateY(-1px);box-shadow:0 14px 34px rgba(36,27,22,.13)}

.microcopy{
  margin-top:18px;
  font-size:14px;
  color:rgba(23,19,16,.58);
}

.dark-band{
  background:var(--espresso);
  color:var(--white);
}

.dark-band .eyebrow,.dark-band .label{color:var(--copper)}
.dark-band .lead{color:rgba(255,250,242,.74)}

.two-col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:36px;
}

.statement-card{
  border:1px solid rgba(255,250,242,.16);
  border-radius:34px;
  padding:32px;
  min-height:240px;
}

.statement-card.light{
  background:var(--white);
  border:1px solid var(--border);
}

.statement-card p{
  font-family:Georgia,'Times New Roman',serif;
  font-size:clamp(24px,3.2vw,38px);
  line-height:1.12;
  margin:0;
}

.edit-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
  margin-top:38px;
}

.edit-card{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:34px;
  overflow:hidden;
}

.edit-card img{
  width:100%;
  height:285px;
  object-fit:cover;
  filter:saturate(.82) contrast(.95) sepia(.07);
}

.edit-card .content{
  padding:26px;
}

.edit-card p,.product-card p,.quiz-copy{
  color:rgba(23,19,16,.68);
}

.products{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
  margin-top:38px;
}

.product-card{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:34px;
  padding:30px;
}

.price{
  font-family:Georgia,'Times New Roman',serif;
  font-size:44px;
  margin:18px 0 8px;
}

.quiz-wrap{
  display:grid;
  grid-template-columns:minmax(0,.85fr) minmax(0,1fr);
  gap:40px;
  align-items:start;
}

.quiz{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:34px;
  padding:28px;
}

.quiz-step{display:none}
.quiz-step.active{display:grid;gap:12px}

.option{
  display:grid;
  grid-template-columns:28px 1fr;
  align-items:center;
  gap:12px;
  padding:17px;
  border:1px solid var(--border);
  border-radius:20px;
  background:#fffdf9;
  cursor:pointer;
}

.option input{display:none}

.dot{
  width:16px;
  height:16px;
  border:1px solid var(--wine);
  border-radius:50%;
}

.option input:checked + .dot{
  background:var(--wine);
  box-shadow:inset 0 0 0 4px #fffdf9;
}

.option:hover{border-color:rgba(91,40,40,.44)}

.preview{
  display:none;
  margin-top:22px;
  background:#fffdf9;
  border:1px solid var(--border);
  border-radius:26px;
  padding:24px;
}

.preview.visible{display:block}

.locked-list{
  list-style:none;
  padding:0;
  margin:20px 0 0;
}

.locked-list li{
  border-bottom:1px solid var(--border);
  padding:12px 0;
  color:rgba(23,19,16,.68);
}

.split-page{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(330px,.78fr);
  gap:clamp(38px,7vw,88px);
  align-items:center;
  min-height:80vh;
}

.footer{
  display:flex;
  justify-content:space-between;
  gap:24px;
  padding:44px clamp(20px,7vw,98px);
  border-top:1px solid var(--border);
  color:rgba(23,19,16,.58);
}

.shake{animation:shake .34s ease}
@keyframes shake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-4px)}
  75%{transform:translateX(4px)}
}

@media (max-width: 940px){
  .hero,.two-col,.edit-grid,.products,.quiz-wrap,.split-page{
    grid-template-columns:1fr;
  }
  .hero-visual{min-height:auto}
  .hero-visual img,.page-photo{min-height:390px}
  .editor-note{position:relative;left:auto;bottom:auto;margin-top:-70px}
}

@media (max-width: 760px){
  .nav a{display:none}
  h1{font-size:clamp(44px,13vw,64px)}
  .section,.hero{padding-left:20px;padding-right:20px}
  .footer{flex-direction:column}
}
