
  :root{
    --black:#070707;
    --black-warm:#0c0707;
    --red:#a4051d;
    --red-deep:#5c020f;
    --cream:#ebebe3;
    --cream-warm:#f1ede2;
    /* Warm stone — dominant page surface */
    --stone:#e8e0d8;
    --stone-2:#ded3c6;
    --stone-line:#cabfb0;
    --ink:#1a1a1a;
    --ink-soft:#5a514a;
    --gold:#c9a24a;
    --serif:'Cormorant Garamond', serif;
    --sans:'Outfit', system-ui, sans-serif;
  }
  *{box-sizing:border-box; margin:0; padding:0;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--stone); color:var(--ink);
    font-family:var(--sans); font-weight:400; line-height:1.65;
    overflow-x:hidden; -webkit-font-smoothing:antialiased; font-size:21px;
    text-wrap:pretty;
  }
  body::before{
    content:""; position:fixed; inset:0; pointer-events:none; z-index:1;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.32 0 0 0 0 0.27 0 0 0 0 0.20 0 0 0 0.16 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.5'/></svg>");
    opacity:.30; mix-blend-mode:multiply;
  }
  img{max-width:100%; display:block;}
  a{color:inherit; text-decoration:none;}
  button{font:inherit; cursor:pointer; background:none; border:none; color:inherit;}
  ::selection{background:var(--red); color:var(--cream);}
  .serif{font-family:var(--serif);}
  p, li{text-wrap:pretty;}
  h1, h2, h3, h4{text-wrap:balance;}

  /* Reusable */
  .micro{font-family:var(--sans); font-size:.72rem; letter-spacing:.32em; text-transform:uppercase; font-weight:500;}
  .micro-red{color:var(--red);}
  .container{max-width:1320px; margin:0 auto; padding:0 32px; position:relative; z-index:2;}
  .narrow{max-width:920px; margin:0 auto; padding:0 32px; position:relative; z-index:2;}
  .ultra-narrow{max-width:720px; margin:0 auto; padding:0 32px; position:relative; z-index:2;}

  /* Hairline label with lines */
  .kicker{display:flex; align-items:center; justify-content:center; gap:18px; margin-bottom:24px;}
  .kicker .l{display:block; height:1px; width:60px; background:var(--red);}
  .kicker .t{font-family:var(--sans); font-size:.95rem; letter-spacing:.34em; text-transform:uppercase; color:var(--red); font-weight:700;}
  .kicker.start{justify-content:flex-start;}
  .kicker.dark .t{color:var(--cream); opacity:.55;}
  .kicker.dark .l{background:rgba(235,235,227,.35);}

  /* CTA */
  .cta{
    display:inline-flex; align-items:center; gap:14px;
    background:var(--red); color:var(--cream);
    padding:20px 38px; font-family:var(--sans); font-weight:500;
    letter-spacing:.18em; text-transform:uppercase; font-size:.78rem;
    border:1px solid var(--red); cursor:pointer; position:relative;
    transition:transform .3s, background .3s;
    animation:ctaPulse 2.5s ease-in-out infinite;
  }
  .cta:hover{transform:translateY(-2px); animation-play-state:paused; box-shadow:0 0 50px 4px rgba(164,5,29,.7);}
  .cta .arrow{display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border:1px solid currentColor; border-radius:50%; transition:transform .3s;}
  .cta:hover .arrow{transform:translateX(6px);}
  .cta.outline{background:transparent; color:var(--cream);}
  .cta.outline:hover{background:var(--red);}
  .cta.cream{background:var(--cream); color:var(--black); border-color:var(--cream);}
  .cta.cream:hover{background:var(--red); color:var(--cream); border-color:var(--red);}
  @keyframes ctaPulse{0%,100%{box-shadow:0 0 0 0 rgba(164,5,29,.45);} 50%{box-shadow:0 0 28px 6px rgba(164,5,29,.5);}}

  /* Elevated CTA with sublabel */
  .cta-elev{display:inline-flex; flex-direction:column; align-items:center; gap:14px;}
  .cta-elev .sub{font-size:.66rem; letter-spacing:.42em; text-transform:uppercase; color:var(--red); font-weight:600;}
  .cta-elev .meta{font-family:var(--serif); font-style:italic; color:var(--cream); opacity:.7; font-size:.95rem; margin-top:6px;}

  /* ============ LAUNCH PRICE BADGE (premium, repeated at every CTA) ============ */
  .launch-badge{
    display:inline-flex; align-items:center; gap:16px; max-width:560px;
    padding:16px 26px; border:1px solid var(--red); background:rgba(164,5,29,.06);
    text-align:left;
  }
  .launch-badge .lb-mark{
    flex:none; font-family:var(--sans); font-weight:700; font-size:.62rem; letter-spacing:.28em;
    text-transform:uppercase; color:var(--cream); background:var(--red); padding:7px 12px; line-height:1;
  }
  .launch-badge .lb-text{font-family:var(--serif); font-style:italic; font-weight:500; font-size:1.12rem; line-height:1.32; color:var(--ink);}
  .launch-badge .lb-text b{font-style:normal; font-weight:700; color:var(--red);}
  /* On dark sections */
  .on-dark .launch-badge{background:rgba(7,7,7,.55); border-color:var(--red);}
  .on-dark .launch-badge .lb-text{color:var(--cream);}
  .on-dark .launch-badge .lb-text b{color:var(--gold);}
  @media(max-width:560px){.launch-badge{flex-direction:column; align-items:flex-start; gap:10px;}}

  /* Section CTA block — reusable closing CTA with badge */
  .cta-stop{display:flex; flex-direction:column; align-items:center; gap:24px; text-align:center; padding:96px 32px 0;}
  .cta-stop.tight{padding-top:64px;}
  .cta-stop .cta{padding:24px 44px; font-size:.9rem;}

  /* Reveal — scroll motion: slides in on enter, eases out off-screen */
  .reveal{opacity:0; transform:translateY(34px); transition:opacity 1s ease, transform 1.05s cubic-bezier(.2,.7,.2,1); transition-delay:calc(var(--i, 0) * 0.09s); will-change:opacity, transform;}
  .reveal.in{opacity:1; transform:none;}
  .reveal.left{transform:translateX(-48px);} .reveal.left.in{transform:none;}
  .reveal.right{transform:translateX(48px);} .reveal.right.in{transform:none;}
  .reveal.scale{transform:scale(.93);} .reveal.scale.in{transform:none;}
  .reveal.blur{filter:blur(9px);} .reveal.blur.in{filter:none;}
  .reveal-scale{opacity:0; transform:scale(.94); transition:opacity 1s ease, transform 1.2s cubic-bezier(.2,.7,.2,1); transition-delay:calc(var(--i,0)*.08s);}
  .reveal-scale.in{opacity:1; transform:none;}
  @media(prefers-reduced-motion:reduce){.reveal,.reveal.left,.reveal.right,.reveal.scale,.reveal.blur,.reveal-scale{opacity:1 !important; transform:none !important; filter:none !important;}}

  /* Float */
  .float{animation:floatY 6s ease-in-out infinite;}
  @keyframes floatY{0%,100%{transform:translateY(0);} 50%{transform:translateY(-8px);}}
  .ring-rotate{animation:ringRotate 60s linear infinite; transform-origin:center; transform-box:fill-box;}
  @keyframes ringRotate{to{transform:rotate(360deg);}}

  /* Embers */
  .embers{position:absolute; inset:0; pointer-events:none; overflow:hidden; z-index:2;}
  .ember{position:absolute; bottom:-10px; width:4px; height:4px; background:var(--red); border-radius:50%; opacity:0; box-shadow:0 0 6px 1px rgba(164,5,29,.6); animation:rise linear infinite;}
  @keyframes rise{
    0%{transform:translateY(0); opacity:0;}
    10%{opacity:var(--o,.6);}
    50%{transform:translateY(-50vh) translateX(var(--dx,12px));}
    100%{transform:translateY(-100vh) translateX(var(--dx2,-8px)); opacity:0;}
  }

  /* ============ SCARCITY STRIP ============ */
  .scarcity{
    position:sticky; top:0; z-index:70; background:var(--red);
    height:6px;
  }

  /* ============ NAV ============ */
  nav.site{
    position:sticky; top:36px; z-index:60;
    padding:16px 32px; display:flex; align-items:center; justify-content:space-between;
    background:rgba(232,224,216,.82); backdrop-filter:blur(14px);
    border-bottom:1px solid var(--stone-line);
  }
  nav.site .brand-link{display:flex; align-items:center;}
  nav.site .brand-link img{height:30px; width:auto;}
  nav.site .nav-right{display:flex; align-items:center; gap:16px;}
  nav.site .ig-mini{display:flex; align-items:center; gap:8px; font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink); padding:8px 14px; transition:color .25s;}
  nav.site .ig-mini:hover{color:var(--red);}
  nav.site .ig-mini svg{width:16px; height:16px;}
  nav.site .nav-cta{font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; padding:10px 20px; border:1px solid var(--red); color:var(--red); font-weight:600; transition:background .25s, color .25s;}
  nav.site .nav-cta:hover{background:var(--red); color:var(--cream);}
  @media(max-width:640px){nav.site .ig-mini span{display:none;}}

  /* ============ HERO — FULL-BLEED CINÉTICO ============ */
  .hero{position:relative; min-height:100vh; overflow:hidden; background:var(--black); display:block;}

  /* TEXT overlay — anchored left, floats over the photo */
  .hero .hero-stage{position:relative; z-index:4; display:flex; flex-direction:column;
    padding:52px 28px 80px 64px; min-height:100vh; background:none; max-width:680px;}
  @media(max-width:1000px){.hero .hero-stage{max-width:100%; padding:44px 36px 72px; min-height:100vh;}}
  @media(max-width:760px){.hero .hero-stage{padding:36px 26px 56px;}}
  .hero .hero-stage-inner{display:flex; flex-direction:column; justify-content:center; flex:1; width:100%;}
  .hero .stage-logo{margin-bottom:52px; align-self:flex-start;}
  .hero .stage-logo img{height:104px; width:auto; filter:drop-shadow(0 0 30px rgba(212,175,55,.40));}
  @media(max-width:760px){.hero .stage-logo{margin-bottom:34px;} .hero .stage-logo img{height:66px;}}
  .hero .stage-top-row{display:flex; justify-content:space-between; align-items:flex-start;}

  /* PHOTO — absolute full-bleed background, face on the right */
  .hero .hero-bg{position:absolute; inset:0; z-index:0; overflow:hidden;}
  .hero .hero-bg img{width:100%; height:100%; object-fit:cover; object-position:72% 18%;
    filter:saturate(1.05) contrast(1.06); transition:transform 1.6s cubic-bezier(.2,.7,.2,1);}
  .hero:hover .hero-bg img{transform:scale(1.04);}
  /* Strong dark veil left side → text stays legible while Shakti's face shines right */
  .hero .hero-bg::before{content:""; position:absolute; inset:0; pointer-events:none; z-index:2;
    background:
      linear-gradient(108deg, rgba(7,7,7,.97) 0%, rgba(7,7,7,.88) 30%, rgba(7,7,7,.52) 52%, rgba(7,7,7,.10) 72%, transparent 100%),
      linear-gradient(0deg, rgba(7,7,7,.72) 0%, rgba(7,7,7,0) 40%);}
  /* Red glow — bottom-left warmth */
  .hero .hero-bg::after{content:""; position:absolute; left:-8%; bottom:-12%; z-index:1; width:52%; height:58%; pointer-events:none;
    background:radial-gradient(ellipse at 30% 80%, rgba(164,5,29,.20), transparent 65%); filter:blur(4px);}
  @media(max-width:1000px){
    .hero .hero-bg img{object-position:62% 18%;}
    .hero .hero-bg::before{background:
      linear-gradient(0deg, rgba(7,7,7,.92) 0%, rgba(7,7,7,.72) 38%, rgba(7,7,7,.30) 65%, transparent 100%),
      linear-gradient(90deg, rgba(7,7,7,.88) 0%, transparent 60%);}}

  /* subtle yoni behind photo */
  .hero-yoni-deco{position:absolute; right:15%; top:40%; width:58px; opacity:.2; z-index:0; pointer-events:none;
    filter:drop-shadow(0 0 14px rgba(164,5,29,.4)); animation:heroYoni 22s linear infinite;}
  @keyframes heroYoni{0%{transform:rotate(0deg);} 100%{transform:rotate(360deg);}}
  @media(max-width:1000px){.hero-yoni-deco{display:none;}}

  /* vertical mark on photo edge */
  .hero-photo-mark{position:absolute; right:26px; top:38px; z-index:4; writing-mode:vertical-rl; transform:rotate(180deg);
    font-family:var(--sans); font-size:.68rem; letter-spacing:.42em; text-transform:uppercase; color:var(--cream); opacity:.85; font-weight:500; text-shadow:0 1px 12px rgba(0,0,0,.55);}
  @media(max-width:1000px){.hero-photo-mark{display:none;}}

  .hero .ribbon{display:none;}
  .hero .hero-top{display:none;}

  .hero-title{font-family:var(--serif); font-weight:600; font-size:clamp(2.85rem, 4.4vw, 5.2rem); line-height:1.04; color:var(--cream); letter-spacing:-.012em; margin:0;}
  .hero-title .ln{display:block; text-wrap:balance;}
  .hero-title .ln + .ln{margin-top:.55em;}
  .hero-title em{font-style:italic; font-weight:500;}
  .hero-title .it-red{color:var(--red); font-style:italic; font-weight:600;}
  .hero-title .it-gold{color:var(--gold); font-style:italic; font-weight:600;}
  .hero-quote{font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(1.55rem, 1.9vw, 2.05rem); margin-top:30px; color:var(--cream); max-width:640px; line-height:1.4;}
  .hero-quote-sec{font-family:var(--serif); font-weight:500; font-size:clamp(1.32rem, 1.55vw, 1.65rem); margin-top:16px; color:var(--cream); opacity:.82; max-width:640px; line-height:1.45;}
  .hero-quote-sec em{color:var(--cream); font-style:italic; font-weight:600; opacity:1;}
  .hero-body-long{font-family:var(--sans); font-weight:400; font-size:clamp(1.1rem, 1.2vw, 1.28rem); margin-top:26px; color:var(--cream); opacity:.78; max-width:620px; line-height:1.62;}
  .hero-bottom{display:flex; flex-direction:column; align-items:flex-start; gap:22px; margin-top:40px;}
  .hero-bottom .cta{padding:22px 42px; font-size:.88rem;}

  /* ============ MARQUEE ============ */
  .marquee{padding:22px 0; overflow:hidden; border-top:1px solid rgba(164,5,29,.4); border-bottom:1px solid rgba(164,5,29,.4); background:var(--cream);}
  .marquee-track{display:flex; gap:48px; white-space:nowrap; animation:marquee 22s linear infinite; will-change:transform;}
  .marquee-item{font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(1.4rem,2.6vw,2.1rem); color:var(--red); display:inline-flex; align-items:center; gap:48px;}
  .marquee-item .dot{display:inline-block; width:10px; height:10px; background:var(--red); border-radius:50%; transform:rotate(45deg);}
  @keyframes marquee{from{transform:translateX(0);} to{transform:translateX(-50%);}}

  /* ============ BRAND PNG SYMBOLS ============ */
  .brand-sym{display:block; user-select:none; -webkit-user-drag:none; pointer-events:none;}
  .sym-float{animation:symFloat 7s ease-in-out infinite;}
  @keyframes symFloat{0%,100%{transform:translateY(0) rotate(-1.5deg);} 50%{transform:translateY(-14px) rotate(1.5deg);}}
  /* contextual floating marks, low-opacity, behind content */
  .ambient-sym{position:absolute; pointer-events:none; z-index:0; opacity:.10;}
  .ambient-sym img{width:100%; height:auto; display:block; filter:drop-shadow(0 0 20px rgba(164,5,29,.25));}
  .camino-origin{margin:48px auto 0; opacity:.95; filter:drop-shadow(0 0 22px rgba(164,5,29,.35));}
  .wall-heart{margin:0 auto 18px; opacity:.95;}
  .final-yoni{position:absolute; left:50%; bottom:14%; transform:translateX(-50%); opacity:.20; z-index:1; filter:drop-shadow(0 0 30px rgba(164,5,29,.4));}

  /* ============ FOR-YOU EXTRAS ============ */
  .fy-closer{margin:60px auto 0; max-width:920px; padding:38px 32px 0; border-top:1px solid rgba(164,5,29,.4); text-align:center; font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(1.6rem,2.4vw,2.1rem); line-height:1.35; color:var(--ink);}
  .fy-closer em{color:var(--red); font-style:italic;}
  .fy-cta-block{margin:50px auto 0; text-align:center; display:flex; flex-direction:column; align-items:center; gap:22px;}
  .fy-cta-note{font-family:var(--serif); font-style:italic; color:var(--ink-soft); font-size:1.05rem; max-width:640px; line-height:1.5;}
  .hook{background:var(--stone); color:var(--ink); padding:140px 32px; text-align:center;}
  .hook .kicker .t{color:var(--red);}
  .hook .kicker .l{background:var(--red);}
  .hook h2{font-family:var(--serif); font-weight:500; font-size:clamp(2.3rem, 4.2vw, 3.5rem); line-height:1.1; color:var(--ink); max-width:1120px; margin:0 auto; text-wrap:balance;}
  .hook h2 em{color:var(--red); font-style:italic; font-weight:600;}
  .hook .body{max-width:880px; margin:34px auto 0; font-size:1.5rem; line-height:1.72; color:var(--ink-soft);}
  .hook .body p{margin-bottom:18px;}
  .hook .body em{color:var(--red); font-style:italic;}
  .hook .closer{font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(1.6rem,2.4vw,2rem); margin-top:42px; color:var(--ink);}
  .hook .closer .acc{color:var(--red);}

  /* ============ ¿ES PARA TI? — numbered list ============ */
  .for-you{padding:140px 32px; background:var(--stone-2); border-top:1px solid var(--stone-line); border-bottom:1px solid var(--stone-line);}
  .for-you .fy-inner{max-width:1100px; margin:0 auto;}
  .for-you .grid{display:flex; flex-direction:column; gap:0; margin:48px auto 0; max-width:880px;}
  @media(max-width:760px){.for-you .grid{margin-top:32px;}}
  .for-you h2{font-family:var(--serif); font-weight:500; font-size:clamp(2.2rem, 3.8vw, 3.2rem); color:var(--ink); line-height:1.1; margin-top:18px;}
  .fy-item{display:block; text-align:center; padding:26px 16px; border-bottom:1px solid var(--stone-line);}
  .fy-item .n{font-family:var(--serif); font-style:italic; font-weight:600; color:var(--red); font-size:1.2em; margin-right:.05em;}
  .fy-item .n::after{content:' — '; color:var(--red);}
  .fy-item .t{font-family:var(--serif); font-weight:500; font-style:italic; font-size:clamp(1.45rem, 2.1vw, 1.95rem); line-height:1.4; color:var(--ink);}
  @media(max-width:760px){.fy-item{padding:20px 6px;} .fy-item .t{font-size:1.35rem;}}

  /* ============ PILLARS — black, cream text, red accents ============ */
  .pillars{background:var(--black); padding:140px 32px; position:relative;}
  .pillars .head{text-align:center; max-width:980px; margin:0 auto 70px;}
  .pillars .head h2{font-family:var(--serif); font-weight:500; font-size:clamp(2.4rem,4.4vw,3.8rem); color:var(--cream); line-height:1.06; margin-top:18px;}
  .pillars .head h2 em{color:var(--red); font-style:italic;}
  .pillars .head p{font-family:var(--serif); font-style:italic; font-size:1.35rem; color:rgba(235,235,227,.78); margin-top:18px;}
  .pillars-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:28px; max-width:1500px; margin:0 auto;}
  @media(max-width:1100px){.pillars-grid{grid-template-columns:repeat(2,1fr);}}
  @media(max-width:640px){.pillars-grid{grid-template-columns:1fr;}}
  .pcol{display:flex; flex-direction:column; background:var(--cream); border:1px solid rgba(164,5,29,.18); border-top:3px solid var(--red); box-shadow:0 28px 56px -30px rgba(0,0,0,.7); transition:transform .4s ease, box-shadow .4s ease;}
  .pcol:hover{transform:translateY(-5px); box-shadow:0 36px 70px -30px rgba(120,20,30,.45);}
  .pcol .photo{aspect-ratio:4/5; overflow:hidden; position:relative;}
  /* UNIFIED photo treatment — same camera/filter feel across all four */
  .pcol .photo img{width:100%; height:100%; object-fit:cover; filter:saturate(.78) contrast(1.06) brightness(1.02) sepia(.08); transition:transform 1s ease;}
  .pcol:hover .photo img{transform:scale(1.05);}
  .pcol .photo::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(92,2,15,.06) 0%, rgba(92,2,15,0) 40%, rgba(40,24,16,.32) 100%); mix-blend-mode:multiply;}
  .pcol .body{background:transparent; color:var(--ink); padding:40px 32px 44px; flex:1; display:flex; flex-direction:column;}
  .pcol .body .n{font-family:var(--serif); font-style:italic; font-weight:700; font-size:2rem; color:var(--red); opacity:.9; line-height:1; margin-bottom:14px;}
  .pcol .body .lab{font-size:.66rem; letter-spacing:.32em; text-transform:uppercase; color:var(--red); margin-bottom:14px; font-weight:700;}
  .pcol .body h3{font-family:var(--serif); font-weight:600; font-size:1.7rem; line-height:1.2; color:var(--ink); margin-bottom:16px;}
  .pcol .body .pl-sub{font-family:var(--serif); font-style:italic; font-weight:500; font-size:1.18rem; color:var(--red); margin-bottom:16px; line-height:1.3;}
  .pcol .body p{color:rgba(26,26,26,.75); font-size:1.08rem; line-height:1.7; margin-bottom:16px;}

  /* ============ CHAPTERS ============ */
  .chapters{padding:140px 0; background:var(--black);}
  .chapters .head{text-align:center; max-width:980px; margin:0 auto 70px; padding:0 32px;}
  .chapters .head h2{font-family:var(--serif); font-weight:500; font-size:clamp(2.4rem,4.4vw,3.8rem); color:var(--cream); line-height:1.06; margin-top:18px;}
  .chapters .head h2 em{color:var(--red); font-style:italic;}
  .chapters .head p{font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--cream); opacity:.88; margin-top:18px;}

  .chapter{position:relative; margin:0 0 120px;}
  .chapter:last-child{margin-bottom:0;}
  .ch-photo{position:relative; width:100vw; height:80vh; min-height:540px; overflow:hidden;}
  .ch-photo img{width:100%; height:100%; object-fit:cover;}
  .ch-photo::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(7,7,7,.3), rgba(7,7,7,.7));}
  .ch-dropcap{
    position:absolute; left:50%; top:30%; transform:translateX(-50%);
    font-family:var(--serif); font-style:italic; font-weight:700;
    font-size:clamp(220px, 30vw, 380px); color:var(--cream);
    opacity:.18; line-height:.85; z-index:2; pointer-events:none;
    letter-spacing:-.04em;
  }
  .ch-card{
    position:relative; max-width:560px; margin:-100px auto 0; padding:42px 44px;
    background:var(--cream-warm); color:var(--black); z-index:3;
    border-top:4px solid var(--red); box-shadow:0 30px 80px -20px rgba(0,0,0,.7);
  }
  .chapter.right .ch-card{margin-right:8%; margin-left:auto;}
  .chapter.left .ch-card{margin-left:8%; margin-right:auto;}
  @media(max-width:760px){.chapter.right .ch-card, .chapter.left .ch-card{margin-inline:auto;}}
  .ch-card .ch-month{font-family:var(--sans); font-size:.66rem; letter-spacing:.32em; text-transform:uppercase; color:var(--red); font-weight:600; margin-bottom:14px;}
  .ch-card h3{font-family:var(--serif); font-weight:500; font-size:clamp(1.7rem,2.6vw,2.2rem); color:var(--black); line-height:1.15; margin-bottom:16px;}
  .ch-card h3 em{color:var(--red); font-style:italic;}
  .ch-card p{color:#1a0a0a; font-size:1.15rem; line-height:1.7;}

  .ch-bridge{text-align:center; padding:54px 32px 30px;}
  .ch-bridge .b{font-family:var(--serif); font-style:italic; font-weight:500; color:var(--cream); font-size:1.15rem; letter-spacing:.04em; opacity:.7;}
  .ch-bridge .b::before{content:"— "; color:var(--red); opacity:.8;}

  /* Activities asymmetric grid */
  .activities{display:grid; grid-template-columns:repeat(12, 1fr); gap:18px; padding:0 32px 0; max-width:1320px; margin:0 auto;}
  .activities .act{display:flex; flex-direction:column; gap:14px;}
  .act .a-photo{overflow:hidden; position:relative;}
  .act .a-photo img{width:100%; height:100%; object-fit:cover; transition:transform 1s ease;}
  .act:hover .a-photo img{transform:scale(1.04);}
  .act h4{font-family:var(--serif); font-style:italic; font-weight:500; font-size:1.55rem; color:var(--cream); line-height:1.25;}
  .act p{color:var(--cream); opacity:.9; font-size:1.1rem; line-height:1.6;}
  .a-43 .a-photo{aspect-ratio:4/3;}
  .a-74 .a-photo{aspect-ratio:7/4;}
  .a-56 .a-photo{aspect-ratio:5/6;}

  /* ============ INCLUDES ============ */
  .includes{padding:72px 32px 140px; background:var(--stone);}
  .includes .inc-inner{max-width:1180px; margin:0 auto;}
  .includes h2{font-family:var(--serif); font-weight:500; font-size:clamp(2.4rem,4vw,3.4rem); color:var(--ink); margin-top:18px; line-height:1.08; text-align:center; max-width:820px; margin-inline:auto;}
  .includes h2 em{color:var(--red); font-style:italic;}
  .includes h2 .t-line{display:block; text-wrap:balance;}
  .inc-lead{font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(1.3rem,1.9vw,1.6rem); color:var(--ink-soft); max-width:760px; margin:24px auto 0; text-align:center; line-height:1.5;}
  /* ===== QUÉ INCLUYE — tres tiers diferenciados por fondo ===== */
  .inc-tiers{max-width:1080px; margin:60px auto 0; display:flex; flex-direction:column; gap:26px;}
  .inc-tier{border-radius:7px; padding:48px 50px 54px; position:relative; overflow:hidden; box-shadow:0 34px 64px -44px rgba(40,20,12,.55);}
  .tier-head{display:flex; align-items:baseline; gap:18px; margin-bottom:30px;}
  .tier-num{font-family:var(--sans); font-weight:700; font-size:.78rem; letter-spacing:.2em; color:var(--gold); border:1px solid rgba(201,162,74,.55); border-radius:999px; padding:7px 13px; flex:none;}
  .tier-label{font-family:var(--serif); font-weight:600; font-size:clamp(1.7rem,2.7vw,2.35rem); line-height:1.12; margin:0;}
  .tier-label em{font-style:italic; color:var(--red);}
  .tier-label .tl-sub{font-style:italic; font-weight:500; opacity:.55; font-size:.74em;}

  /* TIER 1 — base, fondo crema cálido claro */
  .tier-base{background:linear-gradient(180deg,#f3ece3,#ece2d6); color:var(--ink);}
  .tier-base .tier-label{color:var(--ink);}
  .base-grid{display:grid; grid-template-columns:1fr 1fr; gap:34px 46px;}
  .base-card{position:relative; padding-left:56px;}
  .base-card .bc-num{position:absolute; left:0; top:0; font-family:var(--serif); font-style:italic; font-weight:600; font-size:1.55rem; color:var(--red);}
  .base-card .bc-num::after{content:""; position:absolute; left:7px; top:2.1em; height:42px; width:1px; background:linear-gradient(180deg, rgba(164,5,29,.45), transparent);}
  .base-card h4{font-family:var(--serif); font-weight:600; font-size:1.4rem; color:var(--ink); margin:0 0 9px; line-height:1.2;}
  .base-card p{color:var(--ink-soft); font-size:1.02rem; line-height:1.58;}

  /* TIER 2 — festividades, fondo arena cálido (peso equilibrado con los otros) */
  .tier-fest{background:linear-gradient(180deg,#ece1cb,#e4d3b3); color:var(--ink);}
  .tier-fest::before{content:""; position:absolute; left:-6%; bottom:-22%; width:48%; height:74%; pointer-events:none; background:radial-gradient(circle at 30% 70%, rgba(164,5,29,.10), transparent 65%); filter:blur(6px);}
  .tier-fest .tier-label{color:var(--ink); position:relative;}
  .tier-label .gold{font-style:italic; color:#9a7415;}
  .fest-intro{font-family:var(--serif); font-style:italic; font-size:clamp(1.32rem,1.95vw,1.62rem); color:#3a2f24; line-height:1.5; max-width:820px; margin:0 0 38px; position:relative;}
  .fest-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:32px; position:relative;}
  .fest-card{border-top:1px solid rgba(164,5,29,.3); padding-top:18px;}
  .fest-name{display:block; font-family:var(--serif); font-style:italic; font-weight:600; font-size:1.55rem; color:#9a7415; margin-bottom:11px; line-height:1.1;}
  .fest-card p{color:#4a3d2e; font-size:1.1rem; line-height:1.56;}
  .fest-closer{margin:36px auto 0; font-family:var(--serif); font-style:italic; font-size:1.28rem; color:#5a4a36; text-align:center; max-width:760px; line-height:1.5; position:relative;}

  /* TIER 3 — y además, fondo rosa-piedra cálido */
  .tier-extra{background:linear-gradient(180deg,#e2d0c7,#d7c0b6); color:var(--ink);}
  .tier-extra .tier-label{color:var(--ink);}
  .extra-list{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:22px;}
  .extra-list li{display:grid; grid-template-columns:22px 1fr; gap:16px; align-items:start;}
  .extra-list .ex-mark{color:var(--gold); font-size:1rem; line-height:1.6;}
  .extra-list .ex-text{color:var(--ink); font-size:1.1rem; line-height:1.62;}
  .extra-list .ex-text b{font-weight:600; color:#8b0419;}

  /* decorative graphics + ghost numerals + motion per tier */
  .tier-ghost{position:absolute; top:-22px; right:24px; font-family:var(--serif); font-weight:700; font-style:italic; font-size:clamp(7rem,13vw,12rem); line-height:1; pointer-events:none; z-index:0; user-select:none; animation:ghostDrift 9s ease-in-out infinite;}
  .tier-base .tier-ghost{color:rgba(164,5,29,.06);}
  .tier-fest .tier-ghost{color:rgba(154,116,21,.13);}
  .tier-extra .tier-ghost{color:rgba(164,5,29,.07);}
  .tier-head, .base-grid, .fest-intro, .fest-grid, .fest-closer, .extra-list{position:relative; z-index:2;}
  .tier-deco{position:absolute; pointer-events:none; z-index:1;}
  .deco-tri{width:118px; right:6%; bottom:7%; opacity:.14;}
  .deco-sun{width:150px; left:3%; top:14%; opacity:.5;}
  .deco-heart{width:120px; right:6%; bottom:9%; opacity:.18;}
  @keyframes ghostDrift{0%,100%{transform:translateY(0);} 50%{transform:translateY(-12px);}}
  @keyframes spinSlow{to{transform:rotate(360deg);}}
  .spin-slow{animation:spinSlow 64s linear infinite;}
  @media(prefers-reduced-motion:reduce){.spin-slow,.sym-float,.tier-ghost{animation:none;}}

  @media(max-width:760px){
    .inc-tier{padding:38px 28px 42px;}
    .base-grid{grid-template-columns:1fr; gap:26px;}
    .fest-grid{grid-template-columns:1fr; gap:24px;}
    .tier-deco{display:none;}
  }

  /* ============ DEPTH SYSTEM — layered backgrounds, parallax-feel ============ */
  /* Soft glow that follows the page — sense of atmosphere */
  body::after{
    content:""; position:fixed; left:50%; top:24%; transform:translate(-50%,-50%);
    width:1000px; height:1000px; pointer-events:none; z-index:0;
    background:radial-gradient(circle, rgba(164,5,29,.05), transparent 62%);
    filter:blur(70px);
    animation:atmosphere 18s ease-in-out infinite alternate;
  }
  @keyframes atmosphere{
    0%{transform:translate(-50%,-50%) scale(1); opacity:.85;}
    50%{transform:translate(-30%,-40%) scale(1.15); opacity:1;}
    100%{transform:translate(-65%,-55%) scale(1.05); opacity:.9;}
  }

  /* Section transition — thin red filament with center dot */
  .section-pass{position:relative; height:140px; display:flex; align-items:center; justify-content:center; pointer-events:none;}
  .section-pass::before{content:""; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:1px; height:90px;
    background:linear-gradient(180deg, transparent, var(--red), transparent);}
  .section-pass .dot{position:relative; width:6px; height:6px; border-radius:50%; background:var(--red); box-shadow:0 0 18px rgba(164,5,29,.85);}
  .section-pass .label{position:absolute; left:50%; top:calc(50% + 60px); transform:translateX(-50%); font-family:var(--sans); font-size:.6rem; letter-spacing:.46em; text-transform:uppercase; color:var(--red); opacity:.55; font-weight:600; white-space:nowrap;}

  /* Section vignette — dark fade top/bottom of dark sections so they feel deep */
  .vignette-top::before,
  .vignette-bot::after{content:""; position:absolute; left:0; right:0; height:120px; pointer-events:none; z-index:1;}
  .vignette-top::before{top:0; background:linear-gradient(180deg, rgba(0,0,0,.7), transparent);}
  .vignette-bot::after{bottom:0; background:linear-gradient(0deg, rgba(0,0,0,.7), transparent);}

  /* Floating brand symbols across sections — contextual, not pegatinas */
  .float-sym{position:absolute; pointer-events:none; z-index:0; opacity:.06; filter:none;}
  .float-sym img{width:100%; height:auto; display:block;}

  /* Reveal long, with translateY large — stronger journey feel */
  .reveal-long{opacity:0; transform:translateY(60px); transition:opacity 1.4s ease, transform 1.4s cubic-bezier(.2,.7,.2,1); transition-delay:calc(var(--i, 0) * 0.14s);}
  .reveal-long.in{opacity:1; transform:none;}
  .reveal-scale{opacity:0; transform:scale(.92); transition:opacity 1.6s ease, transform 1.6s cubic-bezier(.2,.7,.2,1);}
  .reveal-scale.in{opacity:1; transform:none;}

  /* Parallax surface — simple, no scroll listeners */
  .px-photo{position:relative; overflow:hidden;}
  .px-photo img{transform:translateZ(0) scale(1.06); transition:transform 18s linear;}
  .px-photo.in img{transform:scale(1.0);}

  /* ============ GUIDE (Shakti) on black ============ */
  .guide{background:radial-gradient(ellipse at 28% 18%, #160e0f 0%, var(--black) 58%); padding:180px 32px; position:relative; overflow:hidden;}
  .guide::before{content:""; position:absolute; left:50%; top:14%; transform:translateX(-50%); width:520px; height:520px; pointer-events:none;
    background:radial-gradient(circle, rgba(164,5,29,.18), transparent 70%); filter:blur(40px);}
  /* incense / smoke plumes — strategic warmth so the section isn't flat-dark */
  .guide .incense{position:absolute; bottom:-12%; width:340px; height:130%; pointer-events:none; z-index:0; filter:blur(46px); opacity:0;
    background:radial-gradient(ellipse at center, rgba(201,162,74,.20), transparent 70%); animation:incense 17s ease-in-out infinite;}
  .guide .incense.i1{left:6%;  animation-delay:0s;}
  .guide .incense.i2{right:9%; animation-delay:-8.5s; background:radial-gradient(ellipse at center, rgba(164,5,29,.20), transparent 70%);}
  @keyframes incense{0%{opacity:0; transform:translateY(60px) scaleX(1);} 35%{opacity:.85;} 100%{opacity:0; transform:translateY(-150px) scaleX(1.5);}}
  @media(prefers-reduced-motion:reduce){.guide .incense{animation:none; opacity:.5;}}
  .guide-grid{display:grid; grid-template-columns:5fr 7fr; gap:90px; align-items:center; max-width:1280px; margin:0 auto; position:relative; z-index:2;}
  @media(max-width:900px){.guide-grid{grid-template-columns:1fr; gap:60px;}}
  .guide-photos{position:relative; perspective:1000px;}
  .guide-photo-main{position:relative; aspect-ratio:4/5; overflow:hidden; box-shadow:0 50px 100px -30px rgba(0,0,0,.85), 0 0 0 1px rgba(164,5,29,.25);}
  .guide-photo-main img{width:100%; height:100%; object-fit:cover;}
  .guide-photo-2{position:absolute; right:-46px; bottom:-72px; width:55%; aspect-ratio:4/5;
    overflow:hidden; border:8px solid var(--black); z-index:2;
    box-shadow:0 30px 60px -15px rgba(0,0,0,.7), 0 0 0 1px rgba(164,5,29,.3);}
  .guide-photo-2 img{width:100%; height:100%; object-fit:cover;}
  /* Thin red corner accent on main photo */
  .guide-photo-main::before{content:""; position:absolute; top:-1px; left:-1px; width:44px; height:44px; border-top:1px solid var(--red); border-left:1px solid var(--red); pointer-events:none; z-index:3;}
  .guide-photo-main::after{content:""; position:absolute; bottom:-1px; right:-1px; width:44px; height:44px; border-bottom:1px solid var(--red); border-right:1px solid var(--red); pointer-events:none; z-index:3;}
  .guide-heart{position:absolute; top:-26px; left:-26px; width:80px; z-index:3; opacity:.9;}
  .guide-copy h2{font-family:var(--serif); font-weight:600; font-size:clamp(2.6rem,4.6vw,4rem); color:var(--cream); line-height:1; margin-bottom:8px;}
  .guide-copy .role{color:var(--red); font-size:.78rem; letter-spacing:.32em; text-transform:uppercase; font-weight:600; margin-bottom:30px;}
  .guide-copy p{color:var(--cream); margin-bottom:20px; font-size:1.22rem; line-height:1.78; opacity:.96;}
  .guide-copy p em{font-style:italic; color:var(--cream);}
  .guide-copy .pull{font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(1.3rem,1.9vw,1.65rem); color:var(--cream); line-height:1.35; margin:28px 0; padding-left:22px; border-left:2px solid var(--red);}
  .pill-lead{font-family:var(--sans); font-size:.74rem; letter-spacing:.34em; text-transform:uppercase; color:var(--gold); font-weight:700; margin-top:34px; margin-bottom:16px;}
  .pill-row{display:flex; gap:12px; flex-wrap:wrap; margin-top:0;}
  .pill{display:inline-flex; align-items:center; gap:9px; padding:12px 20px; border:1px solid rgba(201,162,74,.45); border-radius:999px; font-size:.74rem; letter-spacing:.15em; text-transform:uppercase; color:var(--cream); font-weight:500;
    background:linear-gradient(180deg, rgba(201,162,74,.10), rgba(201,162,74,.02)); transition:border-color .3s ease, background .3s ease, transform .3s ease, box-shadow .3s ease;}
  .pill::before{content:"✦"; color:var(--gold); font-size:.72rem; line-height:1; transform:translateY(.5px);}
  .pill:hover{border-color:var(--gold); background:linear-gradient(180deg, rgba(201,162,74,.20), rgba(201,162,74,.06)); transform:translateY(-3px); box-shadow:0 10px 28px -12px rgba(201,162,74,.55);}

  /* ============ EARLY BIRD — two price cards ============ */
  .early{padding:150px 32px; background:var(--stone); text-align:center; position:relative;}
  .early::before{content:""; position:absolute; left:50%; top:0; transform:translateX(-50%); width:70%; height:340px; pointer-events:none; background:radial-gradient(ellipse at center top, rgba(164,5,29,.08), transparent 70%);}
  .early .head h2{font-family:var(--serif); font-weight:500; font-size:clamp(2.4rem,4.2vw,3.6rem); color:var(--ink); margin-top:18px; line-height:1.06;}
  .early .head h2 em{color:var(--red); font-style:italic;}
  .early-grid{display:grid; grid-template-columns:minmax(0, 640px); justify-content:center; gap:24px; max-width:1080px; margin:56px auto 0; position:relative; z-index:2;}
  @media(max-width:760px){.early-grid{grid-template-columns:1fr;}}
  .price-card{padding:54px 42px 50px; text-align:left; position:relative;}
  .price-card.featured{background:var(--red); color:var(--cream);}
  .price-card.plain{background:rgba(235,235,227,.04); color:var(--cream); border:1px solid rgba(235,235,227,.12);}
  .price-card .tag{font-family:var(--sans); font-size:.66rem; letter-spacing:.34em; text-transform:uppercase; font-weight:600; margin-bottom:16px;}
  .price-card.featured .tag{color:var(--cream); opacity:.92;}
  .price-card.plain .tag{color:var(--red);}
  .price-card h3{font-family:var(--serif); font-weight:500; font-size:clamp(1.7rem,2.6vw,2.1rem); line-height:1.15; margin-bottom:22px;}
  .price-card .price-row{display:flex; align-items:baseline; gap:18px; margin-bottom:24px;}
  .price-card .price-big{font-family:var(--serif); font-weight:700; font-size:clamp(3rem,6vw,4.4rem); line-height:1;}
  .price-card .price-old{font-family:var(--serif); font-weight:500; font-size:1.7rem; opacity:.5; text-decoration:line-through;}
  .price-card.featured .price-big{color:var(--cream);}
  .price-card.plain .price-big{color:var(--red);}
  .price-card .per{font-family:var(--sans); font-size:.7rem; letter-spacing:.24em; text-transform:uppercase; opacity:.75; font-weight:500;}
  .price-card ul{list-style:none; display:flex; flex-direction:column; gap:12px; margin-bottom:30px;}
  .price-card ul li{display:grid; grid-template-columns:18px 1fr; gap:14px; font-size:1.15rem; line-height:1.55;}
  .price-card ul li::before{content:"✦"; font-family:var(--serif); font-size:1rem; line-height:1; padding-top:2px;}
  .price-card.featured ul li::before{color:var(--cream);}
  .price-card.plain ul li::before{color:var(--red);}
  .price-card .cta{margin-top:auto; animation:none;}
  .price-card.featured .cta{background:var(--cream); color:var(--black); border-color:var(--cream);}
  .price-card.featured .cta:hover{background:var(--black); color:var(--cream); border-color:var(--black);}
  .price-card.plain .cta{background:var(--red); color:var(--cream);}

  /* ============ RESERVATION — dark red 4-col ============ */
  .reserve{background:var(--red-deep); padding:80px 32px; color:var(--cream);}
  .reserve-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:0; max-width:1180px; margin:0 auto;}
  @media(max-width:900px){.reserve-grid{grid-template-columns:repeat(2,1fr);}}
  @media(max-width:560px){.reserve-grid{grid-template-columns:1fr;}}
  .reserve-cell{padding:34px 28px; position:relative;}
  .reserve-cell + .reserve-cell{border-left:1px solid rgba(235,235,227,.18);}
  @media(max-width:900px){.reserve-cell:nth-child(3){border-left:none;} .reserve-cell:nth-child(odd){border-left:none;}}
  .reserve-cell .l{font-family:var(--sans); font-size:.66rem; letter-spacing:.32em; text-transform:uppercase; color:var(--cream); opacity:.7; margin-bottom:12px; font-weight:500;}
  .reserve-cell .v{font-family:var(--serif); font-weight:500; font-size:clamp(1.5rem,2.4vw,2rem); color:var(--cream); line-height:1.15;}
  .reserve-cell .v em{color:var(--cream); font-style:italic; font-weight:600;}
  .reserve-cell .sub{font-family:var(--serif); font-style:italic; color:var(--cream); opacity:.82; font-size:1.1rem; margin-top:6px;}

  /* ============ FORM ============ */
  .form-section{padding:140px 32px; background:var(--black);}
  .form-section h2{font-family:var(--serif); font-weight:500; font-size:clamp(2.2rem,3.6vw,3rem); color:var(--cream); text-align:center; margin-top:18px;}
  .form-section .sub-it{font-family:var(--serif); font-style:italic; color:var(--cream); text-align:center; margin-top:12px; font-size:1.32rem; opacity:.9;}
  form.contact{max-width:780px; margin:54px auto 0; display:grid; grid-template-columns:1fr 1fr; gap:28px 32px;}
  @media(max-width:640px){form.contact{grid-template-columns:1fr;}}
  .field{display:flex; flex-direction:column; gap:10px;}
  .field.full{grid-column:1/-1;}
  .field label{font-family:var(--sans); font-size:.66rem; letter-spacing:.32em; text-transform:uppercase; color:var(--cream); opacity:.7; font-weight:500;}
  .field input, .field textarea{background:transparent; border:none; border-bottom:1px solid var(--red); color:var(--cream); padding:14px 2px; font-family:var(--sans); font-size:1.2rem; outline:none; transition:border-color .3s;}
  .field input::placeholder, .field textarea::placeholder{color:rgba(235,235,227,.35);}
  .field input:focus, .field textarea:focus{border-color:var(--cream);}
  .field textarea{min-height:120px; resize:vertical;}
  form.contact .cta{grid-column:1/-1; justify-self:start; margin-top:8px;}

  /* ============ CLOSING SCENE ============ */
  .closing{position:relative; width:100vw; height:100vh; min-height:620px; overflow:hidden;}
  .closing img.bg{position:absolute; inset:0; width:100%; height:100%; object-fit:cover;}
  .closing::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(7,7,7,.55), rgba(7,7,7,.85)); z-index:1;}
  .closing-content{position:absolute; inset:0; z-index:2; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:0 32px; text-align:center;}
  .closing .final-yoni{position:absolute; left:50%; bottom:8%; transform:translateX(-50%); width:240px; opacity:.2; pointer-events:none; z-index:1;}
  .closing-content h2{font-family:var(--serif); font-weight:500; font-size:clamp(2.8rem,6vw,5rem); color:var(--cream); line-height:1.02; max-width:1000px;}
  .closing-content h2 em{color:var(--red); font-style:italic; font-weight:600;}
  .closing-content .it{font-family:var(--serif); font-style:italic; color:var(--cream); margin-top:24px; font-size:clamp(1.35rem,2vw,1.7rem); max-width:860px;}
  .closing-content .cta{margin-top:48px;}

  /* ============ FOOTER ============ */
  .footer-marquee{padding:18px 0; overflow:hidden; background:var(--red); color:var(--cream); border-top:none; border-bottom:none;}
  .footer-marquee .marquee-track{animation-duration:50s;}
  .footer-marquee .marquee-item{font-family:var(--serif); font-style:italic; color:var(--cream); font-size:1.6rem;}
  .footer-marquee .marquee-item .dot{background:var(--cream);}

  footer{padding:60px 32px 44px; text-align:center; background:var(--black);}
  footer .fbrand img{height:68px; margin:0 auto 18px; filter:drop-shadow(0 0 12px rgba(201,162,74,.4));}
  footer .fsocial{display:flex; justify-content:center; gap:24px; margin:0 0 18px; flex-wrap:wrap;}
  footer .fsocial a{color:var(--cream); transition:color .25s; display:flex; align-items:center; gap:8px; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;}
  footer .fsocial a:hover{color:var(--red);}
  footer .fsocial svg{width:18px; height:18px;}
  footer .fcopy{font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:var(--cream); opacity:.55;}

  /* ============ TESTIMONIALS WALL — captures mosaic ============ */
  .wall{padding:160px 32px 130px; background:var(--black); position:relative; overflow:hidden;}
  .wall::before{content:""; position:absolute; left:50%; top:80px; transform:translateX(-50%); width:340px; height:340px; pointer-events:none;
    background:radial-gradient(circle, rgba(164,5,29,.18), transparent 70%); filter:blur(20px);}
  .wall .head{text-align:center; max-width:920px; margin:0 auto 70px; position:relative; z-index:2;}
  .wall .head h2{font-family:var(--serif); font-weight:500; font-size:clamp(2.4rem,4.4vw,3.6rem); color:var(--cream); line-height:1.05; margin-top:14px;}
  .wall .head h2 em{color:var(--red); font-style:italic;}
  .wall .head p{font-family:var(--serif); font-style:italic; color:var(--cream); margin-top:18px; font-size:1.2rem; opacity:.86;}

  /* Mosaic — column-based masonry, no rotation, no polaroid pin */
  .wall-mosaic{column-count:4; column-gap:18px; max-width:1440px; margin:0 auto; padding:0;}
  @media(max-width:1100px){.wall-mosaic{column-count:3;}}
  @media(max-width:760px){.wall-mosaic{column-count:2;}}
  @media(max-width:480px){.wall-mosaic{column-count:1;}}
  .mt{margin:0 0 18px; break-inside:avoid; display:block; padding:0; position:relative; overflow:hidden;
    background:#1a1014; border:1px solid rgba(235,235,227,.06);
    box-shadow:0 18px 36px -16px rgba(0,0,0,.75);
    transition:transform .4s ease, box-shadow .4s ease, border-color .4s ease;}
  .mt:hover{transform:translateY(-4px); border-color:rgba(164,5,29,.5); box-shadow:0 26px 50px -16px rgba(164,5,29,.45);}
  .mt img{display:block; width:100%; height:auto;}
  /* Subtle red top hairline as if WhatsApp-style frame */
  .mt::before{content:""; position:absolute; left:0; right:0; top:0; height:2px; background:linear-gradient(90deg, transparent, var(--red), transparent); opacity:0; transition:opacity .35s;}
  .mt:hover::before{opacity:.9;}

  .wall-note{margin:80px auto 0; max-width:820px; text-align:center; position:relative; z-index:2;}
  .wall-note p{font-family:var(--serif); font-style:italic; font-size:clamp(1.4rem,2.2vw,1.85rem); color:var(--cream); line-height:1.35;}
  .wall-note p em{color:var(--red); font-style:italic;}
  .wall-note .attr{display:inline-block; margin-top:24px; font-family:var(--sans); font-size:.68rem; letter-spacing:.32em; text-transform:uppercase; color:var(--cream); opacity:.55; font-weight:500; position:relative; padding-top:16px;}
  .wall-note .attr::before{content:""; position:absolute; top:0; left:50%; transform:translateX(-50%); width:36px; height:1px; background:var(--red);}

  /* ============ CAMINO TIMELINE (cream bg + wave line) ============ */
  .camino{padding:150px 0 56px; position:relative; background:var(--stone); overflow:hidden;}
  .camino::before{content:""; position:absolute; left:50%; top:0; transform:translateX(-50%); width:80%; height:380px; pointer-events:none;
    background:radial-gradient(ellipse at center top, rgba(164,5,29,.08), transparent 70%);}
  .camino::after{content:none;}
  .camino .head{text-align:center; max-width:1000px; margin:0 auto 70px; padding:0 32px; position:relative; z-index:2;}
  .camino .head .kicker .t{color:var(--red);}
  .camino .head .kicker .l{background:var(--red);}
  .camino .head h2{font-family:var(--serif); font-weight:600; font-size:clamp(2.8rem,5.2vw,4.6rem); color:var(--ink); line-height:1.02; margin-top:18px; letter-spacing:-.005em;}
  .camino .head h2 em{color:var(--red); font-style:italic;}
  .camino .head p{font-family:var(--serif); font-style:italic; color:var(--ink-soft); margin-top:22px; font-size:1.45rem; max-width:760px; margin-inline:auto; line-height:1.5;}
  .camino-body{position:relative; max-width:1180px; margin:0 auto; padding:0 32px; z-index:2;}

  /* THREAD — thin glowing red line that ripples like a plucked string on hover */
  .camino-wave{position:absolute; left:50%; top:0; bottom:0; width:120px; transform:translateX(-50%); pointer-events:none; z-index:1;}
  .camino-wave svg{display:block; width:100%; height:100%; overflow:visible;}
  .thread-line{fill:none; stroke:var(--red); stroke-width:1.6; stroke-linecap:round;
    filter:drop-shadow(0 0 4px rgba(164,5,29,.55)) drop-shadow(0 0 10px rgba(164,5,29,.28));}
  @media(max-width:760px){.camino-wave{left:30px;}}

  .stop{position:relative; display:grid; grid-template-columns:1fr 110px 1fr; gap:0; min-height:300px; padding:36px 0; align-items:center;}
  @media(max-width:760px){.stop{grid-template-columns:80px 1fr; padding:26px 0;}}
  .stop .stop-rail{display:flex; align-items:center; justify-content:center; position:relative; z-index:3;}
  .stop .stop-rail .lotus{position:relative; width:64px; height:64px; display:flex; align-items:center; justify-content:center; transition:transform .4s cubic-bezier(.2,.7,.2,1);}
  .stop .stop-rail .lotus .sun-node{width:100%; height:100%; object-fit:contain; display:block; transform-origin:center;
    filter:drop-shadow(0 0 7px rgba(201,162,74,.55)); transition:filter .4s ease;}
  /* soft gold halo behind the sun, masks the thread cleanly */
  .stop .stop-rail .lotus::before{content:""; position:absolute; inset:-12px; border-radius:50%; z-index:-1;
    background:radial-gradient(circle, var(--stone) 30%, rgba(232,224,216,.65) 46%, rgba(201,162,74,.28) 60%, transparent 74%);}
  .stop .stop-rail .lotus::after{content:none;}
  .stop .stop-rail .lotus.in .sun-node{animation:sunSpin 34s linear infinite;}
  .stop .stop-rail .lotus.in::before{animation:sunHalo 3.4s ease-in-out infinite;}
  @keyframes sunSpin{from{transform:rotate(0);} to{transform:rotate(360deg);}}
  @keyframes sunHalo{0%,100%{opacity:.7; transform:scale(1);} 50%{opacity:1; transform:scale(1.12);}}
  @media(prefers-reduced-motion:reduce){.stop .stop-rail .lotus.in .sun-node{animation:none;}}
  .stop-side{padding:0 56px;}
  .stop.right .stop-side.l{visibility:hidden;}
  .stop.left  .stop-side.r{visibility:hidden;}
  .stop.right .stop-side.r{text-align:left;}
  .stop.left  .stop-side.l{text-align:right;}
  /* per-month card so each stop reads as its own chapter */
  .stop.right .stop-side.r, .stop.left .stop-side.l{
    background:var(--cream-warm); border:1px solid var(--stone-line);
    padding:32px 38px; box-shadow:0 16px 40px -26px rgba(60,30,20,.5);
    transition:transform .4s ease, box-shadow .4s ease;}
  .stop.right .stop-side.r{border-left:3px solid var(--red);}
  .stop.left  .stop-side.l{border-right:3px solid var(--red);}
  .stop:hover .stop-side.r, .stop:hover .stop-side.l{transform:translateY(-4px); border-color:var(--red); box-shadow:0 26px 58px -24px rgba(120,20,30,.5);}
  @media(max-width:760px){.stop .stop-side.l{display:none;} .stop .stop-side.r{visibility:visible !important; text-align:left !important; background:var(--cream-warm); border:1px solid var(--stone-line); border-left:3px solid var(--red); padding:26px 24px !important; box-shadow:0 16px 40px -26px rgba(60,30,20,.5);}}
  .stop-month{font-family:var(--sans); font-weight:700; color:var(--ink-soft); font-size:.74rem; letter-spacing:.42em; text-transform:uppercase; margin-bottom:10px; transition:letter-spacing .35s ease;}
  .stop-festival{font-family:var(--serif); font-style:italic; font-weight:500; font-size:1.02rem; letter-spacing:0; text-transform:none; color:var(--red); opacity:1; margin-bottom:14px; line-height:1.35;}
  .stop-title{font-family:var(--serif); font-weight:600; font-size:clamp(1.6rem,2.2vw,2rem); color:var(--ink); line-height:1.16; margin-bottom:10px; text-wrap:balance; transition:color .35s ease;}
  .stop-title em{color:var(--red); font-style:italic;}
  .stop-body{color:var(--ink-soft); font-size:1.12rem; line-height:1.58; max-width:520px;}
  .stop:hover .lotus{transform:scale(1.2) rotate(8deg);}
  .stop:hover .lotus .sun-node{filter:drop-shadow(0 0 18px rgba(201,162,74,.95));}
  .stop:hover .stop-month{letter-spacing:.5em;}
  .stop:hover .stop-title em{text-shadow:0 0 18px rgba(164,5,29,.4);}
  .stop .lotus{transition:transform .4s ease;}
  .stop.right .stop-body{margin-left:0;}
  .stop.left  .stop-body{margin-left:auto;}
  .stop-tags{display:flex; gap:10px; flex-wrap:wrap; margin-top:18px;}
  .stop.left .stop-tags{justify-content:flex-end;}
  .stop-tag{font-family:var(--sans); font-size:.78rem; letter-spacing:.26em; text-transform:uppercase; color:var(--red); font-weight:700; padding:8px 14px; border:1px solid rgba(164,5,29,.5); background:rgba(164,5,29,.04);}
  .camino-start, .camino-end{text-align:center; padding:24px 0; position:relative; z-index:3;}
  .camino-start .label-mark, .camino-end .label-mark{font-family:var(--sans); font-size:.82rem; letter-spacing:.42em; text-transform:uppercase; color:var(--red); font-weight:700; padding:18px 28px; background:var(--cream-warm); display:inline-block; position:relative; z-index:3; border:1px solid rgba(164,5,29,.3);}
  .camino-end .label-mark{color:var(--cream); background:var(--red); border-color:var(--red);}
