/* ===================================================================
   Maria's Bar & Grill — stylesheet
   Palette: black / dark wood, white, red, gold accents
   =================================================================== */
:root{
  --black:#0e0c0c;
  --panel:#161313;
  --panel-2:#1e1a1a;
  --red:#c41e22;
  --red-bright:#e2262b;
  --gold:#f0be46;
  --white:#f4f2ef;
  --muted:#b7aea6;
  --line:rgba(196,30,34,.55);
  --shadow:0 12px 30px rgba(0,0,0,.55);
  --header-h:96px;
  --wood:linear-gradient(180deg,#1b1717 0%,#0e0c0c 100%);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:var(--header-h)}
body{
  font-family:'Montserrat',system-ui,sans-serif;
  background:var(--black);
  color:var(--white);
  line-height:1.6;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1180px,92%);margin-inline:auto}
.gold{color:var(--gold)}
.slash{color:var(--red);font-weight:400}
.section{padding:70px 0;position:relative}
.section::after{content:"";display:block;height:3px;width:100%;
  background:linear-gradient(90deg,transparent,var(--red),transparent);
  position:absolute;left:0;bottom:0}

/* headings */
.section-title{font-family:'Anton',sans-serif;font-weight:400;letter-spacing:.5px;
  text-transform:uppercase;line-height:1.05;font-size:clamp(1.6rem,3.4vw,2.6rem)}
.section-title.big{font-size:clamp(2rem,5vw,3.4rem)}
.section-title .es{color:var(--muted);font-size:.7em}
.center{text-align:center}

/* ===================== BUTTONS ===================== */
.btn{display:inline-flex;align-items:center;gap:.5em;justify-content:center;
  font-family:'Bebas Neue',sans-serif;letter-spacing:1.5px;font-size:1.15rem;
  padding:.7em 1.6em;border-radius:6px;cursor:pointer;border:2px solid transparent;
  transition:transform .15s ease,background .2s ease,color .2s ease;text-transform:uppercase}
.btn:hover{transform:translateY(-2px)}
.btn-order{background:var(--red);color:#fff;box-shadow:0 6px 16px rgba(196,30,34,.4)}
.btn-order:hover{background:var(--red-bright)}
.btn-outline{background:rgba(0,0,0,.35);color:#fff;border-color:#fff}
.btn-outline:hover{background:#fff;color:var(--black)}
.btn-block{display:flex;width:100%}
.center-btn{text-align:center;margin-top:34px}

/* ===================== HEADER ===================== */
.site-header{position:fixed;inset:0 0 auto 0;z-index:100;height:var(--header-h);
  background:rgba(10,9,9,.92);backdrop-filter:blur(6px);
  border-bottom:2px solid var(--red);transition:height .25s ease,background .25s ease}
.site-header.scrolled{background:rgba(6,5,5,.98)}
.site-header.scrolled .header-logo img{height:52px}
.header-inner{height:100%;position:relative;display:flex;align-items:center;
  width:min(1320px,96%);margin-inline:auto;gap:18px}
.header-logo{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}
.header-logo img{height:60px;width:auto}
.header-nav ul{display:flex;align-items:center;gap:20px;list-style:none}
.nav-right{margin-left:auto}
.nav-link{font-family:'Bebas Neue',sans-serif;font-size:1.12rem;letter-spacing:1px;
  text-transform:uppercase;color:var(--white);position:relative;padding:6px 2px;white-space:nowrap}
.nav-link::after{content:"";position:absolute;left:0;bottom:-2px;height:3px;width:0;
  background:var(--red);transition:width .25s ease}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-link:hover{color:var(--gold)}

.header-actions{display:flex;align-items:center;gap:16px}
.header-social{display:flex;gap:10px;font-size:1.05rem}
.header-social a{width:34px;height:34px;display:grid;place-items:center;border-radius:50%;
  border:1px solid rgba(255,255,255,.25);transition:.2s}
.header-social a:hover{background:var(--red);border-color:var(--red)}
.header-actions .btn-order{font-size:1rem;padding:.5em 1.1em}

.hamburger{display:none;background:none;border:0;cursor:pointer;margin-left:auto}
.hamburger span{display:block;width:28px;height:3px;background:#fff;margin:5px 0;border-radius:2px;transition:.3s}
.hamburger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* mobile drawer */
.mobile-menu{position:fixed;top:var(--header-h);left:0;right:0;z-index:99;
  background:rgba(10,9,9,.98);border-bottom:2px solid var(--red);
  transform:translateY(-140%);transition:transform .35s ease;padding:20px 6%}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu ul{list-style:none;display:flex;flex-direction:column;gap:4px}
.mobile-menu .nav-link{display:block;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08);font-size:1.3rem}
.mobile-social{display:flex;gap:18px;font-size:1.3rem;margin:16px 0}

/* ===================== HERO ===================== */
.hero{min-height:100vh;background-size:cover;background-position:center;
  display:grid;place-items:center;text-align:center;position:relative;padding-top:var(--header-h)}
.hero-overlay{position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(0,0,0,.35),rgba(0,0,0,.82))}
.hero-content{position:relative;z-index:2;padding:20px;width:min(900px,92%)}
.hero-logo{width:min(560px,80%);margin:0 auto 10px;filter:drop-shadow(0 8px 24px rgba(0,0,0,.7))}
.hero-tagline{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.4rem,4vw,2.6rem);
  letter-spacing:2px;text-transform:uppercase;margin:6px 0 28px}
.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ===================== ABOUT ===================== */
.about{background:var(--wood);padding:60px 0;border-bottom:2px solid var(--red)}
.about-grid{display:grid;grid-template-columns:120px 1fr 260px;gap:34px;align-items:center}
.about-mark img{width:110px;opacity:.95}
.about-text p{color:var(--muted);max-width:60ch}
.about-text em{color:var(--white);font-style:italic}
.about-history{border-left:2px solid var(--red);padding-left:24px}
.about-history h3{font-family:'Anton',sans-serif;color:var(--gold);font-size:1.8rem;
  text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.hist-line{font-weight:600}
.hist-sub{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:1px}

/* ===================== SECTION HEAD ===================== */
.section-head.split{display:flex;justify-content:space-between;align-items:flex-end;
  gap:20px;flex-wrap:wrap;margin-bottom:34px;
  border-bottom:2px solid var(--line);padding-bottom:16px}
.schedule{text-align:right}
.sched-days{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:1px}
.sched-time{color:var(--muted)}
.sched-price{font-family:'Anton',sans-serif;font-size:2rem}
.sched-note{text-transform:uppercase;font-size:.8rem;letter-spacing:1px;color:var(--muted)}

/* ===================== CARDS ===================== */
.cards{display:grid;gap:24px}
.two-cards{grid-template-columns:1fr 1fr}
.four-cards{grid-template-columns:repeat(4,1fr)}
.dish-card{background:var(--panel);border:2px solid var(--red);border-radius:12px;
  overflow:hidden;box-shadow:var(--shadow);text-align:left;color:var(--white);
  width:100%;font:inherit;display:flex;flex-direction:column}
.dish-img{aspect-ratio:4/3;background-size:cover;background-position:center;position:relative}
.dish-body{padding:16px 18px}
.dish-topline{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.dish-topline h3{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;letter-spacing:.5px;line-height:1.1}
.price{font-family:'Anton',sans-serif;color:var(--gold);font-size:1.4rem;white-space:nowrap}
.dish-body p{color:var(--muted);font-size:.95rem;margin-top:6px}
.dish-name{font-family:'Bebas Neue',sans-serif;font-size:1.35rem;letter-spacing:1px;
  text-transform:uppercase;text-align:center;padding:12px 10px;background:var(--panel-2)}

/* clickable cards */
.dish-card.clickable{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}
.dish-card.clickable:hover{transform:translateY(-6px);box-shadow:0 18px 36px rgba(196,30,34,.35)}
.view-badge{position:absolute;left:10px;bottom:10px;background:rgba(196,30,34,.92);
  color:#fff;font-family:'Bebas Neue',sans-serif;letter-spacing:1px;font-size:.9rem;
  padding:5px 10px;border-radius:5px;display:inline-flex;gap:6px;align-items:center}
.dish-body.alt h3{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:.5px;margin-bottom:4px}
.dish-body.alt .mini{font-size:.9rem}
.price-big{font-family:'Anton',sans-serif;font-size:2rem;margin:2px 0}

/* ===================== SLIDER ===================== */
.slider{display:flex;align-items:center;gap:8px}
.slider-viewport{overflow:hidden;flex:1}
.slider-track{display:flex;list-style:none;transition:transform .45s ease}
.slide{flex:0 0 var(--slide-w,33.333%);padding:0 12px}
.slider-arrow{flex:0 0 auto;width:48px;height:48px;border-radius:50%;border:0;cursor:pointer;
  background:var(--red);color:#fff;font-size:1.4rem;display:grid;place-items:center;
  box-shadow:var(--shadow);transition:.2s}
.slider-arrow:hover{background:var(--red-bright);transform:scale(1.08)}
.slider-arrow:disabled{opacity:.35;cursor:default;transform:none}

/* ===================== HAPPY HOUR BANNER ===================== */
.hh-banner{position:relative;min-height:60vh;background-size:cover;
  background-position:center;background-attachment:fixed;display:grid;place-items:center;text-align:center}
.hh-banner-overlay{position:absolute;inset:0;background:rgba(0,0,0,.62)}
.hh-banner-content{position:relative;z-index:2;padding:30px}
.hh-join{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.4rem,3vw,2rem);letter-spacing:3px;text-transform:uppercase}
.hh-title{font-family:'Anton',sans-serif;font-size:clamp(3rem,10vw,7rem);text-transform:uppercase;line-height:.95}
.hh-title.neon{color:#fff;
  text-shadow:0 0 6px var(--gold),0 0 18px var(--red),0 0 34px var(--red)}
.hh-sub{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.2rem,2.6vw,1.8rem);letter-spacing:2px;color:var(--gold)}

/* ===================== FRIDAY BANNER ===================== */
.friday-banner{position:relative;background-size:cover;background-position:center;padding:80px 0;text-align:center}
.friday-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.7),rgba(0,0,0,.85))}
.friday-content{position:relative;z-index:2}
.friday-kicker{font-family:'Bebas Neue',sans-serif;font-size:clamp(1.3rem,3vw,2rem);letter-spacing:3px;text-transform:uppercase}
.friday-title{font-family:'Anton',sans-serif;font-size:clamp(2.4rem,7vw,5rem);text-transform:uppercase;margin:6px 0 22px}
.friday-info{display:flex;gap:26px;justify-content:center;flex-wrap:wrap;
  font-family:'Bebas Neue',sans-serif;font-size:1.4rem;letter-spacing:1px;margin-bottom:20px}
.friday-info .fi{border-left:3px solid var(--red);padding-left:14px}
.friday-info .fi:first-child{border-left:0;padding-left:0}
.friday-cta{font-family:'Anton',sans-serif;color:var(--gold);font-size:clamp(1.4rem,3vw,2rem);text-transform:uppercase}
.friday-sub{color:var(--muted)}

/* ===================== SPECIALTIES ===================== */
.specialties{background:var(--wood)}
.specialties .section-title{margin-bottom:34px}
.spec-card{background:var(--panel);border:2px solid var(--red);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.spec-card .dish-img{aspect-ratio:1/1}

/* ===================== FOOTER ===================== */
.footer{background:#0a0909;border-top:3px solid var(--red);padding-top:54px}
.footer-grid{display:grid;grid-template-columns:1.1fr .9fr 1.1fr 1.2fr;gap:34px}
.footer-col h4{font-family:'Anton',sans-serif;text-transform:uppercase;letter-spacing:1px;
  color:#fff;font-size:1.3rem;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--red);display:inline-block}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.contact-list li,.social-list li{display:flex;gap:10px;align-items:center;color:var(--muted)}
.contact-list i,.social-list i{color:var(--red);width:18px;text-align:center}
.social-list a:hover{color:var(--gold)}
.hours-list li{display:flex;justify-content:space-between;gap:16px;color:var(--muted);border-bottom:1px dashed rgba(255,255,255,.08);padding-bottom:6px}
.hours-list li span:first-child{color:#fff;font-weight:600}
.map-wrap{border:2px solid var(--red);border-radius:10px;overflow:hidden;aspect-ratio:4/3}
.map-wrap iframe{width:100%;height:100%;border:0;filter:grayscale(.25)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:44px;padding:20px 0;
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  width:min(1180px,92%);margin-inline:auto;color:var(--muted);font-size:.9rem}
.footer-bottom a{color:var(--gold)}
.footer-bottom a:hover{text-decoration:underline}

/* ===================== MODAL ===================== */
.modal{position:fixed;inset:0;z-index:200;display:none}
.modal.open{display:grid;place-items:center}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.78)}
.modal-dialog{position:relative;z-index:2;background:var(--panel);border:2px solid var(--red);
  border-radius:14px;width:min(560px,92%);max-height:90vh;overflow:auto;box-shadow:var(--shadow)}
.modal-img{aspect-ratio:16/10;background-size:cover;background-position:center}
.modal-body{padding:22px 24px 28px}
.modal-body h3{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:1.8rem;margin-bottom:12px;color:#fff}
.modal-body p{color:var(--muted);margin-bottom:8px}
.modal-body .price{font-size:1.6rem;display:inline-block}
.modal-body ul{margin:8px 0 8px 18px;color:var(--muted)}
.modal-close{position:absolute;top:10px;right:14px;z-index:3;background:var(--red);color:#fff;
  border:0;width:38px;height:38px;border-radius:50%;font-size:1.5rem;cursor:pointer;line-height:1}
.modal-close:hover{background:var(--red-bright)}

/* ===================== RESPONSIVE ===================== */
@media(max-width:1024px){
  :root{--header-h:76px}
  .header-nav,.header-actions{display:none}
  .hamburger{display:block}
  .about-grid{grid-template-columns:1fr;text-align:center}
  .about-history{border-left:0;border-top:2px solid var(--red);padding-left:0;padding-top:18px}
  .about-mark{display:none}
  .four-cards{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .hh-banner{background-attachment:scroll}
  .two-cards{grid-template-columns:1fr}
  .section-head.split{flex-direction:column;align-items:flex-start}
  .schedule{text-align:left}
}
@media(max-width:560px){
  .four-cards{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .friday-info{flex-direction:column;gap:8px}
  .friday-info .fi{border-left:0;padding-left:0}
}
