/* ═══════════════════════════════════════════════════════════
   LOTELITO — Rooms & Pool
   Quiet Luxury / Architectural Editorial — 2025 redesign
   ═══════════════════════════════════════════════════════════ */

:root {
  /* palette */
  --bone:       #ece3d3;
  --bone-soft:  #f3ecdf;
  --bone-deep:  #e2d7c2;
  --ink:        #17150f;
  --ink-soft:   #221f17;
  --ink-mut:    #6f6859;
  --clay:       #c2683d;
  --clay-deep:  #a9512c;
  --clay-light: #d98a5f;
  --sand:       #d6c9b0;
  --green:      #6f7a52;
  --line:       rgba(23,21,15,.14);
  --line-soft:  rgba(23,21,15,.08);
  --line-light: rgba(236,227,211,.16);

  /* type */
  --serif: 'Fraunces', Georgia, serif;
  --sans:  'Inter', system-ui, sans-serif;
  --mono:  'Space Grotesk', monospace;

  /* motion */
  --ease: cubic-bezier(.22,1,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  --pad: clamp(20px, 5vw, 90px);
  --maxw: 1480px;
}

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

html { font-size: 16px; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; overflow-x: hidden; }
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }

body {
  font-family: var(--sans);
  background: var(--bone);
  color: var(--ink);
  line-height: 1.55;
  overflow-x: hidden;
  font-weight: 400;
}

a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
img { max-width: 100%; display: block; }
button, input, select, textarea { font-family: inherit; color: inherit; }
::selection { background: var(--clay); color: var(--bone-soft); }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad); }
.section { padding: clamp(80px, 12vh, 180px) 0; position: relative; }
.accent { color: var(--clay); }
.it { font-style: italic; }
.green { color: var(--green); }

/* hide native cursor on fine pointers when custom cursor active */
@media (hover: hover) and (pointer: fine) {
  body.has-cursor, body.has-cursor * { cursor: none; }
}

/* ═══════════ GRAIN ═══════════ */
.grain {
  position: fixed; inset: 0; z-index: 9000; pointer-events: none;
  opacity: .045; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px 200px;
  animation: grain 5s steps(6) infinite;
}
@keyframes grain {
  0%,100%{background-position:0 0} 16%{background-position:-20px 20px} 33%{background-position:16px -24px}
  50%{background-position:-24px 12px} 66%{background-position:20px 16px} 83%{background-position:-12px -20px}
}

/* ═══════════ CUSTOM CURSOR ═══════════ */
.cursor { position: fixed; top: 0; left: 0; z-index: 9999; pointer-events: none; mix-blend-mode: difference; }
.cursor-dot {
  position: fixed; top: 0; left: 0; width: 7px; height: 7px; border-radius: 50%;
  background: #fff; transform: translate(-50%,-50%);
}
.cursor-ring {
  position: fixed; top: 0; left: 0; width: 40px; height: 40px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,.7); transform: translate(-50%,-50%);
  display: grid; place-items: center;
  transition: width .35s var(--ease), height .35s var(--ease), background .35s var(--ease), border-color .35s var(--ease);
}
.cursor-label {
  font-family: var(--mono); font-size: 9px; letter-spacing: .08em; text-transform: uppercase;
  color: #fff; opacity: 0; transition: opacity .25s; white-space: nowrap;
}
body.cur-hover .cursor-ring { width: 64px; height: 64px; background: rgba(255,255,255,.08); }
body.cur-view .cursor-ring { width: 92px; height: 92px; background: rgba(255,255,255,.12); border-color: transparent; }
body.cur-view .cursor-label { opacity: 1; }
body.cur-text .cursor-ring { width: 4px; height: 30px; border-radius: 2px; background: #fff; border: none; }
body.cur-text .cursor-dot { opacity: 0; }
@media (hover: none), (pointer: coarse) { .cursor { display: none; } }

/* ═══════════ PRELOADER ═══════════ */
.preloader {
  position: fixed; inset: 0; z-index: 10000; background: var(--ink);
  display: grid; place-items: center; color: var(--bone);
}
.pre-inner { width: min(82vw, 560px); }
.pre-word { font-family: var(--serif); font-weight: 400; font-size: clamp(2.4rem, 9vw, 6rem); line-height: 1; letter-spacing: -.01em; display: flex; overflow: hidden; }
.pre-word span { display: inline-block; transform: translateY(105%); }
.pre-meta { display: flex; justify-content: space-between; align-items: baseline; margin-top: 18px; font-family: var(--mono); font-size: .78rem; letter-spacing: .12em; text-transform: uppercase; color: var(--sand); opacity: 0; }
.pre-bar { margin-top: 14px; height: 1px; background: var(--line-light); overflow: hidden; }
.pre-bar i { display: block; height: 100%; width: 0%; background: var(--clay); }

/* ═══════════ NAV ═══════════ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 800;
  display: flex; align-items: center; justify-content: space-between;
  padding: clamp(16px,2.4vw,30px) var(--pad);
  color: var(--bone);
  transition: background .45s var(--ease), backdrop-filter .45s var(--ease), padding .45s var(--ease), border-color .45s var(--ease);
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(15,13,9,.72);
  backdrop-filter: blur(18px) saturate(1.4);
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
  border-bottom-color: rgba(236,227,211,.1);
  padding-top: 14px; padding-bottom: 14px;
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand-mark {
  width: 34px; height: 34px; border: 1px solid currentColor; border-radius: 50%;
  display: grid; place-items: center; font-family: var(--serif); font-size: 1.05rem; font-style: italic;
}
.brand-name { font-family: var(--mono); font-size: .8rem; font-weight: 600; letter-spacing: .16em; line-height: 1.1; display: flex; flex-direction: column; }
.brand-name em { font-style: normal; font-weight: 400; font-size: .62rem; letter-spacing: .2em; opacity: .65; }
.nav-center { display: flex; gap: clamp(18px,2.4vw,42px); }
.nav-center a { position: relative; font-family: var(--mono); font-size: .78rem; letter-spacing: .08em; text-transform: uppercase; padding: 4px 0; }
.nav-center a::after { content: ''; position: absolute; left: 0; bottom: 0; width: 100%; height: 1px; background: currentColor; transform: scaleX(0); transform-origin: right; transition: transform .45s var(--ease); }
.nav-center a:hover::after, .nav-center a.active::after { transform: scaleX(1); transform-origin: left; }
.nav-cta { display: inline-flex; align-items: center; gap: 10px; font-family: var(--mono); font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; border: 1px solid currentColor; border-radius: 50px; padding: 11px 22px; }
.nav-cta .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--clay); }
.nav-burger { display: none; width: 40px; height: 40px; background: none; border: none; flex-direction: column; gap: 6px; align-items: center; justify-content: center; }
.nav-burger i { display: block; width: 26px; height: 1.5px; background: currentColor; transition: transform .4s var(--ease), opacity .3s; }
.nav.menu-open .nav-burger i:nth-child(1) { transform: translateY(3.75px) rotate(45deg); }
.nav.menu-open .nav-burger i:nth-child(2) { transform: translateY(-3.75px) rotate(-45deg); }

/* fullscreen menu */
.menu {
  position: fixed; inset: 0; z-index: 700; background: var(--ink); color: var(--bone);
  display: grid; place-items: center; clip-path: inset(0 0 100% 0); pointer-events: none;
  overflow: hidden;
}
.menu.open { pointer-events: auto; }
.menu ul { width: 100%; padding: 0 var(--pad); }
.menu li { overflow: hidden; border-top: 1px solid var(--line-light); }
.menu li:last-child { border-bottom: 1px solid var(--line-light); }
.menu a { display: flex; align-items: baseline; gap: 16px; font-family: var(--serif); font-size: clamp(1.7rem,8.5vw,4.6rem); padding: clamp(8px,1.5vw,18px) 0; transform: translateY(110%); }
.menu a span { font-family: var(--mono); font-size: .8rem; color: var(--clay); }
.menu a:hover { color: var(--clay); }

/* ═══════════ BUTTONS ═══════════ */
.btn { position: relative; display: inline-flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; padding: 16px 30px; border-radius: 50px; overflow: hidden; will-change: transform; }
.btn span { position: relative; z-index: 2; transition: color .4s var(--ease); }
.btn-solid { background: var(--ink); color: var(--bone); }
.btn-solid::before { content: ''; position: absolute; inset: 0; background: var(--clay); transform: translateY(101%); transition: transform .5s var(--ease); z-index: 1; }
.btn-solid:hover::before { transform: translateY(0); }
.btn-line { border: 1px solid var(--line); color: var(--ink); }
.btn-line::before { content: ''; position: absolute; inset: 0; background: var(--ink); transform: translateY(101%); transition: transform .5s var(--ease); z-index: 1; }
.btn-line:hover span { color: var(--bone); }
.btn-line:hover::before { transform: translateY(0); }
.btn-block { width: 100%; }

/* ═══════════ SECTION HEADERS ═══════════ */
.sec-head { margin-bottom: clamp(40px,6vw,80px); max-width: 900px; }
.sec-head-row { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; max-width: var(--maxw); flex-wrap: wrap; }
.eyebrow { display: inline-block; font-family: var(--mono); font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; color: var(--clay); margin-bottom: 22px; }
.eyebrow.light { color: var(--clay-light); }
.sec-title { font-family: var(--serif); font-weight: 300; font-size: clamp(2.2rem, 6vw, 5rem); line-height: 1.02; letter-spacing: -.02em; }
.sec-title.light { color: var(--bone); }
.sec-desc { margin-top: 24px; font-size: clamp(1rem,1.4vw,1.18rem); color: var(--ink-mut); max-width: 520px; line-height: 1.65; }
.sec-desc.light { color: var(--sand); }
.sec-desc em { font-style: italic; opacity: .8; }

/* ═══════════ HERO ═══════════ */
.hero { position: relative; height: 100svh; min-height: 640px; overflow: hidden; display: flex; }
.hero-media { position: absolute; inset: 0; z-index: 0; }
.hero-img { width: 100%; height: 120%; object-fit: cover; will-change: transform; }
.hero-canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 1; pointer-events: none; }
.hero-veil { position: absolute; inset: 0; z-index: 2; background:
  linear-gradient(180deg, rgba(13,11,7,.55) 0%, rgba(13,11,7,.12) 32%, rgba(13,11,7,.3) 70%, rgba(13,11,7,.82) 100%); }
.hero-grid {
  position: relative; z-index: 3; width: 100%; max-width: var(--maxw); margin: 0 auto;
  padding: 0 var(--pad); align-self: stretch;
  display: grid; grid-template-rows: 1fr auto auto; gap: 0; color: var(--bone);
  padding-top: 18vh; padding-bottom: 7vh;
}
.hero-eyebrow { font-family: var(--mono); font-size: .8rem; letter-spacing: .14em; text-transform: uppercase; display: flex; align-items: center; gap: 12px; align-self: start; }
.hero-eyebrow .pulse { width: 8px; height: 8px; border-radius: 50%; background: var(--clay); box-shadow: 0 0 0 0 rgba(194,104,61,.6); animation: pulse 2.4s infinite; }
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(194,104,61,.5)} 70%{box-shadow:0 0 0 14px rgba(194,104,61,0)} 100%{box-shadow:0 0 0 0 rgba(194,104,61,0)} }
.hero-title { font-family: var(--serif); font-weight: 300; font-size: clamp(2.7rem, 8.5vw, 8.4rem); line-height: .97; letter-spacing: -.025em; align-self: end; }
.hero-title .line { display: block; overflow: hidden; }
.hero-title .w { display: inline-block; }
.hero-foot { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; margin-top: 40px; flex-wrap: wrap; }
.hero-sub { max-width: 440px; font-size: 1rem; line-height: 1.6; color: rgba(236,227,211,.82); }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.hero .btn-line { border-color: rgba(236,227,211,.4); color: var(--bone); }
.hero .btn-line::before { background: var(--bone); }
.hero .btn-line:hover span { color: var(--ink); }
.hero-scroll { position: absolute; bottom: 4vh; left: 50%; transform: translateX(-50%); z-index: 3; display: flex; flex-direction: column; align-items: center; gap: 10px; color: var(--bone); font-family: var(--mono); font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; }
.scroll-track { width: 1px; height: 54px; background: rgba(236,227,211,.3); position: relative; overflow: hidden; }
.scroll-track i { position: absolute; top: -50%; left: 0; width: 100%; height: 50%; background: var(--clay); animation: scroll 2s var(--ease) infinite; }
@keyframes scroll { 0%{top:-50%} 100%{top:100%} }
.hero-side { position: absolute; right: var(--pad); top: 50%; transform: translateY(-50%) rotate(180deg); writing-mode: vertical-rl; z-index: 3; display: flex; gap: 28px; color: rgba(236,227,211,.7); font-family: var(--mono); font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; }

/* ═══════════ MARQUEE ═══════════ */
.marquee { background: var(--ink); color: var(--bone); padding: 22px 0; overflow: hidden; border-block: 1px solid var(--ink-soft); }
.marquee-track { display: flex; align-items: center; gap: 36px; white-space: nowrap; width: max-content; will-change: transform; }
.marquee-track span { font-family: var(--serif); font-style: italic; font-weight: 300; font-size: clamp(1.4rem,3vw,2.4rem); }
.marquee-track i { color: var(--clay); font-style: normal; font-size: 1rem; }

/* ═══════════ MANIFESTO ═══════════ */
.manifesto { padding: clamp(90px,14vh,200px) 0; }
.manifesto .eyebrow { color: var(--ink-mut); }
.manifesto-text { font-family: var(--serif); font-weight: 300; font-size: clamp(1.7rem, 4.4vw, 4rem); line-height: 1.22; letter-spacing: -.015em; max-width: 1180px; }
.manifesto-text [data-word] { display: inline-block; }
.manifesto-text strong { font-weight: 500; color: var(--clay); }
.manifesto-text em { font-style: italic; }

/* ═══════════ ABOUT / PILLARS ═══════════ */
.pillars { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; border-top: 1px solid var(--line); }
.pillar { position: relative; padding: 40px 30px 50px; border-right: 1px solid var(--line); overflow: hidden; }
.pillar:last-child { border-right: none; }
.pillar-no { font-family: var(--mono); font-size: .76rem; color: var(--clay); letter-spacing: .1em; }
.pillar h3 { font-family: var(--serif); font-weight: 300; font-size: clamp(1.5rem,2.2vw,2rem); line-height: 1.08; margin: 60px 0 18px; }
.pillar p { font-size: .96rem; color: var(--ink-mut); line-height: 1.6; max-width: 90%; }
.pillar-line { position: absolute; left: 0; bottom: 0; width: 100%; height: 2px; background: var(--clay); transform: scaleX(0); transform-origin: left; transition: transform .6s var(--ease); }
.pillar:hover .pillar-line { transform: scaleX(1); }
.pillar:hover h3 { color: var(--clay); transition: color .4s; }

/* ═══════════ PROCESS ═══════════ */
.process { background: var(--bone-soft); }
.process-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px,7vw,120px); align-items: start; }
.process-sticky { position: sticky; top: 14vh; }
.process-visual { position: relative; aspect-ratio: 4/5; border-radius: 4px; overflow: hidden; background: var(--bone-deep); }
.process-visual img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease); }
.process-count { position: absolute; left: 24px; bottom: 22px; color: var(--bone); font-family: var(--mono); display: flex; align-items: baseline; gap: 8px; text-shadow: 0 2px 20px rgba(0,0,0,.4); }
.process-count span { font-family: var(--serif); font-size: 3.4rem; line-height: 1; }
.process-count i { font-style: normal; font-size: .8rem; letter-spacing: .1em; opacity: .8; }
.process-list { display: flex; flex-direction: column; }
.step { display: grid; grid-template-columns: 64px 1fr; gap: 18px; padding: clamp(28px,4vw,48px) 0; border-bottom: 1px solid var(--line); opacity: .42; transition: opacity .5s var(--ease); }
.step.in-view { opacity: 1; }
.step:first-child { border-top: 1px solid var(--line); }
.step-no { font-family: var(--mono); font-size: .85rem; color: var(--clay); padding-top: 8px; }
.step-body h3 { font-family: var(--serif); font-weight: 300; font-size: clamp(1.5rem,2.6vw,2.3rem); line-height: 1.1; margin-bottom: 14px; }
.step-body p { color: var(--ink-mut); font-size: 1.02rem; line-height: 1.6; max-width: 460px; }
.step-body strong { color: var(--ink); font-weight: 600; }
.step.is-key .step-body h3 { color: var(--clay); }
.step-checks { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.step-checks li { font-family: var(--mono); font-size: .74rem; letter-spacing: .03em; padding: 7px 13px; border: 1px solid var(--line); border-radius: 50px; color: var(--ink); }
.step-checks li::before { content: '✓ '; color: var(--green); }

/* ═══════════ PORTFOLIO / BOUQUETS ═══════════ */
.bouquets { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px,3vw,40px); }
.bouquet { background: var(--bone-soft); border: 1px solid var(--line); border-radius: 6px; overflow: hidden; display: flex; flex-direction: column; }
.bouquet-media { position: relative; aspect-ratio: 16/10; overflow: hidden; }
.bouquet-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.1s var(--ease); }
.bouquet:hover .bouquet-media img { transform: scale(1.05); }
.bouquet-status { position: absolute; top: 18px; left: 18px; font-family: var(--mono); font-size: .7rem; letter-spacing: .08em; text-transform: uppercase; padding: 8px 14px; border-radius: 50px; backdrop-filter: blur(8px); }
.bouquet-status.open { background: rgba(111,122,82,.85); color: var(--bone-soft); }
.bouquet-status.locked { background: rgba(23,21,15,.6); color: var(--sand); }
.bouquet-locked { opacity: .9; }
.bouquet-body { padding: clamp(24px,3vw,38px); display: flex; flex-direction: column; flex: 1; }
.bouquet-top { display: flex; justify-content: space-between; align-items: center; gap: 14px; }
.bouquet-top h3 { font-family: var(--serif); font-weight: 300; font-size: clamp(1.8rem,3vw,2.6rem); }
.bouquet-tag { font-family: var(--mono); font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--clay); border: 1px solid var(--line); padding: 6px 12px; border-radius: 50px; white-space: nowrap; }
.bouquet-tag.muted { color: var(--ink-mut); }
.bouquet-value { margin: 26px 0; padding-bottom: 24px; border-bottom: 1px solid var(--line); }
.bouquet-value .num { font-family: var(--serif); font-size: clamp(2.2rem,4vw,3.2rem); font-weight: 300; color: var(--clay); display: block; line-height: 1; }
.bouquet-value .cur { font-size: .5em; }
.bouquet-value small { font-family: var(--mono); font-size: .72rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-mut); margin-top: 10px; display: block; }
.bouquet-feats { display: flex; flex-direction: column; gap: 14px; margin-bottom: 26px; }
.bouquet-feats li { display: flex; flex-direction: column; gap: 2px; padding-left: 18px; position: relative; }
.bouquet-feats li::before { content: ''; position: absolute; left: 0; top: 8px; width: 7px; height: 7px; border-radius: 50%; background: var(--clay); }
.bouquet-feats b { font-weight: 600; font-size: .98rem; }
.bouquet-feats span { font-size: .86rem; color: var(--ink-mut); }
.bouquet-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; padding: 22px 0; margin-bottom: 26px; border-block: 1px solid var(--line); margin-top: auto; }
.bouquet-stats div { text-align: center; }
.bouquet-stats b { display: block; font-family: var(--serif); font-size: clamp(1.1rem,1.8vw,1.5rem); font-weight: 400; }
.bouquet-stats span { font-family: var(--mono); font-size: .62rem; letter-spacing: .05em; text-transform: uppercase; color: var(--ink-mut); margin-top: 6px; display: block; }
/* waitlist */
.bouquet-waitlist { margin-top: auto; }
.bouquet-waitlist > p { font-size: .9rem; color: var(--ink-mut); margin-bottom: 16px; line-height: 1.55; }
.waitlist-field { display: flex; gap: 8px; }
.waitlist-field input { flex: 1; background: var(--bone); border: 1px solid var(--line); border-radius: 50px; padding: 14px 20px; font-size: .9rem; outline: none; transition: border-color .3s; }
.waitlist-field input:focus { border-color: var(--clay); }
.waitlist-field button { font-family: var(--mono); font-size: .76rem; letter-spacing: .06em; text-transform: uppercase; background: var(--ink); color: var(--bone); border: none; border-radius: 50px; padding: 0 24px; white-space: nowrap; transition: background .3s; }
.waitlist-field button:hover { background: var(--clay); }
.waitlist-ok { display: none; margin-top: 14px; font-family: var(--mono); font-size: .8rem; color: var(--green); }

/* waitlist — name + phone */
.waitlist-fields { display: flex; flex-direction: column; gap: 8px; margin-bottom: 10px; }
.waitlist-fields input { width: 100%; background: var(--bone); border: 1px solid var(--line); border-radius: 12px; padding: 13px 18px; font-size: .92rem; outline: none; transition: border-color .3s; }
.waitlist-fields input:focus { border-color: var(--clay); }
.waitlist-fields input::placeholder { color: var(--text-muted, var(--ink-mut)); }
.waitlist-submit { width: 100%; font-family: var(--mono); font-size: .78rem; letter-spacing: .06em; text-transform: uppercase; background: var(--ink); color: var(--bone); border: none; border-radius: 50px; padding: 14px; cursor: pointer; transition: background .3s; }
.waitlist-submit:hover { background: var(--clay); }
.waitlist-submit span { color: var(--bone); }

/* locked bouquet — blurred preview + lock */
.locked-media { position: relative; }
.locked-media img { filter: blur(7px) brightness(.62) saturate(.9); transform: scale(1.1); }
.locked-media::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,18,12,.42), rgba(20,18,12,.66)); }
.locked-lock { position: absolute; inset: 0; z-index: 2; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; color: var(--bone); }
.lock-ico { width: 60px; height: 60px; border-radius: 50%; display: grid; place-items: center; background: rgba(236,227,211,.13); border: 1px solid rgba(236,227,211,.32); backdrop-filter: blur(4px); }
.lock-txt { font-family: var(--mono); font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; }
.bouquet-locked:hover .locked-media img { filter: blur(6px) brightness(.66) saturate(.95); }

/* ═══════════ GALLERY ═══════════ */
.gallery { overflow: hidden; }
.gallery .sec-head { margin-bottom: clamp(40px,5vw,70px); }
.gallery-track { display: flex; gap: clamp(16px,2vw,28px); padding: 0 var(--pad); width: max-content; will-change: transform; }
.g-item { position: relative; width: clamp(260px,28vw,440px); flex-shrink: 0; }
.g-item img { width: 100%; aspect-ratio: 4/5; object-fit: cover; border-radius: 4px; transition: transform .8s var(--ease); }
.g-item figcaption { font-family: var(--mono); font-size: .74rem; letter-spacing: .05em; text-transform: uppercase; color: var(--ink-mut); margin-top: 16px; }
.g-item:hover img { transform: scale(.985); }

/* ═══════════ CALCULATOR ═══════════ */
.calc { background: var(--ink); color: var(--bone); min-height: 100svh; display: flex; align-items: center;
  padding-top: clamp(34px,4.5vh,58px); padding-bottom: clamp(34px,4.5vh,58px); }
.calc .wrap { width: 100%; }
.calc .sec-head { max-width: 760px; margin-bottom: clamp(14px,2vh,26px); }
.calc .sec-title { font-size: clamp(1.7rem,3.2vw,2.6rem); }
.calc .sec-desc { margin-top: 12px; font-size: clamp(.95rem,1.1vw,1.05rem); }
.calc-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(26px,4vw,54px); align-items: stretch; }

/* left */
.calc-left { display: flex; flex-direction: column; gap: clamp(16px,2.4vh,24px); min-width: 0; }
.calc-field label { display: block; font-family: var(--mono); font-size: .76rem; letter-spacing: .06em; text-transform: uppercase; color: var(--sand); margin-bottom: 12px; }
.calc-input-wrap { display: flex; align-items: baseline; border-bottom: 1px solid var(--line-light); padding-bottom: 12px; }
.calc-input-wrap input { flex: 1; background: none; border: none; outline: none; font-family: var(--serif); font-weight: 300; font-size: clamp(2rem,4vw,3.1rem); color: var(--bone); letter-spacing: -.02em; min-width: 0; }
.calc-cur { font-family: var(--mono); font-size: 1rem; color: var(--clay-light); letter-spacing: .06em; }
.calc-slider { -webkit-appearance: none; appearance: none; width: 100%; height: 2px; margin-top: 20px; background: linear-gradient(to right, var(--clay) 0%, var(--clay) var(--fill,6%), rgba(236,227,211,.18) var(--fill,6%)); outline: none; border-radius: 2px; }
.calc-slider::-webkit-slider-thumb { -webkit-appearance: none; width: 20px; height: 20px; border-radius: 50%; background: var(--bone); border: 4px solid var(--clay); cursor: none; transition: transform .2s; }
.calc-slider::-webkit-slider-thumb:hover { transform: scale(1.15); }
.calc-slider::-moz-range-thumb { width: 16px; height: 16px; border-radius: 50%; background: var(--bone); border: 4px solid var(--clay); }
.calc-slider-labels { display: flex; justify-content: space-between; font-family: var(--mono); font-size: .68rem; color: var(--ink-mut); margin-top: 12px; letter-spacing: .04em; }
.calc-presets { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.calc-presets button { font-family: var(--mono); font-size: .76rem; letter-spacing: .04em; background: none; border: 1px solid var(--line-light); color: var(--sand); border-radius: 50px; padding: 8px 16px; transition: all .3s var(--ease); }
.calc-presets button:hover { border-color: var(--clay-light); color: var(--bone); }
.calc-presets button.active { background: var(--clay); border-color: var(--clay); color: var(--bone-soft); }

.calc-params { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--line-light); border: 1px solid var(--line-light); }
.calc-params div { background: var(--ink); padding: 13px 16px; display: flex; flex-direction: column; gap: 5px; }
.calc-params span { font-family: var(--mono); font-size: .64rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-mut); }
.calc-params b { font-weight: 500; font-size: 1rem; }

.calc-formula { border: 1px dashed var(--line-light); border-radius: 4px; padding: 14px 18px; }
.formula-label { font-family: var(--mono); font-size: .66rem; letter-spacing: .1em; text-transform: uppercase; color: var(--clay-light); display: block; margin-bottom: 10px; }
.calc-formula p { font-family: var(--mono); font-size: .76rem; color: var(--sand); line-height: 1.5; margin-bottom: 4px; }

/* right */
.calc-right { display: flex; flex-direction: column; gap: 12px; min-width: 0; }
.calc-share { display: flex; align-items: center; gap: clamp(18px,2.6vw,32px); padding: clamp(18px,2.4vw,26px) clamp(20px,2.6vw,30px); border: 1px solid var(--line-light); border-radius: 6px; background: linear-gradient(150deg, rgba(194,104,61,.08), transparent 60%); }
.calc-donut { position: relative; width: 122px; height: 122px; flex-shrink: 0; }
.calc-donut svg { width: 100%; height: 100%; }
.donut-track { fill: none; stroke: rgba(236,227,211,.1); stroke-width: 12; }
.donut-fill { fill: none; stroke: var(--clay); stroke-width: 12; stroke-linecap: round; stroke-dasharray: 527.79; stroke-dashoffset: 527.79; }
.donut-center { position: absolute; inset: 0; display: grid; place-content: center; text-align: center; }
.donut-center span { font-family: var(--serif); font-size: 1.35rem; color: var(--clay-light); display: block; }
.donut-center small { font-family: var(--mono); font-size: .62rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-mut); }
.calc-share-text .rlabel { font-family: var(--mono); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--sand); }
.rbig { font-family: var(--serif); font-weight: 300; font-size: clamp(2.1rem,3.8vw,3.2rem); line-height: 1; margin: 6px 0 8px; letter-spacing: -.02em; }
.rsub { font-family: var(--mono); font-size: .8rem; color: var(--ink-mut); }
.calc-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--line-light); border: 1px solid var(--line-light); border-radius: 6px; overflow: hidden; }
.calc-card { background: var(--ink); padding: 15px 16px; display: flex; flex-direction: column; gap: 9px; }
.calc-card .rlabel { font-family: var(--mono); font-size: .64rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-mut); }
.rmid { font-family: var(--serif); font-weight: 300; font-size: clamp(1.2rem,2vw,1.6rem); line-height: 1; }
.calc-proj { border: 1px solid var(--line-light); border-radius: 6px; overflow: hidden; }
.proj-head { padding: 11px 20px; border-bottom: 1px solid var(--line-light); }
.proj-head span { font-family: var(--mono); font-size: .7rem; letter-spacing: .08em; text-transform: uppercase; color: var(--sand); }
.proj-table { width: 100%; border-collapse: collapse; }
.proj-table th { text-align: left; font-family: var(--mono); font-size: .62rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-mut); font-weight: 400; padding: 8px 20px; }
.proj-table td { padding: 8px 20px; font-size: .86rem; border-top: 1px solid var(--line-light); }
.proj-table td:first-child { font-family: var(--mono); color: var(--sand); font-size: .82rem; }
.proj-table td:last-child { color: var(--clay-light); font-weight: 500; }
.proj-table tr:last-child td { font-weight: 600; }
.calc-disc { font-size: .76rem; color: var(--ink-mut); line-height: 1.5; }

/* ═══════════ CEOs / VALUES ═══════════ */
.ceo-quote { max-width: 1100px; margin-bottom: clamp(60px,8vw,110px); }
.ceo-quote p { font-family: var(--serif); font-weight: 300; font-size: clamp(1.5rem,3.4vw,3rem); line-height: 1.32; letter-spacing: -.01em; }
.ceo-quote em { font-style: italic; color: var(--clay); }
.ceo-people { display: flex; gap: clamp(28px,4vw,60px); margin-top: 48px; flex-wrap: wrap; }
.ceo { display: flex; align-items: center; gap: 16px; }
.ceo-av { width: 56px; height: 56px; border-radius: 50%; border: 1px solid var(--clay); display: grid; place-items: center; font-family: var(--serif); font-style: italic; font-size: 1.1rem; color: var(--clay); }
.ceo b { display: block; font-weight: 600; font-size: 1rem; }
.ceo i { font-style: normal; font-family: var(--mono); font-size: .74rem; letter-spacing: .04em; color: var(--ink-mut); }
.values { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.value { background: var(--bone); padding: 38px 30px; min-height: 220px; display: flex; flex-direction: column; }
.v-no { font-size: 1.4rem; color: var(--clay); margin-bottom: auto; }
.value h4 { font-family: var(--serif); font-weight: 400; font-size: 1.5rem; margin: 30px 0 12px; }
.value p { font-size: .92rem; color: var(--ink-mut); line-height: 1.55; }

/* ═══════════════ HERO STATS ═══════════════ */
.hero-stats { display: flex; gap: clamp(16px,3.4vw,48px); margin-top: clamp(26px,4vh,44px); flex-wrap: wrap; }
.hero-stat { display: flex; flex-direction: column; gap: 6px; position: relative; }
.hero-stat + .hero-stat { padding-left: clamp(16px,3.4vw,48px); }
.hero-stat + .hero-stat::before { content: ''; position: absolute; left: 0; top: 4px; bottom: 14px; width: 1px; background: rgba(236,227,211,.22); }
.hero-stat b { font-family: var(--serif); font-weight: 300; font-size: clamp(1.9rem,4.2vw,3.3rem); line-height: 1; color: var(--bone); letter-spacing: -.02em; }
.hero-stat b .u { color: var(--clay-light); }
.hero-stat span { font-family: var(--mono); font-size: .66rem; letter-spacing: .07em; text-transform: uppercase; color: rgba(236,227,211,.6); max-width: 150px; }

/* ═══════════════ PLATFORMS ═══════════════ */
.platforms { padding: clamp(50px,7vh,96px) 0; border-bottom: 1px solid var(--line); }
.platforms-inner { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 26px; }
.platforms-label { font-family: var(--mono); font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-mut); }
.platforms-logos { display: flex; align-items: center; gap: clamp(22px,4vw,54px); }
.plat { display: inline-flex; align-items: center; gap: 10px; font-weight: 700; letter-spacing: -.02em; line-height: 1; }
.plat-airbnb { color: #FF5A5F; font-size: clamp(1.4rem,3.2vw,2.1rem); }
.plat-ico { width: clamp(26px,3.6vw,38px); height: auto; }
.plat-booking { color: #003b95; font-size: clamp(1.4rem,3.2vw,2.1rem); }
.plat-booking span { color: #006ce4; }
.plat-sep { width: 1px; height: 32px; background: var(--line); }
.platforms-note { max-width: 560px; font-size: .96rem; color: var(--ink-mut); line-height: 1.65; }
.platforms-note strong { color: var(--clay); font-weight: 600; }

/* ═══════════════ SECTION HEAD LINK ═══════════════ */
.head-link { display: inline-flex; align-items: center; gap: 10px; font-family: var(--mono); font-size: .76rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink); border-bottom: 1px solid var(--line); padding-bottom: 6px; white-space: nowrap; transition: color .3s, border-color .3s; }
.head-link:hover { color: var(--clay); border-color: var(--clay); }
.head-link i { font-style: normal; transition: transform .3s var(--ease); }
.head-link:hover i { transform: translateX(5px); }

/* ═══════════════ FOUNDERS ═══════════════ */
.founders { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px,3vw,48px); margin: clamp(48px,6vw,82px) 0; }
.founder-card { display: flex; gap: clamp(20px,2.4vw,32px); }
.founder-photo { flex: 0 0 44%; max-width: 240px; overflow: hidden; border-radius: 6px; background: var(--bone-deep); }
.founder-photo img { width: 100%; height: 100%; object-fit: cover; object-position: top center; aspect-ratio: 3/4; transition: transform .9s var(--ease); }
.founder-card:hover .founder-photo img { transform: scale(1.05); }
.founder-info { display: flex; flex-direction: column; min-width: 0; }
.founder-role { font-family: var(--mono); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; color: var(--clay); }
.founder-info h3 { font-family: var(--serif); font-weight: 300; font-size: clamp(1.6rem,2.6vw,2.4rem); margin: 10px 0 14px; line-height: 1.05; }
.founder-info p { font-size: .95rem; color: var(--ink-mut); line-height: 1.65; }
.founder-more { margin-top: auto; padding-top: 18px; font-family: var(--mono); font-size: .72rem; letter-spacing: .05em; text-transform: uppercase; color: var(--ink); display: inline-flex; gap: 8px; align-items: center; width: fit-content; }
.founder-more i { font-style: normal; transition: transform .3s var(--ease); }
.founder-more:hover { color: var(--clay); }
.founder-more:hover i { transform: translateX(4px); }

/* ═══════════ CONTACT ═══════════ */
.contact { background: var(--bone-soft); }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px,6vw,100px); align-items: start; }
.contact-lead { font-size: 1.1rem; color: var(--ink-mut); line-height: 1.65; margin: 26px 0 40px; max-width: 420px; }
.contact-list { border-top: 1px solid var(--line); margin-bottom: 40px; }
.contact-list li { display: flex; justify-content: space-between; align-items: center; padding: 18px 0; border-bottom: 1px solid var(--line); }
.contact-list span { font-family: var(--mono); font-size: .74rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-mut); }
.contact-list b { font-family: var(--serif); font-weight: 400; font-size: 1.15rem; font-style: italic; }
.contact-list a { transition: color .3s; }
.contact-list a:hover { color: var(--clay); }
.contact-tag { display: flex; flex-direction: column; gap: 4px; font-family: var(--serif); font-style: italic; font-size: 1.3rem; font-weight: 300; }
.contact-form { background: var(--bone); border: 1px solid var(--line); border-radius: 8px; padding: clamp(28px,3.5vw,48px); display: flex; flex-direction: column; gap: 22px; }
.fg { display: flex; flex-direction: column; gap: 10px; }
.fg label { font-family: var(--mono); font-size: .72rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-mut); }
.fg label i { text-transform: none; letter-spacing: 0; }
.fg input, .fg select, .fg textarea { background: var(--bone-soft); border: 1px solid var(--line); border-radius: 4px; padding: 14px 16px; font-size: .98rem; outline: none; transition: border-color .3s; resize: vertical; }
.fg input:focus, .fg select:focus, .fg textarea:focus { border-color: var(--clay); }
.form-ok { display: none; font-family: var(--mono); font-size: .82rem; color: var(--green); padding: 12px 0; }

/* ═══════════ FOOTER ═══════════ */
.footer { background: var(--ink); color: var(--bone); padding-top: clamp(60px,8vw,120px); overflow: hidden; }
.footer-big { font-family: var(--serif); font-weight: 300; font-size: clamp(4rem,21vw,20rem); line-height: .8; letter-spacing: -.03em; white-space: nowrap; color: var(--bone); margin-bottom: 50px; }
.footer-row { display: flex; gap: clamp(40px,8vw,120px); flex-wrap: wrap; padding-bottom: 60px; border-bottom: 1px solid var(--ink-soft); }
.footer-col { display: flex; flex-direction: column; gap: 14px; }
.footer-col span { font-family: var(--mono); font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-mut); margin-bottom: 6px; }
.footer-col a { font-size: 1.05rem; color: var(--sand); transition: color .3s; width: fit-content; }
.footer-col a:hover { color: var(--clay-light); }
.footer-tag { margin-left: auto; max-width: 280px; }
.footer-tag span { color: var(--clay-light); }
.footer-tag p { font-family: var(--serif); font-style: italic; font-size: 1.2rem; color: var(--sand); margin-top: 8px; }
.footer-bottom { padding: 30px 0 40px; display: flex; justify-content: space-between; gap: 30px; flex-wrap: wrap; }
.footer-bottom p { font-size: .8rem; color: var(--ink-mut); }
.footer-disc { max-width: 640px; line-height: 1.6; }

/* ═══════════════ STRUCTURE ═══════════════ */
.structure { background: var(--bone-soft); }
.struct-grid { display: grid; grid-template-columns: repeat(4,1fr); border-top: 1px solid var(--line); }
.struct { padding: 34px 28px 44px; border-right: 1px solid var(--line); position: relative; transition: background .4s var(--ease); }
.struct:last-child { border-right: none; }
.struct:hover { background: var(--bone-deep); }
.struct-no { font-family: var(--mono); font-size: .76rem; color: var(--clay); letter-spacing: .1em; }
.struct h3 { font-family: var(--serif); font-weight: 300; font-size: clamp(1.4rem,2vw,1.85rem); margin: 46px 0 14px; line-height: 1.1; }
.struct p { font-size: .94rem; color: var(--ink-mut); line-height: 1.62; }
.struct strong { color: var(--clay); font-weight: 600; }

/* ═══════════════ FAQ ═══════════════ */
.faq-list { max-width: 880px; margin: 0 auto; border-top: 1px solid var(--line); }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-q { width: 100%; background: none; border: none; text-align: left; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: clamp(20px,2.6vw,30px) 4px; font-family: var(--serif); font-weight: 300; font-size: clamp(1.1rem,1.8vw,1.5rem); color: var(--ink); line-height: 1.3; transition: color .3s; }
.faq-q:hover { color: var(--clay); }
.faq-ico { position: relative; width: 16px; height: 16px; flex-shrink: 0; }
.faq-ico::before, .faq-ico::after { content: ''; position: absolute; background: var(--clay); transition: transform .4s var(--ease); }
.faq-ico::before { top: 50%; left: 0; width: 100%; height: 1.5px; transform: translateY(-50%); }
.faq-ico::after { left: 50%; top: 0; width: 1.5px; height: 100%; transform: translateX(-50%); }
.faq-item.open .faq-ico::after { transform: translateX(-50%) scaleY(0); }
.faq-a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .45s var(--ease); }
.faq-item.open .faq-a { grid-template-rows: 1fr; }
.faq-a-inner { overflow: hidden; }
.faq-a-inner p { padding: 0 4px clamp(20px,2.4vw,28px); max-width: 700px; color: var(--ink-mut); font-size: 1rem; line-height: 1.7; }
.faq-a-inner a { color: var(--clay); border-bottom: 1px solid currentColor; }

/* ═══════════════ CALC CTA ═══════════════ */
.calc-cta { margin-top: auto; }
.calc-cta span { color: var(--bone); }

/* ═══════════════ WHATSAPP BUTTON ═══════════════ */
.wa-btn { margin-bottom: 36px; background: #1faf54 !important; }
.wa-btn::before { background: #178f44 !important; }
.wa-btn span { display: inline-flex; align-items: center; gap: 10px; color: #fff; }

/* ═══════════════ MOBILE STICKY CTA ═══════════════ */
.mobile-cta { position: fixed; left: 0; right: 0; bottom: 0; z-index: 600; display: none; gap: 10px;
  padding: 11px clamp(14px,4vw,20px) calc(11px + env(safe-area-inset-bottom));
  background: rgba(15,13,9,.85); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-top: 1px solid rgba(236,227,211,.12); transform: translateY(130%); transition: transform .45s var(--ease); }
.mobile-cta.show { transform: translateY(0); }
.mobile-cta.show.hide { transform: translateY(130%); }
.mcta-btn { display: flex; align-items: center; justify-content: center; height: 50px; border-radius: 50px;
  font-family: var(--mono); font-size: .78rem; letter-spacing: .04em; text-transform: uppercase; }
.mcta-primary { flex: 1; background: var(--clay); color: var(--bone-soft); font-weight: 600; }
.mcta-wa { width: 52px; flex-shrink: 0; background: #1faf54; color: #fff; }
@media (max-width: 920px) { .mobile-cta { display: flex; } }

/* ═══════════════ FOCUS (a11y) ═══════════════ */
:focus-visible { outline: 2px solid var(--clay); outline-offset: 3px; }
.calc :focus-visible, .menu :focus-visible, .nav :focus-visible, .footer :focus-visible { outline-color: var(--clay-light); }

/* ═══════════════ LEGAL PAGES ═══════════════ */
.legal-page { padding: clamp(120px,16vh,180px) 0 clamp(56px,9vh,110px); }
.legal-page h1 { font-family: var(--serif); font-weight: 300; font-size: clamp(2.1rem,5vw,3.6rem); letter-spacing: -.02em; margin-bottom: 14px; }
.legal-updated { font-family: var(--mono); font-size: .72rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-mut); margin-bottom: clamp(36px,5vw,56px); }
.legal-body { max-width: 760px; }
.legal-body h2 { font-family: var(--serif); font-weight: 400; font-size: clamp(1.35rem,2.4vw,1.85rem); margin: 42px 0 14px; }
.legal-body h2:first-child { margin-top: 0; }
.legal-body p, .legal-body li { color: var(--ink-mut); font-size: 1rem; line-height: 1.75; margin-bottom: 13px; }
.legal-body ul { padding-left: 20px; list-style: disc; margin-bottom: 16px; }
.legal-body strong { color: var(--ink); font-weight: 600; }
.legal-body a { color: var(--clay); border-bottom: 1px solid currentColor; }
.legal-body .todo { background: rgba(194,104,61,.12); border-left: 2px solid var(--clay); padding: 3px 10px; color: var(--clay-deep); font-style: italic; display: inline-block; }
.legal-body .risk-box { background: var(--bone-soft); border: 1px solid var(--border-gold, var(--line)); border-left: 3px solid var(--clay); border-radius: 6px; padding: 22px 26px; margin: 22px 0; }

/* ═══════════════ FONDATEURS PAGE ═══════════════ */
.page-hero { padding: clamp(120px,16vh,180px) 0 clamp(30px,5vh,56px); }
.page-hero h1 { font-family: var(--serif); font-weight: 300; font-size: clamp(2.1rem,5.4vw,4.2rem); line-height: 1; letter-spacing: -.025em; margin: 18px 0 22px; }
.page-hero p { max-width: 540px; font-size: clamp(1rem,1.3vw,1.12rem); color: var(--ink-mut); line-height: 1.6; }
.founder-full { display: grid; grid-template-columns: 0.62fr 1fr; gap: clamp(28px,4.5vw,64px); align-items: center; padding: clamp(40px,6.5vh,82px) 0; border-top: 1px solid var(--line); scroll-margin-top: 84px; }
.founder-full.reverse .ff-media { order: 2; }
.ff-media { border-radius: 8px; overflow: hidden; background: var(--bone-deep); max-width: 330px; }
.ff-media img { width: 100%; aspect-ratio: 4/5; object-fit: cover; object-position: top center; display: block; }
.ff-body { max-width: 560px; }
.ff-body .founder-role { font-family: var(--mono); font-size: .7rem; letter-spacing: .08em; text-transform: uppercase; color: var(--clay); }
.ff-body h2 { font-family: var(--serif); font-weight: 300; font-size: clamp(1.7rem,3.2vw,2.6rem); margin: 12px 0 18px; line-height: 1.05; }
.ff-body p { color: var(--ink-mut); font-size: clamp(.96rem,1.2vw,1.04rem); line-height: 1.72; margin-bottom: 14px; }
.ff-quote { font-family: var(--serif); font-style: italic; font-weight: 300; font-size: clamp(1.15rem,1.8vw,1.5rem); color: var(--ink); line-height: 1.42; margin: 22px 0 0; padding-left: 20px; border-left: 2px solid var(--clay); }
.cta-band { text-align: center; padding: clamp(72px,13vh,160px) 0; border-top: 1px solid var(--line); }
.cta-band .eyebrow { color: var(--clay); }
.cta-band h2 { font-family: var(--serif); font-weight: 300; font-size: clamp(2.2rem,5.5vw,4.4rem); line-height: 1.04; margin: 18px 0 34px; letter-spacing: -.02em; }

/* ═══════════ JS REVEAL INITIAL STATES ═══════════ */
.js [data-reveal] { opacity: 0; }
.js .reveal-line { opacity: 0; }
.js .hero-title .w { transform: translateY(110%); opacity: 0; }
.js .manifesto-text [data-word] { opacity: .14; }

/* ═══════════ RESPONSIVE ═══════════ */
@media (max-width: 1100px) {
  .pillars { grid-template-columns: 1fr 1fr; }
  .pillar:nth-child(2) { border-right: none; }
  .pillar { border-bottom: 1px solid var(--line); }
  .values { grid-template-columns: 1fr 1fr; }
  .struct-grid { grid-template-columns: 1fr 1fr; }
  .struct { border-bottom: 1px solid var(--line); }
  .struct:nth-child(2n) { border-right: none; }
}
@media (max-width: 920px) {
  .nav-center { display: none; }
  .nav-cta { display: none; }
  .nav-burger { display: flex; }
  .process-layout { grid-template-columns: 1fr; }
  .process-sticky { position: relative; top: 0; max-width: 440px; margin-bottom: 20px; }
  .bouquets { grid-template-columns: 1fr; }
  .calc-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .hero-side { display: none; }
  .founders { grid-template-columns: 1fr; }
  .calc-cta { display: none; }   /* mobile uses the sticky CTA bar instead */
  .founder-full { grid-template-columns: 1fr; gap: 24px; }
  .founder-full.reverse .ff-media { order: 0; }
  .ff-media { max-width: 300px; }
}
@media (max-width: 600px) {
  .pillars { grid-template-columns: 1fr; }
  .pillar { border-right: none; }
  .values { grid-template-columns: 1fr; }
  .calc { min-height: 0; display: block; padding-top: 36px; padding-bottom: 44px; }
  .calc-grid { gap: 18px; }
  .calc-left { gap: 14px; }
  .calc-formula { display: none; }              /* explanatory — hidden on phones to keep results in view */
  .calc-params { grid-template-columns: 1fr 1fr; }
  .calc-cards { grid-template-columns: repeat(3,1fr); }
  .calc-card { padding: 12px 9px; gap: 7px; }
  .calc-card .rlabel { font-size: .56rem; }
  .rmid { font-size: 1.04rem; }
  .calc-share { padding: 16px 18px; gap: 16px; }
  .calc-donut { width: 92px; height: 92px; }
  .donut-center span { font-size: 1.05rem; }
  .rbig { font-size: 2rem; }
  .proj-table th, .proj-table td { padding: 7px 16px; }
  .hero-foot { flex-direction: column; align-items: flex-start; }
  .bouquet-stats { grid-template-columns: 1fr; gap: 0; }
  .bouquet-stats div { padding: 10px 0; border-bottom: 1px solid var(--line); }
  .footer-bottom { flex-direction: column; }
  .waitlist-field { flex-direction: column; }
  .waitlist-field button { padding: 14px; }
  .struct-grid { grid-template-columns: 1fr; }
  .struct { border-right: none; }
  .hero { height: auto; min-height: 100svh; }
  .hero-grid { padding-top: 13vh; padding-bottom: 15vh; text-shadow: 0 2px 22px rgba(8,6,3,.5); }
  .hero-title { font-size: clamp(2.3rem, 10vw, 3.3rem); }
  .hero-foot { margin-top: 22px; gap: 18px; }
  .hero-sub { font-size: .92rem; line-height: 1.55; }
  .hero-stats { gap: 14px; width: 100%; margin-top: 20px; }
  .hero-stat span { max-width: none; }
  .founder-photo { flex-basis: 40%; max-width: 150px; }
  .platforms-note { font-size: .9rem; }
}

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .01ms !important; transition-duration: .01ms !important; }
  .js [data-reveal], .js .reveal-line, .js .hero-title .w, .js .manifesto-text [data-word] { opacity: 1; transform: none; }
}
