
  :root{
    --brown-950:#1A1A1A;
    --brown-900:#FFFBF2;
    --brown-800:#FFFFFF;
    --cream:#1A1A1A;
    --cream-dim:#5b5b54;
    --marigold:#FFC72C;
    --marigold-deep:#e0a800;
    --pink:#E91E7B;
    --green:#1E7A4C;
    --green-deep:#155c39;
    --chile:#E91E7B;
    --shadow-soft: 0 12px 30px rgba(26,26,26,.12);
  }

  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--brown-900);
    color:var(--cream);
    font-family:'DM Sans',sans-serif;
    line-height:1.5;
    overflow-x:hidden;
  }
  h1,h2,h3,.display{
    font-family:'Anton',sans-serif;
    text-transform:uppercase;
    letter-spacing:.03em;
    line-height:1.05;
  }
  a{color:inherit;text-decoration:none;}
  img{max-width:100%;display:block;}
  .wrap{max-width:1140px;margin:0 auto;padding:0 24px;}

  /* ===== Banner / bunting motif ===== */
  .bunting{
    display:flex;
    justify-content:center;
    gap:14px;
    padding:14px 0;
    flex-wrap:wrap;
  }
  .bunting span{
    width:26px;height:32px;
    clip-path:polygon(0 0,100% 0,50% 100%);
    display:inline-block;
    animation:sway 3.4s ease-in-out infinite;
    transform-origin:top center;
  }
  .bunting span:nth-child(1){background:var(--pink);animation-delay:0s;}
  .bunting span:nth-child(2){background:var(--marigold);animation-delay:.15s;}
  .bunting span:nth-child(3){background:var(--green);animation-delay:.3s;}
  .bunting span:nth-child(4){background:var(--pink);animation-delay:.45s;}
  .bunting span:nth-child(5){background:var(--marigold);animation-delay:.6s;}
  .bunting span:nth-child(6){background:var(--green);animation-delay:.75s;}
  .bunting span:nth-child(7){background:var(--pink);animation-delay:.9s;}
  @keyframes sway{
    0%,100%{transform:rotate(-4deg);}
    50%{transform:rotate(4deg);}
  }
  @media (prefers-reduced-motion: reduce){
    .bunting span{animation:none;}
  }

  /* ===== Header ===== */
  header{
    position:sticky;top:0;z-index:50;
    background:rgba(255,251,242,.95);
    backdrop-filter:blur(6px);
    border-bottom:3px solid var(--green);
  }
  .nav{
    display:flex;align-items:center;justify-content:space-between;
    padding:12px 24px;
    max-width:1140px;margin:0 auto;
  }
  .nav-brand{display:flex;align-items:center;gap:12px;}
  .nav-brand img{height:52px;width:auto;border-radius:50%;}
  .nav-brand .name{
    font-family:'Anton',sans-serif;
    font-size:1.05rem;
    letter-spacing:.02em;
    color:var(--green);
  }
  .nav-brand .name small{
    display:block;
    font-family:'DM Sans',sans-serif;
    font-size:.62rem;
    letter-spacing:.18em;
    color:var(--cream-dim);
    text-transform:uppercase;
    margin-top:2px;
  }
  .nav ul{display:flex;gap:28px;list-style:none;margin:0;padding:0;}
  .nav ul a{
    font-size:.85rem;
    font-weight:600;
    letter-spacing:.04em;
    text-transform:uppercase;
    color:var(--cream-dim);
    transition:color .2s;
    position:relative;
  }
  .nav ul a:hover, .nav ul a:focus-visible{color:var(--pink);}
  .nav-cta{
    background:var(--pink);
    color:#fff;
    padding:10px 20px;
    border-radius:999px;
    font-weight:700;
    font-size:.85rem;
    letter-spacing:.03em;
    white-space:nowrap;
    box-shadow:var(--shadow-soft);
    transition:transform .2s, background .2s;
  }
  .nav-cta:hover{background:#c4156a;transform:translateY(-2px);}
  .menu-toggle{display:none;background:none;border:none;color:var(--green);font-size:1.6rem;cursor:pointer;}

  @media (max-width:840px){
    .nav ul{
      position:absolute;top:100%;left:0;right:0;
      flex-direction:column;
      background:#fff;
      padding:20px 24px;
      gap:18px;
      display:none;
      border-bottom:3px solid var(--green);
    }
    .nav ul.open{display:flex;}
    .menu-toggle{display:block;}
    .nav-cta{display:none;}
  }

  /* ===== Hero ===== */
  .hero{
    position:relative;
    padding:48px 0 64px;
    background:#1A1A1A;
    overflow:hidden;
  }
  .hero-wrap{
    display:grid;
    grid-template-columns:1.1fr 1fr;
    gap:48px;
    align-items:center;
  }
  .hero-eyebrow{
    display:inline-block;
    color:var(--marigold);
    font-weight:700;
    letter-spacing:.18em;
    text-transform:uppercase;
    font-size:.78rem;
    margin-bottom:14px;
  }
  .hero-text h1{
    font-size:clamp(2.4rem, 5.2vw, 4rem);
    color:#fff;
  }
  .hero-text h1 em{
    font-style:normal;
    color:var(--marigold);
  }
  .hero-sub{
    max-width:480px;
    margin:18px 0 30px;
    color:#cfcfc8;
    font-size:1.05rem;
  }
  .hero-buttons{
    display:flex;gap:16px;flex-wrap:wrap;
  }
  .btn{
    display:inline-block;
    padding:14px 30px;
    border-radius:999px;
    font-weight:700;
    letter-spacing:.03em;
    font-size:.95rem;
    transition:transform .2s, box-shadow .2s;
  }
  .btn-primary{background:var(--pink);color:#fff;box-shadow:var(--shadow-soft);}
  .btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(0,0,0,.3);}
  .btn-outline{border:2px solid #fff;color:#fff;}
  .btn-outline:hover{background:#fff;color:var(--green);}

  .hero-strip{
    margin-top:42px;
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:1px;
    background:var(--green);
    border-radius:18px;
    overflow:hidden;
    max-width:560px;
    box-shadow:var(--shadow-soft);
  }
  .hero-strip div{
    background:#fff;
    padding:16px 10px;
    text-align:center;
  }
  .hero-strip strong{
    display:block;
    color:var(--pink);
    font-family:'Anton',sans-serif;
    font-size:1.15rem;
    letter-spacing:.02em;
  }
  .hero-strip span{font-size:.72rem;color:var(--cream-dim);text-transform:uppercase;letter-spacing:.04em;}

  .hero-photo-card{
    position:relative;
    border-radius:28px;
    overflow:hidden;
    box-shadow:0 24px 50px rgba(0,0,0,.5);
    border:6px solid #fff;
    max-width:460px;
    margin-inline:auto;
  }
  .hero-photo-card img{
    width:100%;height:auto;display:block;
  }
  .hero-photo-card .bunting{
    position:absolute;top:0;left:0;right:0;
    padding:10px 0 0;
    background:linear-gradient(180deg, rgba(0,0,0,.35), transparent);
  }

  @media (max-width:900px){
    .hero-wrap{grid-template-columns:1fr;text-align:center;}
    .hero-buttons{justify-content:center;}
    .hero-strip{margin-inline:auto;}
    .hero-photo-card{order:-1;max-width:380px;}
  }

  @media (max-width:600px){
    .hero-strip{grid-template-columns:1fr;max-width:300px;}
  }

  /* ===== Section heads ===== */
  .section{padding:84px 0;}
  .section-alt{background:var(--brown-950);}
  .section-alt .section-head h2, .section-alt .menu-banner-label h3{color:#fff;}
  .section-alt .section-head p{color:#cfcfc8;}
  .section-alt .tag{color:var(--marigold);}
  .section-head{text-align:center;max-width:640px;margin:0 auto 50px;}
  .section-head .tag{
    color:var(--green);
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.2em;
    font-size:.78rem;
  }
  .section-head h2{
    font-size:clamp(2rem,5vw,3rem);
    margin-top:10px;
    color:var(--cream);
  }
  .section-head p{
    margin-top:14px;
    color:var(--cream-dim);
    font-size:1.02rem;
  }

  /* ===== About ===== */
  .about{
    display:grid;
    grid-template-columns:1.1fr 1fr;
    gap:56px;
    align-items:center;
  }
  .about-card{
    background:var(--brown-800);
    border:1px solid #eee2c8;
    border-radius:24px;
    padding:36px;
    position:relative;
    box-shadow:var(--shadow-soft);
  }
  .about-card::before{
    content:"";
    position:absolute;top:-14px;left:36px;right:36px;height:6px;
    background:repeating-linear-gradient(90deg,var(--pink) 0 14px, var(--marigold) 14px 28px, var(--green) 28px 42px);
    border-radius:6px;
  }
  .about h2{font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:18px;color:var(--green);}
  .about p{color:var(--cream-dim);margin-bottom:16px;font-size:1.02rem;}
  .about-tags{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px;}
  .about-tags span{
    background:rgba(30,122,76,.08);
    border:1px solid rgba(30,122,76,.3);
    color:var(--green);
    font-size:.82rem;
    font-weight:600;
    padding:7px 16px;
    border-radius:999px;
  }
  .cuisine-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;
  }
  .cuisine-grid .card{
    background:var(--brown-800);
    border:1px solid #eee2c8;
    border-radius:18px;
    padding:24px 20px;
    text-align:center;
    transition:transform .25s, border-color .25s;
  }
  .cuisine-grid .card:hover{transform:translateY(-6px);border-color:var(--pink);}
  .cuisine-grid .card .icon{font-size:1.8rem;margin-bottom:8px;display:block;}
  .cuisine-grid .card h3{font-size:1rem;letter-spacing:.02em;color:var(--pink);margin-bottom:4px;}
  .cuisine-grid .card p{font-size:.82rem;color:var(--cream-dim);}

  @media (max-width:840px){
    .about{grid-template-columns:1fr;}
  }

  /* ===== Menu ===== */
  .menu-tabs{
    display:flex;
    justify-content:center;
    gap:10px;
    flex-wrap:wrap;
    margin-bottom:46px;
  }
  .menu-tabs button{
    background:#fff;
    border:1px solid #e4d8b8;
    color:var(--cream-dim);
    padding:10px 20px;
    border-radius:999px;
    font-weight:600;
    font-size:.85rem;
    letter-spacing:.02em;
    cursor:pointer;
    transition:all .2s;
  }
  .menu-tabs button:hover{border-color:var(--pink);color:var(--pink);}
  .menu-tabs button.active{
    background:var(--pink);
    color:#fff;
    border-color:var(--pink);
  }

  .menu-category{display:none;}
  .menu-category.active{display:block;animation:fadein .35s ease;}
  @keyframes fadein{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

  .menu-banner-label{
    display:flex;align-items:center;gap:16px;
    margin-bottom:28px;
  }
  .menu-banner-label .flagrow{display:flex;gap:6px;}
  .menu-banner-label .flagrow span{
    width:16px;height:20px;
    clip-path:polygon(0 0,100% 0,50% 100%);
  }
  .menu-banner-label .flagrow span:nth-child(1){background:var(--pink);}
  .menu-banner-label .flagrow span:nth-child(2){background:var(--marigold);}
  .menu-banner-label .flagrow span:nth-child(3){background:var(--green);}
  .menu-banner-label .flagrow span:nth-child(4){background:var(--pink);}
  .menu-banner-label h3{
    font-size:1.5rem;
    color:#fff;
    white-space:nowrap;
  }
  .menu-banner-label .price-note{
    color:var(--marigold);
    font-size:.85rem;
    font-weight:600;
    margin-left:auto;
    white-space:nowrap;
  }
  .menu-banner-label::after{
    content:"";flex:1;height:1px;
    background:repeating-linear-gradient(90deg, rgba(255,199,44,.5) 0 6px, transparent 6px 12px);
  }

  .dish-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:14px;
    margin-bottom:46px;
  }
  .dish{
    background:#fff;
    border-radius:14px;
    padding:18px 20px;
    display:flex;
    justify-content:space-between;
    gap:14px;
    border:1px solid transparent;
    transition:border-color .2s, transform .2s;
  }
  .dish:hover{border-color:var(--marigold);transform:translateY(-2px);}
  .dish .info h4{
    font-family:'DM Sans',sans-serif;
    font-weight:700;
    font-size:1rem;
    color:#1A1A1A;
    margin-bottom:4px;
  }
  .dish .info p{
    font-size:.82rem;
    color:#6b6b63;
    line-height:1.4;
  }
  .dish .price{
    font-family:'Anton',sans-serif;
    color:var(--pink);
    font-size:1.1rem;
    white-space:nowrap;
    align-self:flex-start;
  }

  @media (max-width:700px){
    .dish-grid{grid-template-columns:1fr;}
    .menu-banner-label h3{font-size:1.2rem;}
  }

  .menu-footnote{
    text-align:center;
    color:#cfcfc8;
    font-size:.88rem;
    margin-top:-8px;
  }

  /* ===== Gallery ===== */
  .gallery-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:14px;
  }
  .gallery-item{
    position:relative;
    border-radius:16px;
    overflow:hidden;
    border:1px solid #eee2c8;
    aspect-ratio:1;
    background:#f0e8d8;
  }
  .gallery-item img{
    width:100%;height:100%;
    object-fit:cover;
    display:block;
    transition:transform .35s ease;
  }
  .gallery-item:hover img{transform:scale(1.06);}
  .gallery-label{
    position:absolute;bottom:0;left:0;right:0;
    background:linear-gradient(transparent, rgba(0,0,0,.65));
    color:#fff;
    font-size:.75rem;
    font-weight:600;
    padding:20px 10px 8px;
    text-align:center;
    letter-spacing:.04em;
    text-transform:uppercase;
  }
  @media (max-width:760px){
    .gallery-grid{grid-template-columns:repeat(2,1fr);}
  }

  /* ===== Location ===== */
  .location{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:48px;
    align-items:start;
  }
  .loc-card{
    background:var(--brown-800);
    border:1px solid #eee2c8;
    border-radius:24px;
    padding:38px;
    box-shadow:var(--shadow-soft);
  }
  .loc-card h3{color:var(--green);font-size:1.3rem;margin-bottom:18px;}
  .loc-row{display:flex;gap:14px;margin-bottom:20px;align-items:flex-start;}
  .loc-row .ico{
    width:42px;height:42px;border-radius:50%;
    background:rgba(233,30,123,.1);
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;font-size:1.2rem;
  }
  .loc-row h4{font-size:.95rem;color:var(--cream);margin-bottom:3px;}
  .loc-row p, .loc-row a{font-size:.9rem;color:var(--cream-dim);}
  .loc-row a:hover{color:var(--pink);}
  .hours-table{width:100%;margin-top:6px;}
  .hours-table tr{border-bottom:1px solid #eee2c8;}
  .hours-table td{padding:8px 0;font-size:.88rem;color:var(--cream-dim);}
  .hours-table td:last-child{text-align:right;color:var(--cream);font-weight:600;}
  .hours-table tr.closed td:last-child{color:var(--pink);}

  .map-embed{
    border-radius:24px;
    overflow:hidden;
    box-shadow:var(--shadow-soft);
    border:1px solid #eee2c8;
    min-height:340px;
  }
  .map-embed iframe{width:100%;height:100%;min-height:340px;border:0;display:block;}

  .social-row{display:flex;gap:12px;margin-top:24px;}
  .social-row a{
    width:42px;height:42px;border-radius:50%;
    background:var(--brown-900);
    display:flex;align-items:center;justify-content:center;
    font-size:1.1rem;
    color:var(--green);
    border:1px solid #eee2c8;
    transition:background .2s, transform .2s, color .2s;
  }
  .social-row a:hover{background:var(--pink);color:#fff;border-color:var(--pink);transform:translateY(-3px);}

  @media (max-width:860px){
    .location{grid-template-columns:1fr;}
  }

  /* ===== Contact ===== */
  .contact-wrap{
    background:var(--brown-800);
    border:1px solid #eee2c8;
    border-radius:28px;
    padding:54px;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:50px;
    box-shadow:var(--shadow-soft);
  }
  .contact-info h2{font-size:clamp(1.8rem,4vw,2.4rem);margin-bottom:16px;color:var(--green);}
  .contact-info p{color:var(--cream-dim);margin-bottom:24px;}
  .contact-info .big-phone{
    display:inline-flex;align-items:center;gap:10px;
    font-family:'Anton',sans-serif;
    font-size:1.6rem;
    color:var(--pink);
    margin-bottom:30px;
  }
  form{display:flex;flex-direction:column;gap:16px;}
  label{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--cream-dim);margin-bottom:6px;display:block;}
  input,textarea{
    width:100%;
    background:var(--brown-900);
    border:1px solid #e4d8b8;
    border-radius:12px;
    padding:13px 16px;
    color:var(--cream);
    font-family:'DM Sans',sans-serif;
    font-size:.95rem;
    resize:vertical;
  }
  input:focus,textarea:focus{outline:2px solid var(--pink);outline-offset:1px;}
  input::placeholder,textarea::placeholder{color:#a8a89c;}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
  .submit-btn{
    background:var(--pink);
    color:#fff;
    border:none;
    padding:15px 0;
    border-radius:12px;
    font-weight:700;
    font-size:1rem;
    letter-spacing:.03em;
    cursor:pointer;
    transition:background .2s, transform .2s;
    margin-top:6px;
  }
  .submit-btn:hover{background:#c4156a;transform:translateY(-2px);}
  .form-note{font-size:.78rem;color:#a8a89c;text-align:center;}

  @media (max-width:840px){
    .contact-wrap{grid-template-columns:1fr;padding:36px 24px;}
    .form-row{grid-template-columns:1fr;}
  }

  /* ===== Footer ===== */
  footer{
    background:var(--brown-950);
    padding:50px 0 26px;
    border-top:3px solid var(--marigold);
  }
  .footer-grid{
    display:grid;
    grid-template-columns:2fr 1fr 1fr;
    gap:40px;
    margin-bottom:36px;
  }
  .footer-brand{display:flex;gap:14px;align-items:center;margin-bottom:14px;}
  .footer-brand img{height:48px;border-radius:50%;}
  .footer-brand span{font-family:'Anton',sans-serif;color:var(--marigold);font-size:1.1rem;}
  footer p{color:#cfcfc8;font-size:.88rem;max-width:340px;}
  footer h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#fff;margin-bottom:14px;}
  footer ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
  footer ul a{color:#cfcfc8;font-size:.9rem;transition:color .2s;}
  footer ul a:hover{color:var(--marigold);}
  .footer-bottom{
    text-align:center;
    border-top:1px solid rgba(255,255,255,.1);
    padding-top:22px;
    font-size:.8rem;
    color:#8a8a82;
  }
  @media (max-width:760px){
    .footer-grid{grid-template-columns:1fr;gap:28px;}
  }

  /* skip link */
  .skip-link{
    position:absolute;left:-999px;top:0;
    background:var(--marigold);color:var(--brown-950);
    padding:10px 16px;border-radius:8px;z-index:100;
  }
  .skip-link:focus{left:16px;top:16px;}

  /* ===== Interior page header ===== */
  .page-header{
    background:#1A1A1A;
    padding:56px 0 64px;
    text-align:center;
    position:relative;
    overflow:hidden;
  }
  .page-header .tag{
    color:var(--marigold);
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.2em;
    font-size:.78rem;
  }
  .page-header h1{
    font-size:clamp(2.2rem,5.5vw,3.4rem);
    color:#fff;
    margin-top:10px;
  }
  .page-header p{
    color:#cfcfc8;
    max-width:560px;
    margin:16px auto 0;
    font-size:1.02rem;
  }
  .breadcrumb{
    font-size:.8rem;
    color:#a8a89c;
    margin-bottom:14px;
  }
  .breadcrumb a{color:var(--marigold);}
  .breadcrumb a:hover{text-decoration:underline;}

  /* current nav page indicator */
  .nav ul a.current{color:var(--pink);}

