/* ══════════════════════════════════════════════════════════════
   Cantina Frijol — first-draft site
   Palette + type pulled from the brand's own materials.
   ══════════════════════════════════════════════════════════════ */

:root{
  --bone:    #D8D2C7;   /* paper / primary background        */
  --bone-2:  #E4DED3;   /* lifted card bone                  */
  --bone-3:  #CBC4B7;   /* hairlines on bone                 */
  --ink:     #1A1714;   /* near-black text                   */
  --ink-soft:#4A443D;   /* secondary text                    */
  --terra:   #BE4D20;   /* signature terracotta (accents/fills) */
  --terra-d: #9E3D17;   /* darker terracotta (hovers)        */
  --terra-text:#8F3614; /* AA-safe terracotta for TEXT on bone (>=4.5:1) */
  --night:   #20251F;   /* cantina dark (charcoal-green)     */
  --night-2: #2C322A;   /* lifted dark card                  */
  --night-l: #C9C8BC;   /* muted text on dark                */

  --serif: "Fraunces", Georgia, serif;
  --sans:  "DM Sans", system-ui, sans-serif;
  --mono:  "Space Mono", ui-monospace, monospace;

  --pad: clamp(1.25rem, 5vw, 6rem);
  --maxw: 1180px;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; scroll-padding-top:5rem; -webkit-text-size-adjust:100%; }

body{
  font-family:var(--sans);
  background:var(--bone);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  /* faint paper grain */
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%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)' opacity='0.035'/%3E%3C/svg%3E");
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
em{ font-style:italic; }
.nowrap{ white-space:nowrap; }

/* skip-to-content link (visible only on keyboard focus) */
.skip-link{ position:absolute; left:-9999px; top:0; z-index:300;
  background:var(--ink); color:var(--bone); font-family:var(--mono); font-size:.8rem;
  letter-spacing:.04em; padding:.8em 1.2em; border-radius:0 0 8px 0; }
.skip-link:focus{ left:0; }

/* visible keyboard focus everywhere (WCAG 2.4.7) */
a:focus-visible, button:focus-visible, input:focus-visible,
.btn:focus-visible, .nav__toggle:focus-visible{
  outline:2px solid var(--ink); outline-offset:3px; border-radius:3px;
}

/* ── shared type ───────────────────────────────────────────── */
.section-label{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--terra-text);          /* AA on bone */
  margin-bottom:1.4rem;
}
h1,h2,h3{ font-family:var(--serif); font-weight:500; line-height:1.04; letter-spacing:-0.01em; }
h2{ font-size:clamp(2.1rem,6vw,4rem); }

.eyebrow{
  font-family:var(--mono); font-size:.74rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-soft);
}
.tag{
  font-family:var(--mono); font-size:.6rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--terra-text);
  border:1px solid currentColor; border-radius:2em;
  padding:.15em .7em; vertical-align:middle; white-space:nowrap;
}

/* ── buttons ───────────────────────────────────────────────── */
.btn{
  display:inline-block; font-family:var(--mono); font-size:.8rem;
  letter-spacing:.08em; text-transform:uppercase;
  padding:.95em 1.7em; border-radius:2em; transition:.25s ease;
  border:1.5px solid var(--ink); cursor:pointer;
}
.btn--solid{ background:var(--ink); color:var(--bone); }
.btn--solid:hover{ background:var(--terra); border-color:var(--terra); }
.btn--ghost{ background:transparent; color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--bone); }

/* ════ Intro splash ════════════════════════════════════════ */
.intro{
  position:fixed; inset:0; z-index:200;
  background:var(--terra);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:1.5rem;
  transition:transform 1s cubic-bezier(.76,0,.24,1), opacity .6s ease;
}
.intro.lift{ transform:translateY(-101%); }
.intro__logo{
  /* Nina's GIF carries its own reveal animation; terracotta bg matches .intro */
  height:min(58vh,520px); width:auto; max-width:88vw;
  opacity:0; animation:introFade .5s .1s ease forwards;
}
@keyframes introFade{ to{ opacity:1; } }
.intro__word{
  display:flex; gap:.6rem; font-family:var(--serif); font-style:italic;
  color:var(--bone); font-size:clamp(1rem,4vw,1.4rem); letter-spacing:.02em;
  opacity:0; animation:fadeUp .8s 1.1s ease forwards;
}
@keyframes fadeUp{ from{opacity:0; transform:translateY(10px);} to{opacity:1; transform:translateY(0);} }
.intro__skip{
  position:absolute; bottom:1.6rem; right:1.6rem;
  font-family:var(--mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase;
  color:#fff; background:transparent; border:1px solid #fff;
  border-radius:2em; padding:.5em 1.1em; cursor:pointer; transition:.2s;
}
.intro__skip:hover{ background:var(--bone); color:var(--terra-d); border-color:var(--bone); }

/* ════ Nav ═════════════════════════════════════════════════ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem var(--pad);
  transition:background .3s ease, padding .3s ease, box-shadow .3s ease;
}
.nav.scrolled{
  background:rgba(216,210,199,.86);
  -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
  padding-top:.8rem; padding-bottom:.8rem;
  box-shadow:0 1px 0 var(--bone-3);
}
/* opaque fallback where backdrop-filter is unsupported */
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .nav.scrolled{ background:rgba(216,210,199,.97); }
}
.nav__brand{
  font-family:var(--serif); font-weight:600; font-size:1.25rem;
  letter-spacing:-.01em;
}
.nav__links{ display:flex; align-items:center; gap:1.8rem; }
.nav__links a{
  font-family:var(--mono); font-size:.78rem; letter-spacing:.06em;
  text-transform:uppercase; color:var(--ink); opacity:.82; transition:.2s;
}
.nav__links a:hover{ opacity:1; color:var(--terra-text); }
.nav__cta{
  border:1.5px solid var(--ink); border-radius:2em; padding:.5em 1.1em;
  opacity:1 !important;
}
.nav__cta:hover{ background:var(--ink); color:var(--bone)!important; }
.nav__toggle{ display:none; background:none; border:0; cursor:pointer; flex-direction:column; gap:5px; padding:6px; }
.nav__toggle span{ width:24px; height:2px; background:var(--ink); transition:.3s; }

/* ════ Hero ════════════════════════════════════════════════ */
.hero{
  min-height:100svh; display:flex; flex-direction:column; justify-content:center;
  padding:7rem var(--pad) 3rem; max-width:var(--maxw); margin:0 auto;
}
.hero__title{
  font-size:clamp(2.8rem,10vw,7.2rem);
  margin:1.2rem 0 1.8rem; max-width:14ch;
}
.hero__title em{ color:var(--terra); font-weight:400; }
.hero__lede{
  font-size:clamp(1.05rem,2.2vw,1.4rem); max-width:42ch;
  color:var(--ink-soft); margin-bottom:2.4rem;
}
.hero__lede strong{ color:var(--ink); font-weight:500; }
.hero__actions{ display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:2.6rem; }
.hero__status{
  font-family:var(--mono); font-size:.76rem; letter-spacing:.05em;
  color:var(--ink-soft); display:flex; align-items:center; gap:.6rem;
}
.dot{ width:8px; height:8px; border-radius:50%; background:var(--terra);
  box-shadow:0 0 0 0 rgba(190,77,32,.5); animation:pulse 2.4s infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(190,77,32,.5);} 70%{box-shadow:0 0 0 9px rgba(190,77,32,0);} 100%{box-shadow:0 0 0 0 rgba(190,77,32,0);} }

/* ════ Marquee ═════════════════════════════════════════════ */
.marquee{
  background:var(--ink); color:var(--bone); overflow:hidden;
  padding:.9rem 0; border-top:1px solid var(--ink); border-bottom:1px solid var(--ink);
}
.marquee__track{
  display:inline-flex; gap:2.5rem; white-space:nowrap;
  font-family:var(--serif); font-style:italic; font-size:1.2rem;
  animation:scroll 34s linear infinite;
}
.marquee__track span{ display:inline-block; }
.marquee__track span[aria-hidden]{ color:var(--terra); font-style:normal; }
@keyframes scroll{ from{transform:translateX(0);} to{transform:translateX(-50%);} }

/* ════ Story ═══════════════════════════════════════════════ */
.story{
  position:relative; max-width:var(--maxw); margin:0 auto;
  padding:clamp(4rem,12vw,9rem) var(--pad);
}
.story__motif{ position:absolute; top:clamp(2rem,8vw,5rem); right:var(--pad);
  width:clamp(70px,10vw,120px); color:var(--terra); opacity:.55; }
.story__head{ font-size:clamp(2rem,6vw,3.6rem); max-width:16ch; margin-bottom:2.6rem; }
.story__cols{ display:grid; grid-template-columns:1fr 1fr; gap:2.4rem; max-width:880px; }
.story__cols p{ font-size:1.06rem; color:var(--ink-soft); }
.story__cols strong{ color:var(--ink); font-weight:500; }
.values{ list-style:none; display:flex; flex-wrap:wrap; gap:.7rem; margin-top:2.8rem; }
.values li{
  font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase;
  border:1px solid var(--bone-3); border-radius:2em; padding:.5em 1.1em; color:var(--ink-soft);
}

/* ════ Dayparts / menus ════════════════════════════════════ */
.daypart{ padding:clamp(4rem,11vw,8rem) var(--pad); }
.daypart--cafe{ background:var(--bone-2); border-top:1px solid var(--bone-3); border-bottom:1px solid var(--bone-3); }
.daypart--cantina{ background:var(--night); color:var(--night-l); }
.daypart__head{ max-width:var(--maxw); margin:0 auto 2.6rem; }
.daypart__head h2{ margin:.2rem 0 .6rem; }
.daypart--cantina .daypart__head h2{ color:var(--bone); }
.daypart--cantina .section-label{ color:#E8895F; }  /* lighter terra reads on dark */
.daypart__hours{ font-family:var(--mono); font-size:.82rem; letter-spacing:.04em; color:var(--ink-soft); }
.daypart--cantina .daypart__hours{ color:var(--night-l); }
.daypart--cantina .tag{ color:#E8895F; }
.daypart__lede{ margin:0 auto 3rem; font-size:1.1rem; max-width:var(--maxw); }
.daypart--cantina .daypart__lede{ color:var(--night-l); }
.daypart__note{ max-width:var(--maxw); margin:2.4rem auto 0; font-family:var(--mono);
  font-size:.74rem; letter-spacing:.05em; color:var(--night-l); opacity:.85; }

.menu{ max-width:var(--maxw); margin:0 auto; display:grid;
  grid-template-columns:repeat(3,1fr); gap:clamp(1.6rem,4vw,3.4rem); }
.menu__group h3{ font-size:1.05rem; font-family:var(--mono); font-weight:700;
  text-transform:uppercase; letter-spacing:.08em; color:var(--terra-text);
  padding-bottom:.8rem; margin-bottom:1rem; border-bottom:1px solid var(--bone-3); }
.menu--dark .menu__group h3{ color:#E8895F; border-color:rgba(201,200,188,.25); }
.menu__group ul{ list-style:none; display:flex; flex-direction:column; gap:1.1rem; }
.menu__group li{ display:flex; flex-direction:column; gap:.15rem; }
.menu__group li span{ font-family:var(--serif); font-size:1.18rem; color:var(--ink); }
.menu--dark .menu__group li span{ color:var(--bone); }
.menu__group li i{ font-style:normal; font-size:.86rem; color:var(--ink-soft); }
.menu--dark .menu__group li i{ color:var(--night-l); opacity:.9; }

/* ════ OI-NO ═══════════════════════════════════════════════ */
.oino{
  background:var(--terra); color:#fff;
  display:grid; grid-template-columns:.85fr 1.15fr; align-items:center;
  gap:clamp(2rem,6vw,5rem);
  padding:clamp(4rem,11vw,8rem) var(--pad);
}
.oino__art{ display:flex; justify-content:center; align-items:center; min-height:320px; }
/* the wolf's terracotta background == section background, so it floats seamlessly */
.oino__wolf{ height:clamp(300px,48vh,480px); width:auto; max-width:100%; display:block;
  box-shadow:0 0 0 8px var(--terra); }  /* bleed the fill past the bitmap edge (P3 safety) */
.oino__body{ max-width:560px; }
.oino__body .section-label{ color:#fff; }
.oino__body h2{ color:var(--bone); margin:.2rem 0 1.2rem; }
.oino__body > p{ font-size:1.1rem; color:#fff; margin-bottom:2rem; }
.oino__menu{ display:flex; flex-direction:column; gap:.9rem; margin-bottom:2.4rem;
  border-top:1px solid rgba(255,255,255,.35); padding-top:1.6rem; }
.oino__menu > div{ display:grid; grid-template-columns:auto 1fr auto; gap:.8rem; align-items:baseline; }
.oino__menu span{ font-family:var(--serif); font-size:1.25rem; color:#fff; }
.oino__menu i{ font-style:normal; font-size:.82rem; color:#fff; }
.oino__menu b{ font-family:var(--mono); font-weight:700; color:#fff; }
.oino .btn--solid{ background:var(--ink); border-color:var(--ink); color:var(--bone); }
.oino .btn--solid:hover{ background:var(--bone); color:var(--ink); border-color:var(--bone); }

/* ════ Visit ═══════════════════════════════════════════════ */
.visit{
  max-width:var(--maxw); margin:0 auto;
  padding:clamp(4rem,11vw,8rem) var(--pad);
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center;
}
.visit__info h2{ margin:.2rem 0 1.4rem; }
.visit address{ font-style:normal; font-family:var(--serif); font-size:1.5rem; line-height:1.3; margin-bottom:1rem; }
.visit__meta{ color:var(--ink-soft); max-width:40ch; margin-bottom:2rem; }
.visit__hours{ display:flex; flex-direction:column; gap:.7rem; margin-bottom:1.4rem; }
.visit__hours > div{ display:flex; gap:1rem; align-items:baseline;
  border-bottom:1px dotted var(--bone-3); padding-bottom:.7rem; }
.visit__hours dt{ font-family:var(--mono); font-size:.74rem; letter-spacing:.08em;
  text-transform:uppercase; color:var(--terra-text); min-width:96px; }
.visit__hours dd{ font-family:var(--serif); font-size:1.05rem; }
.visit__map{
  position:relative; display:block; aspect-ratio:1/1;
  border-radius:14px; overflow:hidden; border:1px solid var(--bone-3); transition:.3s;
}
.visit__map img{ width:100%; height:100%; object-fit:cover; display:block; }
.visit__map:hover{ transform:translateY(-3px); box-shadow:0 18px 40px rgba(26,23,20,.12); }
.visit__map-badge{ position:absolute; bottom:.8rem; left:.8rem;
  font-family:var(--mono); font-size:.68rem; letter-spacing:.06em; text-transform:uppercase;
  background:var(--ink); color:var(--bone); padding:.45em .9em; border-radius:2em;
  box-shadow:0 2px 8px rgba(0,0,0,.28); }

/* ════ List ════════════════════════════════════════════════ */
.list{
  text-align:center; max-width:680px; margin:0 auto;
  padding:clamp(4rem,12vw,9rem) var(--pad);
}
.list h2{ margin:.4rem 0 1rem; }
.list__lede{ color:var(--ink-soft); margin-bottom:2.4rem; }
.list__form{ display:flex; gap:.6rem; max-width:440px; margin:0 auto 1.2rem; }
.list__form input{
  flex:1; font-family:var(--mono); font-size:.9rem; padding:.95em 1.2em;
  border:1.5px solid var(--ink); border-radius:2em; background:var(--bone); color:var(--ink);
}
.list__form input:focus-visible{ outline:2px solid var(--ink); outline-offset:2px; border-color:var(--ink); }
.list__msg{ font-family:var(--mono); font-size:.8rem; color:var(--terra-text); min-height:1.2em; margin-bottom:.6rem; }
.list__alt{ font-family:var(--mono); font-size:.8rem; color:var(--ink-soft); }
.list__alt a{ color:var(--terra-text); border-bottom:1px solid currentColor; }

/* ════ Footer ══════════════════════════════════════════════ */
.foot{ background:var(--night); color:var(--night-l); padding:clamp(3rem,8vw,5rem) var(--pad) 2.5rem; }
.foot__brand{ font-family:var(--serif); font-size:clamp(2.4rem,9vw,5rem); color:var(--bone); margin-bottom:2.5rem; }
.foot__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; max-width:var(--maxw);
  border-top:1px solid rgba(201,200,188,.2); padding-top:2.5rem; }
.foot__cols p{ font-size:.95rem; line-height:1.7; }
.foot__cols a{ display:block; font-family:var(--mono); font-size:.8rem; letter-spacing:.04em;
  margin-bottom:.6rem; opacity:.82; transition:.2s; }
.foot__cols a:hover{ opacity:1; color:#E8895F; }
.foot__fine{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem;
  margin-top:3rem; font-family:var(--mono); font-size:.72rem; letter-spacing:.04em; opacity:.7; }

/* ════ Reveal on scroll ════════════════════════════════════ */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }

/* ════ Responsive ══════════════════════════════════════════ */
@media (max-width:860px){
  .nav__toggle{ display:flex; }
  .nav__links{
    position:fixed; inset:0 0 0 30%; flex-direction:column; justify-content:center;
    gap:1.6rem; background:var(--bone); padding:var(--pad);
    transform:translateX(100%); transition:transform .35s ease; box-shadow:-10px 0 40px rgba(0,0,0,.1);
  }
  .nav__links.open{ transform:translateX(0); }
  .nav__links a{ font-size:1rem; }
  .story__cols{ grid-template-columns:1fr; gap:1.4rem; }
  .menu{ grid-template-columns:1fr; gap:2.4rem; }
  .oino{ grid-template-columns:1fr; text-align:center; }
  .oino__menu > div{ justify-items:center; }
  .visit{ grid-template-columns:1fr; }
  .visit__map{ order:-1; aspect-ratio:3/2; }
  .foot__cols{ grid-template-columns:1fr; }
}
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *{ animation-duration:.001s!important; transition-duration:.001s!important; }
  .marquee__track, .dot{ animation:none!important; }
  .reveal{ opacity:1; transform:none; }
}
