/* ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░
   LA RESERVA DE VENDORS — archival scrapbook / pressed-zine
   ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░ */

:root{
  --paper:#F0E6CD;
  --paper-2:#E8DABA;
  --paper-3:#F6EFDC;
  --green:#20402E;
  --green-2:#15301F;
  --green-soft:#3a5a45;
  --red:#C24430;
  --orange:#E07B3C;
  --ink:#23211A;
  --ink-soft:#5b554440;
  --line:rgba(32,64,46,.22);
  --line-2:rgba(32,64,46,.5);
  --shadow:18px 22px 44px -24px rgba(21,48,31,.55);

  --f-display:"Fraunces", Georgia, serif;
  --f-body:"Newsreader", Georgia, serif;
  --f-mono:"Spline Sans Mono", ui-monospace, monospace;
  --f-script:"Caveat", cursive;

  --maxw:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  background:var(--paper);
  color:var(--ink);
  font-size:clamp(1rem,.95rem + .25vw,1.18rem);
  line-height:1.6;
  overflow-x:hidden;
  position:relative;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic}

/* ── paper grain overlay ───────────────────────────── */
.grain{
  position:fixed;inset:0;z-index:999;pointer-events:none;
  opacity:.5;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
}
body::before{ /* warm vignette */
  content:"";position:fixed;inset:0;z-index:998;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 8%, transparent 55%, rgba(58,42,18,.16) 100%);
}

/* ── shared bits ───────────────────────────────────── */
.eyebrow{
  font-family:var(--f-mono);
  font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;
  color:var(--red);font-weight:500;margin-bottom:1.1rem;
}
.sec-head{max-width:760px;margin:0 auto clamp(2.4rem,5vw,4rem);text-align:center}
.sec-head h2{font-size:clamp(2.4rem,1.4rem + 4vw,4.6rem)}
.sec-sub{font-size:1.12rem;color:var(--green-soft);margin-top:1.2rem}

h1,h2,h3{font-family:var(--f-display);font-weight:600;color:var(--green);line-height:1.02;letter-spacing:-.01em}
h2{font-variation-settings:"opsz" 80}

.script-accent{font-family:var(--f-script);color:var(--red);font-size:1.9rem;line-height:1;transform:rotate(-3deg);transform-origin:left}

/* hand-drawn underline svg — sits under one word */
.hero-title .word-ul{position:relative;display:inline-block;white-space:nowrap}
.ul{position:absolute;left:-.02em;bottom:-.12em;width:104%;height:.34em;color:var(--red);overflow:visible;pointer-events:none}
.ul--red{color:var(--red)}
/* manifiesto heading underline keeps its own placement */
.man-text h2 .ul{bottom:-.06em;height:.3em;width:101%}

/* botanical sprigs */
.sprig{position:absolute;color:var(--green-soft);opacity:.32;width:clamp(70px,8vw,120px);pointer-events:none}

/* ── buttons ───────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5em;cursor:pointer;
  font-family:var(--f-mono);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.95em 1.6em;border-radius:999px;border:1.5px solid var(--green);
  transition:transform .25s cubic-bezier(.2,.9,.3,1), background .25s, color .25s, box-shadow .25s;
}
.btn--solid{background:var(--green);color:var(--paper-3)}
.btn--solid:hover{background:var(--green-2);transform:translateY(-3px);box-shadow:0 12px 22px -12px rgba(21,48,31,.7)}
.btn--ghost{background:transparent;color:var(--green)}
.btn--ghost:hover{background:var(--green);color:var(--paper-3);transform:translateY(-3px)}
.btn--full{width:100%;justify-content:center}

/* ░░░ HEADER ░░░ */
.site-head{
  position:sticky;top:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;padding:.85rem clamp(1.1rem,4vw,3rem);
  background:color-mix(in srgb, var(--paper) 82%, transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.7rem}
.brand-seal{width:40px;height:40px;color:var(--green);display:block}
.brand-seal svg{width:100%;height:100%}
.brand-word{font-family:var(--f-display);font-weight:700;color:var(--green);font-size:.96rem;line-height:1;letter-spacing:.01em}
.brand-word em{font-weight:400;font-style:italic;color:var(--green-soft)}
.site-nav{display:flex;align-items:center;gap:1.9rem}
.site-nav a{font-family:var(--f-mono);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--green);position:relative;padding:.3em 0}
.site-nav a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--red);transition:width .3s}
.site-nav a:not(.nav-cta):hover::after{width:100%}
.nav-cta{border:1.5px solid var(--green);border-radius:999px;padding:.55em 1.1em!important;background:var(--green);color:var(--paper-3)!important;transition:background .25s}
.nav-cta:hover{background:var(--green-2)}
.menu-btn{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.menu-btn span{width:26px;height:2px;background:var(--green);transition:.3s}

/* ░░░ HERO ░░░ */
.hero{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(2rem,6vw,5rem) clamp(1.1rem,4vw,3rem) 2rem;position:relative}
.hero-frame{
  position:relative;width:100%;max-width:var(--maxw);
  border:1.5px solid var(--line-2);border-radius:10px;
  padding:clamp(2rem,5vw,4.4rem) clamp(1.4rem,5vw,4.4rem);
  text-align:left;
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3.2rem);align-items:center;
  background:
    linear-gradient(var(--paper-3),var(--paper-3)) padding-box;
  box-shadow:var(--shadow);
}
.hero-copy{position:relative;z-index:2}
.hero-figure{position:relative;z-index:2;display:flex;justify-content:center}
.hero-figure img{
  width:100%;max-width:440px;height:auto;
  filter:drop-shadow(10px 16px 22px rgba(21,48,31,.28));
  animation:heroFloat 6s ease-in-out infinite;
}
@keyframes heroFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hero-frame::after{ /* inner hairline */
  content:"";position:absolute;inset:7px;border:1px solid var(--line);border-radius:6px;pointer-events:none;
}
.hero-tape{position:absolute;width:128px;height:38px;background:rgba(224,123,60,.32);border:1px dashed rgba(120,70,30,.3);transform:rotate(-6deg);z-index:3;mix-blend-mode:multiply}
.hero-tape--a{top:-16px;left:42px;transform:rotate(-7deg)}
.hero-tape--b{bottom:-15px;right:60px;transform:rotate(5deg);background:rgba(32,64,46,.16)}

.hero-seal{position:absolute;top:clamp(-30px,-2vw,-20px);right:clamp(-26px,2vw,40px);width:clamp(96px,13vw,160px);color:var(--green);z-index:4}
.hero-seal svg{width:100%;height:100%}
.seal-spin{animation:spin 44s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.sprig--tl{top:18px;left:14px;transform:scaleX(-1) rotate(8deg)}
.sprig--br{bottom:18px;right:18px;transform:rotate(8deg)}

.hero-title{font-size:clamp(2.6rem,1rem + 6.4vw,5.6rem);line-height:.94;letter-spacing:-.025em;font-weight:600;margin:.15em 0 .45em;font-variation-settings:"opsz" 120,"SOFT" 0}
.hero-title span{display:block}
.hero-title__accent{position:relative;color:var(--green);display:inline-block}
.hero-lead{max-width:540px;margin:0;font-size:clamp(1.02rem,.96rem + .4vw,1.22rem);color:var(--green-soft)}
.hero-lead strong{color:var(--ink);font-weight:600}
.hero-cta{display:flex;gap:.9rem;justify-content:flex-start;flex-wrap:wrap;margin:2rem 0 1.4rem}
.hero-meta{display:flex;gap:.9rem;justify-content:flex-start;align-items:center;flex-wrap:wrap}
.chip{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;background:var(--green);color:var(--paper-3);padding:.5em 1em;border-radius:999px;display:inline-flex;align-items:center;gap:.6em}
.chip .dot{width:7px;height:7px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 0 rgba(224,123,60,.7);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(224,123,60,.6)}70%{box-shadow:0 0 0 9px rgba(224,123,60,0)}100%{box-shadow:0 0 0 0 rgba(224,123,60,0)}}
.chip-soft{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--green-soft);border:1px dashed var(--line-2);padding:.5em 1em;border-radius:999px}

.scroll-cue{margin-top:2.4rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--green-soft);font-family:var(--f-mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase}
.scroll-cue svg{width:20px;height:20px;animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ░░░ MANIFIESTO ░░░ */
.manifiesto{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,8rem) clamp(1.1rem,4vw,3rem)}
.man-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.man-photo{position:relative}
.polaroid{background:#fbf6e9;padding:14px 14px 54px;box-shadow:var(--shadow);transform:rotate(-3deg);border:1px solid rgba(0,0,0,.05);position:relative}
.polaroid img{width:100%;aspect-ratio:1/1;object-fit:cover;filter:saturate(.94) contrast(1.02)}
.polaroid figcaption{position:absolute;bottom:14px;left:0;width:100%;text-align:center}
.stamp-mini{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red)}
.photo-tape{position:absolute;top:-16px;left:50%;transform:translateX(-50%) rotate(-4deg);width:120px;height:34px;background:rgba(224,123,60,.4);mix-blend-mode:multiply;z-index:5;border:1px dashed rgba(120,70,30,.25)}
.seal-stamp{position:absolute;bottom:-26px;right:-18px;width:96px;color:var(--red);opacity:.85;transform:rotate(-12deg);mix-blend-mode:multiply}

.man-text h2{font-size:clamp(2rem,1.2rem + 3.4vw,3.7rem);position:relative;display:inline-block;margin-bottom:1.4rem}
.man-text p{margin-bottom:1.1rem;color:var(--ink)}
.man-text .pull{font-family:var(--f-display);font-style:italic;font-size:1.4rem;line-height:1.35;color:var(--green);border-left:3px solid var(--red);padding-left:1.2rem;margin:1.6rem 0}
.signature{font-family:var(--f-script);font-size:2rem;color:var(--green);line-height:1}
.signature span{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--green-soft);vertical-align:middle}

/* ░░░ CÓMO FUNCIONA ░░░ */
.funciona{background:var(--paper-2);border-block:1px solid var(--line);padding:clamp(4rem,9vw,8rem) clamp(1.1rem,4vw,3rem)}
.funciona h2 em{font-style:italic;color:var(--red)}
.steps{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,3vw,2.4rem)}
.step{background:var(--paper-3);border:1px solid var(--line);border-radius:8px;padding:2rem 1.8rem 2.2rem;position:relative;box-shadow:0 10px 30px -22px rgba(21,48,31,.6);transition:transform .3s, box-shadow .3s}
.step:hover{transform:translateY(-6px);box-shadow:0 18px 38px -22px rgba(21,48,31,.6)}
.step-no{font-family:var(--f-mono);font-size:.8rem;color:var(--red);letter-spacing:.1em}
.step h3{font-size:1.7rem;margin:.5rem 0 .7rem}
.step p{font-size:1rem;color:var(--green-soft)}

.criteria{max-width:760px;margin:clamp(2.6rem,5vw,4rem) auto 0;text-align:center;background:var(--green);color:var(--paper-3);border-radius:12px;padding:clamp(2rem,4vw,3rem);box-shadow:var(--shadow)}
.criteria h3{color:var(--paper-3);font-size:1.8rem;margin-bottom:1.4rem}
.check{list-style:none;display:inline-grid;gap:.7rem;text-align:left;margin-bottom:2rem}
.check li{position:relative;padding-left:2rem;color:#e9e0c8;font-size:1.06rem}
.check li::before{content:"\2713";position:absolute;left:0;top:0;color:var(--orange);font-family:var(--f-mono);font-weight:600}
.criteria .btn--solid{background:var(--orange);border-color:var(--orange);color:var(--green-2)}
.criteria .btn--solid:hover{background:#f08f4e;border-color:#f08f4e}

/* ░░░ RESERVA / ARCHIVO ░░░ */
.reserva{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,8rem) clamp(1.1rem,4vw,3rem)}
.entry-feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;background:var(--paper-3);border:1px solid var(--line);border-radius:14px;padding:clamp(1.2rem,3vw,2rem);box-shadow:var(--shadow);position:relative}
.entry-feature__media{position:relative}
.entry-feature__media img{border-radius:8px;width:100%;box-shadow:0 14px 30px -18px rgba(21,48,31,.6)}
.entry-no{position:absolute;top:14px;left:14px;z-index:2;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;background:var(--paper);color:var(--green);padding:.4em .8em;border-radius:999px;border:1px solid var(--line)}
.entry-feature__body .kicker{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:.6rem}
.entry-feature__body h3{font-size:clamp(2.4rem,1.6rem + 3vw,3.8rem);margin-bottom:.3rem}
.entry-feature__body .script-accent{margin-bottom:1.1rem}
.entry-feature__body p{font-size:1rem;color:var(--ink);margin-bottom:.9rem}
.entry-tags{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.2rem;font-family:var(--f-mono);font-size:.78rem;letter-spacing:.04em;color:var(--green-soft)}
.entry-tags a{color:var(--red)}
.entry-tags a:hover{text-decoration:underline}

.entry-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.9rem;margin-top:clamp(2rem,4vw,3rem)}
.entry-card{aspect-ratio:3/4;border-radius:8px;border:1px dashed var(--line-2);background:var(--paper-3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--green-soft);text-align:center;padding:1rem;transition:transform .25s, background .25s}
.entry-card:hover{transform:translateY(-4px);background:var(--paper)}
.entry-card .ec-no{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.1em;color:var(--green)}
.entry-card .ec-state{font-family:var(--f-script);font-size:1.5rem;color:var(--red);line-height:1}
.entry-card .ec-seal{width:34px;height:34px;color:var(--line-2)}
.entry-card.is-reserved .ec-seal{color:var(--green-soft)}
.entry-card.is-filled{border-style:solid;border-color:var(--green);background:var(--paper-3);color:var(--green);text-decoration:none}
.entry-card.is-filled:hover{background:var(--green);color:var(--paper-3)}
.entry-card.is-filled .ec-seal{color:var(--green)}
.entry-card.is-filled:hover .ec-seal{color:var(--paper-3)}
.entry-card .ec-name{font-family:var(--f-display);font-size:1.15rem;line-height:1.05;color:inherit}
.entry-card .ec-cat{font-family:var(--f-mono);font-size:.64rem;letter-spacing:.06em;text-transform:uppercase;color:inherit;opacity:.7}
.foot-admin{opacity:.55}
.foot-admin:hover{opacity:1}
.entry-foot{text-align:center;margin-top:2.4rem;color:var(--green-soft);font-size:1rem}
.entry-foot a{color:var(--red);font-weight:600}

/* ░░░ INTAKE ░░░ */
.intake{padding:clamp(4rem,9vw,8rem) clamp(1.1rem,4vw,3rem);background:var(--paper-2);border-top:1px solid var(--line)}
.intake-card{max-width:720px;margin:0 auto;background:var(--paper-3);border:1.5px solid var(--line-2);border-radius:16px;padding:clamp(1.8rem,5vw,3.4rem);box-shadow:var(--shadow);position:relative;overflow:hidden;text-align:center}
.sprig--intake{position:absolute;top:-20px;right:-10px;opacity:.18;transform:rotate(18deg)}
.intake-card h2{font-size:clamp(1.9rem,1.2rem + 3vw,3rem);margin-bottom:1.8rem}
.intake-card h2 em{color:var(--red);font-style:italic}
.tabs{display:inline-flex;gap:.4rem;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.35rem;margin-bottom:2rem}
.tab{font-family:var(--f-mono);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;border:0;background:none;cursor:pointer;padding:.6em 1.3em;border-radius:999px;color:var(--green);transition:background .25s,color .25s}
.tab.is-active{background:var(--green);color:var(--paper-3)}

.intake-form{display:none;text-align:left}
.intake-form.is-active{display:block;animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1rem}
.field label{display:block;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--green-soft)}
.field label span{color:var(--red)}
.field label span.opt{color:var(--green-soft);text-transform:none;letter-spacing:0}
.field input,.field textarea{
  width:100%;margin-top:.45rem;font-family:var(--f-body);font-size:1rem;color:var(--ink);
  background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:.8em .9em;resize:vertical;
  transition:border-color .25s, box-shadow .25s;
}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 3px rgba(32,64,46,.12)}
.intake-form .btn{margin-top:.6rem}
.intake-note{margin-top:1.2rem;font-family:var(--f-mono);font-size:.82rem;letter-spacing:.02em;min-height:1.2em}
.intake-note.ok{color:var(--green)}
.intake-note.err{color:var(--red)}

/* ░░░ FOOTER ░░░ */
.site-foot{background:var(--green);color:var(--paper-3);text-align:center;padding:clamp(3.5rem,7vw,6rem) 1.5rem clamp(2rem,4vw,3rem);position:relative}
.foot-seal{width:120px;color:var(--paper-3);opacity:.9;margin:0 auto 1.6rem}
.foot-tag{font-family:var(--f-display);font-style:italic;font-size:clamp(1.6rem,1.2rem + 2vw,2.6rem);color:var(--paper-3)}
.foot-lead{color:#cdbf9d;margin:.6rem auto 1.8rem;max-width:440px}
.foot-links{display:flex;gap:1.6rem;justify-content:center;flex-wrap:wrap;margin-bottom:2rem}
.foot-links a{font-family:var(--f-mono);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;position:relative}
.foot-links a:hover{color:var(--orange)}
.foot-fine{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.06em;color:#9d9173}
.foot-fine a{text-decoration:underline;color:inherit}
.foot-fine a:hover{color:var(--orange)}

/* ░░░ SCROLL REVEAL ░░░ */
.reveal,.reveal-up{opacity:0;will-change:transform,opacity}
.reveal{transform:translateY(14px)}
.reveal-up{transform:translateY(34px)}
.reveal.in,.reveal-up.in{opacity:1;transform:none;transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.hero .reveal[data-d="1"]{transition-delay:.05s}
.hero .reveal[data-d="2"]{transition-delay:.12s}
.hero .reveal[data-d="3"]{transition-delay:.20s}
.hero .reveal[data-d="4"]{transition-delay:.28s}
.hero .reveal[data-d="5"]{transition-delay:.40s}
.hero .reveal[data-d="6"]{transition-delay:.50s}
.hero .reveal[data-d="7"]{transition-delay:.60s}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal,.reveal-up{opacity:1;transform:none}
}

/* ░░░ RESPONSIVE ░░░ */
@media (max-width:860px){
  .site-nav{
    position:fixed;inset:0 0 auto 0;top:64px;flex-direction:column;gap:1.4rem;
    background:var(--paper-3);padding:2rem;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .4s cubic-bezier(.2,.8,.2,1);
  }
  .site-nav.open{transform:translateY(0)}
  .menu-btn{display:flex}
  .menu-btn.open span:first-child{transform:translateY(3.5px) rotate(45deg)}
  .menu-btn.open span:last-child{transform:translateY(-3.5px) rotate(-45deg)}
  .man-grid{grid-template-columns:1fr;gap:3rem}
  .man-photo{max-width:340px;margin:0 auto}
  .steps{grid-template-columns:1fr}
  .entry-feature{grid-template-columns:1fr}
  .hero-seal{width:84px;top:-22px;right:6px}
  .hero-frame{grid-template-columns:1fr;text-align:center;gap:1.4rem}
  .hero-copy{order:2}
  .hero-figure{order:1}
  .hero-figure img{max-width:300px;animation:none}
  .hero-lead{margin:0 auto;max-width:560px}
  .hero-cta,.hero-meta{justify-content:center}
}
@media (max-width:520px){
  .row{grid-template-columns:1fr}
  .hero-tape{display:none}
  .hero-frame{padding-inline:1.2rem}
}
