/* ============================================================
   LE TI TAURUS — Design system
   ============================================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}

:root{
  --ocean-950:#04181e;
  --ocean-900:#062730;
  --ocean-800:#0a3742;
  --ocean-700:#0f4a58;
  --sand:#f5ecdd;
  --sand-dim:#d8cdb8;
  --cream:#fbf6ec;
  --coral:#ff6a45;
  --coral-soft:#ff8a68;
  --gold:#f2b134;
  --gold-soft:#ffcf6b;
  --turq:#2bc4b0;
  --ink:#0c1a1e;
  --line:rgba(245,236,221,.14);
  --line-dark:rgba(6,39,48,.12);

  --serif:'Fraunces',Georgia,serif;
  --sans:'Manrope',system-ui,sans-serif;

  --container:1240px;
  --pad:clamp(20px,5vw,64px);
  --ease:cubic-bezier(.16,.84,.32,1);
  --radius:18px;
}

body{
  background:var(--ocean-950);
  color:var(--sand);
  font-family:var(--sans);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.08}
em{font-style:italic;color:var(--gold-soft)}
section{position:relative}

/* film grain + sunburst ambiance */
.grain{position:fixed;inset:0;z-index:998;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:1001;background:linear-gradient(90deg,var(--coral),var(--gold))}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:16px 30px;border-radius:100px;
  font-weight:700;font-size:.95rem;border:1px solid transparent;cursor:pointer;white-space:nowrap;position:relative;
  transition:transform .4s var(--ease),background .3s,border-color .3s,color .3s,box-shadow .3s}
.btn span{position:relative;z-index:1}
.btn--primary{background:linear-gradient(135deg,var(--gold-soft),var(--coral));color:#2a0f06}
.btn--primary:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 14px 34px rgba(255,106,69,.4)}
.btn--outline{border-color:var(--line);color:var(--sand)}
.btn--outline:hover{border-color:var(--gold);color:var(--gold-soft);transform:translateY(-3px)}
.btn--ghost{color:var(--sand)}
.btn--ghost:hover{color:var(--gold-soft)}
.btn--sm{padding:11px 20px;font-size:.85rem}
.btn--lg{padding:19px 40px;font-size:1.02rem}
.btn--block{width:100%}
.btn--dark{background:var(--ocean-900);color:var(--sand)}

.link-arrow{display:inline-flex;align-items:center;gap:9px;font-weight:700;color:var(--gold-soft);
  padding-bottom:4px;border-bottom:1px solid var(--line)}
.link-arrow span{transition:transform .3s var(--ease)}
.link-arrow:hover span{transform:translateX(6px)}

.kicker{font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);font-weight:700;
  margin-bottom:16px;display:block}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px var(--pad);
  transition:padding .4s var(--ease),background .4s,backdrop-filter .4s,border-color .4s;border-bottom:1px solid transparent}
.nav.scrolled{padding:12px var(--pad);background:rgba(4,24,30,.82);backdrop-filter:blur(16px);border-color:var(--line)}
.nav__in{max-width:var(--container);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:1.3rem;letter-spacing:.01em;white-space:nowrap}
.brand__mark{width:34px;height:34px;flex:0 0 34px}
.brand b{font-weight:600}
.brand i{font-style:normal;color:var(--gold-soft)}
.nav__links{display:flex;gap:30px;font-size:.9rem}
.nav__links a{position:relative;opacity:.85;transition:opacity .25s}
.nav__links a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold-soft);transition:width .3s var(--ease)}
.nav__links a:hover,.nav__links a[aria-current]{opacity:1}
.nav__links a:hover::after,.nav__links a[aria-current]::after{width:100%}
.nav__act{display:flex;gap:12px;align-items:center}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;z-index:200}
.burger span{width:24px;height:1.6px;background:var(--sand);transition:.3s}
.burger.active span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}

.mobile{position:fixed;inset:0;z-index:90;background:var(--ocean-950);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:24px;font-family:var(--serif);font-size:1.6rem;
  transform:translateY(-100%);transition:transform .5s var(--ease)}
.mobile.open{transform:translateY(0)}

/* ---------- Perspective wrapper for 3D scroll ---------- */
.scene{perspective:1400px;perspective-origin:50% 40%}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden;transform-style:preserve-3d}
.hero__layer{position:absolute;inset:-6%;background-size:cover;background-position:center;will-change:transform}
.hero__overlay{position:absolute;inset:0;background:
  radial-gradient(120% 80% at 80% 10%,rgba(255,171,52,.20),transparent 55%),
  linear-gradient(180deg,rgba(4,24,30,.35),rgba(4,24,30,.35) 30%,rgba(4,24,30,.92)),
  linear-gradient(90deg,rgba(4,24,30,.6),transparent 60%)}
.hero__content{position:relative;z-index:3;padding:0 var(--pad) 120px;max-width:900px}
.hero__eyebrow{display:inline-flex;align-items:center;gap:10px;text-transform:uppercase;letter-spacing:.22em;
  font-size:.78rem;color:var(--gold-soft);font-weight:700;margin-bottom:22px}
.hero__eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--turq);box-shadow:0 0 12px var(--turq)}
.hero h1{font-size:clamp(2.7rem,7vw,5.8rem);font-weight:400;margin-bottom:24px}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .word{display:inline-block}
.hero h1 .accent{color:var(--gold-soft);font-style:italic}
.hero__sub{font-size:clamp(1.02rem,1.6vw,1.28rem);color:var(--sand-dim);max-width:540px;margin-bottom:38px}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap}
.hero__scroll{position:absolute;right:var(--pad);bottom:44px;z-index:3;display:flex;align-items:center;gap:10px;
  color:var(--sand-dim);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}
.hero__scroll .rail{width:1px;height:42px;background:var(--line);position:relative;overflow:hidden}
.hero__scroll .rail::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--gold-soft);animation:rail 2s ease-in-out infinite}
@keyframes rail{50%{top:0}100%{top:100%}}

/* ---------- Stats strip ---------- */
.stats{background:var(--ocean-900);border-block:1px solid var(--line);padding:34px var(--pad)}
.stats__in{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.stat{text-align:center}
.stat b{font-family:var(--serif);font-size:clamp(1.8rem,3vw,2.6rem);display:block;color:var(--cream)}
.stat span{font-size:.8rem;letter-spacing:.06em;color:var(--sand-dim);text-transform:uppercase}

/* ---------- Generic section ---------- */
.sec{max-width:var(--container);margin:0 auto;padding:clamp(90px,12vw,150px) var(--pad)}
.sec__head{max-width:720px;margin-bottom:60px}
.sec__head h2{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:18px}
.sec__head p{color:var(--sand-dim)}
.sec--center .sec__head{margin-inline:auto;text-align:center}

/* intro split */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:70px;align-items:center;max-width:var(--container);margin:0 auto;padding:clamp(90px,12vw,140px) var(--pad)}
.split__media{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;will-change:transform}
.split__media img{width:100%;height:100%;object-fit:cover}
.split__body h2{font-size:clamp(1.9rem,3.4vw,2.9rem);margin-bottom:22px}
.split__body p{color:var(--sand-dim);margin-bottom:18px;max-width:520px}
.split--rev .split__media{order:2}

/* ---------- 3D dish cards ---------- */
.dishes{background:linear-gradient(180deg,var(--ocean-950),var(--ocean-900))}
.dish-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;max-width:var(--container);margin:0 auto}
.dish{background:var(--ocean-800);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  will-change:transform;transform-style:preserve-3d;transition:box-shadow .4s,border-color .4s}
.dish:hover{border-color:rgba(242,177,52,.4);box-shadow:0 30px 60px -30px rgba(0,0,0,.7)}
.dish__img{aspect-ratio:4/3;overflow:hidden}
.dish__img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.dish:hover .dish__img img{transform:scale(1.07)}
.dish__body{padding:24px}
.dish__row{display:flex;justify-content:space-between;align-items:baseline;gap:14px}
.dish__row h3{font-size:1.3rem}
.dish__price{font-family:var(--serif);color:var(--gold-soft);font-size:1.15rem;white-space:nowrap}
.dish__body p{color:var(--sand-dim);font-size:.92rem;margin-top:8px}
.dish__tag{display:inline-block;margin-top:14px;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--turq);border:1px solid rgba(43,196,176,.35);border-radius:100px;padding:4px 12px}

/* ---------- Reviews teaser ---------- */
.reviews{background:var(--ocean-900)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:var(--container);margin:0 auto}
.rev-card{background:var(--ocean-800);border:1px solid var(--line);border-radius:var(--radius);padding:30px;
  will-change:transform;transform-style:preserve-3d}
.rev-stars{color:var(--gold);letter-spacing:2px;margin-bottom:14px;font-size:1.05rem}
.rev-card p{font-family:var(--serif);font-size:1.12rem;line-height:1.5;color:var(--cream)}
.rev-card footer{margin-top:20px;display:flex;align-items:center;gap:12px}
.rev-av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--turq),var(--ocean-700));
  display:grid;place-items:center;font-weight:800;color:#032;font-family:var(--sans)}
.rev-card cite{font-style:normal;font-size:.9rem}
.rev-card cite b{display:block;color:var(--sand)}
.rev-card cite span{color:var(--sand-dim);font-size:.8rem}

/* ---------- Gallery ---------- */
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:var(--container);margin:0 auto}
.gal-item{border-radius:14px;overflow:hidden;aspect-ratio:3/4;will-change:transform;transform-style:preserve-3d}
.gal-item.tall{grid-row:span 2;aspect-ratio:3/5.4}
.gal-item.wide{grid-column:span 2;aspect-ratio:auto}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),filter .6s;filter:saturate(1.02)}
.gal-item:hover img{transform:scale(1.06)}

/* ---------- Menu page ---------- */
.menu-cat{max-width:var(--container);margin:0 auto;padding:0 var(--pad)}
.menu-cat h2{font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:8px;display:flex;align-items:center;gap:16px}
.menu-cat h2::after{content:'';flex:1;height:1px;background:var(--line)}
.menu-cat>p{color:var(--sand-dim);margin-bottom:34px}
.menu-list{display:grid;grid-template-columns:1fr 1fr;gap:8px 60px;margin-bottom:70px}
.menu-item{display:grid;grid-template-columns:1fr auto;gap:10px;padding:16px 0;border-bottom:1px dashed var(--line);align-items:baseline;will-change:transform}
.menu-item h3{font-family:var(--sans);font-weight:700;font-size:1.02rem}
.menu-item .m-desc{grid-column:1;color:var(--sand-dim);font-size:.88rem;margin-top:3px}
.menu-item .m-price{font-family:var(--serif);color:var(--gold-soft);font-size:1.12rem;white-space:nowrap}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;text-align:center;padding:clamp(80px,12vw,140px) var(--pad)}
.cta-band__bg{position:absolute;inset:-10%;background-size:cover;background-position:center;will-change:transform;z-index:0}
.cta-band__veil{position:absolute;inset:0;z-index:1;background:linear-gradient(0deg,rgba(4,24,30,.9),rgba(4,24,30,.72))}
.cta-band__in{position:relative;z-index:2;max-width:760px;margin:0 auto}
.cta-band h2{font-size:clamp(2rem,4.5vw,3.4rem);margin-bottom:20px}
.cta-band p{color:var(--sand-dim);margin-bottom:34px;font-size:1.05rem}
.cta-band .hero__cta{justify-content:center}

/* ---------- Contact ---------- */
.contact{display:grid;grid-template-columns:1fr 1fr;min-height:640px;background:var(--ocean-900);border-top:1px solid var(--line)}
.contact__body{padding:clamp(70px,10vw,120px) var(--pad);display:flex;flex-direction:column;justify-content:center}
.contact__body h2{font-size:clamp(2rem,3.4vw,2.9rem);margin-bottom:36px;max-width:460px}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-bottom:40px}
.contact__grid h4{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.contact__grid p{color:var(--sand-dim);font-size:.95rem}
.contact__grid a{color:var(--sand-dim);border-bottom:1px solid var(--line)}
.contact__grid a:hover{color:var(--gold-soft)}
.contact__cta{display:flex;gap:14px;flex-wrap:wrap}
.contact__map{position:relative;min-height:420px;filter:saturate(.55) brightness(.9) contrast(1.05)}
.contact__map iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---------- Footer ---------- */
.footer{max-width:var(--container);margin:0 auto;padding:64px var(--pad) 44px}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--line)}
.footer__top p{color:var(--sand-dim);font-size:.92rem;margin-top:16px;max-width:320px}
.footer__col h5{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.footer__col a{display:block;color:var(--sand-dim);font-size:.92rem;padding:5px 0}
.footer__col a:hover{color:var(--sand)}
.footer__bottom{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;padding-top:24px;font-size:.8rem;color:var(--sand-dim)}

/* ---------- Sticky mobile CTA ---------- */
.sticky-cta{position:fixed;left:14px;right:14px;bottom:14px;z-index:95;display:none;gap:10px;
  transform:translateY(160%);transition:transform .45s var(--ease)}
.sticky-cta.show{transform:translateY(0)}
.sticky-cta .btn{flex:1}

/* page hero (subpages) */
.phero{position:relative;min-height:56vh;display:flex;align-items:flex-end;overflow:hidden}
.phero__bg{position:absolute;inset:-6%;background-size:cover;background-position:center;will-change:transform}
.phero__veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(4,24,30,.5),rgba(4,24,30,.92))}
.phero__in{position:relative;z-index:2;padding:0 var(--pad) 60px;max-width:var(--container);margin:0 auto;width:100%}
.phero h1{font-size:clamp(2.4rem,6vw,4.4rem);margin-bottom:12px}
.phero p{color:var(--sand-dim);max-width:560px}
.crumb{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.crumb a{opacity:.8}
.crumb a:hover{opacity:1}

/* ---------- reveal base states (JS animates) ---------- */
.r-up{opacity:0;transform:translateY(40px)}
.r-img{opacity:0;transform:scale(1.08)}
.r-word{transform:translateY(115%)}
.d3{opacity:0;transform:perspective(1000px) rotateX(14deg) translateY(60px);transform-origin:top center}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .nav__links,.nav__act .btn--ghost{display:none}
  .burger{display:flex}
  .stats__in{grid-template-columns:repeat(2,1fr);gap:26px}
  .split,.contact{grid-template-columns:1fr}
  .split--rev .split__media{order:0}
  .split__media{aspect-ratio:16/10}
  .dish-grid,.rev-grid{grid-template-columns:1fr 1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .menu-list{grid-template-columns:1fr;gap:0}
  .footer__top{grid-template-columns:1fr 1fr}
  .sticky-cta{display:flex}
  .contact__map{min-height:340px}
}
@media(max-width:600px){
  .dish-grid,.rev-grid,.footer__top{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:1fr}
  .gal-item.wide{grid-column:span 1}
  .hero__cta{flex-direction:column;align-items:stretch}
  .contact__grid{grid-template-columns:1fr}
  .hero__content{padding-bottom:96px}
}

/* ---------- reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .r-up,.r-img,.d3{opacity:1!important;transform:none!important}
  .r-word{transform:none!important}
  .hero__scroll .rail::after{animation:none}
  *{transition-duration:.01ms!important;animation-duration:.01ms!important}
}
