/* ===== Chubby's Diner · Blackstone — shared styles ===== */
:root{
  --red:#e23b3b; --red-deep:#b3242c; --cream:#fdf6ec; --ink:#1d1d24;
  --teal:#1fb3b3; --teal-deep:#0d8c8c; --mustard:#f5b841; --yellow:#ffd21e; --pink:#ff6f91;
  --chrome:#e9eef2; --shadow:rgba(0,0,0,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Poppins',sans-serif;color:var(--ink);background:var(--cream);overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
section{position:relative}
.script{font-family:'Pacifico',cursive}
.display{font-family:'Bebas Neue',sans-serif;letter-spacing:.5px}

/* TOP BAR */
.topbar{background:var(--ink);color:#fff;font-size:.82rem;padding:7px 0}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.topbar .pill{display:inline-flex;align-items:center;gap:7px}
.topbar a:hover{color:var(--mustard)}

/* NAV */
header{position:sticky;top:0;z-index:50;background:var(--red);box-shadow:0 4px 14px var(--shadow)}
nav{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.brand{display:flex;align-items:center;gap:12px;color:#fff}
.brandlogo{height:46px;width:auto;display:block;filter:drop-shadow(0 2px 2px rgba(0,0,0,.25))}
.navlinks{display:flex;align-items:center;gap:26px}
.navlinks a{color:#fff;font-weight:600;font-size:.95rem;position:relative}
.navlinks a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-6px;height:3px;width:0;background:var(--yellow);transition:width .25s}
.navlinks a:not(.btn):hover::after,.navlinks a.current::after{width:100%}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;border-radius:40px;padding:11px 22px;cursor:pointer;border:none;transition:transform .15s, box-shadow .15s;font-size:.95rem;white-space:nowrap}
.btn-call{background:var(--yellow);color:var(--ink);box-shadow:0 3px 0 #c8a313}
.btn-call:hover{transform:translateY(-2px);box-shadow:0 5px 0 #c8a313}
.btn-ghost{background:transparent;border:2px solid #fff;color:#fff}
.btn-ghost:hover{background:#fff;color:var(--red)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.hamburger span{width:26px;height:3px;background:#fff;border-radius:2px}

/* HERO */
.hero{background:linear-gradient(160deg,#16161d 0%,#26222b 60%,#3a2030 100%);color:#fff;padding:64px 0 0;overflow:hidden}
.checker{height:26px;background:repeating-conic-gradient(var(--ink) 0% 25%, var(--cream) 0% 50%) 0 0/52px 52px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;padding-bottom:60px}
.hero-logo{max-width:380px;width:80%;margin-bottom:14px;filter:drop-shadow(0 6px 10px rgba(0,0,0,.5))}
.hero .neon{font-family:'Monoton',cursive;font-size:.95rem;color:var(--teal);letter-spacing:4px;text-shadow:0 0 10px rgba(31,179,179,.7)}
.hero h1{font-family:'Bebas Neue';font-size:clamp(2.6rem,6vw,4.6rem);line-height:.95;margin:6px 0 6px}
.hero h1 em{font-family:'Pacifico';font-style:normal;color:var(--yellow);font-size:.55em;display:block;text-shadow:0 3px 0 rgba(0,0,0,.3)}
.hero p.lead{font-size:1.08rem;opacity:.9;max-width:480px;margin:14px 0 26px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 4px 0 var(--red-deep)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 0 var(--red-deep)}
.hero-stats{display:flex;gap:30px;margin-top:34px;flex-wrap:wrap}
.hero-stats div{border-left:3px solid var(--teal);padding-left:12px}
.hero-stats b{font-family:'Bebas Neue';font-size:1.8rem;display:block;color:var(--yellow)}
.hero-stats small{opacity:.8;font-size:.8rem;letter-spacing:1px;text-transform:uppercase}
.hero-photo-wrap{position:relative;justify-self:center}
.hero-photo{width:min(440px,82vw);aspect-ratio:1;border-radius:50%;overflow:hidden;border:10px solid #fff;box-shadow:0 30px 60px rgba(0,0,0,.55);background:#fff}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-photo-wrap .ring{position:absolute;inset:-16px;border:2px dashed rgba(255,255,255,.3);border-radius:50%}
.hero-badge{position:absolute;bottom:6px;right:-6px;background:var(--red);color:#fff;border:4px solid #fff;border-radius:50%;width:108px;height:108px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;text-align:center;font-family:'Bebas Neue';line-height:.9;transform:rotate(-8deg);box-shadow:0 8px 20px rgba(0,0,0,.35)}
.hero-badge b{font-size:2.1rem;display:block;color:var(--yellow);line-height:.9}
.hero-badge span{font-size:.6rem;letter-spacing:1.5px}

/* PAGE BANNER (inner pages) */
.pagehero{background:linear-gradient(160deg,#16161d,#3a2030);color:#fff;text-align:center;padding:50px 0;position:relative}
.pagehero .plogo{height:64px;margin:0 auto 14px;width:auto;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5))}
.pagehero .kicker{font-family:'Pacifico';color:var(--yellow);font-size:1.4rem}
.pagehero h1{font-family:'Bebas Neue';font-size:clamp(2.4rem,6vw,4rem);line-height:1;margin-top:4px}
.pagehero p{max-width:620px;margin:12px auto 0;opacity:.85}
.crumbs{font-size:.82rem;opacity:.7;margin-top:14px}
.crumbs a:hover{color:var(--yellow)}

/* MARQUEE */
.marquee{background:var(--teal);color:#062d2d;font-family:'Bebas Neue';letter-spacing:2px;font-size:1.15rem;padding:10px 0;white-space:nowrap;overflow:hidden}
.marquee div{display:inline-block;animation:scroll 26s linear infinite}
.marquee span{margin:0 26px}
.marquee .dot{color:var(--red)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTION HEADERS */
.sec{padding:70px 0}
.sec-head{text-align:center;margin-bottom:44px}
.sec-head .kicker{font-family:'Pacifico';color:var(--red);font-size:1.4rem}
.sec-head h2{font-family:'Bebas Neue';font-size:clamp(2.2rem,5vw,3.4rem);line-height:1;margin-top:4px}
.sec-head p{max-width:620px;margin:12px auto 0;color:#5a5560}

/* FEATURED */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 12px 30px var(--shadow);border:3px solid var(--ink);transition:transform .2s}
.card:hover{transform:translateY(-6px)}
.card .ph{height:210px;position:relative;overflow:hidden;background:#222}
.card .ph img{width:100%;height:100%;object-fit:cover}
.card .ph .tag{position:absolute;top:12px;left:12px;background:var(--yellow);color:var(--ink);font-family:'Poppins';font-weight:700;font-size:.7rem;letter-spacing:1px;padding:4px 10px;border-radius:30px;box-shadow:0 2px 6px rgba(0,0,0,.25)}
.card .body{padding:18px 20px 22px}
.card h3{font-family:'Bebas Neue';font-size:1.55rem;letter-spacing:.5px}
.card .price{color:var(--red);font-weight:800;font-size:1.15rem;float:right}
.card p{color:#6a646f;font-size:.9rem;margin-top:8px;line-height:1.5}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gfig{position:relative;border-radius:16px;overflow:hidden;border:3px solid var(--ink);box-shadow:0 10px 24px var(--shadow);margin:0;aspect-ratio:1}
.gfig img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.gfig:hover img{transform:scale(1.07)}
.gfig figcaption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(0,0,0,.78));color:#fff;font-family:'Bebas Neue';letter-spacing:.5px;font-size:1.1rem;padding:26px 14px 12px}

/* MENU */
.menu-dark{background:var(--ink);color:var(--cream)}
.menu-dark .sec-head h2{color:#fff}
.menu-dark .sec-head .kicker{color:var(--yellow)}
.menu-dark .sec-head p{color:#bdb7c2}
.menu-tools{display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap;margin-bottom:26px}
.search{display:flex;align-items:center;gap:8px;background:#2a2a33;border:2px solid #3c3c47;border-radius:40px;padding:9px 18px;min-width:280px}
.search input{background:none;border:none;outline:none;color:#fff;font-size:.95rem;width:100%;font-family:'Poppins'}
.search input::placeholder{color:#8a8593}
.tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:34px}
.tab{background:#2a2a33;color:#cfc9d6;border:2px solid #3c3c47;border-radius:30px;padding:8px 16px;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .18s}
.tab:hover{border-color:var(--yellow)}
.tab.active{background:var(--red);color:#fff;border-color:var(--red)}
.menu-cat{margin-bottom:40px}
.menu-cat h3{font-family:'Bebas Neue';font-size:2rem;color:var(--yellow);border-bottom:2px dashed #44444f;padding-bottom:8px;margin-bottom:6px}
.menu-cat .note{color:#9a94a3;font-size:.82rem;margin-bottom:18px;font-style:italic}
.items{display:grid;grid-template-columns:1fr 1fr;gap:6px 40px}
.item{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid #2f2f38;align-items:baseline}
.item .nm{font-weight:600;color:#fff}
.item .ds{display:block;color:#9a94a3;font-size:.82rem;font-weight:400;margin-top:3px;line-height:1.45}
.item .dots{flex:1;border-bottom:2px dotted #4a4a55;margin:0 4px;transform:translateY(-4px)}
.item .pr{color:var(--teal);font-weight:800;white-space:nowrap}
.noresults{text-align:center;color:#9a94a3;padding:30px;font-style:italic}
.menu-foot{text-align:center;color:#8a8593;font-size:.8rem;margin-top:20px}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.about-card{background:#fff;border-radius:20px;border:3px solid var(--ink);box-shadow:10px 10px 0 var(--teal);padding:34px}
.about-card .script{color:var(--red);font-size:1.6rem}
.about-card h2{font-family:'Bebas Neue';font-size:2.6rem;line-height:1;margin:6px 0 16px}
.about-card p{color:#5a5560;line-height:1.7;margin-bottom:14px}
.signature{font-family:'Pacifico';font-size:1.5rem;color:var(--ink);margin-top:8px}
.signature small{display:block;font-family:'Poppins';font-size:.75rem;letter-spacing:2px;color:#8a8593;text-transform:uppercase}
.about-photo{border-radius:20px;overflow:hidden;border:3px solid var(--ink);box-shadow:14px 14px 0 var(--mustard);aspect-ratio:4/3}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about-feats{display:grid;gap:18px}
.ftile{background:linear-gradient(135deg,var(--red),var(--red-deep));color:#fff;border-radius:16px;padding:22px 24px;box-shadow:0 10px 24px var(--shadow)}
.ftile:nth-child(2){background:linear-gradient(135deg,var(--teal),var(--teal-deep))}
.ftile:nth-child(3){background:linear-gradient(135deg,var(--mustard),#d99a1c);color:var(--ink)}
.ftile h4{font-family:'Bebas Neue';font-size:1.5rem;letter-spacing:.5px}
.ftile p{font-size:.9rem;opacity:.95;margin-top:4px;line-height:1.5}

/* REVIEWS */
.reviews-bg{background:repeating-conic-gradient(#f3ead9 0% 25%, var(--cream) 0% 50%) 0 0/64px 64px}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rev{background:#fff;border-radius:18px;padding:26px;box-shadow:0 10px 26px var(--shadow);border-top:6px solid var(--yellow)}
.stars{color:var(--mustard);font-size:1.1rem;letter-spacing:2px}
.rev p{color:#444;line-height:1.6;margin:12px 0 16px;font-size:.95rem}
.rev .who{display:flex;align-items:center;gap:12px}
.rev .av{width:42px;height:42px;border-radius:50%;background:var(--teal);color:#fff;display:grid;place-items:center;font-family:'Bebas Neue';font-size:1.2rem}
.rev .who b{display:block;font-size:.95rem}
.rev .who small{color:#999}
.gmaps-rating{text-align:center;margin-top:34px;font-family:'Bebas Neue';font-size:1.4rem;color:var(--ink)}
.gmaps-rating b{color:var(--red);font-size:1.8rem}

/* LOCATION / CONTACT */
.visit-dark{background:var(--ink);color:#fff}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:22px;overflow:hidden;box-shadow:0 16px 40px rgba(0,0,0,.4);border:3px solid #000}
.visit-info{padding:44px;background:linear-gradient(160deg,#26222b,#1d1d24)}
.visit-info .script{color:var(--yellow);font-size:1.5rem}
.visit-info h2{font-family:'Bebas Neue';font-size:2.6rem;margin:4px 0 22px}
.info-row{display:flex;gap:14px;margin-bottom:20px;align-items:flex-start}
.info-row .ic{width:42px;height:42px;border-radius:12px;background:var(--red);display:grid;place-items:center;flex:0 0 auto;font-size:1.2rem}
.info-row b{display:block;font-size:1.05rem}
.info-row span{color:#b7b2bf;font-size:.92rem}
.info-row a{color:var(--teal)}
.visit-cta{display:flex;gap:12px;margin-top:26px;flex-wrap:wrap}
.map-wrap{min-height:420px;background:#333}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}
.senior-banner{background:var(--yellow);color:var(--ink);text-align:center;padding:16px;font-weight:700;font-family:'Bebas Neue';font-size:1.4rem;letter-spacing:1px}

/* CONTACT FORM */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.cform{background:#fff;border-radius:20px;border:3px solid var(--ink);box-shadow:10px 10px 0 var(--red);padding:32px}
.cform h3{font-family:'Bebas Neue';font-size:2rem;margin-bottom:6px}
.cform p.sub{color:#6a646f;font-size:.9rem;margin-bottom:20px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.85rem;margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;padding:12px 14px;border:2px solid #e2dccf;border-radius:12px;font-family:'Poppins';font-size:.95rem;background:var(--cream);outline:none;transition:border .2s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--teal)}
.field textarea{resize:vertical;min-height:120px}
.form-note{font-size:.78rem;color:#8a8593;margin-top:10px}
.form-success{display:none;background:#e7f7f2;border:2px solid var(--teal);color:#0d6e5f;border-radius:12px;padding:14px;font-weight:600;margin-top:14px}

/* HOURS TABLE */
.hours-card{background:#fff;border-radius:20px;border:3px solid var(--ink);box-shadow:10px 10px 0 var(--mustard);padding:32px}
.hours-card h3{font-family:'Bebas Neue';font-size:2rem;margin-bottom:14px}
.hrow{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px dashed #e2dccf;font-size:.95rem}
.hrow b{color:var(--red)}
.hrow.today{background:var(--cream);margin:0 -10px;padding:11px 10px;border-radius:8px;border-bottom:none}

/* FOOTER */
footer{background:#111;color:#cfc9d6;padding:54px 0 24px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;margin-bottom:30px}
.footlogo{height:54px;width:auto;margin-bottom:6px}
footer h5{font-family:'Bebas Neue';font-size:1.3rem;letter-spacing:1px;color:var(--yellow);margin-bottom:14px}
footer ul{list-style:none}
footer li{margin-bottom:9px}
footer a:hover{color:var(--yellow)}
footer p{color:#8a8593;line-height:1.6;font-size:.9rem;margin-top:14px}
.foot-bottom{border-top:1px solid #2a2a33;padding-top:20px;text-align:center;color:#777;font-size:.82rem}

/* BACK TO TOP */
.totop{position:fixed;right:22px;bottom:22px;width:48px;height:48px;border-radius:50%;background:var(--red);color:#fff;border:3px solid var(--ink);display:grid;place-items:center;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .25s;z-index:60;font-size:1.3rem;box-shadow:0 6px 16px var(--shadow)}
.totop.show{opacity:1;pointer-events:auto}

/* RESPONSIVE */
@media(max-width:900px){
  .hero-grid,.about-grid,.visit-grid,.form-grid{grid-template-columns:1fr}
  .hero-photo-wrap{order:-1}
  .feat-grid,.rev-grid{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .items{grid-template-columns:1fr}
  .navlinks{position:fixed;top:0;right:-100%;height:100vh;width:74%;max-width:320px;background:var(--red-deep);flex-direction:column;align-items:flex-start;padding:90px 30px;gap:22px;transition:right .3s;box-shadow:-10px 0 30px rgba(0,0,0,.3)}
  .navlinks.open{right:0}
  .navlinks .btn{width:100%;justify-content:center}
  .hamburger{display:flex;z-index:60}
  .about-card,.cform,.hours-card{box-shadow:6px 6px 0 var(--teal)}
  /* centered, balanced hero on mobile */
  .hero{padding-top:36px}
  .hero-grid{text-align:center}
  .hero-logo{margin-left:auto;margin-right:auto}
  .hero p.lead{margin-left:auto;margin-right:auto}
  .hero-cta{justify-content:center;gap:12px}
  .hero-cta .btn{flex:1 1 0;justify-content:center;padding:10px 10px;font-size:.82rem;gap:6px}
  .hero-stats{justify-content:center;gap:14px}
  .hero-stats div{border-left:none;border-top:3px solid var(--teal);padding-left:0;padding-top:8px;flex:1 1 0}
  .foot-grid{grid-template-columns:1fr 1fr;gap:26px 30px}
  .foot-grid>div:first-child{grid-column:1 / -1;text-align:center}
  .foot-grid>div:first-child .footlogo{margin-left:auto;margin-right:auto}
}
@media(max-width:560px){
  .topbar{font-size:.72rem}
  .hero-stats{gap:18px}
  .map-wrap{min-height:300px}
  .gallery{grid-template-columns:1fr 1fr}
  .visit-cta{flex-wrap:nowrap;gap:10px}
  .visit-cta .btn{flex:1;justify-content:center;padding-left:12px;padding-right:12px;font-size:.85rem}
}
