/* =========================================================================
   bica — Normal Heights, San Diego
   A sunlit coffee shop, wine bar & community gathering space.
   Palette pulled from the brand: ink-navy wordmark, cream stucco walls,
   golden-hour light, soft sky, the black sardine.
   ========================================================================= */

:root{
  /* ---- brand palette ---- */
  --ink:        #15384E;   /* navy hand-lettered wordmark / primary text */
  --ink-soft:   #415C6D;   /* muted navy */
  --ink-faint:  #8AA0AC;   /* hairlines, captions */
  --paper:      #F6F0E3;   /* warm cream — main canvas (the stucco walls) */
  --paper-2:    #FBF7EE;   /* lighter paper — cards */
  --paper-3:    #EEE4D1;   /* subtle panel */
  --amber:      #E0A24B;   /* golden-hour sun + string lights */
  --amber-soft: #F4CE92;
  --amber-deep: #C77F32;
  --sky:        #AEC6D6;   /* soft San Diego sky */
  --sage:       #8FA06E;   /* plants */
  --night:      #122029;   /* dark sections (the night events) */
  --night-2:    #0B141A;
  --black:      #16181A;   /* the sardine */

  --ease:   cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(0.16,1,0.3,1);

  --maxw: 1240px;
  --pad: clamp(20px, 5vw, 64px);
  --radius: 26px;

  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
}

/* =========================================================================
   base
   ========================================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:auto; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  font-size:clamp(15px,1.05vw,17px);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
::selection{ background:var(--amber-soft); color:var(--ink); }

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:380;
  line-height:1.02;
  letter-spacing:-.01em;
  margin:0;
  font-optical-sizing:auto;
}
.display{
  font-size:clamp(2.6rem,7vw,6.2rem);
  font-weight:340;
}
h2{ font-size:clamp(2rem,4.4vw,3.7rem); }
h3{ font-size:clamp(1.3rem,2.2vw,1.85rem); }
.eyebrow{
  font-family:var(--font-body);
  font-size:.74rem; font-weight:600;
  letter-spacing:.28em; text-transform:uppercase;
  color:var(--amber-deep);
  margin:0 0 1.1rem;
  display:flex; align-items:center; gap:.7em;
}
.eyebrow::before{
  content:""; width:26px; height:1px; background:currentColor; opacity:.6;
}
p{ margin:0 0 1.1em; }
.lede{ font-size:clamp(1.05rem,1.5vw,1.3rem); color:var(--ink-soft); }
.muted{ color:var(--ink-soft); }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
section{ position:relative; }
.section{ padding-block:clamp(72px,10vw,150px); }

/* =========================================================================
   buttons  (incl. retuned sun-glow effect #5)
   ========================================================================= */
.btn{
  position:relative; display:inline-flex; align-items:center; gap:.6em;
  padding:.95em 1.6em; border-radius:100px;
  font-size:.92rem; font-weight:560; letter-spacing:.01em;
  cursor:pointer; border:1px solid transparent;
  transition:transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease), box-shadow .4s var(--ease);
  will-change:transform;
}
.btn:hover{ transform:translateY(-2px); }
.btn--solid{ background:var(--ink); color:var(--paper-2); }
.btn--solid:hover{ box-shadow:0 14px 34px -12px rgba(21,56,78,.6); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:rgba(21,56,78,.28); }
.btn--ghost:hover{ border-color:var(--ink); background:rgba(21,56,78,.04); }
.btn--light{ background:var(--paper-2); color:var(--ink); }

/* sun-glow (effect #5) — warm light tracks the cursor */
.btn--sun{ position:relative; overflow:hidden; isolation:isolate; }
.btn--sun > span{ position:relative; z-index:2; display:inline-flex; align-items:center; gap:.55em; }
.btn--sun::after{
  content:""; position:absolute; z-index:1; left:var(--bx,50%); top:var(--by,50%);
  width:200px; height:200px; transform:translate(-50%,-50%); border-radius:50%;
  pointer-events:none; opacity:0; transition:opacity .45s var(--ease); mix-blend-mode:screen;
  background:radial-gradient(circle, rgba(255,248,228,.95) 0%, rgba(255,205,130,.6) 38%, rgba(255,180,90,0) 72%);
}
.btn--sun:hover::after{ opacity:1; }

.arrow{ transition:transform .4s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }

/* =========================================================================
   nav  (frosted sticky — effect #8)
   ========================================================================= */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:60;
  transition:background .45s var(--ease), backdrop-filter .45s, box-shadow .45s, padding .45s;
  padding-block:18px;
}
.nav.scrolled{
  background:rgba(246,240,227,.78);
  backdrop-filter:blur(16px) saturate(1.5);
  box-shadow:0 1px 0 rgba(21,56,78,.08);
  padding-block:10px;
}
.nav__row{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand{ display:flex; align-items:center; gap:11px; }
.brand__fish{ width:46px; height:auto; transition:transform .5s var(--ease); }
.brand:hover .brand__fish{ transform:rotate(-8deg) translateX(-2px); }
.brand__word{ font-family:var(--font-display); font-size:1.5rem; letter-spacing:-.02em; }
.nav__links{ display:flex; align-items:center; gap:6px; }
.nav__link{
  position:relative; padding:.5em .85em; border-radius:100px;
  font-size:.92rem; font-weight:500; color:var(--ink-soft);
  transition:color .3s var(--ease);
}
.nav__link:hover, .nav__link[aria-current="page"]{ color:var(--ink); }
.nav__link::after{
  content:""; position:absolute; left:.85em; right:.85em; bottom:.32em; height:1.5px;
  background:var(--amber); transform:scaleX(0); transform-origin:left;
  transition:transform .4s var(--ease);
}
.nav__link:hover::after, .nav__link[aria-current="page"]::after{ transform:scaleX(1); }
.nav__cta{ margin-left:6px; }
.nav__burger{ display:none; background:none; border:0; cursor:pointer; padding:8px; }
.nav__burger span{ display:block; width:24px; height:2px; background:var(--ink); margin:5px 0; transition:.35s var(--ease); border-radius:2px; }

/* mobile menu */
.nav.open .nav__burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav.open .nav__burger span:nth-child(2){ opacity:0; }
.nav.open .nav__burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media (max-width:860px){
  .nav__burger{ display:block; }
  .nav__links{
    position:fixed; inset:0 0 0 auto; width:min(80vw,340px);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:14px;
    background:var(--paper-2); padding:48px var(--pad);
    transform:translateX(100%); transition:transform .55s var(--ease-out);
    box-shadow:-30px 0 80px rgba(0,0,0,.12);
  }
  .nav.open .nav__links{ transform:translateX(0); }
  .nav__link{ font-size:1.4rem; font-family:var(--font-display); color:var(--ink); }
  .nav__cta{ margin-left:0; margin-top:10px; }
}

/* =========================================================================
   hero
   ========================================================================= */
.hero{
  position:relative; min-height:100svh; display:flex; flex-direction:column;
  justify-content:center; align-items:center; text-align:center; overflow:hidden;
  padding:120px var(--pad) 90px;
}
/* the sun — a soft warm glow */
.hero__sun{
  position:absolute; top:-18vh; left:50%; transform:translateX(-50%);
  width:min(120vw,1100px); aspect-ratio:1; border-radius:50%; pointer-events:none;
  background:radial-gradient(circle, rgba(244,206,146,.55) 0%, rgba(224,162,75,.18) 34%, transparent 62%);
  filter:blur(8px); z-index:0;
  animation:sunbreathe 9s var(--ease) infinite alternate;
}
@keyframes sunbreathe{ from{ transform:translateX(-50%) scale(1); opacity:.9 } to{ transform:translateX(-50%) scale(1.07); opacity:1 } }

.hero__inner{ position:relative; z-index:3; max-width:980px; }
.hero__wordmark{ width:min(72vw,560px); margin:0 auto .4rem; }
.hero__wordmark img{ width:100%; }
.hero__tag{
  font-family:var(--font-display); font-style:italic; font-weight:340;
  font-size:clamp(1.4rem,3.2vw,2.4rem); color:var(--ink); margin:.2em 0 .1em;
}
.hero__sub{ max-width:540px; margin:1.1rem auto 2rem; color:var(--ink-soft); font-size:clamp(1rem,1.4vw,1.18rem); }
.hero__cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* school of fish drifting in the hero */
.fish-layer{ position:absolute; inset:0; z-index:1; pointer-events:none; overflow:hidden; }
.fish-drift{ position:absolute; opacity:.0; color:var(--ink); will-change:transform; }

/* scroll hint (effect #10) */
.scroll-hint{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:4;
  width:26px; height:42px; border:1.5px solid rgba(21,56,78,.3); border-radius:14px;
}
.scroll-hint span{
  position:absolute; top:8px; left:50%; width:4px; height:8px; background:var(--amber-deep);
  border-radius:2px; transform:translateX(-50%); animation:scrolldot 1.9s var(--ease) infinite;
}
@keyframes scrolldot{
  0%{opacity:0;transform:translate(-50%,0)} 30%{opacity:1}
  80%{opacity:0;transform:translate(-50%,16px)} 100%{opacity:0} }

/* =========================================================================
   marquee  (effect #9)
   ========================================================================= */
.marquee{
  overflow:hidden; border-block:1px solid rgba(21,56,78,.12);
  padding-block:18px; background:var(--paper-2);
}
.marquee__track{
  display:flex; gap:30px; align-items:center; white-space:nowrap; width:max-content;
  animation:marquee 34s linear infinite;
}
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__track span{
  font-family:var(--font-display); font-style:italic; font-size:clamp(1.3rem,2.6vw,2.1rem);
  color:var(--ink);
}
.marquee__track .dot{ color:var(--amber-deep); font-size:1.3rem; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* =========================================================================
   reveal-on-scroll  (effect #3)
   ========================================================================= */
/* Hidden state only applies once JS is confirmed (html.js). With no JS — or if
   the script fails to load — content stays fully visible. */
.js .reveal{ opacity:0; transform:translateY(36px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s } .reveal.d2{ transition-delay:.16s }
.reveal.d3{ transition-delay:.24s } .reveal.d4{ transition-delay:.32s }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1 !important; transform:none !important; }
  .hero__sun, .fish-drift, .scroll-hint span, .marquee__track{ animation:none !important; }
}

/* =========================================================================
   layout helpers
   ========================================================================= */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,80px); align-items:center; }
.split--rev{ direction:rtl; } .split--rev > *{ direction:ltr; }
@media (max-width:820px){ .split{ grid-template-columns:1fr; gap:34px; } .split--rev{ direction:ltr; } }

.section-head{ max-width:680px; margin-bottom:clamp(34px,5vw,64px); }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head.center .eyebrow{ justify-content:center; }

/* framed photo with soft corner + fish caption */
.photo{ position:relative; border-radius:var(--radius); overflow:hidden; background:var(--paper-3); }
.photo img{ width:100%; height:100%; object-fit:cover; transition:transform 1.4s var(--ease); }
.photo--tall{ aspect-ratio:4/5; }
.photo--wide{ aspect-ratio:16/11; }
.photo:hover img{ transform:scale(1.045); }
.photo__tag{
  position:absolute; left:14px; bottom:14px; z-index:2;
  background:rgba(246,240,227,.9); backdrop-filter:blur(6px);
  padding:.4em .85em; border-radius:100px; font-size:.78rem; font-weight:560; color:var(--ink);
  display:flex; align-items:center; gap:.45em;
}

/* =========================================================================
   "story" / values
   ========================================================================= */
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:820px){ .values{ grid-template-columns:1fr; } }

/* glow card (effect #4 — retuned amber) */
.glow-card{
  position:relative; overflow:hidden; border-radius:var(--radius);
  background:var(--paper-2); padding:34px 30px 30px;
  border:1px solid rgba(21,56,78,.08);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.glow-card:hover{ transform:translateY(-4px); box-shadow:0 26px 50px -28px rgba(21,56,78,.35); }
.glow-card::before{
  content:""; position:absolute; width:320px; height:320px; border-radius:50%;
  background:radial-gradient(circle, rgba(224,162,75,.42), transparent 60%); filter:blur(34px);
  left:var(--mx,50%); top:var(--my,50%); transform:translate(-50%,-50%);
  opacity:0; transition:opacity .4s; pointer-events:none;
}
.glow-card:hover::before{ opacity:1; }
.glow-card > *{ position:relative; z-index:1; }
.glow-card .ic{ width:40px; height:40px; margin-bottom:14px; }
.glow-card h3{ margin-bottom:.4em; }
.glow-card p{ color:var(--ink-soft); font-size:.97rem; margin:0; }

/* =========================================================================
   menu / fare list
   ========================================================================= */
.fare{ display:grid; grid-template-columns:repeat(2,1fr); gap:6px 56px; }
@media (max-width:680px){ .fare{ grid-template-columns:1fr; } }
.fare__row{
  display:flex; align-items:baseline; gap:14px; padding:16px 0;
  border-bottom:1px solid rgba(21,56,78,.12);
}
.fare__name{ font-family:var(--font-display); font-size:1.2rem; white-space:nowrap; }
.fare__dots{ flex:1; border-bottom:1.5px dotted rgba(21,56,78,.3); transform:translateY(-4px); }
.fare__desc{ color:var(--ink-soft); font-size:.88rem; flex-basis:100%; margin-top:-6px; }
.fare__price{ font-weight:600; color:var(--amber-deep); }

/* =========================================================================
   events  (dark section + glowing strands)
   ========================================================================= */
.night{ background:var(--night); color:var(--paper); overflow:hidden; }
.night .eyebrow{ color:var(--amber-soft); }
.night .lede,.night .muted{ color:#C6D2D8; }
.night h1,.night h2,.night h3{ color:var(--paper); }
.strands{ position:absolute; inset:0; z-index:0; opacity:.9; pointer-events:none; }
.night .wrap{ position:relative; z-index:2; }

.event-list{ display:flex; flex-direction:column; gap:14px; }
.event-card{
  display:grid; grid-template-columns:96px 1fr auto; gap:24px; align-items:center;
  padding:22px 26px; border-radius:20px; cursor:pointer;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  transition:background .4s var(--ease), transform .4s var(--ease), border-color .4s;
}
.event-card:hover{ background:rgba(255,255,255,.08); transform:translateX(6px); border-color:rgba(244,206,146,.4); }
.event-date{ text-align:center; line-height:1; }
.event-date .d{ font-family:var(--font-display); font-size:2.2rem; color:var(--amber-soft); }
.event-date .m{ font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:#9FB0B8; margin-top:4px; }
.event-info h3{ margin-bottom:.25em; }
.event-info p{ margin:0; color:#AEBEC6; font-size:.92rem; }
.event-when{ font-size:.85rem; color:#9FB0B8; white-space:nowrap; }
.event-card .arrow-c{ color:var(--amber-soft); }
@media (max-width:640px){
  .event-card{ grid-template-columns:64px 1fr; gap:16px; padding:18px; }
  .event-when{ grid-column:2; }
}

/* =========================================================================
   gallery strip
   ========================================================================= */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.gallery a{ border-radius:18px; overflow:hidden; aspect-ratio:1; background:var(--paper-3); }
.gallery img{ width:100%; height:100%; object-fit:cover; transition:transform 1s var(--ease); }
.gallery a:hover img{ transform:scale(1.08); }
.gallery a:nth-child(1){ grid-row:span 2; aspect-ratio:auto; }
@media (max-width:820px){ .gallery{ grid-template-columns:repeat(2,1fr); } .gallery a:nth-child(1){ grid-row:auto; aspect-ratio:1; } }

/* =========================================================================
   info / visit
   ========================================================================= */
.info-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:820px){ .info-grid{ grid-template-columns:1fr; } }
.info-card{ background:var(--paper-2); border:1px solid rgba(21,56,78,.08); border-radius:var(--radius); padding:30px; }
.info-card .ic{ width:30px; height:30px; margin-bottom:12px; }
.info-card h3{ font-size:1.25rem; margin-bottom:.5em; }
.info-card p{ margin:0; color:var(--ink-soft); }
.hours{ list-style:none; padding:0; margin:0; }
.hours li{ display:flex; justify-content:space-between; padding:7px 0; border-bottom:1px solid rgba(21,56,78,.1); font-size:.95rem; }
.hours li:last-child{ border-bottom:0; }
.hours .day{ color:var(--ink-soft); }

/* =========================================================================
   CTA banner
   ========================================================================= */
.cta-band{ position:relative; overflow:hidden; border-radius:var(--radius); padding:clamp(40px,7vw,84px); text-align:center; background:var(--ink); color:var(--paper); }
.cta-band #aurora{ position:absolute; inset:0; z-index:0; opacity:.55; }
.cta-band > *{ position:relative; z-index:1; }
.cta-band h2{ color:var(--paper-2); max-width:680px; margin-inline:auto; }
.cta-band p{ color:#C6D2D8; max-width:520px; margin:1rem auto 1.8rem; }

/* =========================================================================
   footer
   ========================================================================= */
.footer{ background:var(--paper-2); border-top:1px solid rgba(21,56,78,.1); padding-block:64px 34px; }
.footer__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
@media (max-width:760px){ .footer__top{ grid-template-columns:1fr; gap:30px; } }
.footer__brand .brand__word{ font-size:2rem; }
.footer__brand p{ color:var(--ink-soft); max-width:320px; margin-top:14px; }
.footer h4{ font-family:var(--font-body); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:var(--amber-deep); margin:0 0 16px; }
.footer__col a, .footer__col p{ display:block; color:var(--ink-soft); margin:0 0 10px; transition:color .3s var(--ease); }
.footer__col a:hover{ color:var(--ink); }
.footer__bottom{ display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; margin-top:46px; padding-top:24px; border-top:1px solid rgba(21,56,78,.1); font-size:.84rem; color:var(--ink-faint); }
.footer__bottom a:hover{ color:var(--ink); }

/* =========================================================================
   modal  (effect #7)
   ========================================================================= */
.modal{ position:fixed; inset:0; z-index:100; display:flex; align-items:center; justify-content:center; padding:24px; }
.modal[hidden]{ display:none; }
.modal__overlay{ position:absolute; inset:0; background:rgba(11,20,26,.55); backdrop-filter:blur(6px); }
.modal__card{
  position:relative; z-index:1; width:min(620px,100%); max-height:86vh; overflow:auto;
  background:var(--paper); border-radius:24px; padding:40px clamp(24px,4vw,44px);
  box-shadow:0 40px 100px rgba(0,0,0,.4); will-change:transform,opacity;
}
.modal__close{
  position:absolute; top:16px; right:16px; width:38px; height:38px; border:none; cursor:pointer;
  border-radius:50%; background:rgba(224,162,75,.18); font-size:22px; line-height:1; color:var(--ink);
  transition:background .3s, transform .3s;
}
.modal__close:hover{ background:rgba(224,162,75,.34); transform:rotate(90deg); }
.modal__card .eyebrow{ margin-bottom:.6rem; }
.modal__card h3{ font-size:1.9rem; margin-bottom:.4em; }

/* forms */
.field{ margin-bottom:16px; }
.field label{ display:block; font-size:.8rem; font-weight:600; letter-spacing:.04em; margin-bottom:6px; color:var(--ink-soft); }
.field input, .field textarea, .field select{
  width:100%; padding:13px 15px; border-radius:14px; border:1px solid rgba(21,56,78,.2);
  background:var(--paper-2); font-family:inherit; font-size:.95rem; color:var(--ink); transition:border-color .3s, box-shadow .3s;
}
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--amber); box-shadow:0 0 0 3px rgba(224,162,75,.18); }
.field textarea{ resize:vertical; min-height:110px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:520px){ .field-row{ grid-template-columns:1fr; } }
.form-note{ font-size:.82rem; color:var(--ink-faint); margin-top:4px; }

/* =========================================================================
   shop / coming soon
   ========================================================================= */
.shop-empty{ text-align:center; max-width:560px; margin-inline:auto; }
.shop-empty .fish-badge{ width:120px; margin:0 auto 26px; opacity:.9; }
.bean{ display:inline-block; }

/* page hero (interior pages) */
.page-hero{ padding:160px var(--pad) 0; text-align:center; }
.page-hero .display{ font-size:clamp(2.4rem,6vw,5rem); }
.page-hero p{ max-width:560px; margin:1rem auto 0; color:var(--ink-soft); }

/* divider with swimming fish */
.fish-divider{ display:flex; align-items:center; gap:18px; max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
.fish-divider .line{ flex:1; height:1px; background:rgba(21,56,78,.18); }
.fish-divider .ic{ width:42px; height:22px; color:var(--ink); }

/* utility */
.center{ text-align:center; }
.mt-l{ margin-top:36px; }
.tag-pill{ display:inline-flex; align-items:center; gap:.5em; padding:.4em .9em; border-radius:100px; background:rgba(224,162,75,.16); color:var(--amber-deep); font-size:.78rem; font-weight:600; letter-spacing:.04em; }
.ic{ display:inline-block; vertical-align:middle; }
