*,*::before,*::after{box-sizing:border-box}
:root{
  --bg:#0f1109;--olive:#4c5a35;--olive2:#2a2e22;--cream:#e7e2d8;--paper:#ebe3d3;--brown:#3b2b1f;--orange:#c85a1c;--muted:#afa78f;
  --max:1180px;
}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--cream);
  background:#0c0d07;
  overflow-x:hidden;
  width:100%;
  max-width:100vw;
}
main{overflow-x:hidden;width:100%;}
body:before{
  content:"";
  position:fixed;inset:0;pointer-events:none;z-index:-3;
  background:
    radial-gradient(circle at 66% 10%,rgba(76,90,53,.28),transparent 36rem),
    radial-gradient(circle at 8% 14%,rgba(200,90,28,.16),transparent 30rem),
    linear-gradient(180deg,#0d0f08 0%,#151309 42%,#080904 100%);
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.topnav{
  position:fixed;top:0;left:0;right:0;height:74px;z-index:50;
  display:grid;grid-template-columns:220px 1fr auto;align-items:center;gap:24px;
  padding:0 max(32px,calc((100vw - var(--max))/2));
  border-bottom:1px solid rgba(231,226,216,.12);
  background:rgba(10,12,7,.78);
  backdrop-filter:blur(22px);
}
.logo{font-family:"Playfair Display",serif;font-size:30px;letter-spacing:-.055em}
.topnav nav{display:flex;justify-content:center;gap:42px}
.topnav nav a{font-size:13px;font-weight:800;color:rgba(231,226,216,.78)}
.topnav nav a:hover{color:#fff}
.reserve,.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:48px;padding:0 24px;border-radius:999px;font-weight:900;font-size:13px;
}
.reserve,.btn.primary{background:linear-gradient(135deg,#d76422,var(--orange));color:#fff;box-shadow:0 16px 34px rgba(200,90,28,.23)}
.btn.outline{border:1px solid rgba(231,226,216,.45);background:rgba(255,255,255,.035)}
.menu-btn{display:none}
.hero{
  min-height:650px;
  padding:120px max(32px,calc((100vw - var(--max))/2)) 0;
  display:grid;grid-template-columns:42% 58%;align-items:center;position:relative;overflow:hidden;
  background:
    linear-gradient(90deg,rgba(12,14,7,.98) 0%,rgba(22,29,14,.92) 52%,rgba(12,10,7,.98) 100%);
}
.hero:after{
  content:"";position:absolute;right:0;top:74px;bottom:0;width:155px;
  background:linear-gradient(90deg,rgba(60,35,22,.35),rgba(82,45,25,.78),rgba(30,18,11,.92));
}
.script{
  font-family:Caveat,cursive;color:var(--orange);font-size:40px;line-height:1;margin:0 0 12px;transform:rotate(-5deg);display:inline-block;
}
.script.small{font-size:26px;margin-bottom:8px}
.hero h1,.signature h2,.ambience h2,.about h2{
  font-family:"Playfair Display",Georgia,serif;font-weight:700;letter-spacing:-.07em;line-height:.92;margin:0;
}
.hero h1{font-size:clamp(62px,7.4vw,95px)}
.hero h1 span{color:var(--olive)}
.hero-copy {
  min-width: 0;
  width: 100%;
}
.lead {
  max-width: 500px;
  width: 100%;
  box-sizing: border-box;
  color: rgba(231,226,216,.84);
  font-size: 17px;
  line-height: 1.62;
  margin: 26px 0 28px;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.scroll{display:flex;align-items:center;gap:14px;margin-top:34px;color:rgba(231,226,216,.58);font-size:12px;font-weight:700}
.scroll i{width:2px;height:32px;background:var(--cream);border-radius:99px}
.scroll b{width:22px;height:22px;display:grid;place-items:center;border:1px solid rgba(231,226,216,.22);border-radius:50%;font-weight:500}
.hero-visual{position:relative;z-index:2;align-self:stretch;display:flex;align-items:flex-end;justify-content:flex-end;overflow:hidden}
.hero-visual img{width:min(650px,100%);max-width:100%;border-radius:0;object-fit:contain;filter:drop-shadow(0 30px 46px rgba(0,0,0,.32));transition:transform .18s ease-out}
.section-dots{position:absolute;right:max(42px,calc((100vw - var(--max))/2));top:250px;z-index:5;display:grid;justify-items:center;gap:11px;color:#fff;font-size:14px;font-weight:900}
.section-dots span{width:6px;height:6px;border:1px solid #fff;border-radius:50%}
.signature{
  min-height:360px;
  padding:34px max(32px,calc((100vw - var(--max))/2));
  display:grid;grid-template-columns:225px 1fr 170px;gap:22px;align-items:stretch;
  background:
    radial-gradient(circle at 88% 35%,rgba(231,226,216,.08),transparent 24rem),
    linear-gradient(135deg,#25180d,#19140b 58%,#0f1109);
}
.section-intro{padding:30px 0 0}
.signature h2,.ambience h2,.about h2{font-size:clamp(40px,5.2vw,58px)}
.section-intro p:not(.script),.ambience-copy p,.about-text p{line-height:1.6;color:rgba(231,226,216,.72)}
.text-link,.paper-link{display:inline-flex;align-items:center;gap:10px;margin-top:16px;font-size:13px;font-weight:900;border-bottom:1px solid currentColor;padding-bottom:5px}
.drink-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.drink-card{
  position:relative;min-height:315px;padding:22px 18px 18px;overflow:hidden;
  border-radius:12px;border:1px solid rgba(231,226,216,.17);
  background:linear-gradient(180deg,rgba(231,226,216,.12),rgba(231,226,216,.05));
  box-shadow:0 22px 55px rgba(0,0,0,.22);transition:.28s ease;
}
.drink-card:hover{transform:translateY(-8px);border-color:rgba(200,90,28,.42)}
.drink-card .num{position:absolute;top:18px;left:18px;font-size:13px;font-weight:900}
.drink-img{height:138px;display:grid;place-items:center;margin-top:18px;margin-bottom:4px}
.drink-img img{max-height:136px;width:auto;border-radius:6px;filter:drop-shadow(0 18px 18px rgba(0,0,0,.22))}
.drink-card em{display:inline-block;padding:5px 8px;border-radius:4px;background:var(--orange);color:#fff;font-style:normal;font-size:11px;font-weight:900;margin-bottom:6px}
.drink-card h3{font-family:"Playfair Display",serif;font-size:23px;line-height:1.1;margin:0 0 7px;letter-spacing:-.03em}
.drink-card p{font-size:12px;line-height:1.45;color:rgba(231,226,216,.78);margin:0;min-height:50px}
.price{display:flex;justify-content:space-between;align-items:center;margin-top:14px}
.price strong{font-size:14px}
.price button{width:28px;height:28px;border-radius:50%;border:1px solid rgba(231,226,216,.5);background:transparent;color:var(--cream);font-size:18px}
.vase-asset{align-self:end;width:170px;border-radius:0;filter:drop-shadow(0 24px 30px rgba(0,0,0,.28))}
.ambience{
  padding:34px max(32px,calc((100vw - var(--max))/2));
  display:grid;grid-template-columns:220px 1fr;gap:28px;align-items:center;
  background:var(--paper);color:#2c291f;
}
.ambience .script{color:var(--orange)}
.ambience h2{color:#2e2a20}
.ambience-copy p{color:#675e4e}
.paper-link{color:#2e2a20}
.gallery-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.photo{position:relative;height:174px;overflow:hidden;border-radius:9px;box-shadow:0 18px 36px rgba(41,32,20,.18)}
.photo img{width:100%;height:100%;object-fit:cover;transition:.35s ease}
.photo:hover img{transform:scale(1.06)}
.photo:after{content:"";position:absolute;inset:45% 0 0;background:linear-gradient(transparent,rgba(0,0,0,.66))}
.photo div{position:absolute;left:13px;right:13px;bottom:12px;z-index:2;color:#fff}
.photo strong{font-family:"Playfair Display",serif;font-size:18px;display:block}
.photo span{font-size:11px;line-height:1.35;color:rgba(255,255,255,.78)}
.about{
  min-height:300px;
  display:grid;grid-template-columns:48% 52%;align-items:center;gap:0;
  padding:0 max(32px,calc((100vw - var(--max))/2));
  background:
    radial-gradient(circle at 60% 35%,rgba(76,90,53,.22),transparent 28rem),
    linear-gradient(135deg,#1b150b,#0f1109);
}
.about-img{height:300px;display:flex;align-items:flex-end}
.about-img img{width:520px;max-width:100%;filter:drop-shadow(0 24px 32px rgba(0,0,0,.35))}
.about-text{padding:42px 0}
.about-text h2{font-size:44px;max-width:500px}
.about-text p{max-width:560px;font-size:13px}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:28px}
.features div{display:grid;grid-template-columns:36px 1fr;column-gap:10px;align-items:center}
.features i{grid-row:1/3;width:34px;height:34px;border:1px solid rgba(231,226,216,.26);border-radius:50%;display:grid;place-items:center;font-style:normal}
.features b{font-size:12px}
.features span{font-size:11px;color:rgba(231,226,216,.62);line-height:1.35}
.visit{
  padding:34px max(32px,calc((100vw - var(--max))/2)) 32px;
  background:linear-gradient(180deg,#11130b,#0b0c07);
}
.visit-panel{
  min-height:160px;display:grid;grid-template-columns:1fr 1fr 1fr 140px;gap:24px;align-items:center;
  position:relative;overflow:hidden;padding:24px 26px;border-radius:12px;border:1px solid rgba(231,226,216,.16);
  background:linear-gradient(135deg,rgba(231,226,216,.085),rgba(231,226,216,.035));
}
.visit-col{position:relative;z-index:2;border-right:1px solid rgba(231,226,216,.11);min-height:105px;padding-right:24px}
.visit-col:last-of-type{border-right:0}
.plant{width:80px;float:left;margin-right:18px;border-radius:8px}
.visit h3{font-family:"Playfair Display",serif;font-size:24px;margin:0 0 12px}
.visit p{font-size:13px;line-height:1.6;color:rgba(231,226,216,.74);margin:0 0 6px}
.visit p b{float:right;color:var(--cream)}
.visit small{color:var(--muted);font-size:12px}
.chair{position:absolute;right:12px;bottom:-10px;width:125px;z-index:1}
.map{height:360px;margin-top:18px;border-radius:12px;overflow:hidden;border:1px solid rgba(231,226,216,.13)}
.map iframe{width:100%;height:100%;border:0;filter:grayscale(.25) sepia(.15) brightness(.82)}
.footer{
  display:grid;grid-template-columns:1.4fr .7fr .7fr 1.4fr;gap:34px;
  padding:36px max(32px,calc((100vw - var(--max))/2));
  background:#080904;border-top:1px solid rgba(231,226,216,.12);color:rgba(231,226,216,.72);
}
.footer h2{font-family:"Playfair Display",serif;font-size:32px;margin:0 0 8px;color:var(--cream)}
.footer h4{margin:0 0 12px;color:var(--cream)}
.footer a{display:block;margin:7px 0;font-size:13px}
.footer p{font-size:13px;line-height:1.5}
.newsletter label{display:flex;margin-top:12px;border:1px solid rgba(231,226,216,.14);border-radius:4px;overflow:hidden}
.newsletter input{flex:1;background:transparent;border:0;color:var(--cream);outline:0;padding:12px}
.newsletter button{width:44px;border:0;background:var(--orange);color:#fff;font-size:18px}
.fade{opacity:0;transform:translateY(20px);transition:.75s ease}
.fade.show{opacity:1;transform:none}

/* --- WHATSAPP ORDERING & CART SYSTEM --- */
.floating-cart {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 90;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 18px;
  border-radius: 99px;
  background: rgba(26, 21, 15, 0.88);
  border: 1px solid rgba(231, 226, 216, 0.16);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.45);
  cursor: pointer;
  opacity: 0;
  transform: translateY(30px) scale(0.9);
  pointer-events: none;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.floating-cart.active {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.floating-cart:hover {
  transform: translateY(-4px) scale(1.02);
  border-color: var(--orange);
  background: rgba(36, 29, 20, 0.94);
}
.cart-icon-wrapper {
  position: relative;
  font-size: 20px;
  display: flex;
  align-items: center;
}
.cart-badge {
  position: absolute;
  top: -8px;
  right: -8px;
  background: var(--orange);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  border: 1px solid rgba(26, 21, 15, 0.88);
}
.cart-info {
  display: flex;
  flex-direction: column;
}
.cart-label {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  font-weight: 700;
}
.cart-total {
  font-size: 13px;
  font-weight: 800;
  color: var(--cream);
}
.cart-btn-open {
  background: var(--orange);
  color: #fff;
  border: none;
  border-radius: 99px;
  padding: 5px 12px;
  font-weight: 800;
  font-size: 11px;
  cursor: pointer;
  transition: opacity 0.2s;
}
.cart-btn-open:hover {
  opacity: 0.9;
}

/* Toast Notifications */
.toast-container {
  position: fixed;
  top: 24px;
  right: 24px;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  gap: 10px;
  pointer-events: none;
}
.toast-notification {
  background: rgba(30, 26, 20, 0.94);
  border: 1px solid rgba(231, 226, 216, 0.2);
  border-radius: 8px;
  color: var(--cream);
  padding: 12px 18px;
  font-size: 13px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.3);
  transform: translateX(120%);
  transition: transform 0.35s cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity 0.3s;
  opacity: 0;
  pointer-events: auto;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.toast-notification.show {
  transform: translateX(0);
  opacity: 1;
}
.toast-notification span {
  font-size: 16px;
  color: var(--orange);
}
.toast-notification b {
  color: var(--orange);
}

/* Cart Drawer Overlay & Panel */
.cart-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 100;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.cart-overlay.active {
  opacity: 1;
  pointer-events: auto;
}
.cart-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 440px;
  max-width: 100%;
  z-index: 101;
  background: #0d0f08;
  border-left: 1px solid rgba(231, 226, 216, 0.12);
  box-shadow: -10px 0 40px rgba(0, 0, 0, 0.6);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.cart-drawer.open {
  transform: translateX(0);
}
.drawer-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  border-bottom: 1px solid rgba(231, 226, 216, 0.1);
}
.drawer-header h3 {
  font-family: "Playfair Display", Georgia, serif;
  font-size: 22px;
  margin: 0;
  color: var(--cream);
  letter-spacing: -0.02em;
}
.drawer-close {
  background: none;
  border: none;
  font-size: 28px;
  color: var(--muted);
  cursor: pointer;
  padding: 0;
  line-height: 1;
  transition: color 0.2s;
}
.drawer-close:hover {
  color: #fff;
}
.drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 24px;
  scrollbar-width: thin;
}
.cart-items-list {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.cart-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(231, 226, 216, 0.08);
}
.cart-item-img {
  width: 54px;
  height: 54px;
  border-radius: 8px;
  object-fit: cover;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(231, 226, 216, 0.08);
}
.cart-item-info {
  flex: 1;
}
.cart-item-info h5 {
  margin: 0 0 4px;
  font-family: "Playfair Display", Georgia, serif;
  font-size: 16px;
  color: var(--cream);
}
.cart-item-info p {
  margin: 0;
  font-size: 12px;
  color: var(--muted);
  font-weight: 600;
}
.cart-item-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
.qty-btn {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 1px solid rgba(231, 226, 216, 0.25);
  background: transparent;
  color: var(--cream);
  font-size: 14px;
  font-weight: 700;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: all 0.2s;
}
.qty-btn:hover {
  background: var(--orange);
  border-color: var(--orange);
}
.qty-val {
  font-size: 13px;
  font-weight: 800;
  min-width: 18px;
  text-align: center;
}
.btn-delete {
  background: none;
  border: none;
  color: #bf4545;
  cursor: pointer;
  font-size: 15px;
  padding: 4px;
  margin-left: 4px;
  transition: color 0.2s;
}
.btn-delete:hover {
  color: #ff6060;
}
.empty-message {
  text-align: center;
  color: var(--muted);
  font-size: 14px;
  padding: 40px 0;
}
.order-form {
  margin-top: 32px;
  border-top: 1px solid rgba(231, 226, 216, 0.1);
  padding-top: 24px;
}
.order-form h4 {
  font-family: "Playfair Display", Georgia, serif;
  font-size: 18px;
  margin: 0 0 16px;
  color: var(--cream);
}
.form-group {
  margin-bottom: 16px;
}
.form-group label {
  display: block;
  font-size: 11px;
  font-weight: 800;
  color: var(--muted);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(231, 226, 216, 0.14);
  border-radius: 6px;
  color: var(--cream);
  padding: 10px 12px;
  font-size: 13px;
  outline: none;
  font-family: inherit;
  transition: border-color 0.2s;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--orange);
}
.form-group select option {
  background: #0d0f08;
  color: var(--cream);
}
.drawer-footer {
  padding: 20px 24px;
  border-top: 1px solid rgba(231, 226, 216, 0.1);
  background: rgba(12, 14, 8, 0.95);
}
.cart-summary-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}
.cart-summary-total span {
  font-size: 11px;
  font-weight: 800;
  color: var(--muted);
  text-transform: uppercase;
}
.cart-summary-total strong {
  font-size: 20px;
  color: var(--orange);
  font-weight: 800;
}
.btn-checkout {
  width: 100%;
  border: none;
  cursor: pointer;
}

/* Full Menu Modal */
.menu-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.menu-modal.active {
  display: flex;
}
.menu-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 11, 6, 0.85);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.menu-modal-content {
  position: relative;
  z-index: 2;
  background: #11130a;
  border: 1px solid rgba(231, 226, 216, 0.15);
  border-radius: 16px;
  width: 820px;
  max-width: 100%;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.65);
  animation: modalScaleIn 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}
@keyframes modalScaleIn {
  from { opacity: 0; transform: scale(0.96) translateY(12px); }
  to { opacity: 1; transform: scale(1) translateY(0); }
}
.menu-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 24px;
  border-bottom: 1px solid rgba(231, 226, 216, 0.08);
}
.menu-modal-header h2 {
  font-family: "Playfair Display", Georgia, serif;
  font-size: 24px;
  margin: 0;
  letter-spacing: -0.02em;
}
.menu-modal-close {
  background: none;
  border: none;
  font-size: 30px;
  color: var(--muted);
  cursor: pointer;
  padding: 0;
  line-height: 1;
  transition: color 0.2s;
}
.menu-modal-close:hover {
  color: #fff;
}
.menu-modal-tabs {
  display: flex;
  gap: 8px;
  padding: 12px 24px;
  border-bottom: 1px solid rgba(231, 226, 216, 0.06);
  background: rgba(255, 255, 255, 0.01);
  overflow-x: auto;
  scrollbar-width: none;
}
.menu-modal-tabs::-webkit-scrollbar {
  display: none;
}
.tab-btn {
  background: transparent;
  border: 1px solid rgba(231, 226, 216, 0.15);
  border-radius: 99px;
  color: var(--muted);
  padding: 6px 16px;
  font-weight: 700;
  font-size: 11px;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}
.tab-btn:hover {
  color: var(--cream);
  border-color: rgba(231, 226, 216, 0.4);
}
.tab-btn.active {
  background: var(--orange);
  border-color: var(--orange);
  color: #fff;
  box-shadow: 0 4px 12px rgba(200, 90, 28, 0.2);
}
.menu-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 24px;
  scrollbar-width: thin;
}
.modal-menu-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.modal-drink-card {
  display: flex;
  gap: 14px;
  padding: 14px;
  background: linear-gradient(180deg, rgba(231, 226, 216, 0.08), rgba(231, 226, 216, 0.03));
  border: 1px solid rgba(231, 226, 216, 0.12);
  border-radius: 10px;
  transition: all 0.25s ease;
}
.modal-drink-card:hover {
  border-color: rgba(200, 90, 28, 0.35);
  transform: translateY(-2px);
  background: linear-gradient(180deg, rgba(231, 226, 216, 0.1), rgba(231, 226, 216, 0.04));
}
.modal-drink-img {
  width: 70px;
  height: 70px;
  border-radius: 6px;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(231, 226, 216, 0.08);
  overflow: hidden;
  flex-shrink: 0;
}
.modal-drink-img img {
  max-height: 64px;
  width: auto;
  filter: drop-shadow(0 6px 10px rgba(0,0,0,0.2));
}
.modal-drink-info {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.modal-drink-info h4 {
  font-family: "Playfair Display", Georgia, serif;
  font-size: 17px;
  margin: 0 0 3px;
  color: var(--cream);
}
.modal-drink-info p {
  margin: 0 0 6px;
  font-size: 11px;
  line-height: 1.4;
  color: var(--muted);
  flex: 1;
}
.modal-drink-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.modal-drink-footer strong {
  font-size: 13px;
  color: var(--cream);
}
.modal-drink-footer button {
  background: transparent;
  border: 1px solid rgba(231, 226, 216, 0.3);
  width: 24px;
  height: 24px;
  border-radius: 50%;
  color: var(--cream);
  font-size: 14px;
  font-weight: 700;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: all 0.2s;
}
.modal-drink-footer button:hover {
  background: var(--orange);
  border-color: var(--orange);
  color: #fff;
}

@keyframes wiggle {
  0% { transform: scale(1); }
  25% { transform: scale(1.15) rotate(-6deg); }
  50% { transform: scale(1.15) rotate(6deg); }
  100% { transform: scale(1); }
}
.wiggle {
  animation: wiggle 0.4s ease;
}

/* ============================================================
   RESPONSIVE - Tablet (<= 1050px)
   ============================================================ */
@media(max-width:1050px){
  /* Navbar */
  .topnav{
    grid-template-columns: 1fr auto;
    padding-left: 24px;
    padding-right: 24px;
  }
  .topnav nav{
    position: absolute;
    left: 16px; right: 16px;
    top: 78px;
    display: none;
    flex-direction: column;
    gap: 0;
    padding: 10px;
    background: rgba(10,12,7,.97);
    border: 1px solid rgba(231,226,216,.15);
    border-radius: 16px;
    box-shadow: 0 16px 40px rgba(0,0,0,.5);
    z-index: 999;
  }
  .topnav nav.open { display: flex; }
  .topnav nav a { padding: 13px 16px; border-radius: 10px; font-size: 14px; }
  .topnav nav a:hover { background: rgba(255,255,255,.06); }
  .reserve { display: none; }
  .menu-btn {
    display: grid;
    place-items: center;
    width: 44px; height: 44px;
    border-radius: 50%;
    border: 1px solid rgba(231,226,216,.2);
    background: rgba(255,255,255,.05);
    color: var(--cream);
    font-size: 20px;
    cursor: pointer;
  }

  /* Hero - switch to single column */
  .hero {
    grid-template-columns: 1fr;
    padding-top: 100px;
    padding-bottom: 0;
    min-height: auto;
    overflow: hidden;
  }
  .hero h1 {
    font-size: clamp(44px, 8vw, 68px);
    line-height: 1.1;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }
  .hero:after, .section-dots { display: none; }
  .hero-copy {
    order: 1;
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
  }
  .hero-visual {
    order: 2;
    justify-content: center;
    align-items: center;
    max-height: 340px;
    overflow: hidden;
  }
  .hero-visual img {
    width: min(420px, 90%);
    max-height: 320px;
    object-fit: contain;
  }

  /* Sections */
  .signature { grid-template-columns: 1fr; }
  .drink-grid { grid-template-columns: repeat(2, 1fr); }
  .vase-asset { display: none; }
  .ambience { grid-template-columns: 1fr; }
  .gallery-strip { grid-template-columns: repeat(2, 1fr); }
  .about { grid-template-columns: 1fr; padding-top: 40px; }
  .visit-panel { grid-template-columns: 1fr 1fr; }
  .chair { display: none; }
  .footer { grid-template-columns: 1fr 1fr; }

  /* Cart */
  .floating-cart {
    right: 50%;
    transform: translateX(50%) translateY(30px) scale(0.9);
    bottom: 16px;
  }
  .floating-cart.active {
    transform: translateX(50%) translateY(0) scale(1);
  }
  .floating-cart:hover {
    transform: translateX(50%) translateY(-2px) scale(1.02);
  }
}

/* ============================================================
   RESPONSIVE - Mobile (<= 680px)
   ============================================================ */
@media(max-width:680px){

  /* Prevent any horizontal overflow */
  html, body {
    overflow-x: hidden !important;
    max-width: 100vw !important;
    width: 100% !important;
    position: relative;
    margin: 0;
    padding: 0;
  }
  main, section, header, footer {
    max-width: 100% !important;
    width: 100% !important;
    overflow-x: hidden !important;
    box-sizing: border-box;
  }

  /* Navbar */
  .topnav {
    height: 62px;
    padding-left: 16px;
    padding-right: 16px;
    overflow: visible !important;
  }
  .topnav nav {
    left: 12px; right: 12px;
    top: 70px;
  }
  .logo { font-size: 22px; }

  /* Hero */
  .hero {
    grid-template-columns: 1fr;
    padding: 90px 20px 0;
    min-height: auto;
    gap: 0;
    overflow: hidden;
  }
  .hero:after, .section-dots { display: none; }
  .hero-copy {
    order: 1;
    text-align: center;
    padding-bottom: 16px;
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
  }
  .hero h1 {
    font-size: clamp(34px, 10vw, 52px);
    line-height: 1.1;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }
  .script { font-size: 28px; }
  .lead {
    font-size: 14px;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
    margin: 16px 0 20px;
    word-wrap: break-word;
    overflow-wrap: break-word;
    white-space: normal;
  }
  .hero-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .btn, .reserve {
    width: 100%;
    min-height: 48px;
    justify-content: center;
  }
  .scroll { justify-content: center; margin-top: 20px; }
  .hero-visual {
    order: 2;
    justify-content: center;
    align-items: flex-end;
    max-height: 260px;
    overflow: hidden;
    margin-top: -10px;
  }
  .hero-visual img {
    width: min(320px, 95%);
    max-height: 260px;
    object-fit: contain;
    margin: 0 auto;
  }

  /* Signature / Menu section */
  .signature {
    grid-template-columns: 1fr;
    padding: 36px 20px;
    gap: 24px;
  }
  .drink-grid { grid-template-columns: 1fr; gap: 16px; }
  .drink-card { display: flex; flex-direction: row; align-items: center; gap: 16px; padding: 16px; }
  .drink-img { width: 90px; height: 90px; flex-shrink: 0; }
  .drink-img img { width: 100%; height: 100%; object-fit: contain; }
  .vase-asset { display: none; }
  .num { display: none; }

  /* About */
  .about {
    grid-template-columns: 1fr;
    padding: 36px 20px;
    gap: 24px;
  }
  .about-img img { border-radius: 16px; max-height: 220px; object-fit: cover; width: 100%; }
  .features { grid-template-columns: 1fr; gap: 12px; }

  /* Ambience / Gallery */
  .ambience {
    grid-template-columns: 1fr;
    padding: 36px 20px;
    gap: 20px;
  }
  .gallery-strip { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .photo { height: 160px; border-radius: 12px; }
  .photo img { width: 100%; height: 100%; object-fit: cover; }

  /* Location / Visit */
  .visit { padding: 36px 20px; }
  .visit-panel { grid-template-columns: 1fr; gap: 0; }
  .visit-col {
    border-right: 0;
    border-bottom: 1px solid rgba(231,226,216,.12);
    padding: 18px 0;
  }
  .visit-col:last-of-type { border-bottom: 0; }
  .chair { display: none; }
  .map { margin-top: 20px; }
  .map iframe { height: 220px; }

  /* Footer */
  .footer {
    grid-template-columns: 1fr;
    padding: 32px 20px;
    gap: 28px;
    text-align: center;
  }
  .footer nav { justify-content: center; flex-wrap: wrap; gap: 12px; }

  /* Newsletter */
  .newsletter {
    padding: 0;
    margin-top: 12px;
    width: 100%;
  }
  .newsletter label {
    display: flex;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }
  .newsletter input {
    flex: 1;
    width: auto;
  }
  .newsletter button {
    width: 44px;
    flex-shrink: 0;
  }

  /* Cart Drawer */
  .cart-drawer { width: 100%; border-radius: 0; }
  .floating-cart {
    right: 50%;
    bottom: 18px;
    transform: translateX(50%) translateY(30px) scale(0.9);
  }
  .floating-cart.active {
    transform: translateX(50%) translateY(0) scale(1);
  }

  /* Full Menu Modal */
  .menu-modal { padding: 8px; }
  .menu-modal-content { max-height: 92vh; border-radius: 20px; }
  .menu-modal-header { padding: 16px 20px 12px; }
  .modal-menu-grid { grid-template-columns: 1fr; gap: 10px; }
  .modal-drink-card { flex-direction: row; align-items: center; }
  .modal-drink-img { width: 80px; height: 80px; flex-shrink: 0; }
  .menu-modal-tabs { gap: 6px; padding: 0 20px 14px; flex-wrap: wrap; }
  .tab-btn { font-size: 12px; padding: 6px 12px; }

  /* Toast */
  .toast-container {
    top: 12px;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    width: calc(100vw - 32px);
    max-width: 380px;
    align-items: center;
  }
  .toast-notification {
    transform: translateY(-20px);
    width: 100%;
    justify-content: center;
  }
  .toast-notification.show { transform: translateY(0); }

  /* Back to top */
  .back-to-top { bottom: 18px; right: 14px; width: 42px; height: 42px; font-size: 18px; }

  /* Lightbox */
  .lightbox-nav { width: 38px; height: 38px; font-size: 22px; }
  .lightbox-prev { left: 4px; }
  .lightbox-next { right: 4px; }
  .lightbox-close { top: 14px; right: 14px; width: 40px; height: 40px; font-size: 22px; }
  .lightbox-content { max-width: 96vw; }
  .lightbox-content img { max-height: 60vh; }
}

/* ============================================================
   SCROLLSPY – active nav link highlight
   ============================================================ */
.topnav nav a.active {
  color: #fff;
  position: relative;
}
.topnav nav a.active::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -4px;
  height: 2px;
  border-radius: 999px;
  background: var(--orange);
  animation: spyIn .25s ease;
}
@keyframes spyIn { from { transform: scaleX(0); } to { transform: scaleX(1); } }

/* ============================================================
   BACK-TO-TOP BUTTON
   ============================================================ */
.back-to-top {
  position: fixed;
  bottom: 32px;
  right: 28px;
  z-index: 200;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: none;
  background: linear-gradient(135deg, #d76422, var(--orange));
  color: #fff;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 8px 28px rgba(200,90,28,.45);
  display: grid;
  place-items: center;
  opacity: 0;
  transform: translateY(20px) scale(.85);
  transition: opacity .3s, transform .3s;
  pointer-events: none;
}
.back-to-top.visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.back-to-top:hover {
  transform: translateY(-3px) scale(1.06);
  box-shadow: 0 14px 38px rgba(200,90,28,.55);
}

/* ============================================================
   LIGHTBOX GALLERY MODAL
   ============================================================ */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}
.lightbox.active {
  opacity: 1;
  pointer-events: auto;
}
.lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(6,7,4,.92);
  backdrop-filter: blur(12px);
  cursor: zoom-out;
}
.lightbox-content {
  position: relative;
  z-index: 2;
  max-width: min(90vw, 900px);
  max-height: 82vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.lightbox-content img {
  max-width: 100%;
  max-height: 70vh;
  object-fit: contain;
  border-radius: 12px;
  box-shadow: 0 24px 64px rgba(0,0,0,.6);
  animation: lbIn .28s cubic-bezier(.22,.68,0,1.18);
}
@keyframes lbIn {
  from { transform: scale(.88); opacity: 0; }
  to   { transform: scale(1);   opacity: 1; }
}
.lightbox-caption {
  color: var(--cream);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.lightbox-caption strong { font-size: 16px; }
.lightbox-caption span   { font-size: 13px; color: var(--muted); }
.lightbox-close {
  position: fixed;
  top: 22px;
  right: 26px;
  z-index: 3;
  background: rgba(255,255,255,.12);
  border: none;
  color: #fff;
  font-size: 28px;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background .2s, transform .2s;
}
.lightbox-close:hover { background: rgba(255,255,255,.22); transform: rotate(90deg); }
.lightbox-nav {
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  background: rgba(255,255,255,.1);
  border: none;
  color: #fff;
  font-size: 36px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background .2s, transform .2s;
  user-select: none;
}
.lightbox-prev { left: 16px; }
.lightbox-next { right: 16px; }
.lightbox-nav:hover { background: rgba(200,90,28,.55); }
.lightbox-dots {
  position: relative;
  z-index: 2;
  display: flex;
  gap: 8px;
  margin-top: 4px;
}
.lb-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.35);
  cursor: pointer;
  transition: background .2s, transform .2s;
}
.lb-dot.active { background: var(--orange); transform: scale(1.35); }

/* Gallery photo hover – zoom cursor */
.gallery-strip .photo {
  cursor: zoom-in;
  transition: transform .25s ease, box-shadow .25s ease;
}
.gallery-strip .photo:hover {
  transform: scale(1.03);
  box-shadow: 0 12px 40px rgba(0,0,0,.5);
}

/* Responsive lightbox nav */
@media(max-width:640px) {
  .lightbox-nav { width: 40px; height: 40px; font-size: 26px; }
  .lightbox-prev { left: 6px; }
  .lightbox-next { right: 6px; }
  .back-to-top { bottom: 20px; right: 16px; }
}
