:root {
    --gold:    #C9A84C;
    --gold-lt: #E2C47A;
    --gold-dk: #A8872E;
    --crimson: #8B1020;
    --cream:   #FAF3E8;
    --dark:    #1A0808;
    --dark2:   #220B0B;
    --text:    #3A1810;
    --muted:   #7A5040;
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Jost',sans-serif; color:var(--text); background:var(--cream); line-height:1.7; }
h1,h2,h3,h4 { font-family:'Cormorant Garamond',serif; color:var(--dark); }
.container { width:90%; max-width:1200px; margin:0 auto; }

/* HEADER */
header { background:var(--crimson); position:fixed; width:100%; z-index:1000; border-bottom:2px solid var(--gold); }
.top-bar { display:flex; justify-content:space-between; align-items:center; padding:10px 0; position:relative; }
.logo-container { display:flex; align-items:center; gap:12px; text-decoration:none; }
.logo-img { height:54px; width:54px; object-fit:contain; border-radius:50%; }
.logo-name { font-family:'Jost',sans-serif; font-size:1.55rem; font-weight:600; color:var(--gold); letter-spacing:1px; line-height:1.1; display:inline-block; padding-bottom:3px; border-bottom:2px solid var(--gold); }
.logo-sub { font-size:0.58rem; letter-spacing:2.5px; text-transform:uppercase; color:rgba(201,168,76,0.6); display:block; margin-top:2px; }
nav { display:flex; align-items:center; gap:16px; }
nav ul { display:flex; list-style:none; align-items:center; gap:2px; }
nav ul li a { text-decoration:none; color:rgba(255,255,255,0.75); font-size:0.76rem; font-weight:500; text-transform:uppercase; letter-spacing:1.5px; padding:6px 10px; transition:color 0.2s; }
nav ul li a:hover, nav ul li a.active { color:var(--gold); }
.booking-btn { background:var(--gold) !important; color:var(--dark) !important; padding:9px 20px !important; border-radius:2px; font-weight:600 !important; }
.booking-btn:hover { background:var(--gold-lt) !important; }

/* LANG SWITCHER */
.lang-switcher { display:flex; gap:4px; }
.lang-btn { background:none; border:1px solid rgba(201,168,76,0.35); color:rgba(255,255,255,0.5); font-family:'Jost',sans-serif; font-size:0.68rem; font-weight:600; letter-spacing:1px; padding:4px 9px; border-radius:2px; cursor:pointer; transition:all 0.2s; text-transform:uppercase; }
.lang-btn.active, .lang-btn:hover { background:var(--gold); color:var(--dark); border-color:var(--gold); }

/* SECTION TITLE */
.section-title { text-align:center; padding:66px 0 44px; }
.section-eyebrow { font-size:0.66rem; letter-spacing:4px; text-transform:uppercase; color:var(--gold); margin-bottom:10px; display:block; }
.section-title h2 { font-size:clamp(1.9rem,4vw,2.9rem); font-weight:600; }
.section-title h2::after { content:''; display:block; width:42px; height:2px; background:var(--gold); margin:13px auto 0; }
.section-title p { color:var(--muted); max-width:490px; margin:13px auto 0; font-size:0.9rem; }

/* STATS BAR */
.stats-bar { background:var(--dark2); padding:24px 0; border-bottom:1px solid rgba(201,168,76,0.2); }
.stats-grid { display:flex; justify-content:center; gap:54px; flex-wrap:wrap; }
.stat-item { text-align:center; }
.stat-number { font-family:'Cormorant Garamond',serif; font-size:2rem; color:var(--gold); font-weight:700; line-height:1; }
.stat-item.stat-takeaway .stat-label { max-width:140px; line-height:1.3; }
.stat-label { font-size:0.62rem; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.38); margin-top:3px; }

/* MENU CARD GRID (INDEX) */
.menu-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:24px; margin-bottom:68px; }
.menu-card { background:white; border-radius:3px; overflow:hidden; box-shadow:0 4px 20px rgba(26,8,8,0.07); transition:transform 0.3s,box-shadow 0.3s; border-bottom:3px solid transparent; }
.menu-card:hover { transform:translateY(-5px); box-shadow:0 12px 34px rgba(26,8,8,0.13); border-bottom-color:var(--gold); }
.card-img-wrap { overflow:hidden; height:240px; }
.menu-card-img { width:100%; height:240px; object-fit:cover; display:block; transition:transform 0.5s; }
.menu-card:hover .menu-card-img { transform:scale(1.04); }
.menu-info { padding:20px 22px 22px; }
.menu-tag { font-size:0.59rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold-dk); font-weight:600; margin-bottom:5px; display:block; }
.menu-info h3 { font-size:1.42rem; color:var(--dark); margin-bottom:6px; }
.menu-info p { font-size:0.84rem; color:var(--muted); margin-bottom:12px; line-height:1.6; }
.price { color:var(--crimson); font-weight:600; font-size:1.15rem; font-family:'Cormorant Garamond',serif; }

/* SPECIALS STRIP */
.specials-row { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(201,168,76,0.15); border:1px solid rgba(201,168,76,0.15); }
.special-item { background:white; padding:32px 24px; text-align:center; transition:background 0.3s; }
.special-item:hover { background:#fdf4e5; }
.special-icon { font-size:1.7rem; margin-bottom:11px; display:block; }
.special-item h4 { font-size:1.08rem; margin-bottom:6px; }
.special-item p { font-size:0.79rem; color:var(--muted); }

/* ABOUT */
.about-strip { background:var(--crimson); padding:80px 0; position:relative; overflow:hidden; }
.about-strip::before { content:'jimbu'; position:absolute; right:-14px; top:50%; transform:translateY(-50%); font-family:'Jost',sans-serif; font-size:13rem; font-weight:600; color:rgba(201,168,76,0.07); pointer-events:none; line-height:1; }
.about-inner { display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.about-text h2 { font-size:clamp(1.8rem,3vw,2.6rem); color:var(--gold-lt); margin-bottom:18px; font-weight:600; }
.about-text h2 em { color:white; font-style:italic; }
.about-text p { color:rgba(255,255,255,0.65); font-size:0.9rem; margin-bottom:13px; }
.features { display:flex; flex-wrap:wrap; gap:16px; margin-top:26px; }
.feature { display:flex; align-items:center; gap:8px; color:rgba(255,255,255,0.75); font-size:0.8rem; }
.feature i { color:var(--gold); }
.about-img { border-radius:3px; overflow:hidden; box-shadow:0 20px 50px rgba(0,0,0,0.5); position:relative; }
.about-img img { width:100%; height:420px; object-fit:cover; display:block; }
.about-img::after { content:''; position:absolute; inset:0; border:1px solid rgba(201,168,76,0.3); border-radius:3px; pointer-events:none; }

/* REVIEWS */
.reviews { background:#fdf6ed; padding:78px 0; }
.reviews-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:20px; margin-top:8px; }
.review-card { background:white; border-radius:3px; padding:24px; border-left:3px solid var(--gold); box-shadow:0 2px 12px rgba(26,8,8,0.05); }
.stars { color:var(--gold); margin-bottom:9px; font-size:0.8rem; }
.review-text { font-size:0.87rem; color:var(--text); font-style:italic; margin-bottom:13px; line-height:1.7; }
.reviewer { font-size:0.73rem; font-weight:600; color:var(--muted); text-transform:uppercase; letter-spacing:1px; }
.reviewer span { color:var(--crimson); }

/* FOOTER */
footer { background:var(--crimson); color:white; padding:66px 0 22px; border-top:2px solid var(--gold); }
.footer-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); gap:42px; margin-bottom:44px; }
.footer-logo-wrap { display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.footer-logo-img { height:48px; width:48px; object-fit:contain; border-radius:50%; }
.footer-logo-name { font-family:'Jost',sans-serif; font-size:1.45rem; font-weight:600; color:var(--gold); letter-spacing:1px; display:inline-block; padding-bottom:3px; border-bottom:2px solid var(--gold); line-height:1; }
.footer-tagline { font-size:0.62rem; letter-spacing:3px; color:rgba(201,168,76,0.5); text-transform:uppercase; margin-bottom:16px; display:block; }
.footer-section h3 { color:var(--gold); margin-bottom:15px; font-size:1.12rem; font-weight:600; }
.footer-section p { font-size:0.83rem; color:rgba(255,255,255,0.55); margin-bottom:8px; display:flex; align-items:flex-start; gap:9px; }
.footer-section p i { color:var(--gold); margin-top:3px; flex-shrink:0; }
.footer-section a { color:rgba(255,255,255,0.55); text-decoration:none; transition:color 0.3s; }
.footer-section a:hover { color:var(--gold); }
.hours-row { display:flex; justify-content:space-between; font-size:0.8rem; color:rgba(255,255,255,0.55); padding:5px 0; border-bottom:1px solid rgba(255,255,255,0.07); }
.hours-row:last-child { border-bottom:none; }
.hours-row .day { font-weight:500; color:rgba(255,255,255,0.82); }
.closed { color:rgba(255,100,100,0.8) !important; }
.social-icons { display:flex; gap:11px; margin-top:16px; }
.social-icons a { color:rgba(255,255,255,0.45); font-size:1rem; width:36px; height:36px; border:1px solid rgba(201,168,76,0.25); border-radius:50%; display:flex; align-items:center; justify-content:center; transition:color 0.3s,border-color 0.3s,transform 0.2s; }
.social-icons a:hover { color:var(--gold); border-color:var(--gold); transform:translateY(-2px); }
.newsletter-form { display:flex; margin-top:10px; }
.newsletter-form input { flex:1; padding:9px 12px; background:rgba(255,255,255,0.08); border:1px solid rgba(201,168,76,0.2); color:white; font-family:'Jost',sans-serif; font-size:0.8rem; outline:none; border-radius:2px 0 0 2px; }
.newsletter-form input::placeholder { color:rgba(255,255,255,0.25); }
.newsletter-form button { padding:9px 16px; background:var(--gold); color:var(--dark); border:none; cursor:pointer; font-family:'Jost',sans-serif; font-size:0.76rem; font-weight:700; letter-spacing:1px; transition:background 0.3s; border-radius:0 2px 2px 0; }
.newsletter-form button:hover { background:var(--gold-lt); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.08); padding-top:20px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px; }
.footer-bottom p { font-size:0.73rem; color:rgba(255,255,255,0.26); }
.footer-links { display:flex; gap:18px; }
.footer-links a { font-size:0.7rem; color:rgba(255,255,255,0.28); text-decoration:none; transition:color 0.3s; }
.footer-links a:hover { color:var(--gold); }

/* HERO (INDEX) */
.hero { height:100vh; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; text-align:center; color:white; }
.slide { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transition:opacity 1.4s ease; }
.slide.active { opacity:1; }
.slide::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom,rgba(26,8,8,0.52) 0%,rgba(26,8,8,0.3) 45%,rgba(26,8,8,0.72) 100%); }
.slide-dots { position:absolute; bottom:88px; right:32px; z-index:5; display:flex; gap:8px; }
.slide-dot { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,0.3); border:none; cursor:pointer; transition:background 0.3s,transform 0.3s; padding:0; }
.slide-dot.active { background:var(--gold); transform:scale(1.35); }
.hero-content { position:relative; z-index:2; max-width:780px; padding:80px 20px 0; }
.hero-eyebrow { font-size:0.7rem; letter-spacing:5px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; opacity:0.9; display:block; }
.hero h1 { font-family:'Jost',sans-serif; font-size:clamp(3.5rem,9vw,6.5rem); font-weight:600; color:white; letter-spacing:2px; line-height:1; margin-bottom:4px; }
.hero-underline { width:clamp(120px,30vw,220px); height:2px; background:var(--gold); margin:6px auto 14px; }
.hero-sub { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:clamp(1rem,2.5vw,1.45rem); color:rgba(255,255,255,0.7); margin-bottom:26px; letter-spacing:1px; display:block; }
.hero-desc { font-size:0.95rem; color:rgba(255,255,255,0.78); max-width:460px; margin:0 auto 34px; font-weight:300; display:block; }
.hero-buttons { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.cta-primary { background:var(--gold); color:var(--dark); padding:13px 36px; text-decoration:none; font-size:0.76rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; border-radius:2px; transition:background 0.3s,transform 0.2s; }
.cta-primary:hover { background:var(--gold-lt); transform:translateY(-2px); }
.cta-outline { border:1px solid rgba(255,255,255,0.4); color:white; padding:13px 36px; text-decoration:none; font-size:0.76rem; font-weight:500; text-transform:uppercase; letter-spacing:2px; border-radius:2px; transition:border-color 0.3s,background 0.3s; }
.cta-outline:hover { border-color:var(--gold); background:rgba(201,168,76,0.12); }
.scroll-hint { position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:5; display:flex; flex-direction:column; align-items:center; gap:6px; color:rgba(255,255,255,0.35); font-size:0.6rem; letter-spacing:3px; text-transform:uppercase; }
.scroll-hint::after { content:''; width:1px; height:34px; background:linear-gradient(to bottom,rgba(255,255,255,0.35),transparent); animation:pulse 1.9s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:.35} 50%{opacity:.9} }

/* CARTE HERO & MENU (CARTE) */
.carte-hero { height:38vh; min-height:260px; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; text-align:center; color:white; padding-top:80px; }
.carte-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; } /* Bg-image is inline in HTML for Carte */
.carte-hero::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom,rgba(26,8,8,0.6) 0%,rgba(26,8,8,0.4) 100%); }
.carte-hero-content { position:relative; z-index:2; }
.carte-nav-container { background:white; border-bottom:1px solid rgba(201,168,76,0.2); position:sticky; top:78px; z-index:900; overflow-x:auto; }
.carte-nav { display:flex; justify-content:center; list-style:none; padding:15px 0; min-width:max-content; width:100%; }
.carte-nav li { margin:0 15px; }
.carte-nav li a { text-decoration:none; color:var(--muted); font-size:0.75rem; font-weight:600; text-transform:uppercase; letter-spacing:1.5px; transition:color 0.2s; }
.carte-nav li a:hover { color:var(--gold); }
.menu-section { padding:60px 0 20px; }
.menu-section-header { text-align:center; margin-bottom:40px; position:relative; }
.menu-section-header h2 { font-size:2.2rem; display:inline-block; padding:0 30px; position:relative; }
.menu-section-header h2::before, .menu-section-header h2::after { content:''; position:absolute; top:50%; width:60px; height:1px; background:var(--gold); opacity:0.5; }
.menu-section-header h2::before { right:100%; }
.menu-section-header h2::after { left:100%; }
.menu-section-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(400px,1fr)); gap:30px 60px; }
@media(max-width:768px){ .menu-section-grid{grid-template-columns:1fr} }
.menu-item { display:flex; flex-direction:column; gap:6px; border-bottom:1px dashed rgba(201,168,76,0.2); padding-bottom:15px; }
.item-main { display:flex; justify-content:space-between; align-items:flex-end; gap:15px; }
.item-title { font-family:'Cormorant Garamond',serif; font-size:1.35rem; font-weight:600; color:var(--dark); line-height:1.2; }
.item-price { font-family:'Cormorant Garamond',serif; font-size:1.25rem; font-weight:700; color:var(--crimson); flex-shrink:0; }
.item-desc { font-size:0.85rem; color:var(--muted); font-style:italic; line-height:1.4; }
.wine-item { display:flex; justify-content:space-between; align-items:center; padding:10px 0; border-bottom:1px solid rgba(201,168,76,0.1); }
.wine-info { display:flex; flex-direction:column; }
.wine-name { font-family:'Cormorant Garamond',serif; font-size:1.2rem; font-weight:600; color:var(--dark); }
.wine-region { font-size:0.75rem; color:var(--muted); text-transform:uppercase; letter-spacing:1px; }
.wine-prices { display:flex; gap:0; flex-shrink:0; }
.wine-prices span { width:60px; text-align:right; font-family:'Cormorant Garamond',serif; font-size:1rem; color:var(--crimson); font-weight:700; }
@media(max-width:600px){ .wine-sizes span,.wine-prices span{width:44px;font-size:0.85rem} }
@media(max-width:600px) { .item { flex-direction:column; gap:4px; } .item-price { align-self:flex-end; } }

/* FLOATING TAKEAWAY BANNER (SHARED) */
.takeaway-banner {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 999;
  background: var(--crimson);
  border: 1px solid var(--gold);
  color: var(--gold);
  font-family: 'Jost', sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 1px;
  padding: 10px 18px;
  border-radius: 2px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.35);
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
  display: flex;
  align-items: center;
  gap: 8px;
  animation: bannerIn 0.5s ease 1.5s both;
}
.takeaway-banner:hover { background: var(--crimson-lt, #a8192a); transform: translateY(-2px); }
.takeaway-banner-close {
  background: none; border: none; color: rgba(201,168,76,0.5);
  cursor: pointer; font-size: 0.9rem; padding: 0 0 0 6px; line-height: 1;
  transition: color 0.2s;
}
.takeaway-banner-close:hover { color: var(--gold); }
@keyframes bannerIn { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:translateY(0); } }
@media(max-width:480px){ .takeaway-banner { bottom:16px; right:16px; font-size:0.7rem; } }

/* RESPONSIVE (GLOBAL) */
@media(max-width:900px){ .about-inner{grid-template-columns:1fr} .about-strip::before{display:none} .specials-row{grid-template-columns:repeat(2,1fr)} }
@media(max-width:768px){ 
  .top-bar{flex-direction:column;align-items:flex-start;gap:15px;padding-left:5%} 
  .lang-switcher{position:absolute;top:10px;right:5%;z-index:10} 
  nav{width:100%;flex-direction:column;gap:8px} 
  nav ul{flex-wrap:nowrap;justify-content:center;gap:1px;width:100%;overflow-x:hidden} 
  nav ul li a{padding:6px 6px;font-size:0.72rem;letter-spacing:1px}
  .booking-btn{padding:8px 14px !important;font-size:0.7rem !important}
}
@media(max-width:480px){ .specials-row{grid-template-columns:1fr} }


/* ========== CARTE PAGE SPECIFIC ========== */
.carte-hero { height:38vh; min-height:260px; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; text-align:center; color:white; padding-top:80px; }
.carte-hero-bg { position:absolute; inset:0; background-image:url('images/carte-hero-bg.jpg'); background-size:cover; background-position:center; }
.carte-hero-bg::after { content:''; position:absolute; inset:0; background:rgba(26,8,8,0.72); }
.carte-hero-content { position:relative; z-index:2; }
.carte-hero-eyebrow { font-size:0.68rem; letter-spacing:5px; text-transform:uppercase; color:var(--gold); margin-bottom:12px; display:block; }
.carte-hero h1 { font-family:'Cormorant Garamond',serif; font-size:clamp(2.5rem,6vw,4.5rem); font-weight:600; color:white; line-height:1; margin-bottom:8px; }
.carte-hero-line { width:50px; height:2px; background:var(--gold); margin:0 auto; }

/* MENU BODY */
.carte-body { max-width:860px; margin:0 auto; padding:60px 5% 80px; }
.carte-note { text-align:center; font-size:0.8rem; color:var(--muted); font-style:italic; margin-bottom:56px; padding:14px 24px; border:1px solid rgba(201,168,76,0.25); border-radius:2px; background:rgba(201,168,76,0.04); }

/* CATEGORY */
.cat-block { margin-bottom:48px; }
.cat-header { display:flex; align-items:center; gap:16px; margin-bottom:20px; }
.cat-title { font-family:'Cormorant Garamond',serif; font-size:1.7rem; font-weight:600; color:var(--crimson); white-space:nowrap; }
.cat-rule { flex:1; height:1px; background:linear-gradient(to right, rgba(139,16,32,0.3), transparent); }

/* ITEMS */
.item { display:flex; justify-content:space-between; align-items:baseline; gap:16px; padding:10px 0; border-bottom:1px solid rgba(201,168,76,0.12); }
.item:last-child { border-bottom:none; }
.item-left { flex:1; }
.item-name { font-family:'Cormorant Garamond',serif; font-size:1.15rem; color:var(--dark); font-weight:600; display:block; margin-bottom:2px; }
.item-desc { font-size:0.8rem; color:var(--muted); line-height:1.5; display:block; }
.item-price { font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:700; color:var(--crimson); white-space:nowrap; flex-shrink:0; }
.spicy { font-size:0.7rem; color:var(--crimson); font-family:'Jost',sans-serif; margin-left:6px; vertical-align:middle; font-weight:500; font-style:normal; }

/* SUBCATEGORY */
.subcat { margin-bottom:24px; }
.subcat-title { font-size:0.65rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold-dk); font-weight:600; margin-bottom:8px; padding-left:2px; }

/* FORMULES */
.formules-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:2px; background:rgba(201,168,76,0.15); margin-top:8px; }
.formule-card { background:var(--dark); padding:28px 22px; }
.formule-name { font-family:'Cormorant Garamond',serif; font-size:1.4rem; color:var(--gold); font-weight:600; margin-bottom:2px; }
.formule-price { font-family:'Cormorant Garamond',serif; font-size:2.2rem; color:white; font-weight:700; line-height:1; margin-bottom:16px; }
.formule-price sup { font-size:1rem; vertical-align:top; margin-top:5px; }
.formule-tag { font-size:0.58rem; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.3); display:block; margin-bottom:14px; }
.formule-section { margin-bottom:12px; }
.formule-sec-title { font-size:0.58rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-weight:600; margin-bottom:4px; border-bottom:1px solid rgba(201,168,76,0.15); padding-bottom:3px; }
.formule-item { font-size:0.76rem; color:rgba(255,255,255,0.55); padding:1px 0; }
.formule-item::before { content:'—'; color:var(--gold-dk); margin-right:5px; font-size:0.65rem; }
.formule-note { font-size:0.7rem; color:rgba(255,255,255,0.28); margin-top:14px; font-style:italic; }

.wine-size-header { display:flex; justify-content:flex-end; margin-bottom:4px; }
.wine-sizes { display:flex; gap:0; }
.wine-sizes span { width:60px; text-align:right; font-size:0.62rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold-dk); font-weight:600; }
.wine-item .item-price { display:none; }
.wine-prices { display:flex; gap:0; flex-shrink:0; }
.wine-prices span { width:60px; text-align:right; font-family:'Cormorant Garamond',serif; font-size:1rem; color:var(--crimson); font-weight:700; }

@media(max-width:600px) {
    .wine-sizes span, .wine-prices span { width:44px; font-size:0.85rem; }
    .item { flex-direction:column; gap:4px; }
    .item-price { align-self:flex-end; }
}

/* CONTACT PAGE */
.contact-hero { padding:140px 0 60px; text-align:center; position:relative; overflow:hidden; }
.contact-hero::before { content:''; position:absolute; top:0;left:0;right:0;bottom:0; background:linear-gradient(rgba(17,14,14,0.6), rgba(17,14,14,0.9)), url('images/restaurant-interior.jpg') center/cover; z-index:-1; }
.contact-hero h1 { font-family:'Cormorant Garamond',serif; font-size:4.5rem; color:var(--cream); letter-spacing:-1px; text-shadow:2px 2px 20px rgba(0,0,0,0.5); }
.contact-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:24px; margin:40px 0; }
.contact-card { background:white; border-radius:3px; padding:30px; text-align:center; display:flex; flex-direction:column; align-items:center; gap:12px; box-shadow:0 4px 20px rgba(26,8,8,0.05); transition:transform 0.3s, box-shadow 0.3s; border-bottom:3px solid transparent; }
.contact-card:hover { transform:translateY(-5px); box-shadow:0 12px 34px rgba(26,8,8,0.1); border-bottom-color:var(--gold); }
.contact-card i { font-size:2rem; color:var(--gold); margin-bottom:10px; }
.contact-card h3 { font-family:'Cormorant Garamond',serif; font-size:1.6rem; color:var(--dark); }
.contact-card p, .contact-card a { font-size:0.95rem; color:var(--muted); text-decoration:none; transition:0.3s; }
.contact-card a:hover { color:var(--crimson); }
.contact-map-section { margin-bottom:80px; }
.contact-map-container { display:flex; flex-wrap:wrap; gap:0; background:white; border-radius:3px; box-shadow:0 4px 20px rgba(26,8,8,0.05); overflow:hidden; }
.contact-map { flex:1; min-width:300px; min-height:400px; }
.contact-map iframe { width:100%; height:100%; border:none; }
.contact-hours { flex:1; min-width:300px; padding:50px; display:flex; flex-direction:column; justify-content:center; }
.contact-hours h3 { font-family:'Cormorant Garamond',serif; font-size:2rem; color:var(--dark); margin-bottom:20px; }
.contact-hours .hours-row { color:var(--muted); border-bottom:1px dashed rgba(201,168,76,0.3); padding:12px 0; font-size:0.9rem; }
.contact-hours .hours-row .day { color:var(--dark); font-weight:600; }
.contact-form-section { background:#fdf6ed; padding:78px 0; }
.contact-form { max-width:700px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.form-group.full { grid-column:1 / -1; }
.form-group { position:relative; }
.form-control { width:100%; padding:22px 16px 12px; background:white; border:1px solid rgba(201,168,76,0.3); border-radius:3px; color:var(--text); font-family:'Jost',sans-serif; font-size:1rem; outline:none; transition:0.3s; box-sizing:border-box; box-shadow:inset 0 1px 4px rgba(0,0,0,0.02); }
.form-control:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,76,0.15); }
.form-label { position:absolute; top:50%; left:16px; transform:translateY(-50%); font-size:0.95rem; color:var(--muted); pointer-events:none; transition:0.3s; }
textarea.form-control { resize:vertical; min-height:160px; }
textarea + .form-label { top:22px; transform:none; }
.form-control:focus + .form-label, .form-control:not(:placeholder-shown) + .form-label { top:6px; transform:none; font-size:0.75rem; color:var(--crimson); font-weight:600; }
.btn-submit { grid-column:1 / -1; padding:18px; background:var(--gold); color:var(--dark); font-family:'Jost',sans-serif; font-weight:600; font-size:0.9rem; text-transform:uppercase; letter-spacing:2px; border:none; cursor:pointer; border-radius:3px; transition:all 0.3s ease; }
.btn-submit:hover { background:var(--gold-dk); transform:translateY(-2px); box-shadow:0 10px 20px rgba(0,0,0,0.15); }
@media(max-width:600px) { .contact-form { grid-template-columns:1fr; } .contact-hero h1{font-size:3rem;} }
