/* ============================================================
   alívia — editorial Mediterranean homepage
   ============================================================ */
:root{
  /* palette (sampled from brand + menu) */
  --cream:#FBFAF2; --cream-2:#F4EEDF; --sand:#E7DEC9; --sand-2:#DCCFB4;
  --olive:#565539; --olive-2:#46462E; --olive-deep:#33331F;
  --espresso:#1A140F; --ink:#2A2114;
  --terracotta:#8B5530; --rust:#6E310B; --clay:#A6613A;
  --caramel:#C9A06A; --gold:#B98A4C;
  --muted:#857a64;

  --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --display:"Playfair Display", Georgia, serif;
  --sans:"Montserrat", system-ui, -apple-system, sans-serif;
  --script:"Sacramento", cursive;

  --ease:cubic-bezier(.2,.7,.2,1);
  --pad:clamp(20px,6vw,110px);
  --maxw:1320px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; color:var(--ink);
  font-family:var(--sans); font-weight:400; line-height:1.7;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
  background-color:var(--cream);
  background-image:
    radial-gradient(135% 90% at 6% 0%, #FCF9EF 0%, rgba(252,249,239,0) 50%),
    radial-gradient(110% 90% at 100% 0%, #F0E9D6 0%, rgba(240,233,214,0) 44%);
}
/* site-wide tactile paper / plaster grain (over every surface, GPU-cheap) */
body::after{
  content:""; position:fixed; inset:0; z-index:9998; pointer-events:none;
  opacity:.07; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.6' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
  background-size:260px 260px;
}
img,video{display:block; max-width:100%}
a{color:inherit; text-decoration:none}
h1,h2,h3,h4{margin:0; font-weight:500}
ul{margin:0; padding:0; list-style:none}
::selection{background:var(--terracotta); color:var(--cream)}

/* grain texture overlay */
.hero__grain,.reserve__grain{
  position:absolute; inset:0; pointer-events:none; opacity:.5; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.32'/%3E%3C/svg%3E");
}

/* ---------- shared type ---------- */
.display{font-family:var(--display); font-weight:600; line-height:.98; letter-spacing:-.01em;
  font-size:clamp(2.6rem,7vw,5.4rem); color:var(--olive-deep);}
.display--xl{font-size:clamp(3rem,9vw,7.2rem)}
.eyebrow{font-family:var(--sans); font-size:.72rem; letter-spacing:.34em; text-transform:uppercase;
  color:var(--terracotta); margin:0 0 1.1rem; font-weight:500}
.eyebrow--light{color:var(--caramel)}
.lead{font-family:var(--serif); font-size:clamp(1.15rem,1.7vw,1.45rem); line-height:1.6; color:var(--ink);
  margin:0 0 1.4rem; max-width:52ch}
.lead--light{color:rgba(251,250,242,.82)}
.notes{font-family:var(--sans); font-weight:500; letter-spacing:.04em; font-size:.82rem; text-transform:uppercase;
  color:var(--caramel); margin:0 0 1.3rem}

/* ---------- buttons ---------- */
.btn{display:inline-block; font-family:var(--sans); font-weight:500; font-size:.74rem; letter-spacing:.22em;
  text-transform:uppercase; padding:1.05em 2.1em; border-radius:2px; cursor:pointer; border:1px solid transparent;
  transition:background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease), transform .35s var(--ease)}
.btn:hover{transform:translateY(-2px)}
.btn--solid{background:var(--terracotta); color:var(--cream)}
.btn--solid:hover{background:var(--rust)}
.btn--ghost{background:transparent; color:var(--cream); border-color:rgba(251,250,242,.55)}
.btn--ghost:hover{background:var(--cream); color:var(--olive-deep); border-color:var(--cream)}
.btn--cream{background:var(--cream); color:var(--olive-deep)}
.btn--cream:hover{background:var(--caramel); color:var(--olive-deep)}

/* ---------- arch motif ---------- */
.arch{position:relative; overflow:hidden; border-radius:9999px 9999px 6px 6px; background:var(--sand-2)}
.arch--tall{aspect-ratio:3/4}
.media-fill{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}
.arch__veil{position:absolute; inset:0; background:linear-gradient(180deg,rgba(26,20,15,.05),rgba(26,20,15,.28))}

/* ---------- ticker ---------- */
.ticker{position:fixed; top:0; left:0; right:0; height:30px; z-index:60; background:var(--olive-deep);
  color:var(--cream); overflow:hidden; display:flex; align-items:center}
.ticker__track{display:inline-flex; align-items:center; white-space:nowrap; gap:0; animation:scroll-x 38s linear infinite}
.ticker__item{font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; padding:0 1.1rem; opacity:.9}
.ticker__dot{color:var(--caramel); font-size:.5rem}
@keyframes scroll-x{from{transform:translateX(0)} to{transform:translateX(-50%)}}

/* ---------- nav ---------- */
.nav{position:fixed; top:30px; left:0; right:0; z-index:55; display:flex; align-items:center;
  justify-content:space-between; padding:.9rem var(--pad); transition:background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease)}
.nav__brand{font-family:var(--serif); font-weight:600; font-size:1.7rem; color:var(--olive-deep); letter-spacing:.01em}
.nav__brand sup{font-size:.5em; opacity:.6}
.nav__links{display:flex; gap:2.2rem}
.nav__links a{font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink); position:relative; padding:.3rem 0}
.nav__links a::after{content:""; position:absolute; left:0; bottom:0; width:0; height:1px; background:var(--terracotta); transition:width .35s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__right{display:flex; align-items:center; gap:1.2rem}
.nav__cta{padding:.8em 1.6em}
.nav--scrolled{background:var(--cream); box-shadow:0 1px 0 rgba(42,33,20,.08); padding-top:.7rem; padding-bottom:.7rem}
.nav__toggle{display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px}
.nav__toggle span{width:24px; height:2px; background:var(--olive-deep); transition:.3s var(--ease)}

/* brandmark logo ("a" + alívia / by Feel) */
.brandmark{display:flex; align-items:center; gap:11px; text-decoration:none}
.brandmark .logo{width:42px; height:42px; border-radius:50%; background:var(--olive); color:var(--cream);
  display:grid; place-items:center; font-family:var(--serif); font-style:italic; font-weight:600; font-size:25px;
  box-shadow:inset 0 0 0 2px rgba(201,160,106,.7); flex:0 0 auto}
.brandmark__txt{display:flex; flex-direction:column; line-height:1}
.brandmark .wordmark{font-family:var(--serif); font-weight:600; font-size:1.55rem; color:var(--olive-deep); letter-spacing:.01em}
.brandmark .sub{font-family:var(--sans); font-size:.56rem; letter-spacing:.24em; text-transform:uppercase; color:var(--muted); margin-top:3px}
/* language toggle */
.lang-toggle{display:inline-flex; background:rgba(86,85,57,.08); border:1px solid rgba(86,85,57,.18); border-radius:999px; padding:3px; gap:2px}
.lang-toggle button{border:0; background:transparent; padding:5px 11px; border-radius:999px; font-family:var(--sans); font-size:.72rem; font-weight:600; color:var(--muted); cursor:pointer; transition:.2s}
.lang-toggle button.on{background:var(--olive); color:var(--cream)}
/* round icon button (cart) */
.icon-btn{position:relative; width:42px; height:42px; border-radius:50%; border:1px solid rgba(86,85,57,.22);
  background:#FFFDF7; color:var(--olive-deep); display:grid; place-items:center; cursor:pointer; transition:.2s}
.icon-btn:hover{border-color:var(--terracotta); color:var(--terracotta)}
.icon-btn svg{width:20px; height:20px}
.cart-badge{position:absolute; top:-5px; right:-5px; min-width:19px; height:19px; padding:0 4px; background:var(--terracotta);
  color:var(--cream); border-radius:10px; font-family:var(--sans); font-size:.62rem; font-weight:600; display:grid; place-items:center; border:2px solid var(--cream)}
/* olive primary button (Order Now) */
.btn--olive{background:var(--olive); color:var(--cream)}
.btn--olive:hover{background:var(--olive-2)}

/* mobile drawer */
.drawer{position:fixed; inset:0 0 0 auto; width:min(80vw,320px); background:var(--olive-deep); z-index:54;
  transform:translateX(100%); transition:transform .45s var(--ease); display:flex; flex-direction:column;
  gap:.4rem; padding:6rem 2rem 2rem; justify-content:center}
.drawer a{font-family:var(--serif); font-size:1.6rem; color:var(--cream); padding:.5rem 0; border-bottom:1px solid rgba(251,250,242,.12)}
.drawer .btn{margin-top:1.4rem; text-align:center}
.drawer.open{transform:none}
body.nav-open{overflow:hidden}

/* ---------- hero ---------- */
.hero{position:relative; min-height:100svh; display:flex; flex-direction:column; align-items:center;
  justify-content:center; text-align:center; padding:7rem var(--pad) 4rem;
  background:radial-gradient(120% 90% at 50% 0%, var(--cream) 0%, var(--cream-2) 55%, var(--sand) 100%)}
.hero__kicker{font-size:.72rem; letter-spacing:.34em; text-transform:uppercase; color:var(--terracotta); margin:0 0 1.6rem}
.hero__stage{position:relative; display:flex; align-items:flex-end; justify-content:center}
.hero__arch{width:clamp(230px,32vw,380px); aspect-ratio:5/7; box-shadow:0 40px 80px -40px rgba(51,51,31,.6)}
.hero__word{font-family:var(--serif); font-weight:600; color:var(--olive-deep); font-size:clamp(4.5rem,19vw,15rem);
  line-height:.8; letter-spacing:.01em; position:absolute; bottom:-.08em; left:50%; transform:translateX(-50%);
  pointer-events:none; mix-blend-mode:multiply}
.hero__tag{font-family:var(--serif); font-size:clamp(1.1rem,1.7vw,1.5rem); line-height:1.55; color:var(--ink);
  max-width:40ch; margin:2.4rem auto 0}
.hero__scroll{margin-top:2.4rem; display:inline-flex; flex-direction:column; align-items:center; gap:.5rem;
  color:var(--muted); font-size:.62rem; letter-spacing:.3em; text-transform:uppercase}
.hero__scroll svg{animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ---------- running strip ---------- */
.strip{background:var(--terracotta); color:var(--cream); overflow:hidden; padding:.9rem 0}
.strip__track{display:inline-flex; align-items:center; white-space:nowrap; animation:scroll-x 26s linear infinite}
.strip span{font-family:var(--display); font-style:italic; font-size:clamp(1.4rem,3.4vw,2.4rem); padding:0 1.4rem}
.strip i{color:var(--caramel); font-style:normal; font-size:1rem}

/* ---------- split sections ---------- */
.split{display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center;
  padding:clamp(4rem,9vw,8rem) var(--pad)}
.split--sand{background:var(--sand)}
.split--olive{background:var(--olive); color:var(--cream)}
.split__media .arch{box-shadow:0 40px 80px -50px rgba(51,51,31,.7)}
#story .split__media .arch img{height:128%; object-position:50% 80%}
.split__body{max-width:38rem}
.split--olive .display{color:var(--cream)}

/* ---------- feature (full-bleed media split) ---------- */
.feature{display:grid; grid-template-columns:1.05fr 1fr; min-height:88vh; background:var(--espresso); color:var(--cream)}
.feature__media{position:relative; overflow:hidden; min-height:60vh}
.feature__body{display:flex; flex-direction:column; justify-content:center; padding:clamp(3rem,7vw,7rem)}
.feature .display{color:var(--cream)}

/* ---------- menu ---------- */
.menu{padding:clamp(4.5rem,9vw,9rem) var(--pad); background:var(--cream)}
.menu__head{text-align:center; margin-bottom:clamp(2.5rem,5vw,4rem)}
.tiles{display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1rem,2vw,1.8rem); margin-bottom:clamp(3rem,6vw,6rem)}
.tile{text-align:center; transition:transform .4s var(--ease)}
.tile:hover{transform:translateY(-6px)}
.tile__arch{aspect-ratio:3/4; margin-bottom:1.1rem}
.tile h3{font-family:var(--display); font-weight:500; font-size:1.5rem; color:var(--olive-deep)}
.tile span{font-family:var(--serif); font-size:1rem; color:var(--muted)}

/* full tabbed menu */
.full{max-width:var(--maxw); margin:0 auto; background:var(--cream-2); border-radius:18px;
  padding:clamp(1.6rem,4vw,3.5rem); border:1px solid rgba(86,85,57,.14)}
.full__tabs{display:flex; flex-wrap:wrap; gap:.5rem; justify-content:center; margin-bottom:2.5rem}
.full__tabs button{font-family:var(--sans); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase;
  padding:.7em 1.2em; border-radius:40px; border:1px solid rgba(86,85,57,.3); background:transparent; color:var(--olive);
  cursor:pointer; transition:.3s var(--ease)}
.full__tabs button:hover{border-color:var(--terracotta); color:var(--terracotta)}
.full__tabs button.active{background:var(--olive); color:var(--cream); border-color:var(--olive)}
.full__panel{display:grid; grid-template-columns:1fr 1fr; gap:.2rem 3.5rem}
.m-sub{grid-column:1/-1; font-family:var(--display); font-style:italic; font-size:1.3rem; color:var(--terracotta);
  margin:1.4rem 0 .4rem; padding-bottom:.4rem; border-bottom:1px solid rgba(139,85,48,.25)}
.m-sub:first-child{margin-top:0}
.m-item{display:grid; grid-template-columns:1fr auto; align-items:baseline; gap:.6rem; padding:.85rem 0;
  border-bottom:1px dashed rgba(86,85,57,.18)}
.m-item__main{min-width:0}
.m-item__name{font-family:var(--sans); font-weight:500; font-size:.86rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink)}
.m-item__desc{font-family:var(--serif); font-size:1.02rem; color:var(--muted); line-height:1.4; margin-top:.15rem}
.m-item__price{font-family:var(--display); font-weight:600; font-size:1.1rem; color:var(--terracotta); white-space:nowrap}
.m-addons{grid-column:1/-1; margin-top:1.4rem; font-family:var(--serif); color:var(--muted); font-size:1rem}
.m-addons b{color:var(--olive); font-family:var(--sans); font-weight:500; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase}
.full__note{text-align:center; font-size:.68rem; letter-spacing:.06em; color:var(--muted); margin:2.2rem 0 0; font-style:italic}

/* ---------- atmosphere ---------- */
.atmos{position:relative; min-height:92vh; display:flex; align-items:center; justify-content:center; text-align:center;
  color:var(--cream); overflow:hidden; padding:5rem var(--pad)}
.atmos__bg{z-index:0}
.atmos__veil{position:absolute; inset:0; z-index:1; background:linear-gradient(180deg,rgba(26,20,15,.55),rgba(51,51,31,.72))}
.atmos__inner{position:relative; z-index:2; max-width:46rem}
.atmos .display{color:var(--cream)}

/* ---------- ticklist (drinks) ---------- */
.ticklist{margin:0 0 2rem; max-width:30rem}
.ticklist li{display:flex; justify-content:space-between; align-items:baseline; gap:1rem; padding:.7rem 0;
  border-bottom:1px dashed rgba(251,250,242,.22)}
.ticklist span{font-family:var(--serif); font-size:1.15rem; color:rgba(251,250,242,.9)}
.ticklist b{font-family:var(--display); color:var(--caramel); font-weight:600}

/* ---------- gallery ---------- */
.gallery{padding:clamp(4rem,8vw,8rem) var(--pad); background:var(--cream)}
.gallery__head{text-align:center; margin-bottom:2.6rem}
.gallery__grid{display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:minmax(180px,auto); gap:1rem}
.gallery__cell{position:relative; overflow:hidden; border-radius:8px; margin:0; min-height:240px}
.gallery__cell--tall{grid-row:span 2}
.gallery__cell--wide{grid-column:span 2}
.gallery__cell video{transition:transform .8s var(--ease)}
.gallery__cell:hover video{transform:scale(1.06)}

/* ---------- reserve ---------- */
.reserve{position:relative; text-align:center; color:var(--cream); padding:clamp(5rem,11vw,10rem) var(--pad);
  background:linear-gradient(150deg,var(--olive-deep),var(--olive) 60%,var(--rust))}
.reserve__inner{position:relative; z-index:2; max-width:46rem; margin:0 auto}
.reserve .display{color:var(--cream)}
.reserve__actions{display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-top:2rem}

/* ---------- footer ---------- */
.foot{background:var(--olive-deep); color:var(--cream); padding:clamp(3.5rem,7vw,6rem) var(--pad) 2rem; overflow:hidden}
.foot__top{display:grid; grid-template-columns:1.1fr 1.4fr; gap:3rem; max-width:var(--maxw); margin:0 auto}
.foot__news h3{font-family:var(--display); font-size:2.2rem; margin-bottom:1rem; color:var(--cream)}
.foot__news p{color:rgba(251,250,242,.7); max-width:34ch; margin:0 0 1.4rem}
.foot__form{display:flex; max-width:380px; border:1px solid rgba(251,250,242,.3); border-radius:3px; overflow:hidden}
.foot__form input{flex:1; background:transparent; border:0; color:var(--cream); padding:.9rem 1rem; font-family:var(--sans); font-size:.85rem; outline:none}
.foot__form input::placeholder{color:rgba(251,250,242,.5)}
.foot__form button{background:var(--caramel); color:var(--olive-deep); border:0; padding:0 1.5rem; font-family:var(--sans);
  font-weight:500; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; cursor:pointer; transition:background .3s}
.foot__form button:hover{background:var(--cream)}
.foot__cols{display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem}
.foot__cols h4{font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--caramel); margin-bottom:1rem; font-weight:500}
.foot__cols a{display:block; color:rgba(251,250,242,.72); font-family:var(--serif); font-size:1.05rem; padding:.28rem 0; transition:color .25s}
.foot__cols a:hover{color:var(--cream)}
.foot__word{font-family:var(--serif); font-weight:600; font-size:clamp(6rem,26vw,22rem); line-height:.8; text-align:center;
  color:transparent; -webkit-text-stroke:1px rgba(251,250,242,.16); margin:clamp(2rem,5vw,4rem) 0 1rem; user-select:none}
.foot__base{display:flex; flex-wrap:wrap; gap:1rem; align-items:center; justify-content:space-between;
  border-top:1px solid rgba(251,250,242,.14); padding-top:1.6rem; max-width:var(--maxw); margin:0 auto}
.foot__tag{font-family:var(--serif); font-style:italic; font-size:1.05rem; color:rgba(251,250,242,.8)}
.foot__social{display:flex; gap:1.4rem}
.foot__social a{font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(251,250,242,.72)}
.foot__social a:hover{color:var(--caramel)}
.foot__copy{font-size:.68rem; letter-spacing:.08em; color:rgba(251,250,242,.5)}

/* ---------- reveal ---------- */
.reveal{opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease)}
.reveal.in{opacity:1; transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1; transform:none; transition:none}
  .ticker__track,.strip__track,.hero__scroll svg{animation:none}
}

/* ---------- responsive ---------- */
@media (max-width:1024px){
  .tiles{grid-template-columns:repeat(2,1fr)}
  .feature{grid-template-columns:1fr}
  .feature__media{min-height:54vh}
}
@media (max-width:820px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .lang-toggle{display:none}
  .nav__toggle{display:flex}
  .split{grid-template-columns:1fr; gap:2.4rem}
  .split--olive .split__media{order:-1}
  .full__panel{grid-template-columns:1fr; gap:0}
  .foot__top{grid-template-columns:1fr; gap:2.5rem}
  .gallery__grid{grid-template-columns:repeat(2,1fr)}
  .gallery__cell--wide{grid-column:span 2}
}
@media (max-width:520px){
  .tiles{grid-template-columns:1fr 1fr; gap:.8rem}
  .tile h3{font-size:1.2rem}
  .foot__cols{grid-template-columns:1fr 1fr}
  .foot__base{justify-content:center; text-align:center}
  .hero__word{font-size:clamp(4rem,26vw,9rem)}
}
