  /* ============ DESIGN TOKENS ============ */
  :root{
    --cream:#EEE4D2;
    --cream-soft:#F5EEE1;
    --brick:#AE6A48;
    --brick-dark:#7C4630;
    --charcoal:#1C1916;
    --charcoal-soft:#252019;
    --vespa-green:#4B5D40;
    --vespa-green-dark:#313E29;
    --brass:#D9A544;
    --brass-soft:#f0c876;
    --rust:#9C3B29;

    --font-display: 'Bebas Neue', sans-serif;
    --font-script: 'Yellowtail', cursive;
    --font-body: 'Work Sans', sans-serif;

    --radius: 2px;
  }

  *{box-sizing:border-box; margin:0; padding:0;}
  html{scroll-behavior:smooth;}
  body{
    font-family:var(--font-body);
    background:var(--cream);
    color:var(--charcoal);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
  }
  img{max-width:100%; display:block;}
  a{color:inherit; text-decoration:none;}
  ul{list-style:none;}
  .container{
    max-width:1180px;
    margin:0 auto;
    padding:0 32px;
  }
  section{padding:40px 0;}
  @media(max-width:640px){
    section{padding:64px 0;}
    .container{padding:0 20px;}
  }

  .eyebrow{
    font-family:var(--font-body);
    text-transform:uppercase;
    letter-spacing:.22em;
    font-size:12px;
    font-weight:600;
    color:var(--brick-dark);
  }
  h1,h2,h3{
    font-family:var(--font-display);
    letter-spacing:.02em;
    line-height:1;
  }

  /* ============ NAVBAR ============ */
  .navbar{
    position:fixed; top:0; left:0; right:0;
    z-index:100;
    background:rgba(28,25,22,0.92);
    backdrop-filter:blur(6px);
    border-bottom:1px solid rgba(217,165,68,0.25);
  }
  .navbar .container{
    display:flex;
    align-items:center;
    justify-content:space-between;
    height:76px;
  }
  .nav-logo{
    display:flex;
    align-items:center;
    gap:10px;
  }
  .nav-logo img{
    height:30px;
    width:auto;
    display:block;
  }
  .nav-logo span{
    font-family:var(--font-body);
    font-size:14px;
    letter-spacing:.3em;
    text-transform:uppercase;
    color:var(--brass);
    font-weight:600;
  }
  .nav-links{
    display:flex;
    gap:36px;
  }
  .nav-links a{
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:.14em;
    color:var(--cream);
    font-weight:600;
    opacity:.82;
    position:relative;
    padding-bottom:4px;
  }
  .nav-links a:hover{opacity:1;}
  .nav-links a::after{
    content:'';
    position:absolute; left:0; bottom:0;
    width:0; height:1px;
    background:var(--brass);
    transition:width .25s ease;
  }
  .nav-links a:hover::after{width:100%;}
  .nav-cta{
    background:var(--brass);
    color:var(--charcoal);
    padding:10px 22px;
    font-size:12px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.12em;
    border-radius:var(--radius);
  }
  .nav-menu{display:contents;}
  .nav-toggle{display:none;}

  @media(max-width:860px){
    .nav-menu{display:none;}
    .nav-toggle{
      display:block; color:var(--cream); font-size:22px; background:none; border:none;
      cursor:pointer; -webkit-tap-highlight-color:transparent; touch-action:manipulation;
      line-height:1;
    }
    .navbar.is-open .nav-menu{
      display:flex;
      flex-direction:column;
      position:absolute;
      top:76px; left:0; right:0;
      background:rgba(28,25,22,.98);
      border-bottom:1px solid rgba(217,165,68,.25);
      padding:8px 0 18px;
    }
    .navbar.is-open .nav-links{
      display:flex;
      flex-direction:column;
      gap:0;
    }
    .navbar.is-open .nav-links a{
      padding:14px 32px;
      width:100%;
    }
    .navbar.is-open .nav-cta{
      display:block;
      margin:14px 32px 0;
      text-align:center;
    }
  }

  /* ============ HERO ============ */
  .hero{
    position:relative;
    min-height:100vh;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    text-align:center;
    background:
      linear-gradient(180deg, rgba(20,17,14,.55) 0%, rgba(20,17,14,.72) 60%, rgba(20,17,14,.92) 100%),
      url('hero_bg.webp') center 30%/cover no-repeat;
    color:var(--cream);
    overflow:hidden;
    padding-top:76px;
  }

  /* hanging pendant lights — signature element */
  .pendant-row{
    position:absolute;
    top:0; left:0; right:0;
    display:flex;
    justify-content:center;
    gap:min(9vw,110px);
    pointer-events:none;
    z-index:2;
  }
  .pendant{
    display:flex;
    flex-direction:column;
    align-items:center;
  }
  .pendant .wire{
    width:1px;
    background:#3a332a;
  }
  .pendant:nth-child(odd) .wire{height:64px;}
  .pendant:nth-child(even) .wire{height:96px;}
  .pendant .shade{
    width:26px; height:22px;
    border:1.5px solid #4a4136;
    border-bottom:none;
    clip-path: polygon(0 100%, 50% 0, 100% 100%);
    position:relative;
  }
  .pendant .bulb{
    width:9px; height:9px;
    border-radius:50%;
    background:var(--brass-soft);
    margin-top:-4px;
    box-shadow:0 0 12px 4px rgba(240,200,118,.85), 0 0 34px 14px rgba(217,165,68,.35);
    animation:flicker 5s ease-in-out infinite;
  }
  .pendant:nth-child(2) .bulb{animation-delay:.6s;}
  .pendant:nth-child(3) .bulb{animation-delay:1.1s;}
  .pendant:nth-child(4) .bulb{animation-delay:.3s;}
  .pendant:nth-child(5) .bulb{animation-delay:1.5s;}
  @keyframes flicker{
    0%,19%,21%,23%,80%,100%{opacity:1;}
    20%,22%,79%{opacity:.55;}
  }
  @media(max-width:640px){
    .pendant-row{gap:9vw;}
    .pendant .shade{width:18px; height:16px;}
  }

  .hero-inner{position:relative; z-index:3; max-width:760px; padding:0 24px;}
  .hero-eyebrow{
    color:var(--brass);
    font-size:12px;
    letter-spacing:.35em;
    text-transform:uppercase;
    font-weight:700;
    margin-bottom:22px;
  }
  .hero h1{
    font-family:var(--font-script);
    font-size:clamp(64px,11vw,128px);
    color:var(--cream);
    text-shadow:
      0 0 18px rgba(217,165,68,.55),
      0 0 46px rgba(217,165,68,.28);
    line-height:.95;
  }
  .hero h1 small{
    display:block;
    font-family:var(--font-body);
    font-size:14px;
    letter-spacing:.5em;
    text-transform:uppercase;
    color:var(--cream);
    text-shadow:none;
    margin-top:30px;
    font-weight:600;
    opacity:.85;
  }
  .hero p{
    margin-top:26px;
    font-size:18px;
    color:#e7ded0;
    max-width:520px;
    margin-left:auto; margin-right:auto;
  }
  .hero-actions{
    margin-top:40px;
    display:flex;
    gap:18px;
    justify-content:center;
    flex-wrap:wrap;
  }
  .btn{
    display:inline-block;
    padding:15px 32px;
    font-size:13px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.14em;
    border-radius:var(--radius);
    transition:transform .2s ease, box-shadow .2s ease;
  }
  .btn:hover{transform:translateY(-2px);}
  .btn-primary{
    background:var(--brass);
    color:var(--charcoal);
    box-shadow:0 8px 24px rgba(217,165,68,.25);
  }
  .btn-outline{
    border:1.5px solid rgba(238,228,210,.55);
    color:var(--cream);
  }
  .btn-outline:hover{border-color:var(--brass); color:var(--brass);}

  .scroll-cue{
    position:absolute; bottom:10px; left:50%; transform:translateX(-50%);
    z-index:3;
    color:var(--cream);
    font-size:11px;
    letter-spacing:.3em;
    text-transform:uppercase;
    opacity:.65;
    display:flex; flex-direction:column; align-items:center; gap:8px;
  }
  .scroll-cue::after{
    content:'';
    width:1px; height:34px;
    background:linear-gradient(var(--brass), transparent);
    animation:scrolldown 1.8s ease-in-out infinite;
  }
  @keyframes scrolldown{
    0%{opacity:0; transform:translateY(-6px);}
    50%{opacity:1;}
    100%{opacity:0; transform:translateY(10px);}
  }

  /* ============ MARQUEE STRIP ============ */
  .strip{
    background:var(--vespa-green);
    color:var(--cream-soft);
    overflow:hidden;
    white-space:nowrap;
    border-top:1px solid rgba(238,228,210,.15);
    border-bottom:1px solid rgba(238,228,210,.15);
  }
  .strip-track{
    display:inline-block;
    padding:14px 0;
    animation:marquee 26s linear infinite;
    font-family:var(--font-display);
    font-size:20px;
    letter-spacing:.06em;
  }
  .strip-track span{margin:0 28px; opacity:.9;}
  .strip-track span::after{content:'•'; margin-left:28px; color:var(--brass);}
  @keyframes marquee{
    from{transform:translateX(0);}
    to{transform:translateX(-50%);}
  }

  /* ============ ABOUT ============ */
  .about{
    background:var(--cream);
    position:relative;
  }
  .about .container{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:64px;
    align-items:center;
  }
  @media(max-width:900px){
    .about .container{grid-template-columns:1fr;}
  }
  .about-collage{
    position:relative;
    display:grid;
    grid-template-columns:1.2fr 1fr;
    gap:14px;
  }
  .about-collage img{
    border-radius:var(--radius);
    box-shadow:0 18px 40px rgba(28,25,22,.22);
    object-fit:cover;
  }
  .about-collage .tall{grid-row:span 2; height:100%; aspect-ratio:3/4;}
  .about-collage .short{aspect-ratio:4/3;}
  .badge-circle{
    position:absolute;
    bottom:-26px; left:-26px;
    width:112px; height:112px;
    border-radius:50%;
    background:var(--vespa-green);
    color:var(--cream);
    display:flex; align-items:center; justify-content:center;
    text-align:center;
    font-family:var(--font-display);
    font-size:13px;
    letter-spacing:.08em;
    line-height:1.3;
    border:3px solid var(--brass);
    box-shadow:0 10px 26px rgba(28,25,22,.3);
    transform:rotate(-8deg);
  }
  @media(max-width:640px){
    .badge-circle{width:92px; height:92px; font-size:11px; bottom:-18px; left:-14px;}
  }

  .about-text h2{
    font-size:clamp(38px,5vw,56px);
    color:var(--charcoal);
    margin:14px 0 22px;
  }
  .about-text h2 em{
    font-style:normal;
    font-family:var(--font-script);
    color:var(--brick-dark);
    font-size:1.15em;
  }
  .about-text p{
    color:#4a433a;
    font-size:16px;
    margin-bottom:16px;
    max-width:480px;
  }
  .about-facts{
    display:flex;
    gap:36px;
    margin-top:32px;
    flex-wrap:wrap;
  }
  .about-facts div{border-left:3px solid var(--brick); padding-left:14px;}
  .about-facts strong{
    display:block;
    font-family:var(--font-display);
    font-size:30px;
    color:var(--charcoal);
  }
  .about-facts span{
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.12em;
    color:#78706498;
    color:#78706e;
  }

  /* ============ MENU ============ */
  .menu{
    background:var(--charcoal);
    background-image:
      repeating-linear-gradient(0deg, rgba(255,255,255,.02) 0 1px, transparent 1px 42px),
      repeating-linear-gradient(90deg, rgba(255,255,255,.02) 0 1px, transparent 1px 42px);
    color:var(--cream);
  }
  .menu .section-head{
    text-align:left;
    max-width:560px;
    margin:0 0 10px;
  }
  .section-head .eyebrow{color:var(--brass);}
  .section-head h2{
    font-size:clamp(38px,5vw,54px);
    margin-top:12px;
    color:var(--cream);
  }
  .menu-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:28px;
  }
  @media(max-width:900px){
    .menu-grid{grid-template-columns:1fr;}
  }
  .menu-card{
    background:var(--charcoal-soft);
    border:1px solid rgba(217,165,68,.18);
    border-radius:var(--radius);
    padding:34px 30px;
  }
  .menu-card .icon{
    width:44px; height:44px;
    border-radius:50%;
    background:var(--vespa-green);
    display:flex; align-items:center; justify-content:center;
    color:var(--brass);
    font-size:20px;
    margin-bottom:20px;
  }
  .menu-card h3{
    font-family:var(--font-display);
    font-size:26px;
    letter-spacing:.03em;
    margin-bottom:18px;
    color:var(--brass-soft);
  }
  .menu-card ul li{
    display:flex;
    justify-content:space-between;
    gap:12px;
    padding:11px 0;
    border-bottom:1px dashed rgba(238,228,210,.15);
    font-size:15px;
  }
  .menu-card ul li:last-child{border-bottom:none;}
  .menu-card ul li b{
    font-weight:400;
    color:var(--cream);
  }
  .menu-card ul li small{
    display:block;
    color:#9c9284;
    font-size:12px;
    margin-top:2px;
  }
  .menu-card ul li em{
    font-style:normal;
    color:var(--brass);
    font-family:var(--font-display);
    letter-spacing:.03em;
    white-space:nowrap;
  }

  /* ============ GALLERY ============ */
  .gallery{background:var(--cream-soft);}
  .gallery-grid{
    display:grid;
    grid-template-columns:repeat(5,1fr);
    grid-auto-rows:130px;
    gap:10px;
  }
  .gallery-grid button{
    display:block;
    width:100%;
    height:100%;
    overflow:hidden;
    border-radius:var(--radius);
    position:relative;
    border:none;
    padding:0;
    margin:0;
    cursor:pointer;
    background:none;
    -webkit-tap-highlight-color:transparent;
    touch-action:manipulation;
  }
  .gallery-grid img{
    width:100%; height:100%; object-fit:cover;
    transition:transform .5s ease, filter .5s ease;
    filter:saturate(.95);
    pointer-events:none;
  }
  .gallery-grid button:hover img{transform:scale(1.08);}
  .gallery-grid button::after{
    content:'+';
    position:absolute; inset:0;
    display:flex; align-items:center; justify-content:center;
    font-family:var(--font-display);
    font-size:26px;
    color:var(--cream);
    background:rgba(28,25,22,0);
    opacity:0;
    transition:opacity .3s ease, background .3s ease;
    pointer-events:none;
  }
  .gallery-grid button:hover::after{
    opacity:1;
    background:rgba(28,25,22,.35);
  }
  .gallery-grid .g1{grid-column:span 2; grid-row:span 2;}
  @media(max-width:900px){
    .gallery-grid{grid-template-columns:repeat(3,1fr); grid-auto-rows:110px;}
    .gallery-grid .g1{grid-column:span 2; grid-row:span 2;}
  }
  @media(max-width:560px){
    .gallery-grid{grid-template-columns:repeat(2,1fr); grid-auto-rows:100px;}
    .gallery-grid .g1{grid-column:span 2; grid-row:span 1;}
    .gallery-grid .g12{display:none;}
  }

  /* ============ LIGHTBOX / SHADOWBOX ============ */
  .lightbox{
    position:fixed; inset:0; z-index:1000;
    background:rgba(12,10,8,.94);
    display:none;
    align-items:center;
    justify-content:center;
    padding:40px;
  }
  .lightbox.is-open{display:flex;}
  .lightbox-inner{
    position:relative;
    max-width:1000px;
    width:100%;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .lightbox img{
    max-width:100%;
    max-height:82vh;
    width:auto; height:auto;
    margin:0 auto;
    border-radius:var(--radius);
    box-shadow:0 30px 80px rgba(0,0,0,.6);
    border:1px solid rgba(217,165,68,.25);
    pointer-events:none;
  }
  .lightbox-close, .lightbox-prev, .lightbox-next{
    position:absolute;
    background:rgba(238,228,210,.08);
    border:1.5px solid rgba(238,228,210,.35);
    color:var(--cream);
    width:46px; height:46px;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:18px;
    cursor:pointer;
    transition:border-color .2s ease, color .2s ease, background .2s ease;
    -webkit-tap-highlight-color:transparent;
    touch-action:manipulation;
    z-index:1;
  }
  .lightbox-close:hover, .lightbox-prev:hover, .lightbox-next:hover{
    border-color:var(--brass); color:var(--brass); background:rgba(217,165,68,.1);
  }
  .lightbox-close{top:-56px; right:0;}
  .lightbox-prev{left:-58px; top:50%; transform:translateY(-50%);}
  .lightbox-next{right:-58px; top:50%; transform:translateY(-50%);}
  .lightbox-counter{
    position:absolute;
    bottom:-40px; left:50%; transform:translateX(-50%);
    color:var(--cream);
    font-size:12px;
    letter-spacing:.2em;
    text-transform:uppercase;
    opacity:.75;
  }
  @media(max-width:760px){
    .lightbox{padding:20px 20px 70px;}
    .lightbox-prev{left:0; top:auto; bottom:-56px; transform:none;}
    .lightbox-next{right:0; top:auto; bottom:-56px; transform:none;}
    .lightbox-close{top:-48px; right:0;}
    .lightbox-counter{bottom:-56px;}
  }

  /* ============ LOCATION ============ */
  .location{
    background:var(--vespa-green-dark);
    color:var(--cream);
  }
  .location .container{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:56px;
    align-items:start;
  }
  @media(max-width:900px){
    .location .container{grid-template-columns:1fr;}
  }
  .location h2{
    font-size:clamp(36px,5vw,50px);
    margin-bottom:24px;
  }
  .hours-table{width:100%; border-collapse:collapse; margin-top:20px;}
  .hours-table td{
    padding:10px 0;
    border-bottom:1px solid rgba(238,228,210,.15);
    font-size:15px;
  }
  .hours-table td:last-child{text-align:right; font-family:var(--font-display); letter-spacing:.03em; color:var(--brass-soft);}
  .contact-block{margin-top:28px;}
  .contact-block p{margin-bottom:8px; opacity:.9;}
  .social-row{display:flex; gap:14px; margin-top:22px;}
  .social-row a{
    width:42px; height:42px;
    border:1.5px solid rgba(238,228,210,.35);
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:15px;
    transition:border-color .2s ease, color .2s ease;
  }
  .social-row a:hover{border-color:var(--brass); color:var(--brass);}
.map-frame{
    width:100%; height:100%; min-height:340px;
    border-radius:var(--radius);
    overflow:hidden;
    border:1px solid rgba(238,228,210,.2);
    background:var(--charcoal);
    position:relative;
  }
  .map-frame iframe{
    width:100%; height:100%; min-height:340px; border:0;
    filter: invert(92%) hue-rotate(180deg) saturate(0.9) brightness(0.95) contrast(1.05);
  }
  .map-frame::after{
    content:'';
    position:absolute; inset:0;
    background:var(--vespa-green-dark);
    mix-blend-mode:color;
    opacity:.35;
    pointer-events:none;
  }

  /* ============ CTA STRIP ============ */
  .cta-strip{
    background:var(--brick);
    color:var(--cream);
    text-align:center;
    padding:70px 0;
  }
  .cta-strip h2{
    font-family:var(--font-script);
    font-size:clamp(34px,5vw,52px);
    margin-bottom:18px;
  }
  .cta-strip p{margin-bottom:28px; opacity:.92;}
  .cta-strip .btn-primary{background:var(--charcoal); color:var(--brass-soft);}

  /* ============ FOOTER ============ */
  footer{
    background:var(--charcoal);
    color:#a89f92;
    padding:48px 0 28px;
    font-size:13px;
  }
  footer .container{
    display:flex;
    justify-content:space-between;
    align-items:center;
    flex-wrap:wrap;
    gap:16px;
    border-top:1px solid rgba(238,228,210,.1);
    padding-top:24px;
  }
  .footer-logo{
    display:flex;
    align-items:center;
  }
  .footer-logo img{
    height:24px;
    width:auto;
    display:block;
  }