:root{--primary:#6e8834;--primary-700:#556c2a;--accent-gold:#d89c08;--accent-yellow:#f8c945;--accent-orange:#e5613e;--accent-pink:#e2396d;--mint:#6e8834;--mint-700:#556c2a;--lemon:#f8c945;--night:#0B1220;--sand:#F8FAFC;--white:#fff;--berry:#e2396d}
*{box-sizing:border-box}html{scroll-behavior:smooth;overflow-x:hidden}
/* Prevent horizontal overflow on mobile */
body{overflow-x:hidden}
/* Make media elements fluid */
img, video{max-width:100%;height:auto}
iframe{max-width:100%}
body{margin:0;font-family:Raleway,system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,sans-serif;color:var(--night);background:#fff;min-height:100vh;display:flex;flex-direction:column}
/* Headings use Catseye */
h1,h2,h3,h4,h5,h6{font-family:Catseye,Raleway,sans-serif}
main{flex:1}
.dark body{background:var(--night);color:#e5e7eb}
.container{max-width:1120px;margin:0 auto;padding:0 16px}
.site-header{position:sticky;top:0;background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid #e5e7eb;z-index:50}
.dark .site-header{background:rgba(15,23,42,.9);border-color:#1f2937}
.site-header .container{display:flex;align-items:center;gap:16px;min-height:60px}
.logo{display:inline-flex;align-items:center;gap:5px;padding:2px 12px;font-family:Catseye,Inter,sans-serif;font-weight:700;color:var(--night);text-decoration:none}
.logo img{display:block;height:40px;width:auto}
@media (max-width:900px){.logo img{height:48px}}
@media (max-width:900px){.logo img{height:48px}}
@media (max-width:700px){.logo img{height:36px}}
.logo span{color:var(--primary)}
.nav{display:flex;gap:16px;margin-left:auto}
.nav a{color:var(--night);text-decoration:none}
.nav a:hover{color:var(--accent-gold);text-decoration:underline}
.nav a:focus-visible{outline:3px solid var(--accent-pink);outline-offset:2px;border-radius:6px}
.actions{display:flex;gap:8px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:10px;border:1px solid #cbd5e1;text-decoration:none;color:var(--night);background:#fff}
.btn:hover{background:#f8fafc}
.btn-primary{background:var(--primary);border-color:var(--primary-700);color:#fff;font-weight:700}
.btn-primary:hover{background:var(--primary-700)}
.btn-secondary{background:var(--accent-gold);border-color:#b87e06;color:#0B1220;font-weight:700}
.btn-secondary:hover{background:#b87e06;border-color:#966804}
.btn-accent{background:var(--accent-orange);border-color:#c34d30;color:#fff;font-weight:700}
.btn-accent:hover{background:#c34d30}
.btn-berry{background:var(--accent-pink);border-color:#bf2b5f;color:#fff;font-weight:700}
.btn-berry:hover{background:#bf2b5f}
.btn-primary:hover{background:var(--primary-700)}
.btn-primary:focus-visible{outline:3px solid var(--accent-gold);outline-offset:2px}
.btn-outline{background:transparent;border-color:var(--primary);color:var(--primary)}
.btn-outline:hover{background:rgba(110,136,52,0.12);border-color:var(--primary)}
.btn-ghost{background:transparent;border-color:transparent}
.menu-toggle{display:none;margin-left:8px;padding:8px 10px;border:1px solid #e5e7eb;border-radius:8px;background:#fff}
@media (max-width:900px){.nav{display:none}.menu-toggle{display:inline-flex;margin-left:auto}.mobile-nav[hidden]{display:none}.mobile-nav{display:grid;gap:8px;padding:12px;border-top:1px solid #e5e7eb;background:#fff}.mobile-nav a{display:block;padding:10px 12px;border:1px solid var(--primary);border-radius:10px;background:rgba(110,136,52,0.08);text-decoration:none}.mobile-nav a:link,.mobile-nav a:visited{color:var(--primary-700)}.mobile-nav a:hover{background:rgba(110,136,52,0.14);border-color:var(--primary-700)}.mobile-nav a.btn{background:var(--primary);border-color:var(--primary-700);color:#fff;font-weight:700}.dark .mobile-nav{background:#111827;border-color:#1f2937}}
@media (max-width:900px){.site-header .container{flex-wrap:wrap}}
.hero{padding:56px 0 24px;background:linear-gradient(135deg, rgba(110,136,52,0.06), rgba(11,18,32,0))}
.hero-grid{display:grid;gap:24px;grid-template-columns:1.2fr 1fr;align-items:center}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr}}
.hero-copy h1{font-family:Catseye,Inter,sans-serif;font-weight:700;font-size:40px;line-height:1.1;margin:0}
.hero-copy p{color:var(--night);margin:16px 0}
.badge{display:inline-block;font-size:12px;line-height:1;padding:6px 10px;border-radius:999px;color:var(--accent-gold);background:rgba(248,201,69,0.12);border:1px solid rgba(216,156,8,0.35)}
.hero-media img{width:100%;height:auto;max-height:320px;object-fit:cover;border-radius:16px;display:block}
.section{padding:48px 0}
.section.alt{background:var(--sand)}
.section-title{font-family:Catseye,Inter,sans-serif;font-size:28px;margin:0 0 16px 0;color:var(--primary)}
.section-title{position:relative}
.section-title:after{content:"";position:absolute;left:0;bottom:-6px;height:3px;width:72px;border-radius:3px;background:linear-gradient(90deg,var(--primary),var(--accent-gold),var(--accent-orange),var(--accent-pink))}
.cards{display:grid;gap:16px}
.cards.four{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.cards.four{grid-template-columns:repeat(2,1fr)}}
.card{border:1px solid #e5e7eb;border-radius:12px;padding:16px;background:#fff;color:var(--night);text-decoration:none}
.card:hover{box-shadow:0 8px 24px rgba(0,0,0,.06);border-color:var(--accent-gold)}
.steps{display:grid;gap:16px;grid-template-columns:repeat(3,1fr);list-style:none;padding:0;margin:0}
@media (max-width:900px){.steps{grid-template-columns:1fr}}
.step-num{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:999px;background:var(--primary);color:#fff;font-weight:600;margin-bottom:8px}
.steps li:nth-child(2) .step-num{background:var(--accent-gold)}
.steps li:nth-child(3) .step-num{background:var(--accent-orange)}
.testimonials{display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}
@media (max-width:900px){.testimonials{grid-template-columns:1fr}}
.testimonial{border:1px solid #e5e7eb;border-radius:12px;padding:16px;background:#fff}
.testimonial blockquote{margin:0 0 8px 0;color:#0B1220}
.rating{display:flex;justify-content:center;gap:2px;margin:8px 0 10px 0;color:var(--accent-gold);font-size:18px}
.testimonial figcaption{text-align:center;color:#334155}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{border:1px solid rgba(216,156,8,0.45);padding:6px 10px;border-radius:999px;background:rgba(248,201,69,0.12)}
.muted{color:#64748b;font-size:14px}
.site-footer{border-top:1px solid #e5e7eb;padding:24px 0;background:var(--sand)}
.copyright{margin:8px 0 0 0;text-align:center;font-size:12px;color:#64748b}
.footer-grid{display:grid;gap:16px;grid-template-columns:2fr 1fr 1fr;align-items:start}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr}}
.footer-grid.rich{grid-template-columns:2fr 1fr 1fr 1fr}
@media (max-width:1000px){.footer-grid.rich{grid-template-columns:1fr 1fr}}
@media (max-width:700px){.footer-grid.rich{grid-template-columns:1fr}}
.footer-title{margin:0 0 8px 0;font-size:14px;color:var(--primary)}
.footer-list{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.footer-list a{color:var(--night);text-decoration:none}
.footer-list a:hover{color:var(--accent-gold);text-decoration:underline}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid #e5e7eb;margin-top:12px}
@media (max-width:700px){.footer-bottom{flex-direction:column;gap:8px;text-align:center}}
.legal{display:flex;gap:8px;align-items:center}
.legal-link{color:var(--night);text-decoration:none}
.legal-link:hover{color:var(--accent-gold);text-decoration:underline}
.tagline{color:#334155;margin:8px 0 12px 0}
.socials{display:flex;gap:10px}
.socials a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:999px;background:rgba(248,201,69,0.18);color:#7a5b03}
.socials a:hover{background:rgba(216,156,8,0.25)}
.skip-link{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:static;width:auto;height:auto;padding:8px;background:var(--night);color:#fff}
::selection{background:rgba(226,57,109,0.25)}
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible{outline:3px solid var(--accent-pink);outline-offset:2px}

/* Forms */
.form{display:grid;gap:12px}
.field{display:grid;gap:6px}
.field label{font-weight:500}
.input, select, textarea{padding:10px 12px;border-radius:10px;border:1px solid #e5e7eb;width:100%}
.input:focus, select:focus, textarea:focus{outline:2px solid var(--accent-gold);outline-offset:2px;border-color:var(--accent-gold)}
.inline{display:flex;gap:8px;align-items:center}
.grid-2{display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}
@media (max-width:700px){.grid-2{grid-template-columns:1fr}}
.sticky-bar{position:sticky;bottom:0;background:#fff;border-top:1px solid #e5e7eb;padding:12px}
.sticky-bar .container{display:flex;justify-content:space-between;align-items:center}

/* Menu + Cart */
.layout{display:grid;grid-template-columns:2fr 1fr;gap:24px}
@media (max-width:960px){.layout{grid-template-columns:1fr}}
.menu-grid{display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}
@media (max-width:700px){.menu-grid{grid-template-columns:1fr}}
.menu-item{display:grid;grid-template-columns:80px 1fr auto;gap:12px;align-items:center;border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff}
.menu-item{position:relative}
.menu-item h3{margin:0;font-size:16px}
.menu-item p{margin:4px 0 0 0;color:#334155;font-size:14px}
.menu-qty{display:flex;gap:8px;align-items:center}
.menu-qty select{width:64px;padding:8px 10px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;font-weight:600}
.price{font-weight:700;color:var(--primary)}
.cart{position:sticky;top:88px;border:1px solid #e5e7eb;border-radius:12px;padding:16px;background:#fff}
.cart.pulse{animation:cartPulse .4s ease}
.cart h2{margin:0 0 12px 0;font-size:18px}
.cart-list{display:grid;gap:8px;margin:12px 0}
.cart-line{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center}
.qty{display:inline-flex;align-items:center;border:1px solid #e5e7eb;border-radius:8px}
.qty button{background:#fff;border:0;padding:6px 10px;cursor:pointer}
.qty span{min-width:28px;text-align:center}
.cart-total{display:flex;justify-content:space-between;font-weight:700;margin-top:12px}
.divider{height:1px;background:#e5e7eb;margin:12px 0}

/* Add-to-cart animation */
.added-float{position:absolute;right:12px;bottom:42px;background:var(--accent-gold);color:#0B1220;font-weight:700;border-radius:999px;padding:2px 8px;font-size:12px;opacity:0;animation:floatUp .8s ease forwards}
/* Basket icon variant */
.added-basket{position:absolute;right:14px;bottom:40px;width:24px;height:24px;background-repeat:no-repeat;background-size:24px 24px;opacity:0;animation:floatUp .8s ease forwards;
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none"><path d="M3 9h18l-1.5 10.5A2 2 0 0 1 17.52 21H6.48a2 2 0 0 1-1.98-1.5L3 9zm5.2-5.6a1 1 0 1 1 1.6 1.2L7.6 9H6l2.2-5.6zM14.2 3.4a1 1 0 1 1 1.6 1.2L13.6 9H12l2.2-5.6z" fill="%23d89c08"/></svg>');}
@keyframes floatUp{0%{transform:translateY(8px);opacity:0}20%{opacity:1}80%{opacity:1}100%{transform:translateY(-24px);opacity:0}}
@keyframes cartPulse{0%{box-shadow:0 0 0 0 rgba(216,156,8,0.0);border-color:#e5e7eb}
50%{box-shadow:0 0 0 6px rgba(216,156,8,0.25);border-color:var(--accent-gold)}
100%{box-shadow:0 0 0 0 rgba(216,156,8,0.0);border-color:#e5e7eb}}

/* Vaud banner */
.vaud-banner{background:linear-gradient(90deg, rgba(110,136,52,0.08), rgba(248,201,69,0.14));}
.vaud-content{display:grid;gap:8px;align-items:center}
.vaud-content h2{margin:0;font-family:Catseye,Inter,sans-serif;font-size:24px;color:var(--primary)}
.vaud-content p{margin:0;color:var(--accent-orange)}
.vaud-content .chip{background:rgba(226,57,109,0.1);border-color:var(--accent-pink);color:var(--accent-pink)}

/* About section */
.about{background:linear-gradient(135deg, rgba(110,136,52,0.04), rgba(248,201,69,0.06))}
.about-grid{display:grid;gap:20px;grid-template-columns:1.2fr 1fr;align-items:start}
@media (max-width:900px){.about-grid{grid-template-columns:1fr}}
.pills{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 0 0;padding:0;list-style:none}
.pill{padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600}
.pill.green{background:rgba(110,136,52,0.12);color:var(--primary);border:1px solid var(--primary)}
.pill.gold{background:rgba(248,201,69,0.14);color:#7a5b03;border:1px solid var(--accent-gold)}
.pill.orange{background:rgba(229,97,62,0.12);color:var(--accent-orange);border:1px solid var(--accent-orange)}
.about-card{border:1px solid #e5e7eb;border-radius:12px;background:#fff;padding:16px}
.about-card h3{margin:0 0 8px 0;font-size:18px}
.about-card ul{margin:0;padding-left:18px;color:#334155}
.about-card img{width:100%;max-width:400px;height:auto;border-radius:10px;margin:12px auto 0;display:block}
#about{scroll-margin-top:80px}
#menu{scroll-margin-top:80px}
#find-us{scroll-margin-top:25px}
#contact{scroll-margin-top:10px}

/* Ensure elements with the hidden attribute are actually hidden */
[hidden]{display:none !important}

/* Mobile enhancements */
@media (max-width:900px){
  .actions{display:none}
}
@media (max-width:700px){
  .hero{padding:36px 0 12px}
  .hero-copy h1{font-size:32px}
  .hero-cta{display:grid;grid-template-columns:1fr;gap:10px}
  .badge{font-size:11px}
  .map-wrap iframe{height:240px !important}
  .cart{position:relative;top:auto}
  .section{padding:36px 0}
  /* Contact form: use full width and compact spacing on mobile */
  #contact .section-title{margin-bottom:12px}
  #quote-form{max-width:100%}
  #quote-form .form{gap:10px}
  #quote-form .grid-2{gap:10px}
  #quote-form .field{max-width:100% !important}
  #quote-form button[type=submit]{width:100%}
}
@media (max-width:500px){
  .hero-copy h1{font-size:28px}
  .menu-item{grid-template-columns:64px 1fr auto;gap:10px}
  .menu-item h3{font-size:15px}
  .menu-qty input[type=number]{width:56px}
}

/* iOS/mobile safe inputs to avoid overflow/zoom */
input, select, textarea{font-size:16px}
input[type=date]{width:100%;min-width:0}

/* Checkout form: prevent overflow of date/time on mobile */
#checkout-form .grid-2 > .field{min-width:0}
#checkout-form select,#checkout-form input{width:100%}

/* Global select responsiveness */
select{max-width:100%}

@media (max-width:500px){
  .menu-qty{flex-wrap:wrap;justify-content:flex-end}
  .menu-qty select{width:100%}
  .menu-qty + .btn,
  .menu-qty .btn{width:100%}
}

/* Quote form: make date field responsive */
#quote-form .grid-2 > .field{min-width:0}
#quote-form input[type=date]{width:100%;min-width:0}
@media (max-width:700px){
  #quote-form .grid-2{grid-template-columns:1fr}
}

/* Contact date lock on mobile */
#c-date.touch-locked{background:#f3f4f6;color:#6b7280;cursor:not-allowed;pointer-events:none}

