/* ===========================================================
   Can Ferrer · El Petit Refugi — Sistema de diseño cinematográfico
   =========================================================== */
:root{
  --forest:#0f2417; --forest-2:#173021; --forest-3:#21392a;
  --sage:#5f6f4d; --sage-soft:#8a9678;
  --paper:#f4f0e7; --paper-2:#ece6d8; --cream:#faf8f2;
  --gold:#b1894f; --gold-soft:#c9a96e;
  --ink:#16190f; --muted:#5b6450;
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Manrope",-apple-system,BlinkMacSystemFont,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);
  overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.6}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.serif{font-family:var(--serif)}
.eyebrow{font-family:var(--sans);font-size:.7rem;letter-spacing:.42em;
  text-transform:uppercase;font-weight:600}
.wrap{max-width:1320px;margin:0 auto;padding:0 clamp(1.4rem,5vw,4rem)}
em{font-style:italic}

/* film grain */
body::after{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;
  opacity:.05;mix-blend-mode:overlay;
  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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- NAV ---------- */
header{position:fixed;top:0;left:0;width:100%;z-index:1000;transition:all .5s cubic-bezier(.16,1,.3,1)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1.6rem clamp(1.4rem,5vw,4rem);transition:padding .5s}
header.scrolled{background:rgba(244,240,231,.86);backdrop-filter:blur(16px);border-bottom:1px solid rgba(22,25,15,.07)}
header.scrolled .nav{padding-top:1rem;padding-bottom:1rem}
.brand{font-family:var(--serif);font-size:1.5rem;font-weight:600;letter-spacing:.04em;color:#fff;transition:color .5s}
header.scrolled .brand{color:var(--forest)}
.brand span{color:var(--gold-soft)}
/* solid variant for pages without a dark hero */
header.solid{background:rgba(244,240,231,.92);backdrop-filter:blur(16px);border-bottom:1px solid rgba(22,25,15,.07)}
header.solid .brand{color:var(--forest)} header.solid .menu a.lnk{color:var(--muted)}
header.solid .lang a{color:var(--muted)} header.solid .btn-book{border-color:var(--forest);color:var(--forest)}
header.solid .burger span{background:var(--forest)}
.menu{display:flex;gap:2.4rem;align-items:center}
.menu a.lnk{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.82);position:relative;padding:.3rem 0}
header.scrolled .menu a.lnk{color:var(--muted)}
.menu a.lnk::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--gold);transition:width .4s}
.menu a.lnk:hover::after,.menu a.lnk.active::after{width:100%}
.menu a.lnk:hover{color:var(--gold-soft)} .menu a.lnk.active{color:var(--gold-soft)}
header.scrolled .menu a.lnk:hover,header.solid .menu a.lnk:hover,header.scrolled .menu a.lnk.active{color:var(--gold)}
.nav-right{display:flex;align-items:center;gap:1.4rem}
.lang{display:flex;gap:.55rem;font-size:.68rem;letter-spacing:.12em;font-weight:600}
.lang a{color:rgba(255,255,255,.6)} header.scrolled .lang a{color:var(--muted)} .lang a:hover{color:var(--gold-soft)}
.lang a.on{color:var(--gold-soft)}
.btn-book{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;padding:.85rem 1.6rem;border:1px solid rgba(255,255,255,.5);border-radius:999px;color:#fff;transition:all .4s}
.btn-book:hover{background:var(--gold);border-color:var(--gold);color:var(--forest)}
header.scrolled .btn-book{border-color:var(--forest);color:var(--forest)}
header.scrolled .btn-book:hover,header.solid .btn-book:hover{background:var(--forest);color:var(--cream);border-color:var(--forest)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0;padding:6px}
.burger span{width:26px;height:2px;background:#fff;transition:.4s}
header.scrolled .burger span{background:var(--forest)}

/* ---------- HERO (home) ---------- */
.hero{position:relative;height:100vh;min-height:640px;overflow:hidden;display:flex;align-items:flex-end;color:#fff}
.hero video,.hero .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(15,36,23,.55) 0%,rgba(15,36,23,.15) 35%,rgba(15,36,23,.85) 100%)}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:radial-gradient(120% 80% at 50% 30%,transparent 40%,rgba(10,24,15,.6) 100%)}
.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(3rem,8vh,7rem)}
.hero .eyebrow{color:var(--gold-soft);margin-bottom:1.6rem;opacity:0;animation:rise 1s cubic-bezier(.16,1,.3,1) .3s forwards}
.hero h1{font-family:var(--serif);font-weight:300;line-height:.92;font-size:clamp(3.4rem,12vw,11rem);letter-spacing:-.01em;margin-bottom:1.4rem}
.hero h1 em{color:var(--cream)}
.hero h1 .l1,.hero h1 .l2{display:block;overflow:hidden}
.hero h1 .l1 span,.hero h1 .l2 span{display:block;transform:translateY(110%);animation:rise 1.2s cubic-bezier(.16,1,.3,1) forwards}
.hero h1 .l1 span{animation-delay:.45s}.hero h1 .l2 span{animation-delay:.6s}
.hero-sub{max-width:30rem;font-size:1.05rem;font-weight:300;color:rgba(255,255,255,.82);margin-bottom:2.4rem;opacity:0;animation:rise 1s ease .9s forwards}
.hero-cta{display:flex;gap:1.1rem;flex-wrap:wrap;opacity:0;animation:rise 1s ease 1.05s forwards}
.cta-solid{background:var(--gold);color:var(--forest);font-weight:700;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;padding:1.1rem 2.2rem;border-radius:999px;transition:all .4s;display:inline-block}
.cta-solid:hover{background:var(--cream);transform:translateY(-2px)}
.cta-ghost{color:#fff;font-weight:600;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;padding:1.1rem .4rem;border-bottom:1px solid rgba(255,255,255,.4);transition:.4s}
.cta-ghost:hover{border-color:var(--gold-soft);color:var(--gold-soft)}
.scroll-cue{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.7);display:flex;flex-direction:column;align-items:center;gap:.7rem}
.scroll-cue .line{width:1px;height:46px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:cue 2.2s ease-in-out infinite}
.side-tag{position:absolute;right:clamp(1rem,4vw,2.6rem);top:50%;z-index:2;transform:rotate(90deg) translateX(50%);transform-origin:right center;font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.55)}

/* ---------- PAGE HERO (interior) ---------- */
.page-hero{position:relative;height:74vh;min-height:520px;overflow:hidden;display:flex;align-items:flex-end;color:#fff}
.page-hero .bg{position:absolute;inset:0;z-index:0}
.page-hero .bg img{width:100%;height:100%;object-fit:cover}
.page-hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(15,36,23,.5) 0%,rgba(15,36,23,.2) 40%,rgba(11,24,15,.9) 100%)}
.page-hero .inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(3rem,7vh,6rem)}
.page-hero .eyebrow{color:var(--gold-soft);margin-bottom:1.4rem;opacity:0;animation:rise 1s ease .3s forwards}
.page-hero h1{font-family:var(--serif);font-weight:300;line-height:.98;font-size:clamp(2.8rem,8vw,7rem);margin-bottom:1.4rem;max-width:16ch;opacity:0;animation:rise 1.1s cubic-bezier(.16,1,.3,1) .45s forwards}
.page-hero h1 em{color:var(--gold-soft)}
.page-hero .lead{max-width:34rem;font-size:1.08rem;font-weight:300;color:rgba(255,255,255,.85);opacity:0;animation:rise 1s ease .7s forwards}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(38px);transition:opacity 1.1s cubic-bezier(.16,1,.3,1),transform 1.1s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}.reveal.d2{transition-delay:.24s}.reveal.d3{transition-delay:.36s}.reveal.d4{transition-delay:.48s}

/* ---------- generic section ---------- */
.section{padding:clamp(5rem,13vh,10rem) 0}
.section.paper{background:var(--paper)}.section.cream{background:var(--cream)}
.section.forest{background:var(--forest);color:var(--cream)}
.eyebrow.g{color:var(--gold);margin-bottom:1.4rem}
.forest .eyebrow.g{color:var(--gold-soft)}
.h-big{font-family:var(--serif);font-weight:300;font-size:clamp(2.3rem,5.2vw,4.4rem);line-height:1.02;color:var(--forest);margin-bottom:1.6rem}
.forest .h-big{color:var(--cream)}
.h-big em{color:var(--sage)}.forest .h-big em{color:var(--gold-soft)}
.prose p{color:var(--muted);font-size:1.06rem;font-weight:300;margin-bottom:1.1rem;max-width:38rem}
.forest .prose p{color:rgba(250,248,242,.78)}
.link-gold{display:inline-flex;align-items:center;gap:.6rem;color:var(--forest);font-weight:600;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;margin-top:.6rem}
.forest .link-gold{color:var(--cream)}
.link-gold .arr{transition:transform .4s}.link-gold:hover .arr{transform:translateX(6px)}
.link-gold:hover{color:var(--gold)}.forest .link-gold:hover{color:var(--gold-soft)}

/* split: text + framed image alternating */
.split .grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,7vw,6rem);align-items:center}
.split.alt .grid{direction:rtl}.split.alt .grid>*{direction:ltr}
.figure{position:relative}
.figure img{width:100%;height:clamp(360px,60vh,600px);object-fit:cover;border-radius:2px}
.figure::before{content:"";position:absolute;inset:14px;border:1px solid rgba(177,137,79,.55);z-index:2;pointer-events:none}
.forest .figure::before{border-color:rgba(201,169,110,.5)}
.figure .cap{position:absolute;left:-1px;bottom:-1px;background:var(--forest);color:var(--cream);padding:.9rem 1.3rem;font-size:.64rem;letter-spacing:.22em;text-transform:uppercase}

/* feature grid (h3 items) */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.6rem;margin-top:1rem}
.feature{background:var(--cream);padding:2.2rem 1.8rem;border-top:2px solid var(--gold);transition:transform .4s}
.forest .feature{background:var(--forest-3);border-top-color:var(--gold-soft)}
.feature:hover{transform:translateY(-6px)}
.feature h3{font-family:var(--serif);font-weight:400;font-size:1.5rem;color:var(--forest);margin-bottom:.7rem}
.forest .feature h3{color:var(--cream)}
.feature p{color:var(--muted);font-weight:300;font-size:.95rem}
.forest .feature p{color:rgba(250,248,242,.72)}

/* image cards (experiences on home) */
.exp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.card{position:relative;height:clamp(380px,52vh,560px);overflow:hidden;border-radius:2px;display:flex;align-items:flex-end;color:#fff;isolation:isolate}
.card img{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.16,1,.3,1)}
.card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent 35%,rgba(11,26,16,.88) 100%);transition:.5s}
.card:hover img{transform:scale(1.07)}
.card:hover::after{background:linear-gradient(180deg,rgba(11,26,16,.2) 0%,rgba(11,26,16,.92) 100%)}
.card .c{padding:1.8rem;width:100%}
.card .num{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--gold-soft);opacity:.8}
.card h3{font-family:var(--serif);font-weight:400;font-size:1.75rem;line-height:1.05;margin:.4rem 0 .5rem}
.card p{font-size:.86rem;font-weight:300;color:rgba(255,255,255,.78);max-height:0;overflow:hidden;opacity:0;transition:.5s cubic-bezier(.16,1,.3,1)}
.card:hover p{max-height:90px;opacity:1;margin-bottom:.7rem}
.card .more{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--gold-soft);display:inline-flex;gap:.5rem;align-items:center}

/* quote / parallax band */
.quote{position:relative;height:80vh;min-height:440px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;color:#fff}
.quote .bg{position:absolute;inset:-12% 0;z-index:0}
.quote .bg img{width:100%;height:124%;object-fit:cover}
.quote::after{content:"";position:absolute;inset:0;z-index:1;background:rgba(11,26,16,.6)}
.quote .q{position:relative;z-index:2;max-width:60rem;padding:0 1.5rem}
.quote .q p{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(1.6rem,4.2vw,3.2rem);line-height:1.25}
.quote .q .by{margin-top:1.6rem;font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-soft)}

/* inline pull quote */
.pull{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(1.5rem,3vw,2.2rem);line-height:1.3;color:var(--forest);border-left:2px solid var(--gold);padding-left:1.6rem;margin:2rem 0;max-width:40rem}
.forest .pull{color:var(--cream);border-color:var(--gold-soft)}

/* stats */
.stats{display:flex;gap:clamp(1.5rem,4vw,3.4rem);flex-wrap:wrap;margin:2.4rem 0}
.stat .n{font-family:var(--serif);font-weight:300;font-size:clamp(2.6rem,5vw,3.8rem);color:var(--gold);line-height:1}
.forest .stat .n{color:var(--gold-soft)}
.stat .t{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:.5rem;max-width:9rem}
.forest .stat .t{color:rgba(250,248,242,.6)}

/* gallery collage */
.collage{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:200px;gap:1rem}
.collage figure{overflow:hidden;border-radius:2px}
.collage img{width:100%;height:100%;object-fit:cover;transition:transform 1s cubic-bezier(.16,1,.3,1);filter:saturate(.95)}
.collage figure:hover img{transform:scale(1.06);filter:saturate(1.05)}
.collage figure:nth-child(6n+1){grid-column:span 4;grid-row:span 2}
.collage figure:nth-child(6n+2){grid-column:span 2}
.collage figure:nth-child(6n+3){grid-column:span 2}
.collage figure:nth-child(6n+4){grid-column:span 2;grid-row:span 2}
.collage figure:nth-child(6n+5){grid-column:span 2}
.collage figure:nth-child(6n){grid-column:span 2}
.center{text-align:center}.center .h-big{margin-left:auto;margin-right:auto}
.center .prose p{margin-left:auto;margin-right:auto}

/* ---------- CTA ---------- */
.cta{position:relative;background:var(--forest-2);color:var(--cream);padding:clamp(6rem,15vh,11rem) 0;text-align:center;overflow:hidden}
.cta .eyebrow{color:var(--gold-soft);margin-bottom:1.4rem}
.cta h2{font-family:var(--serif);font-weight:300;font-size:clamp(2.8rem,7vw,6rem);line-height:1;margin-bottom:1.6rem}
.cta h2 em{color:var(--gold-soft)}
.cta p.addr{font-weight:300;color:rgba(250,248,242,.8);margin-bottom:2.6rem}
.facts{display:flex;justify-content:center;gap:clamp(1.4rem,5vw,4rem);flex-wrap:wrap;margin-top:4rem;padding-top:3rem;border-top:1px solid rgba(250,248,242,.13)}
.fact{max-width:14rem;text-align:left}
.fact .ft{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:.5rem}
.fact .fv{font-weight:300;font-size:.92rem;color:rgba(250,248,242,.78)}

/* ---------- FOOTER ---------- */
footer{background:var(--forest);color:rgba(250,248,242,.65);padding:4.5rem 0 2.5rem}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
.foot .brand{font-family:var(--serif);font-size:1.7rem;color:var(--cream);margin-bottom:1rem;display:inline-block}
.foot p{font-weight:300;font-size:.9rem;max-width:20rem}
.foot h4{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:1.2rem}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:.7rem}
.foot ul a{font-size:.9rem;font-weight:300;transition:.3s}.foot ul a:hover{color:var(--gold-soft)}
.foot-bottom{border-top:1px solid rgba(250,248,242,.12);padding-top:2rem;text-align:center;font-size:.74rem;letter-spacing:.06em;color:rgba(250,248,242,.45)}

/* WhatsApp */
.wa{position:fixed;right:1.6rem;bottom:1.6rem;z-index:1100;width:56px;height:56px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 12px 34px rgba(0,0,0,.28);transition:transform .35s}
.wa:hover{transform:scale(1.08)} .wa svg{width:28px;height:28px}

/* booking embed */
.book-card{background:#fff;padding:clamp(1.4rem,4vw,2.6rem);border-radius:2px;box-shadow:0 30px 80px rgba(15,36,23,.12)}
.book-card .reserva-embed{width:100%;overflow:hidden;border-radius:2px}
.book-card iframe.cm{display:block;width:1px;min-width:100%;border:0;min-height:560px}
.info-row{display:flex;align-items:flex-start;gap:1.4rem;margin-bottom:1.8rem}
.info-row .ic{width:50px;height:50px;flex:0 0 50px;border-radius:50%;border:1px solid var(--gold);color:var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.1rem}
.info-row .lbl{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:.25rem}
.info-row .val{font-size:1.05rem;color:var(--forest)}
.map-frame{border-radius:2px;overflow:hidden;height:360px;border:1px solid rgba(15,36,23,.1)}
.map-frame iframe{width:100%;height:100%;border:0;filter:grayscale(1);transition:filter .8s}
.map-frame:hover iframe{filter:none}

/* drawer */
.drawer{position:fixed;inset:0;z-index:1200;background:var(--forest);color:var(--cream);display:flex;flex-direction:column;justify-content:center;padding:2.5rem;transform:translateX(100%);transition:transform .55s cubic-bezier(.16,1,.3,1)}
.drawer.open{transform:none}
.drawer a{font-family:var(--serif);font-size:2rem;font-weight:300;padding:.5rem 0}
.drawer .close{position:absolute;top:1.6rem;right:1.6rem;font-size:1.6rem;background:none;border:0;color:var(--cream);cursor:pointer}
.drawer .lang{margin-top:2rem;font-family:var(--sans);font-size:.8rem}.drawer .lang a{color:rgba(250,248,242,.7)}

@keyframes rise{to{transform:none;opacity:1}}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

@media(max-width:1024px){
  .split .grid,.split.alt .grid{grid-template-columns:1fr;direction:ltr;gap:3rem}
  .exp-grid{grid-template-columns:repeat(2,1fr)}
  .collage{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .collage figure{grid-column:span 1 !important;grid-row:span 1 !important}
  .collage figure:nth-child(6n+1),.collage figure:nth-child(6n+4){grid-row:span 2 !important}
  .card p{max-height:90px;opacity:1}
  .book-grid{grid-template-columns:1fr !important}
}
@media(max-width:768px){
  .menu{display:none}.burger{display:flex}.nav-right .lang,.nav-right .btn-book{display:none}
  .exp-grid{grid-template-columns:1fr}.foot{grid-template-columns:1fr;gap:2rem}.side-tag{display:none}
}

/* feature bullet list */
.flist{list-style:none;margin-top:1rem;display:flex;flex-direction:column;gap:.55rem}
.flist li{position:relative;padding-left:1.2rem;font-weight:300;font-size:.92rem;color:var(--muted)}
.forest .flist li{color:rgba(250,248,242,.72)}
.flist li::before{content:"";position:absolute;left:0;top:.6em;width:6px;height:6px;background:var(--gold);transform:rotate(45deg)}
