/* ============================================================================
   RAGAZZI BAR / "Neon Ribbon"
   A single glowing teal tube threads the page like the bar's own leitmotif,
   over warm Carrara-marble cream. Big Shoulders Inline Display (hollow glass
   tubing) + Albert Sans. Teal #13B6A8 + chartreuse #C9F23D neon.
   ============================================================================ */

/* ---------- tokens ---------- */
:root{
  --canvas:#F4F0E8;
  --canvas-2:#ECE6DA;
  --ink:#1C1A24;
  --ink-soft:#403B4C;
  --ink-faint:#6A6478;
  --teal:#13B6A8;
  --teal-deep:#0C8C82;
  --chartreuse:#C9F23D;
  --line:rgba(28,26,36,.14);
  --glow-teal:0 0 6px rgba(19,182,168,.85),0 0 18px rgba(19,182,168,.55),0 0 34px rgba(19,182,168,.32);
  --shadow-soft:0 24px 60px -32px rgba(28,26,36,.45);
  --maxw:1200px;
  --gutter:clamp(20px,5vw,72px);
  --space:clamp(72px,11vw,148px);
  --r:18px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--canvas);
  color:var(--ink);
  font-family:"Albert Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:clamp(16px,1.05vw,17.5px);
  line-height:1.65;
  font-weight:400;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* faint Carrara marble veining, ink-grey, diagonal, very low opacity */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  opacity:.5;
  background:
    radial-gradient(120% 90% at 12% 0%, rgba(255,255,255,.6), transparent 60%),
    repeating-linear-gradient(118deg,
      transparent 0 38px,
      rgba(28,26,36,.018) 38px 39px,
      transparent 39px 96px,
      rgba(28,26,36,.030) 96px 97px,
      transparent 97px 168px),
    repeating-linear-gradient(118deg,
      transparent 0 220px,
      rgba(28,26,36,.022) 220px 222px,
      transparent 222px 480px);
}
main,.site-header,.site-footer{position:relative;z-index:1}

img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}

/* ---------- type ---------- */
.display{
  font-family:"Big Shoulders Inline Display","Big Shoulders Display",sans-serif;
  font-weight:700;
  line-height:.86;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin:0;
}
.eyebrow{
  font-family:"Albert Sans",sans-serif;
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.72rem;
  font-weight:600;
  color:var(--teal-deep);
  margin:0;
}
.lede{
  font-size:clamp(1.08rem,1.7vw,1.34rem);
  line-height:1.62;
  color:var(--ink-soft);
  max-width:54ch;
}
.italic{font-style:italic}

/* ============================================================================
   THE NEON RIBBON / fixed SVG spine routed down the full page
   ============================================================================ */
.neon-spine{
  position:fixed;
  inset:0;
  width:100vw;
  height:100vh;
  z-index:2;
  pointer-events:none;
}
.neon-spine svg{width:100%;height:100%}
.neon-spine .tube-bg{
  fill:none;
  stroke:rgba(19,182,168,.16);
  stroke-width:7;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.neon-spine .tube{
  fill:none;
  stroke:var(--teal);
  stroke-width:2.4;
  stroke-linecap:round;
  stroke-linejoin:round;
  filter:url(#neonGlow);
}
/* draw the lit tube progressively as you scroll (set via JS custom prop) */
html.js .neon-spine .tube{
  stroke-dasharray:var(--tube-len,2600);
  stroke-dashoffset:calc(var(--tube-len,2600) * (1 - var(--lit,0)));
  transition:stroke-dashoffset .18s linear;
}
@media (prefers-reduced-motion:reduce){
  html.js .neon-spine .tube{stroke-dashoffset:0!important}
}
@media (max-width:860px){ .neon-spine{display:none} }

/* ---------- header (no bar; dots clipped onto the tube) ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:30;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gutter);
  transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease);
}
.site-header.scrolled{
  background:rgba(244,240,232,.82);
  backdrop-filter:blur(14px) saturate(1.1);
  -webkit-backdrop-filter:blur(14px) saturate(1.1);
  box-shadow:0 1px 0 var(--line);
  padding-top:12px;padding-bottom:12px;
}
.brand{
  display:flex;align-items:baseline;gap:.5ch;
  font-family:"Big Shoulders Inline Display","Big Shoulders Display",sans-serif;
  font-weight:700;font-size:1.5rem;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink);
}
.brand .dot{color:var(--teal);text-shadow:var(--glow-teal)}

/* dot-nav clipped onto the tube */
.nav{display:flex;align-items:center;gap:6px}
.nav a{
  display:flex;align-items:center;gap:.55ch;
  font-size:.82rem;font-weight:500;color:var(--ink-soft);
  padding:8px 12px;border-radius:999px;
  transition:color .25s var(--ease),background .25s var(--ease);
}
.nav a .nub{
  width:7px;height:7px;border-radius:50%;
  background:transparent;border:1.5px solid var(--teal);
  transition:background .25s var(--ease),box-shadow .25s var(--ease);
}
.nav a:hover{color:var(--ink)}
.nav a:hover .nub{background:var(--teal);box-shadow:var(--glow-teal)}

.lang-toggle{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;margin-left:8px}
.lang-toggle button{
  border:0;background:transparent;cursor:pointer;
  font-size:.74rem;font-weight:600;letter-spacing:.06em;
  padding:7px 12px;color:var(--ink-faint);transition:background .2s,color .2s;
}
.lang-toggle button[aria-pressed="true"]{background:var(--ink);color:var(--canvas)}

.nav-toggle{display:none}

/* ---------- hero ---------- */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;
  padding:140px var(--gutter) clamp(60px,9vh,110px);
}
.hero .ciao{
  display:inline-block;
  font-family:"Big Shoulders Inline Display","Big Shoulders Display",sans-serif;
  font-weight:600;font-size:clamp(1.6rem,4vw,2.6rem);
  text-transform:lowercase;letter-spacing:.02em;
  color:var(--chartreuse);
  -webkit-text-stroke:.6px var(--teal-deep);
  text-shadow:0 0 8px rgba(201,242,61,.5),0 0 22px rgba(201,242,61,.28);
  transform:rotate(-4deg);
  margin-bottom:.2em;
}
.hero-word{
  position:relative;
  font-size:clamp(4.4rem,21vw,18rem);
  line-height:.82;
  margin:0;
  color:var(--ink); /* fallback: solid ink if text-stroke unsupported */
}
/* hollow "unlit glass tubing" outline where the engine supports it */
@supports ((-webkit-text-stroke:1px black) or (text-stroke:1px black)){
  .hero-word{
    color:transparent;
    -webkit-text-stroke:1.5px var(--ink);
    text-stroke:1.5px var(--ink);
  }
}
/* the first letter is "ignited" teal where the ribbon flows in */
.hero-word .ignite{
  color:var(--teal);
  -webkit-text-stroke:0;
  text-stroke:0;
  text-shadow:var(--glow-teal);
}
.hero-sub{
  margin-top:clamp(20px,3vw,34px);
  max-width:40ch;
}
.hero-sub .it{
  font-style:italic;font-size:clamp(1.15rem,2.2vw,1.6rem);
  color:var(--ink);line-height:1.4;font-weight:500;
}
.hero-meta{
  display:flex;flex-wrap:wrap;align-items:center;gap:14px 22px;
  margin-top:clamp(26px,4vw,40px);
}
.hero-cta{
  display:inline-flex;align-items:center;gap:.6ch;
  background:var(--ink);color:var(--canvas);
  font-weight:600;font-size:.95rem;letter-spacing:.01em;
  padding:14px 26px;border-radius:999px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease);
}
.hero-cta:hover{transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(19,182,168,.7);background:var(--teal-deep)}
.hero-cta.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.hero-cta.ghost:hover{background:var(--ink);color:var(--canvas);box-shadow:none}
.rating-chip{
  display:inline-flex;align-items:center;gap:.6ch;
  font-size:.92rem;color:var(--ink-soft);
}
.rating-chip b{color:var(--ink);font-weight:700}
.rating-chip .star{color:var(--teal-deep)}

.scroll-hint{
  position:absolute;left:var(--gutter);bottom:26px;
  display:flex;align-items:center;gap:.7ch;
  font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-faint);
}
.scroll-hint .line{width:46px;height:1px;background:var(--ink-faint);transform-origin:left;animation:slide 2.6s var(--ease) infinite}
@keyframes slide{0%,100%{transform:scaleX(.4);opacity:.5}50%{transform:scaleX(1);opacity:1}}
@media (prefers-reduced-motion:reduce){.scroll-hint .line{animation:none}}

/* ---------- section scaffolding (hangs off the tube) ---------- */
.section{padding-block:var(--space)}
.node{
  display:flex;align-items:center;gap:.9ch;margin-bottom:18px;
}
.node .bead{
  width:13px;height:13px;border-radius:50%;
  background:var(--canvas);border:2px solid var(--teal);
  box-shadow:var(--glow-teal);flex:none;
}
.node .num{
  font-family:"Big Shoulders Inline Display","Big Shoulders Display",sans-serif;
  font-weight:600;font-size:.95rem;letter-spacing:.18em;color:var(--teal-deep);
}
.section-title{
  font-size:clamp(2.6rem,7.5vw,6rem);
  margin-bottom:.18em;
}
.section-title .it{
  display:block;font-family:"Albert Sans",sans-serif;
  font-style:italic;font-weight:400;text-transform:none;
  font-size:clamp(1.05rem,2vw,1.45rem);letter-spacing:0;line-height:1.4;
  color:var(--ink-soft);margin-top:.5em;max-width:46ch;
}

/* ---------- intro / aperitivo split ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.split.reverse{grid-template-columns:.95fr 1.05fr}
.split .copy p+p{margin-top:1em}
.split .frame{position:relative}
.frame{
  position:relative;border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-soft);
  background:var(--canvas-2);
}
.frame img{width:100%;height:100%;object-fit:cover;display:block}
.frame::after{
  content:"";position:absolute;inset:0;border-radius:var(--r);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);pointer-events:none;
}
/* a thin neon underline detail on framed media */
.frame.lit::before{
  content:"";position:absolute;left:14px;right:14px;bottom:12px;height:2px;
  background:var(--teal);border-radius:2px;box-shadow:var(--glow-teal);
  z-index:2;opacity:.9;
}
.aspect-portrait{aspect-ratio:4/5}
.aspect-square{aspect-ratio:1/1}
.aspect-land{aspect-ratio:4/3}
.aspect-wide{aspect-ratio:16/10}

.facts{display:flex;flex-wrap:wrap;gap:10px 12px;margin-top:26px}
.fact{
  display:inline-flex;align-items:center;gap:.6ch;
  border:1px solid var(--line);border-radius:999px;
  padding:8px 15px;font-size:.86rem;color:var(--ink-soft);
  background:rgba(255,255,255,.35);
}
.fact .pip{width:6px;height:6px;border-radius:50%;background:var(--teal);box-shadow:var(--glow-teal)}

/* ---------- "the list" / aperitivo / cicchetti / vino menu-style columns ---------- */
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,3vw,42px);margin-top:14px}
.menu-col{position:relative;padding-top:26px;border-top:1px solid var(--line)}
.menu-col h3{
  font-family:"Big Shoulders Inline Display","Big Shoulders Display",sans-serif;
  font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  font-size:clamp(1.7rem,3vw,2.3rem);margin:0 0 4px;color:var(--ink);
}
.menu-col .tag{
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--teal-deep);
  font-weight:600;display:block;margin-bottom:14px;
}
.menu-col ul{list-style:none;margin:0;padding:0}
.menu-col li{
  display:flex;gap:.7ch;align-items:baseline;
  padding:9px 0;border-bottom:1px dashed var(--line);
  font-size:.96rem;color:var(--ink-soft);
}
.menu-col li::before{
  content:"";width:6px;height:6px;border-radius:50%;flex:none;
  background:var(--chartreuse);box-shadow:0 0 6px rgba(201,242,61,.6);
  transform:translateY(.5em);
}
.menu-col li b{color:var(--ink);font-weight:600}
.menu-note{margin-top:14px;font-size:.8rem;color:var(--ink-faint);font-style:italic}

/* ---------- gallery (Italian bar shelf made of light) ---------- */
.shelf{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-auto-rows:11vw;
  gap:14px;margin-top:18px;
}
.shelf .frame{grid-column:span 4;grid-row:span 2}
.shelf .frame.tall{grid-row:span 3}
.shelf .frame.wide{grid-column:span 6}
.shelf .frame.big{grid-column:span 6;grid-row:span 3}
.shelf .frame.small{grid-column:span 4;grid-row:span 2}
.shelf img{transition:transform 1s var(--ease)}
.shelf .frame:hover img{transform:scale(1.05)}
.cap{
  position:absolute;left:12px;bottom:12px;z-index:3;
  font-size:.72rem;font-weight:600;letter-spacing:.04em;
  color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.55);
  background:rgba(28,26,36,.35);backdrop-filter:blur(2px);
  padding:5px 10px;border-radius:999px;
}

/* ---------- find us / trova-ci ---------- */
.find{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);align-items:stretch}
.find .map{
  border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-soft);
  min-height:340px;background:var(--canvas-2);
}
.find .map iframe{width:100%;height:100%;min-height:340px;border:0;display:block;filter:saturate(.92) contrast(1.02)}
.info-card{
  background:rgba(255,255,255,.5);
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:clamp(24px,3vw,40px);
  display:flex;flex-direction:column;gap:18px;
}
.info-row{display:flex;gap:14px;align-items:flex-start}
.info-row .ico{
  width:38px;height:38px;flex:none;border-radius:50%;
  display:grid;place-items:center;
  border:1.5px solid var(--teal);color:var(--teal-deep);
  box-shadow:0 0 0 0 transparent;
}
.info-row .k{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);font-weight:600}
.info-row .v{font-size:1.02rem;color:var(--ink);font-weight:500;line-height:1.45}
.info-row a.v:hover{color:var(--teal-deep)}
.hours-line{font-size:.92rem;color:var(--ink-soft)}
.info-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:.6ch;
  margin-top:6px;background:var(--ink);color:var(--canvas);
  font-weight:600;padding:13px 22px;border-radius:999px;
  transition:background .3s var(--ease),transform .3s var(--ease);
}
.info-cta:hover{background:var(--teal-deep);transform:translateY(-2px)}

/* ---------- quote / social proof band ---------- */
.band{
  margin-block:var(--space);
  text-align:center;
  padding-inline:var(--gutter);
}
.band .q{
  font-family:"Big Shoulders Inline Display","Big Shoulders Display",sans-serif;
  font-weight:600;text-transform:uppercase;letter-spacing:.01em;
  font-size:clamp(2rem,6.5vw,5rem);line-height:.94;
  color:var(--ink);max-width:16ch;margin:0 auto;
}
.band .q em{font-style:normal;color:var(--teal);text-shadow:var(--glow-teal)}
.band .cite{margin-top:18px;font-size:.86rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint)}

/* ---------- footer ---------- */
.site-footer{
  background:var(--ink);color:#D8D4E0;
  padding:clamp(56px,8vw,96px) 0 36px;
  margin-top:var(--space);
}
.site-footer a{color:#D8D4E0}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.foot-brand .display{font-size:clamp(2.6rem,6vw,4.4rem);color:#fff;line-height:.85}
@supports ((-webkit-text-stroke:1px white) or (text-stroke:1px white)){
  .foot-brand .display{color:transparent;-webkit-text-stroke:1.4px #fff;text-stroke:1.4px #fff}
}
.foot-brand .display .lit{color:var(--teal);-webkit-text-stroke:0;text-stroke:0;text-shadow:var(--glow-teal)}
.foot-brand p{color:#9A95A8;max-width:34ch;margin-top:18px;font-size:.95rem}
.foot-col h4{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--teal);margin:0 0 16px;font-weight:600}
.foot-col p,.foot-col a{display:block;color:#C9C4D4;font-size:.95rem;margin-bottom:9px;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bottom{
  margin-top:clamp(40px,6vw,64px);padding-top:24px;border-top:1px solid rgba(255,255,255,.12);
  display:flex;flex-wrap:wrap;gap:14px 28px;justify-content:space-between;align-items:center;
}
.disclaimer{font-size:.8rem;color:#8C879A;max-width:62ch;line-height:1.55}
.foot-bottom .meta{font-size:.78rem;color:#7C7790}

/* ---------- reveal contract (.js-gated) ---------- */
html.js [data-reveal]{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js [data-reveal].in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .split,.split.reverse{grid-template-columns:1fr;gap:34px}
  .split .frame{order:-1}
  .menu-grid{grid-template-columns:1fr;gap:30px}
  .find{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .shelf{grid-auto-rows:22vw}
  .shelf .frame,.shelf .frame.small{grid-column:span 6;grid-row:span 1}
  .shelf .frame.wide,.shelf .frame.big{grid-column:span 12;grid-row:span 1}
  .shelf .frame.tall{grid-row:span 1}
}
@media (max-width:860px){
  .nav{
    position:fixed;inset:0 0 auto auto;top:0;height:100vh;width:min(78vw,320px);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:8px;
    background:var(--canvas);padding:80px 32px;
    transform:translateX(105%);transition:transform .45s var(--ease);
    box-shadow:-20px 0 60px -30px rgba(28,26,36,.5);
  }
  .nav.open{transform:none}
  .nav a{font-size:1.1rem;padding:10px 0}
  .nav .lang-toggle{margin-left:0;margin-top:14px}
  .nav-toggle{
    display:inline-flex;flex-direction:column;gap:5px;
    background:transparent;border:0;cursor:pointer;padding:8px;z-index:40;
  }
  .nav-toggle span{width:26px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s,opacity .3s}
  .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@media (max-width:620px){
  .foot-top{grid-template-columns:1fr}
  .shelf .frame,.shelf .frame.small,.shelf .frame.wide,.shelf .frame.big,.shelf .frame.tall{grid-column:span 12}
  .hero-word{-webkit-text-stroke-width:1px}
}

/* focus visibility */
a:focus-visible,button:focus-visible{outline:2px solid var(--teal-deep);outline-offset:3px;border-radius:6px}
