/* ================================================
   Harry's · Coffee & Brunch
   Stylesheet
   ================================================ */

/* ---------- Variables ---------- */
:root{
  --beige-1:#F7F2EC;
  --beige-2:#EDE4D8;
  --beige-3:#D6C9B6;
  --brown-1:#9C7B68;
  --brown-2:#6B3A2A;
  --brown-3:#4A2C1E;
  --green-1:#5C7A3E;
  --green-2:#3D5C28;
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
a,button,label,input,select,textarea{touch-action:manipulation}
html,body{background:var(--beige-1);color:var(--brown-3);font-family:'Jost',sans-serif;font-weight:300;line-height:1.5;-webkit-font-smoothing:antialiased}
html{scroll-behavior:smooth}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}

/* ---------- Type system ---------- */
.eyebrow{font-family:'Playfair Display',serif;font-weight:400;font-size:11px;letter-spacing:.32em;text-transform:uppercase}
.display{font-family:'Cormorant Garamond',serif;font-weight:300;line-height:.95;letter-spacing:-.01em}
.display .it{font-style:italic;font-weight:300}
.green{color:var(--green-2)}
.green-1{color:var(--green-1)}
.brown{color:var(--brown-2)}
.brown-d{color:var(--brown-3)}
.beige{color:var(--beige-1)}

/* ---------- Buttons ---------- */
.btn{display:inline-block;padding:18px 34px;font-family:'Jost',sans-serif;font-weight:400;font-size:12px;letter-spacing:.28em;text-transform:uppercase;background:var(--brown-2);color:var(--beige-1);transition:background .25s ease,color .25s ease,letter-spacing .25s ease,transform .25s ease,box-shadow .25s ease}
.btn:not(.btn-outline):hover{background:var(--brown-3);letter-spacing:calc(.28em + 0.02em);transform:scale(1.02)}
.btn-outline{background:transparent;color:var(--beige-1);border:1px solid var(--beige-1)}
.btn-outline:hover{background:var(--beige-1);color:var(--brown-3);transform:scale(1.02)}
.btn-green{background:var(--green-2)}
.btn-green:hover{background:var(--green-1)}

/* ---------- Nav ---------- */
nav.top{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:22px 40px;background:rgba(247,242,236,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
nav.top .mark{height:38px;width:auto;display:block;position:relative;z-index:70}
/* ---------- Mobile menu panel ---------- */
.mobile-menu{position:fixed;top:0;right:0;width:100%;height:100vh;background:#F7F2EC;z-index:150;display:flex;flex-direction:column;justify-content:center;align-items:center;transform:translateX(100%);transition:transform .55s cubic-bezier(.16,1,.3,1);overflow:hidden}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu::before{content:"HARRY'S";position:absolute;font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(80px,20vw,140px);color:rgba(74,44,30,.04);letter-spacing:.1em;pointer-events:none;user-select:none;top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap}
.mobile-menu-links{display:flex;flex-direction:column;align-items:center;gap:0;position:relative;z-index:2}
.mobile-menu-links a{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(40px,10vw,56px);letter-spacing:.04em;color:#4A2C1E;text-decoration:none;line-height:1.3;padding:10px 0;opacity:0;transform:translateY(20px);transition:color .2s ease;position:relative}
.mobile-menu-links a::after{content:'';position:absolute;bottom:6px;left:50%;transform:translateX(-50%) scaleX(0);width:20px;height:1px;background:#5C7A3E;transition:transform .3s ease}
.mobile-menu-links a:hover::after{transform:translateX(-50%) scaleX(1)}
.mobile-menu-links a.green{color:#5C7A3E}
.mobile-menu.open .mobile-menu-links a:nth-child(1){animation:menuLinkIn .6s cubic-bezier(.16,1,.3,1) .15s forwards}
.mobile-menu.open .mobile-menu-links a:nth-child(2){animation:menuLinkIn .6s cubic-bezier(.16,1,.3,1) .25s forwards}
.mobile-menu.open .mobile-menu-links a:nth-child(3){animation:menuLinkIn .6s cubic-bezier(.16,1,.3,1) .35s forwards}
@keyframes menuLinkIn{to{opacity:1;transform:translateY(0)}}
.mobile-menu-footer{position:absolute;bottom:48px;text-align:center;opacity:0}
.mobile-menu.open .mobile-menu-footer{animation:menuLinkIn .6s cubic-bezier(.16,1,.3,1) .45s forwards}
.mobile-menu-footer::before{content:'';display:block;width:32px;height:1px;background:#D6C9B6;margin:0 auto 16px}
.mobile-menu-footer p{font-family:'Jost',sans-serif;font-weight:300;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#9C7B68;line-height:1.8}

/* Hamburger button */
.nav-burger{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:8px;cursor:pointer;position:absolute;right:40px;top:50%;transform:translateY(-50%);z-index:70;color:var(--brown-3)}
.nav-burger svg{pointer-events:none;display:block}
.nav-burger svg path{transform-origin:center}
.nav-burger svg .l1{transform:translateY(-7px);transition:all 300ms cubic-bezier(.5,.85,.25,1.1)}
.nav-burger svg .l2{transition:all 300ms cubic-bezier(.5,.85,.25,1.8)}
.nav-burger svg .l3{transform:translateY(7px);transition:all 300ms cubic-bezier(.5,.85,.25,1.1)}
.nav-burger[aria-expanded="true"] svg .l1{transform:rotate(315deg)}
.nav-burger[aria-expanded="true"] svg .l2{transform:rotate(45deg)}
.nav-burger[aria-expanded="true"] svg .l3{transform:rotate(135deg)}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:120px 40px 80px;overflow:hidden;background:var(--beige-1)}
.hero-inner{position:relative;z-index:5;text-align:center;max-width:1300px;width:100%}
.hero .eyebrow{color:var(--brown-1);margin-bottom:36px;display:inline-block}
.hero h1{font-size:clamp(64px,9vw,130px);margin-bottom:48px}

/* Hero headline reveal — triggered via JS after loader */
.hero-line{display:inline-block;opacity:0;transform:translateY(28px);transition:opacity .75s cubic-bezier(.16,1,.3,1),transform .75s cubic-bezier(.16,1,.3,1)}
.hero-line.visible{opacity:1;transform:translateY(0)}

/* Hero buttons */
.hero-buttons{display:flex;gap:20px;align-items:center;justify-content:center;flex-wrap:wrap;margin-top:40px}
.btn-primary{font-family:'Jost',sans-serif;font-weight:300;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#F7F2EC;background:#4A2C1E;padding:16px 40px;min-width:160px;text-decoration:none;border:1px solid #4A2C1E;transition:letter-spacing .25s ease;position:relative;overflow:hidden;display:inline-block;white-space:nowrap}
.btn-primary::after{content:'';position:absolute;inset:0;background:#6B3A2A;transform:translateX(-101%);transition:transform .35s cubic-bezier(.16,1,.3,1);z-index:0}
.btn-primary:hover::after{transform:translateX(0)}
.btn-primary span{position:relative;z-index:1}
.btn-primary:hover{letter-spacing:.22em}
.btn-secondary{font-family:'Jost',sans-serif;font-weight:300;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#5C7A3E;background:transparent;padding:16px 40px;min-width:160px;text-decoration:none;border:1px solid #5C7A3E;transition:color .25s ease,letter-spacing .25s ease;position:relative;overflow:hidden;display:inline-block;white-space:nowrap}
.btn-secondary::after{content:'';position:absolute;inset:0;background:#5C7A3E;transform:translateX(-101%);transition:transform .35s cubic-bezier(.16,1,.3,1);z-index:0}
.btn-secondary:hover::after{transform:translateX(0)}
.btn-secondary span{position:relative;z-index:1}
.btn-secondary:hover{color:#F7F2EC;letter-spacing:.22em}

.floater{position:absolute;overflow:hidden;z-index:2;box-shadow:0 30px 60px -30px rgba(74,44,30,.35);opacity:0}
.floater img{width:100%;height:100%;object-fit:cover;filter:saturate(0.88) brightness(0.96) sepia(0.06) contrast(1.03)}
.f1{top:90px;left:60px;transform:rotate(-2deg);width:200px;height:260px}
.f2{top:140px;right:80px;transform:rotate(2.5deg);width:190px;height:240px}
.f3{bottom:80px;left:120px;transform:rotate(1.5deg);width:175px;height:220px}
.f4{bottom:60px;right:60px;transform:rotate(-1.5deg);width:185px;height:235px}

.hero-sprinkle{position:absolute;z-index:3;width:80px;height:80px;object-fit:contain}
.hero-sprinkle.s1{top:80px;right:340px;width:70px;height:70px}
.hero-sprinkle.s2{bottom:160px;left:360px;width:90px;height:90px}

/* ---------- MARQUEE ---------- */
.marquee{background:var(--brown-3);color:var(--beige-1);height:44px;padding:0;overflow:hidden;border-top:1px solid var(--brown-2);border-bottom:1px solid var(--brown-2);cursor:default;display:flex;align-items:center}
.marquee-track{display:flex;height:44px;gap:0;white-space:nowrap;animation:scroll 38s linear infinite;font-family:'Jost',sans-serif;font-weight:300;font-size:11px;letter-spacing:.18em;text-transform:uppercase;align-items:center}
.marquee-track span{padding:0 20px;color:rgba(214,201,182,.55)}
.marquee-track span.sep{color:#5C7A3E;font-size:10px;padding:0 6px;text-transform:none}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- PHILOSOPHY ---------- */
.philosophy{display:grid;grid-template-columns:1fr 1.1fr;min-height:90vh}
.philosophy .ph-photo{position:relative;overflow:hidden}
.ph-parallax-img{position:absolute;inset:-35%;background:url('assets/photos/s2-7.webp') center bottom/cover;will-change:transform}
.philosophy .ph-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(45deg,rgba(74,44,30,.15),transparent 60%);z-index:1}
.philosophy .ph-text{background:var(--brown-3);color:var(--beige-2);padding:120px 90px;display:flex;flex-direction:column;justify-content:center;position:relative}
.philosophy .ph-text .eyebrow{color:var(--brown-1);margin-bottom:32px}
.philosophy .ph-text h2{font-size:clamp(56px,6vw,110px);margin-bottom:40px;color:var(--beige-1)}
.philosophy .ph-text p{max-width:460px;font-size:17px;line-height:1.7;color:var(--beige-2);opacity:.85}
.philosophy .ph-text p+p{margin-top:22px}
.philosophy .ph-corner{position:absolute;bottom:60px;right:70px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;color:var(--green-1)}

/* ---------- PILLARS ---------- */
.pillars{background:var(--green-1);color:var(--beige-1);padding:140px 60px 160px;position:relative;overflow:hidden}
.pillars-head{max-width:1200px;margin:0 auto 40px;text-align:center}
.pillars-head .eyebrow{color:var(--beige-2);opacity:.7;display:block;margin-bottom:32px}
.pillars-head h2{font-size:clamp(64px,8vw,140px);color:var(--beige-1)}
.pilares-h2{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(64px,8vw,140px);line-height:.95;text-align:center;color:rgba(247,242,236,.55)}
.pilares-h2 em{font-style:italic;color:var(--brown-3);font-size:1.1em;display:block}
.pillars-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:60px}
.pillar{text-align:center;padding:20px 10px}
.pillar-icon{width:140px;height:140px;border-radius:50%;background:var(--beige-1);display:flex;align-items:center;justify-content:center;margin:0 auto 36px;transition:transform .3s ease}
.pillar-icon img{width:90px;height:90px;object-fit:contain;display:block}
.pillar h3{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:38px;line-height:1.1;margin-bottom:18px;color:var(--beige-1)}
.pillar h3 em{color:#cfe0a3;font-style:italic}
.pillar p{font-size:15px;line-height:1.65;color:var(--beige-2);opacity:.88;max-width:280px;margin:0 auto}
.pillar .num{font-family:'Playfair Display',serif;font-style:italic;font-size:13px;letter-spacing:.4em;color:#cfe0a3;display:block;margin-bottom:18px}

/* ---------- RITUAL ---------- */
.ritual{display:grid;grid-template-columns:1fr 1.2fr;background:var(--beige-2)}
.ritual .r-photo{background:url('assets/photos/s2-3.webp') center/cover;min-height:780px;filter:brightness(0.95) saturate(0.92)}
.ritual .r-text{padding:140px 90px;display:flex;flex-direction:column;justify-content:center}
.ritual .r-text .eyebrow{color:#9C7B68;opacity:1;margin-bottom:32px}
.ritual .r-text h2{font-size:clamp(56px,6.5vw,118px);margin-bottom:80px;color:#4A2C1E;opacity:1}
.ritual .r-text h2 .green-1{color:#5C7A3E;opacity:1}
.r-cols{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid #D6C9B6;border-bottom:1px solid #D6C9B6}
.r-col{padding:38px 36px 38px 0}
.r-col+.r-col{padding-left:36px;border-left:1px solid #D6C9B6}
.r-col h4{font-family:'Playfair Display',serif;font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#4A2C1E;opacity:1;margin-bottom:18px}
.r-col h4 em{font-style:italic;font-weight:400;color:var(--green-2)}
.r-col p{font-size:14px;line-height:1.85;color:#6B3A2A;opacity:1;max-width:280px}

/* ---------- SABORES ---------- */
.sabores{background:var(--beige-1);padding:160px 0 180px;overflow:hidden;position:relative}
.sabores h2{font-size:clamp(80px,14vw,260px);line-height:.9;padding:0 50px 90px;text-align:left}
.stagger{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding:0 50px;align-items:start;position:relative}
.col-img{position:relative;cursor:pointer}
.col-img img{width:100%;height:auto;display:block;filter:saturate(0.88) brightness(0.96) sepia(0.06) contrast(1.03);transition:transform .35s ease}
.col-img:hover img{transform:scale(1.03)}
.stagger .c1{margin-top:0}
.stagger .c2{margin-top:120px}
.stagger .c3{margin-top:-40px}
.stagger .c4{margin-top:80px}
.stagger .caption{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:15px;letter-spacing:.05em;color:#4A2C1E;margin-top:14px;line-height:1.4;opacity:1;visibility:visible}
.stagger .caption b{font-weight:400;font-style:normal;font-family:'Jost',sans-serif;text-transform:uppercase;font-size:10px;letter-spacing:.18em;display:block;margin-bottom:6px;color:#6B3A2A;opacity:1;visibility:visible}
.float-ico{position:absolute;z-index:3;pointer-events:none;object-fit:contain}
.float-ico.fi1{top:200px;left:42%;width:120px;height:120px}
.float-ico.fi2{top:520px;left:12%;width:110px;height:140px}
.float-ico.fi3{bottom:80px;right:18%;width:110px;height:120px}

/* ---------- INTERLUDE ---------- */
.interlude{background:var(--brown-3);color:var(--beige-1);padding:180px 40px;text-align:center;position:relative;overflow:hidden}
.interlude::before,.interlude::after{content:"";position:absolute;top:50%;width:80px;height:1px;background:var(--brown-1);opacity:.5}
.interlude::before{left:10%}
.interlude::after{right:10%}
.interlude .eyebrow{color:var(--brown-1);margin-bottom:50px;display:block}
.interlude h2{font-size:clamp(60px,8vw,140px);font-style:italic;font-weight:300;font-family:'Cormorant Garamond',serif;line-height:1;margin-bottom:60px;color:var(--beige-1);max-width:1100px;margin-left:auto;margin-right:auto}
.interlude h2 .green{color:#a8c275}

/* ---------- INSTAGRAM ---------- */
.insta{background:var(--beige-2);padding:160px 40px;text-align:center;position:relative;overflow:hidden}
.insta .eyebrow{color:var(--brown-1);display:block;margin-bottom:40px}
.insta h2{font-size:clamp(50px,6vw,108px);margin-bottom:24px}
.insta .handle{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:300;font-size:clamp(80px,14vw,240px);line-height:.9;color:var(--brown-2);margin:50px 0 80px;letter-spacing:-.02em}
.insta .handle .at{color:var(--green-2);font-style:normal;font-weight:400;font-size:.6em;vertical-align:.4em;margin-right:8px}
.insta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-width:1200px;margin:0 auto}
.insta-grid img{aspect-ratio:1;object-fit:cover}
.insta-grid img.product{filter:saturate(0.88) brightness(0.96) sepia(0.06) contrast(1.03)}
.insta-grid img.lifestyle{object-position:center top}

/* ---------- VISIT ---------- */
.visit{display:grid;grid-template-columns:1fr 1.15fr;background:var(--beige-1);border-top:1px solid var(--beige-3)}
.visit .v-text{padding:140px 90px;display:flex;flex-direction:column;justify-content:center}
.visit .v-text .eyebrow{color:var(--brown-1);margin-bottom:30px}
.visit .v-text h2{font-size:clamp(56px,6.5vw,128px);margin-bottom:60px}
.visit-info{display:grid;grid-template-columns:1fr 1fr;gap:50px 40px;max-width:560px}
.v-row .label{font-family:'Playfair Display',serif;font-weight:700;font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--green-2);margin-bottom:12px}
.v-row .value{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:var(--brown-3);line-height:1.3}
.v-row .sub{font-size:14px;color:var(--brown-2);margin-top:6px}
.map{background:var(--beige-3);position:relative;min-height:780px;overflow:hidden}
.map-grid{position:absolute;inset:0;background:
  linear-gradient(var(--beige-2) 1px,transparent 1px) 0 0/40px 40px,
  linear-gradient(90deg,var(--beige-2) 1px,transparent 1px) 0 0/40px 40px,
  var(--beige-3)}
.map-road{position:absolute;background:var(--beige-1)}
.map-road.r1{top:35%;left:-5%;right:-5%;height:14px;transform:rotate(-3deg)}
.map-road.r2{top:0;bottom:0;left:48%;width:10px}
.map-road.r3{top:62%;left:-5%;right:30%;height:8px;transform:rotate(6deg)}
.map-road.r4{top:20%;bottom:-10%;right:25%;width:6px;transform:rotate(8deg)}
.map-pin{position:absolute;top:42%;left:52%;width:64px;height:64px;border-radius:50% 50% 50% 0;background:var(--brown-2);transform:rotate(-45deg);box-shadow:0 12px 24px rgba(74,44,30,.4)}
.map-pin::after{content:"";position:absolute;top:18px;left:18px;width:28px;height:28px;background:var(--beige-1);border-radius:50%}
.map-label{position:absolute;top:42%;left:calc(52% + 90px);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:32px;color:var(--brown-3)}
.map-label small{display:block;font-family:'Playfair Display',serif;font-style:normal;font-weight:700;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--green-2);margin-bottom:4px}

/* ---------- FOOTER ---------- */
footer{background:var(--brown-3);color:var(--beige-2);padding:90px 60px 50px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;max-width:1400px;margin:0 auto;border-bottom:1px solid var(--brown-2);padding-bottom:70px}
.foot-mark{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:54px;color:var(--beige-1);line-height:1}
.foot-mark sup{font-family:'Playfair Display',serif;font-style:normal;font-size:11px;letter-spacing:.3em;margin-left:8px;vertical-align:24px;color:var(--brown-1);text-transform:uppercase}
.foot-mark p{font-family:'Jost',sans-serif;font-style:normal;font-size:13px;color:var(--brown-1);letter-spacing:.18em;text-transform:uppercase;margin-top:20px;font-weight:300}
.foot-col h5{font-family:'Playfair Display',serif;font-weight:700;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--brown-1);margin-bottom:22px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:12px;font-size:15px;color:var(--beige-2)}
footer a{color:inherit;text-decoration:none;transition:color .2s ease}
footer a:hover{color:#F7F2EC}
.foot-col li a:hover{color:var(--green-1)}
.foot-bottom{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding-top:36px}
.foot-bottom .legal{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--brown-1)}
.foot-bottom .crafted{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:22px;color:var(--green-1)}

/* ==============================================
   RESPONSIVE — 980px
   ============================================== */
@media (max-width: 980px){
  nav.top{padding:18px 24px;mix-blend-mode:normal;background:rgba(247,242,236,.96)}
  .nav-burger{right:24px}
  .hero{padding:140px 24px 60px}
  .floater{display:none}
  .f1,.f2{display:block}
  .f1{width:100px;height:132px;top:80px;left:10px}
  .f2{width:94px;height:122px;top:80px;right:10px}
  .f3{display:block;width:86px;height:108px;bottom:140px;left:8px}
  .f4{display:block;width:90px;height:114px;bottom:125px;right:8px}
  .philosophy,.ritual,.visit{grid-template-columns:1fr}
  .philosophy .ph-photo{min-height:420px}
  .philosophy .ph-photo .ph-parallax-img,.ph-parallax-img{inset:-10%;background-position:center bottom}
  .ritual .r-photo,.map{min-height:340px}
  .philosophy .ph-text,.ritual .r-text,.visit .v-text{padding:80px 30px}
  .philosophy .ph-corner{right:30px}
  .pillars-grid{grid-template-columns:1fr;gap:80px}
  .stagger{display:flex;overflow-x:scroll;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:0 24px 8px;gap:16px;scrollbar-width:none}
  .stagger::-webkit-scrollbar{display:none}
  .stagger .col-img{flex:0 0 78vw;scroll-snap-align:start}
  .stagger .c1,.stagger .c2,.stagger .c3,.stagger .c4{margin-top:0}
  .insta-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:40px}
  .sabores h2,.ritual .r-text,.philosophy .ph-text{padding-left:30px;padding-right:30px}
}

/* ==============================================
   RESPONSIVE — 480px
   ============================================== */
@media (max-width: 480px){
  .hero{padding:110px 20px 60px}
  .hero h1{font-size:clamp(36px,9.5vw,64px)}
  .marquee{height:38px}
  .marquee-track{font-size:11px;letter-spacing:.15em;height:38px}
  .philosophy .ph-text{padding:60px 20px 72px}
  .philosophy .ph-corner{right:20px;bottom:20px;font-size:16px}
  .pillars{padding:80px 20px 100px}
  .pillars-head{margin-bottom:60px}
  .ritual .r-text{padding:60px 20px}
  .ritual .r-text h2{margin-bottom:50px}
  .r-cols{grid-template-columns:1fr}
  .r-col+.r-col{border-left:0;border-top:1px solid var(--brown-1);padding-left:0;padding-top:32px}
  .sabores{padding:80px 0 100px}
  .sabores h2{padding:0 20px 50px}
  .stagger{padding:0 20px 8px;gap:14px}
  .stagger .col-img{flex:0 0 84vw}
  .interlude{padding:100px 20px}
  .interlude::before,.interlude::after{width:40px}
  .insta{padding:100px 20px}
  .visit .v-text{padding:60px 20px}
  .visit-info{grid-template-columns:1fr;gap:32px}
  .map{min-height:260px}
  .map-label{font-size:22px;left:calc(52% + 56px)}
  footer{padding:60px 20px 40px}
  .foot-grid{grid-template-columns:1fr;gap:48px}
  .foot-bottom{flex-direction:column;gap:16px;text-align:center;padding-top:24px}
  .btn{padding:16px 24px;font-size:11px}
  nav.top.scrolled{backdrop-filter:none;-webkit-backdrop-filter:none}
}

/* ==============================================
   INTERACTIONS & ANIMATIONS
   ============================================== */

/* ---------- PAGE LOADER ---------- */
#harrys-loader{
  position:fixed;inset:0;z-index:9999;
  background:#F7F2EC;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s ease,visibility .8s ease;
}
#harrys-loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{display:flex;flex-direction:column;align-items:center;gap:0}

/* CUP DRAW */
.cup-path{
  fill:none;stroke:#6B3A2A;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:400;stroke-dashoffset:400;
  animation:drawCup 1.4s cubic-bezier(.4,0,.2,1) .2s forwards;
}
.handle-path{
  fill:none;stroke:#9C7B68;stroke-width:1.8;stroke-linecap:round;
  stroke-dasharray:80;stroke-dashoffset:80;
  animation:drawCup .5s cubic-bezier(.4,0,.2,1) .9s forwards;
}
.saucer-path{
  fill:none;stroke:#9C7B68;stroke-width:1.5;stroke-linecap:round;
  stroke-dasharray:200;stroke-dashoffset:200;
  animation:drawCup .8s cubic-bezier(.4,0,.2,1) 1.2s forwards;
}
.saucer-2{animation-delay:1.4s}
@keyframes drawCup{to{stroke-dashoffset:0}}

/* COFFEE FILL */
.coffee-bg{fill:#EDE4D8;opacity:0;animation:showBg .3s ease .8s forwards}
@keyframes showBg{to{opacity:1}}
.coffee-fill{
  fill:#6B3A2A;clip-path:url(#fillClip);
  transform:scaleY(0);transform-origin:bottom center;
  animation:fillUp 1.2s cubic-bezier(.4,0,.2,1) 1.4s forwards;
}
@keyframes fillUp{from{transform:scaleY(0)}to{transform:scaleY(1)}}

/* STEAM */
.steam{fill:none;stroke:#9C7B68;stroke-width:1.5;stroke-linecap:round;opacity:0}
.s1{animation:steamRise 1.6s ease-in-out 2.2s infinite}
.s2{animation:steamRise 1.6s ease-in-out 2.5s infinite}
.s3{animation:steamRise 1.6s ease-in-out 2.0s infinite}
@keyframes steamRise{
  0%{opacity:0;transform:translateY(0)}
  30%{opacity:.5}
  70%{opacity:.2;transform:translateY(-10px)}
  100%{opacity:0;transform:translateY(-18px)}
}

/* LOGO */
.loader-logo-wrap{
  display:flex;flex-direction:column;align-items:center;
  margin-top:28px;opacity:0;transform:translateY(10px);
  animation:logoIn .5s ease 0.1s forwards;
}
@keyframes logoIn{to{opacity:1;transform:translateY(0)}}
.loader-logo-img{width:160px;height:auto;object-fit:contain;filter:none}
.loader-logo-line{
  width:40px;height:1px;background:#D6C9B6;margin-top:14px;
  transform:scaleX(0);animation:lineIn .5s ease 0.5s forwards;
}
@keyframes lineIn{to{transform:scaleX(1)}}

/* PROGRESS */
.loader-progress{
  width:60px;height:1px;background:#EDE4D8;margin-top:20px;
  overflow:hidden;opacity:1;
}
.loader-progress-bar{
  width:100%;height:100%;background:#6B3A2A;
  transform:translateX(-100%);
  animation:progressRun 1.8s ease-in-out 0s infinite;
}
@keyframes showProgress{to{opacity:1}}
@keyframes progressRun{
  0%{transform:translateX(-100%)}
  60%{transform:translateX(0%)}
  100%{transform:translateX(100%)}
}

/* ---------- NAV SCROLL ---------- */
nav.top.scrolled{
  border-bottom:1px solid var(--beige-3);
  box-shadow:0 2px 20px -8px rgba(74,44,30,.12);
}

/* ---------- SCROLL REVEAL base ---------- */
.sr{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease;will-change:opacity,transform}
.sr.sr-h{transform:translateY(32px);transition:opacity .8s ease-out,transform .8s ease-out}
.sr.sr-p{transform:none;transition:opacity .6s ease .1s}
.sr.sr-icon{transform:scale(.85);transition:opacity .6s ease-out,transform .6s ease-out}
.sr.visible{opacity:1;transform:translateY(0)}
.sr.sr-p.visible{transform:none}
.sr.sr-icon.visible{transform:scale(1)}

/* ---------- FLOATING ICONS ---------- */
@keyframes floatA{0%{transform:rotate(-15deg) translateY(0)}100%{transform:rotate(-15deg) translateY(-8px)}}
@keyframes floatB{0%{transform:rotate(8deg) translateY(0)}100%{transform:rotate(8deg) translateY(-8px)}}
@keyframes floatC{0%{transform:rotate(-6deg) translateY(0)}100%{transform:rotate(-6deg) translateY(-8px)}}
@keyframes floatS1{0%{transform:rotate(-12deg) translateY(0)}100%{transform:rotate(-12deg) translateY(-8px)}}
@keyframes floatS2{0%{transform:rotate(18deg) translateY(0)}100%{transform:rotate(18deg) translateY(-8px)}}
.float-ico.fi1{animation:floatA 3s ease-in-out infinite alternate}
.float-ico.fi2{animation:floatB 3s ease-in-out .75s infinite alternate}
.float-ico.fi3{animation:floatC 3s ease-in-out 1.5s infinite alternate}
.hero-sprinkle.s1{animation:floatS1 3.5s ease-in-out .3s infinite alternate}
.hero-sprinkle.s2{animation:floatS2 3.5s ease-in-out 1.2s infinite alternate}

/* ---------- PILLAR ICON BOUNCE ---------- */
@keyframes iconBounce{
  0%{transform:translateY(0)}
  35%{transform:translateY(-6px)}
  65%{transform:translateY(-2px)}
  100%{transform:translateY(0)}
}
.pillar:hover .pillar-icon img{animation:iconBounce .5s ease}

/* ---------- SABORES image wrap ---------- */
.col-img-inner{position:relative;overflow:hidden}
.col-img-inner img{transition:transform .35s ease;display:block;width:100%;height:auto}
.col-img:hover .col-img-inner img{transform:scale(1.03)}
.img-overlay{
  position:absolute;inset:0;
  background:rgba(74,44,30,.44);
  display:flex;align-items:flex-end;padding:18px;
  opacity:0;transition:opacity .35s ease;
  pointer-events:none;
}
.col-img:hover .img-overlay{opacity:1}
.img-overlay-label{
  font-family:'Playfair Display',serif;font-size:10px;
  letter-spacing:.3em;text-transform:uppercase;color:var(--beige-1);
}

/* ---------- INSTAGRAM wrapper ---------- */
.insta-item{position:relative;overflow:hidden;aspect-ratio:1;cursor:pointer}
.insta-item img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease;display:block;will-change:transform}
.insta-item:hover img{transform:scale(1.05)}
.ig-overlay{
  position:absolute;inset:0;
  background:rgba(74,44,30,.3);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .35s ease;
  pointer-events:none;
}
.insta-item:hover .ig-overlay{opacity:1}
.ig-overlay svg{width:36px;height:36px}

/* ==============================================
   SCROLL EFFECTS (Effects 1-6)
   ============================================== */

/* Effect 1 — Word-by-word headline reveal */
.word-wrap{overflow:hidden;display:inline-block;vertical-align:bottom}
.word{display:inline-block;transform:translateY(100%);opacity:0;transition:transform .7s cubic-bezier(.16,1,.3,1),opacity .5s ease}
.word.visible{transform:translateY(0);opacity:1}

/* Effect 2 — Slide from left / right */
.slide-from-left{opacity:0;transform:translateX(-60px);transition:opacity .9s ease,transform .9s cubic-bezier(.16,1,.3,1)}
.slide-from-right{opacity:0;transform:translateX(60px);transition:opacity .9s ease,transform .9s cubic-bezier(.16,1,.3,1)}
.slide-from-left.visible,.slide-from-right.visible{opacity:1;transform:translateX(0)}
@media(max-width:980px){
  .slide-from-left,.slide-from-right{transform:translateY(32px)}
  .slide-from-left.visible,.slide-from-right.visible{transform:translateY(0)}
}

/* Effect 3 — Pillar cards from below */
.pillar-anim{opacity:0;transform:translateY(48px);transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1)}
.pillar-anim.visible{opacity:1;transform:translateY(0)}

/* Effect 4 — Photo grid stagger */
.photo-item{opacity:0;transform:translateY(40px);transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1)}
.photo-item.visible{opacity:1;transform:translateY(0)}

/* Effect 5 — Interlude decorative background text */
.interlude-bg-text{
  position:absolute;top:50%;left:50%;
  transform:translateX(-50%) translateY(-50%);
  font-family:'Cormorant Garamond',serif;font-weight:300;
  font-size:clamp(120px,20vw,240px);
  color:#F7F2EC;opacity:.04;
  white-space:nowrap;letter-spacing:.05em;
  pointer-events:none;user-select:none;z-index:0;
}
.interlude .eyebrow,.interlude h2,.interlude p,.interlude .btn{position:relative;z-index:1}
.interlude p{font-size:16px;line-height:1.7;color:rgba(247,242,236,.65);max-width:520px;margin:0 auto 48px;font-family:'Jost',sans-serif;font-weight:300}
.interlude .btn{border-color:rgba(214,201,182,.6);color:#F7F2EC;background:transparent;padding:16px 40px;font-size:11px;letter-spacing:.18em}
.interlude .btn:hover{background:rgba(247,242,236,.1);border-color:#F7F2EC;color:#F7F2EC;transform:none}

/* Effect 6 — Eyebrow mask sweep left→right */
.eyebrow-reveal{position:relative;overflow:hidden}
.eyebrow-reveal::after{
  content:'';position:absolute;inset:0;
  background:var(--eyebrow-mask,rgb(247,242,236));
  transform:scaleX(1);transform-origin:left;
  transition:transform .6s cubic-bezier(.16,1,.3,1);
}
.eyebrow-reveal.visible::after{transform:scaleX(0);transform-origin:right}
