/* ============================================================
   GREENDOOR · /revamp — stakeholder proposal & marketing page
   Reuses the shared shell (tokens, nav, footer, buttons, banner)
   and adds the dark hero, the interactive 3D door, and the
   proposal sections.
   ============================================================ */

@import url('partner.css');

/* ---------- NAV tweaks ---------- */
.rv-nav .nav-back{ display:inline-flex; }

/* ---------- HERO ---------- */
.rv-hero{
  position:relative;
  background:
    radial-gradient(120% 90% at 50% -10%, rgba(31,61,46,.9), transparent 60%),
    linear-gradient(180deg, var(--ink), #0c1610 70%, var(--ink));
  color:var(--cream);
  padding:60px var(--gutter) 76px;
  overflow:hidden;
}
.rv-hero::after{
  /* soft warm light pooling from the doorway */
  content:"";position:absolute;left:50%;top:46%;width:min(680px,90vw);height:680px;
  transform:translate(-50%,-50%);
  background:radial-gradient(closest-side, rgba(220,110,74,.16), transparent 70%);
  pointer-events:none;
}
.rv-hero-inner{ position:relative;z-index:1;max-width:880px;margin:0 auto;text-align:center; }
.rv-kicker{
  font-family:var(--mono);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--coral);
}
.rv-hero h1{
  font-family:var(--serif);font-variation-settings:"opsz" 144, "SOFT" 60;font-weight:400;
  font-size:2.7rem;line-height:1.03;letter-spacing:-.025em;
  margin:16px 0 0;
}
@media (min-width:560px){ .rv-hero h1{ font-size:3.6rem; } }
@media (min-width:960px){ .rv-hero h1{ font-size:5rem; } }
.rv-hero h1 em{ color:var(--coral);font-style:italic; }
.rv-lede{
  max-width:60ch;margin:22px auto 0;
  font-size:1.06rem;line-height:1.7;color:rgba(244,238,223,.82);
}

/* ---------- The interactive door ---------- */
.rv-door{
  display:inline-flex;flex-direction:column;align-items:center;gap:20px;
  margin:46px auto 8px;
  text-decoration:none;
  cursor:pointer;
}
.rv-door-frame{
  position:relative;
  width:184px;height:264px;
  border-radius:92px 92px 10px 10px;
  perspective:1500px;
  background:
    radial-gradient(120% 80% at 50% 38%, rgba(244,238,223,.96), rgba(220,110,74,.5) 55%, rgba(31,61,46,.2) 100%);
  box-shadow:0 40px 80px -40px rgba(0,0,0,.8), inset 0 0 0 1px rgba(244,238,223,.18);
}
@media (min-width:560px){ .rv-door-frame{ width:212px;height:300px;border-radius:106px 106px 12px 12px; } }
.rv-door-glow{
  position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(closest-side, rgba(255,243,214,.9), rgba(220,110,74,.25) 60%, transparent 100%);
  opacity:.0;transition:opacity .55s var(--easing);
}
.rv-door-enter{
  position:absolute;left:0;right:0;top:54%;transform:translateY(-50%);
  text-align:center;
  font-family:var(--mono);font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;
  color:#3a1a0e;
  opacity:0;transition:opacity .5s var(--easing) .1s;
}
/* The moss door panel that swings open */
.rv-door-panel{
  position:absolute;inset:0;
  border-radius:inherit;
  background:linear-gradient(100deg, #18301f, var(--moss) 55%, #25492f);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.25), inset -10px 0 26px -14px rgba(0,0,0,.6);
  transform-origin:left center;
  transform:rotateY(0deg);
  transition:transform .8s cubic-bezier(.6,.02,.2,1);
  backface-visibility:hidden;
}
.rv-door-knob{
  position:absolute;right:14px;top:50%;
  width:10px;height:10px;border-radius:50%;
  background:var(--coral);transform:translateY(-50%);
  box-shadow:0 0 0 4px rgba(220,110,74,.18);
}
.rv-door-grain{
  position:absolute;left:22px;top:18px;bottom:18px;width:1px;
  background:rgba(244,238,223,.10);
  box-shadow:18px 0 0 rgba(244,238,223,.07), -10px 0 0 rgba(0,0,0,.18);
}
/* Open on hover, keyboard focus, or while JS plays the click animation */
.rv-door:hover .rv-door-panel,
.rv-door:focus-visible .rv-door-panel,
.rv-door.is-opening .rv-door-panel{ transform:rotateY(-82deg); }
.rv-door:hover .rv-door-glow,
.rv-door:focus-visible .rv-door-glow,
.rv-door.is-opening .rv-door-glow{ opacity:1; }
.rv-door:hover .rv-door-enter,
.rv-door:focus-visible .rv-door-enter,
.rv-door.is-opening .rv-door-enter{ opacity:1; }
.rv-door:focus-visible{ outline:none; }
.rv-door:focus-visible .rv-door-frame{ box-shadow:0 0 0 3px var(--coral), 0 40px 80px -40px rgba(0,0,0,.8); }

.rv-door-cta{ display:flex;flex-direction:column;gap:4px; }
.rv-door-cta strong{ font-family:var(--serif);font-size:1.15rem;font-weight:500;color:var(--cream); }
.rv-door-cta small{ font-family:var(--mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sage); }

.rv-hero-meta{
  margin-top:40px;
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px;
  font-size:.86rem;color:rgba(244,238,223,.7);
}
.rv-hero-meta b{ color:var(--cream);font-weight:600; }
.rv-hero-meta .dot{ width:4px;height:4px;border-radius:50%;background:var(--coral);opacity:.7; }

/* ---------- Generic section scaffolding ---------- */
.rv-section{ padding:var(--section-y) var(--gutter); }
.rv-head{ max-width:760px;margin:0 auto 44px;text-align:center; }
.rv-eyebrow{
  font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--leaf);
}
.rv-head h2{
  font-family:var(--serif);font-variation-settings:"opsz" 144, "SOFT" 60;font-weight:400;
  font-size:2rem;line-height:1.1;letter-spacing:-.02em;margin:12px 0 0;
}
@media (min-width:820px){ .rv-head h2{ font-size:2.7rem; } }
.rv-head p{ margin:18px auto 0;max-width:62ch;font-size:1.04rem;line-height:1.65;color:#3a4a40; }

/* Dark / soft section variants */
.rv-dark{ background:linear-gradient(180deg,#0f1c14,#16271c);color:var(--cream); }
.rv-dark .rv-eyebrow{ color:var(--coral); }
.rv-dark .rv-head p{ color:rgba(244,238,223,.78); }
.rv-soft{ background:var(--bone); }

/* ---------- Brief: questions + process ---------- */
.rv-questions{
  max-width:var(--maxw);margin:0 auto 50px;
  display:grid;grid-template-columns:1fr;gap:16px;
}
@media (min-width:760px){ .rv-questions{ grid-template-columns:repeat(3,1fr); } }
.rv-q{
  position:relative;
  background:var(--paper);border:1.5px solid var(--mist);border-radius:18px;
  padding:26px 24px;
  font-family:var(--serif);font-size:1.2rem;font-style:italic;line-height:1.4;color:var(--moss);
}
.rv-q span{ font-size:2.6rem;color:var(--coral);line-height:0;display:block;margin-bottom:6px; }
.rv-q b{ font-style:normal;color:var(--ink); }

.rv-process{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:14px;
}
@media (min-width:680px){ .rv-process{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1080px){ .rv-process{ grid-template-columns:repeat(5,1fr);gap:12px; } }
.rv-step{
  background:var(--cream);border:1.5px solid var(--mist);border-radius:16px;padding:22px 18px;
  position:relative;
}
.rv-step-n{
  display:inline-block;margin-bottom:10px;
  font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--cream);background:var(--moss);padding:6px 12px;border-radius:99px;
}
.rv-step p{ font-size:.92rem;line-height:1.55;color:#3a4a40; }

/* ---------- Card grids ---------- */
.rv-grid{ max-width:var(--maxw);margin:0 auto;display:grid;gap:18px;grid-template-columns:1fr; }
@media (min-width:680px){ .rv-grid-2{ grid-template-columns:repeat(2,1fr); } .rv-grid-3{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1000px){ .rv-grid-3{ grid-template-columns:repeat(3,1fr); } }

.rv-card{
  background:rgba(244,238,223,.04);
  border:1.5px solid rgba(244,238,223,.14);
  border-radius:18px;padding:26px 24px;
  transition:transform .3s var(--easing), border-color .3s var(--easing), background .3s;
}
@media (hover: hover){ .rv-card:hover{ transform:translateY(-3px);border-color:rgba(220,110,74,.55);background:rgba(244,238,223,.06); } }
.rv-card-ic{
  display:grid;place-items:center;width:42px;height:42px;border-radius:12px;
  background:var(--coral);color:#2a1206;font-size:1.2rem;margin-bottom:14px;
}
.rv-card h3{ font-family:var(--serif);font-size:1.22rem;font-weight:500;margin-bottom:8px;color:var(--cream); }
.rv-card p{ font-size:.95rem;line-height:1.6;color:rgba(244,238,223,.76); }

.rv-tcard{
  background:var(--cream);border:1.5px solid var(--mist);border-radius:18px;padding:26px 24px;
  transition:transform .3s var(--easing), box-shadow .3s var(--easing);
}
@media (hover: hover){ .rv-tcard:hover{ transform:translateY(-3px);box-shadow:0 22px 44px -30px rgba(15,27,20,.5); } }
.rv-tcard h3{ font-family:var(--serif);font-size:1.2rem;font-weight:500;margin-bottom:8px;color:var(--ink); }
.rv-tcard p{ font-size:.95rem;line-height:1.6;color:#3a4a40; }

/* ---------- Design system showcase ---------- */
.rv-design{ max-width:var(--maxw);margin:0 auto;display:flex;flex-direction:column;gap:34px; }
.rv-swatches{ display:grid;grid-template-columns:repeat(2,1fr);gap:12px; }
@media (min-width:680px){ .rv-swatches{ grid-template-columns:repeat(5,1fr); } }
.rv-swatches .sw{
  height:108px;border-radius:14px;color:var(--cream);
  display:flex;align-items:flex-end;padding:14px;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;
}
.rv-typeset{ display:grid;grid-template-columns:1fr;gap:16px; }
@media (min-width:680px){ .rv-typeset{ grid-template-columns:repeat(3,1fr); } }
.rv-type{
  background:var(--paper);border:1.5px solid var(--mist);border-radius:16px;padding:22px;
  display:flex;flex-direction:column;gap:6px;
}
.rv-type-lbl{ font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--leaf); }
.rv-type-serif{ font-family:var(--serif);font-size:3.4rem;line-height:1;color:var(--moss); }
.rv-type-sans{ font-family:var(--sans);font-size:3.4rem;line-height:1;font-weight:600;color:var(--moss); }
.rv-type-mono{ font-family:var(--mono);font-size:3.4rem;line-height:1;color:var(--moss); }
.rv-type small{ font-size:.85rem;color:#5a6a5f; }
.rv-design-note{ text-align:center;max-width:64ch;margin:0 auto;font-size:1rem;line-height:1.65;color:#3a4a40; }
.rv-design-note i{ color:var(--moss);font-style:italic; }

/* ---------- Engagement ---------- */
.rv-engage{ max-width:880px;margin:0 auto 50px;list-style:none;display:grid;gap:14px; }
.rv-engage li{
  position:relative;padding:18px 20px 18px 52px;
  background:var(--paper);border:1.5px solid var(--mist);border-radius:14px;
  font-size:1rem;line-height:1.6;color:#3a4a40;
}
.rv-engage li::before{
  content:"";position:absolute;left:20px;top:23px;
  width:14px;height:18px;background:var(--moss);border-radius:7px 7px 2px 2px;
}
.rv-engage li::after{
  content:"";position:absolute;left:30px;top:31px;width:3px;height:3px;border-radius:50%;background:var(--coral);
}
.rv-engage b{ color:var(--ink); }

.rv-stats{ max-width:var(--maxw);margin:0 auto;text-align:center; }
.rv-stats-lbl{ font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--leaf); }
.rv-stat-row{ margin-top:22px;display:grid;grid-template-columns:repeat(2,1fr);gap:14px; }
@media (min-width:820px){ .rv-stat-row{ grid-template-columns:repeat(4,1fr); } }
.rv-stat{
  background:var(--moss);color:var(--cream);border-radius:18px;padding:26px 18px;
  display:flex;flex-direction:column;gap:10px;align-items:center;
}
.rv-stat big{ font-family:var(--serif);font-size:2.8rem;line-height:1;color:var(--coral);font-weight:500; }
.rv-stat span{ font-size:.86rem;line-height:1.4; }
.rv-stat i{ color:var(--sage);font-style:italic;font-size:.8rem; }
.rv-stats-foot{ margin:22px auto 0;max-width:60ch;font-size:.86rem;color:#5a6a5f;line-height:1.5; }

/* ---------- Final CTA ---------- */
.rv-final{
  background:linear-gradient(180deg,#16271c,var(--ink));color:var(--cream);
  padding:var(--section-y) var(--gutter);text-align:center;
}
.rv-final-inner{ max-width:680px;margin:0 auto; }
.rv-eyebrow-light{ color:var(--coral); }
.rv-final h2{
  font-family:var(--serif);font-variation-settings:"opsz" 144, "SOFT" 60;font-weight:400;
  font-size:2.2rem;line-height:1.1;margin:12px 0 0;
}
@media (min-width:820px){ .rv-final h2{ font-size:3rem; } }
.rv-final p{ margin:16px auto 0;max-width:50ch;color:rgba(244,238,223,.8);line-height:1.65; }
.rv-final-btn{ margin-top:30px; }
.rv-final-links{
  margin-top:30px;display:flex;flex-wrap:wrap;gap:8px 28px;justify-content:center;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
}
.rv-final-links a{ color:var(--sage);border-bottom:1px solid transparent;transition:all .25s var(--easing);padding-bottom:2px; }
@media (hover: hover){ .rv-final-links a:hover{ color:var(--cream);border-color:var(--coral); } }

/* ---------- Reveal on scroll (enhanced by revamp.js) ---------- */
.rv-section,.rv-final{ }
.rv-reveal{ opacity:0;transform:translateY(22px);transition:opacity .7s var(--easing), transform .7s var(--easing); }
.rv-reveal.in{ opacity:1;transform:none; }

/* ---------- Hero scroll hint (door now lives at the bottom) ---------- */
.rv-lede em{ color:var(--coral);font-style:italic; }
.rv-scroll-hint{
  display:inline-flex;align-items:center;gap:10px;
  margin:40px auto 0;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--cream);
  border:1.5px solid rgba(244,238,223,.28);
  padding:12px 22px;border-radius:99px;
  transition:border-color .3s var(--easing), background .3s var(--easing);
}
@media (hover: hover){ .rv-scroll-hint:hover{ border-color:var(--coral);background:rgba(220,110,74,.12); } }
.rv-scroll-arrow{ display:inline-block;animation:rvBob 1.8s var(--easing) infinite; }
@keyframes rvBob{ 0%,100%{transform:translateY(0);} 50%{transform:translateY(4px);} }

/* ---------- Final section: recap + the door ---------- */
.rv-final h2 em{ color:var(--coral);font-style:italic; }
.rv-recap{
  list-style:none;
  max-width:760px;margin:32px auto 0;
  display:grid;grid-template-columns:1fr;gap:10px;text-align:left;
}
@media (min-width:680px){ .rv-recap{ grid-template-columns:repeat(2,1fr); } }
.rv-recap li{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;border-radius:12px;
  background:rgba(244,238,223,.05);border:1px solid rgba(244,238,223,.12);
  font-size:.92rem;line-height:1.4;color:rgba(244,238,223,.86);
}
.rv-recap li span{
  flex-shrink:0;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;
  color:#2a1206;background:var(--coral);padding:5px 9px;border-radius:7px;
}
.rv-door-final{ margin:46px auto 10px; }

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  .rv-door-panel,.rv-door-glow,.rv-door-enter,.rv-reveal{ transition:none; }
  .rv-scroll-arrow{ animation:none; }
  .rv-reveal{ opacity:1;transform:none; }
}
