/* ============================================================
   Taggart's Grill — Heritage site stylesheet — DARK CHARCOAL theme
   DRAFT — Pending Mike's Review.  Devon Cross.
   Deep charcoal base so Orange #F08020 + warm white pop.
   Georgia type. Brown/walnut retired in favor of near-black charcoal.
   ============================================================ */

:root{
  --orange:#F08020; --orange-d:#d96d12;
  --bg:#242424;        /* deep charcoal base */
  --bg2:#2C2C2C;       /* alt section */
  --panel:#2E2E2E;     /* cards / form fields-surround */
  --panel2:#333333;    /* hover / raised */
  --near-black:#1A1A1A;/* topbar / footer / CTA */
  --field:#1F1F1F;     /* inputs */
  --white:#F4EEE3;     /* warm white text */
  --muted:#A89F92;     /* warm grey */
  --amber:#E0913F;     /* warm accent label */
  --teal:#46B39D;      /* lightened peacock accent for dark bg */
  --line:rgba(244,238,227,.14);
  --line-strong:rgba(244,238,227,.24);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:Georgia,'Times New Roman',serif;color:var(--white);
  background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.wrap{max-width:1080px;margin:0 auto;padding:0 26px;}
.sc{letter-spacing:3px;text-transform:uppercase;}
.center{text-align:center;}

/* ---- Top promo bar ---- */
.topbar{background:var(--near-black);color:var(--white);text-align:center;
  font-size:.78rem;letter-spacing:2px;padding:8px 10px;text-transform:uppercase;
  border-bottom:1px solid var(--line);}
.topbar span{color:var(--orange);}

/* ---- Header / nav ---- */
header.site{position:sticky;top:0;z-index:50;background:rgba(26,26,26,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line-strong);}
.bar{display:flex;align-items:center;justify-content:space-between;height:94px;}
.brand{display:flex;align-items:center;}
.brand img{height:70px;width:auto;}
nav.main ul{display:flex;gap:24px;align-items:center;list-style:none;}
nav.main a{font-size:.82rem;letter-spacing:1.5px;text-transform:uppercase;transition:.2s;color:var(--white);}
nav.main a:hover,nav.main a.active{color:var(--orange);}
.menu-toggle{display:none;background:none;border:0;color:var(--white);font-size:1.7rem;cursor:pointer;}

/* ---- Buttons ---- */
.btn{display:inline-block;background:transparent;color:var(--white);
  padding:11px 22px;letter-spacing:2px;text-transform:uppercase;font-size:.78rem;
  border:1px solid var(--line-strong);transition:.2s;cursor:pointer;}
.btn:hover{background:var(--orange);border-color:var(--orange);color:#1a1a1a;}
.btn.solid{background:var(--orange);border-color:var(--orange);color:#1a1a1a;font-weight:bold;}
.btn.solid:hover{background:#fff;border-color:#fff;color:#1a1a1a;}
.btn.ghost{background:transparent;color:var(--white);border-color:var(--line-strong);}
.btn.ghost:hover{background:var(--orange);color:#1a1a1a;border-color:var(--orange);}

/* ---- Sections ---- */
section{padding:80px 0;}
.head{text-align:center;margin-bottom:46px;}
.head .est{color:var(--amber);font-size:.74rem;letter-spacing:3px;text-transform:uppercase;margin-bottom:8px;}
.head h2{font-size:clamp(1.9rem,3.5vw,2.7rem);color:var(--white);}
.head p.sub{max-width:50ch;margin:14px auto 0;color:var(--muted);font-style:italic;}
.ornament{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--orange);margin:16px 0;font-size:.9rem;}
.ornament:before,.ornament:after{content:"";height:1px;width:70px;background:var(--line-strong);}

/* ---- Page hero (inner pages) ---- */
.page-hero{position:relative;text-align:center;padding:74px 0 60px;
  background:linear-gradient(var(--bg2),var(--bg));border-bottom:1px solid var(--line);}
.page-hero.photo{background-size:cover;background-position:center;border-bottom:3px solid var(--orange);}
.page-hero .est{color:var(--amber);font-size:.76rem;letter-spacing:3px;text-transform:uppercase;margin-bottom:10px;position:relative;}
.page-hero h1{font-size:clamp(2rem,4.5vw,3.2rem);color:var(--white);position:relative;}
.page-hero p{max-width:54ch;margin:14px auto 0;color:var(--muted);font-style:italic;position:relative;}
.page-hero.photo .p,.page-hero.photo p{color:#e6ddcf;}

/* ---- Home hero ---- */
.hero{position:relative;min-height:80vh;display:flex;align-items:center;text-align:center;
  background-size:cover;background-position:center;}
.hero .wrap{padding:80px 26px;color:var(--white);}
.hero .crest{height:120px;margin:0 auto 20px;}
.hero .est{color:var(--orange);font-size:.8rem;letter-spacing:3px;text-transform:uppercase;margin-bottom:16px;}
.hero h1{font-size:clamp(2.3rem,5.2vw,4rem);line-height:1.1;max-width:18ch;margin:0 auto 8px;}
.hero .ornament{color:var(--orange);}
.hero .ornament:before,.hero .ornament:after{background:rgba(244,238,227,.4);}
.hero p.lede{font-size:clamp(1.05rem,2vw,1.3rem);font-style:italic;max-width:44ch;margin:0 auto 28px;}
.hero .cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* ---- Info band ---- */
.band{background:var(--near-black);color:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.band .wrap{display:flex;flex-wrap:wrap;justify-content:space-around;gap:14px;padding:22px 26px;text-align:center;}
.band .item b{display:block;color:var(--orange);font-size:.7rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:5px;}
.band .item span{font-size:.95rem;}
.band a{color:var(--orange);}

/* ---- Cards ---- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.card{background:var(--panel);border:1px solid var(--line);overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.35);transition:.2s;}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.5);border-color:var(--line-strong);}
.card .img{aspect-ratio:4/3;width:100%;object-fit:cover;background:var(--bg2);}
.card .body{padding:22px;}
.card .tag{color:var(--orange);font-size:.72rem;letter-spacing:2px;text-transform:uppercase;}
.card h3{font-size:1.35rem;color:var(--white);margin:6px 0 8px;}
.card p{font-size:.95rem;color:var(--muted);}

/* ---- Split (image + text) ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;}
.split.wide-text{grid-template-columns:1fr 1.1fr;}
.split .frame{padding:10px;background:var(--panel);border:1px solid var(--line);box-shadow:0 14px 36px rgba(0,0,0,.45);}
.split .frame img{width:100%;aspect-ratio:4/5;object-fit:cover;}
.split h2{font-size:clamp(1.8rem,3.3vw,2.5rem);color:var(--white);margin-bottom:6px;}
.split .est{color:var(--amber);font-size:.74rem;letter-spacing:3px;text-transform:uppercase;}
.split .ornament{justify-content:flex-start;margin:12px 0 16px;}
.split .ornament:before{display:none;}
.split p{margin-bottom:14px;color:#d9d1c4;font-size:1.04rem;}
.split .peacock{color:var(--teal);font-style:italic;font-weight:bold;}

/* ---- Gallery ---- */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.gal img{width:100%;aspect-ratio:1/1;object-fit:cover;border:1px solid var(--line);}

/* ---- Heritage strip ---- */
.heritage{text-align:center;background:var(--near-black);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.heritage .big{font-size:clamp(2.6rem,6vw,4rem);color:var(--orange);line-height:1;}
.heritage p{max-width:48ch;margin:14px auto 0;color:#d9d1c4;font-style:italic;}

/* ---- Order CTA ---- */
.order-cta{background:var(--near-black);color:var(--white);text-align:center;border-top:3px solid var(--orange);}
.order-cta h2{font-size:clamp(1.9rem,3.5vw,2.6rem);margin-bottom:12px;}
.order-cta p{max-width:42ch;margin:0 auto 24px;color:var(--muted);}

/* ---- Menu page ---- */
.menu-tabs{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:14px;}
.menu-tabs a{border:1px solid var(--line-strong);padding:9px 18px;font-size:.78rem;letter-spacing:2px;text-transform:uppercase;color:var(--white);}
.menu-tabs a:hover{background:var(--orange);color:#1a1a1a;border-color:var(--orange);}
.legend{text-align:center;color:var(--muted);font-style:italic;font-size:.9rem;margin-bottom:36px;}
.mcat{margin:0 auto 44px;max-width:820px;}
.mcat h3{color:var(--white);font-size:1.5rem;text-align:center;}
.mcat .catnote{text-align:center;color:var(--muted);font-style:italic;font-size:.9rem;margin-top:4px;}
.mcat .catrule{width:50px;height:3px;background:var(--orange);margin:12px auto 26px;}
.item{display:flex;justify-content:space-between;gap:16px;align-items:baseline;padding:14px 0;border-bottom:1px dotted var(--line-strong);}
.item:last-child{border-bottom:0;}
.item .n{color:var(--white);font-size:1.12rem;}
.item .n small{display:block;font-size:.9rem;color:var(--muted);font-style:italic;font-weight:normal;margin-top:3px;line-height:1.5;}
.item .price{color:var(--orange);white-space:nowrap;font-size:1.05rem;}
.beer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 40px;}

/* ---- Visit page ---- */
.hours-table{width:100%;border-collapse:collapse;}
.hours-table td{padding:11px 0;border-bottom:1px dotted var(--line-strong);font-size:1.02rem;}
.hours-table td:last-child{text-align:right;color:var(--white);}
.hours-table .closed td:first-child{color:var(--muted);}
.policy{max-width:760px;margin:0 auto;}
.policy ol{margin:0 0 24px 20px;}
.policy li{margin-bottom:12px;}
.policy .why{background:var(--panel);border-left:4px solid var(--orange);padding:20px 24px;font-style:italic;color:#d9d1c4;}
.mapframe{width:100%;aspect-ratio:16/7;border:1px solid var(--line-strong);background:var(--panel);}

/* ---- Forms (Careers) ---- */
.formcard{max-width:760px;margin:0 auto;background:var(--panel);border:1px solid var(--line);box-shadow:0 14px 36px rgba(0,0,0,.4);padding:34px;}
.draftnote{max-width:760px;margin:0 auto 26px;background:rgba(224,145,63,.1);border:1px dashed var(--amber);padding:16px 20px;font-size:.9rem;color:#e6ddcf;}
.field{margin-bottom:20px;}
.field label{display:block;font-size:.82rem;letter-spacing:1px;text-transform:uppercase;color:var(--white);margin-bottom:7px;}
.field input,.field select,.field textarea{width:100%;font-family:inherit;font-size:1rem;padding:12px 14px;border:1px solid var(--line-strong);background:var(--field);color:var(--white);}
.field input::placeholder,.field textarea::placeholder{color:#8a8276;}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--orange);border-color:var(--orange);}
.field .hint{font-size:.82rem;color:var(--muted);font-style:italic;margin-top:5px;}
.two{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.checks{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.checks label{display:flex;align-items:center;gap:8px;font-size:.92rem;text-transform:none;letter-spacing:0;color:var(--white);}
.checks input{width:auto;}
.avail-grid{width:100%;border-collapse:collapse;font-size:.9rem;}
.avail-grid th,.avail-grid td{border:1px solid var(--line-strong);padding:8px;text-align:center;}
.avail-grid th{background:var(--bg2);color:var(--white);font-size:.78rem;letter-spacing:1px;text-transform:uppercase;}

/* ---- Footer ---- */
footer.site{background:var(--near-black);color:var(--white);padding:58px 0 24px;border-top:3px solid var(--orange);}
.fcols{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:40px;}
footer.site img.flogo{height:74px;margin-bottom:14px;}
footer.site h4{color:var(--orange);font-size:.78rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:13px;}
footer.site p,footer.site li{color:var(--muted);font-size:.94rem;margin-bottom:6px;list-style:none;}
footer.site a:hover{color:var(--orange);}
footer.site .seasonal{font-style:italic;opacity:.7;font-size:.84rem;}
.social a{display:inline-block;margin-right:12px;border:1px solid var(--orange);color:var(--orange);
  border-radius:50%;width:36px;height:36px;line-height:34px;text-align:center;font-size:.82rem;}
.social a:hover{background:var(--orange);color:#1a1a1a;}
.legal{text-align:center;color:var(--muted);opacity:.7;font-size:.82rem;margin-top:40px;border-top:1px solid var(--line);padding-top:18px;}

/* ---- Responsive ---- */
@media(max-width:860px){
  .bar{height:78px;}
  .brand img{height:56px;}
  nav.main ul{display:none;position:absolute;top:78px;left:0;right:0;flex-direction:column;
    background:var(--near-black);padding:18px 26px;gap:16px;border-bottom:1px solid var(--line-strong);}
  nav.main ul.open{display:flex;}
  .menu-toggle{display:block;}
  .cards{grid-template-columns:1fr;}
  .split,.split.wide-text{grid-template-columns:1fr;gap:30px;}
  .gal{grid-template-columns:repeat(2,1fr);}
  .beer-grid{grid-template-columns:1fr;}
  .two,.checks{grid-template-columns:1fr;}
  .fcols{grid-template-columns:1fr;gap:28px;}
}

/* ---- Season-aware Sunday hours (set by assets/site.js) ---- */
.season-off{opacity:.5;font-style:italic;}
footer.site .sun-line.season-current{color:var(--white);}
footer.site .sun-line.season-current .seasonal{opacity:.85;font-style:normal;}
.hours-table tr.season-current td{color:var(--white);font-weight:bold;}
.hours-table tr.season-off td{opacity:.5;font-style:italic;}

/* ---- Anchor offset so jump-links land below the sticky header ---- */
.mcat{scroll-margin-top:110px;}
@media(max-width:860px){ .mcat{scroll-margin-top:90px;} }

/* ---- Home hero info (hours + directions on the first screen) ---- */
.hero-info{margin-top:22px;font-size:.95rem;color:var(--cream);}
.hero-info p{margin:5px 0;opacity:.92;}
.hero-info a{color:var(--orange);}

/* ---- Mobile hero: tighten top space, size to content ---- */
@media(max-width:860px){
  .hero{min-height:auto;}
  .hero .wrap{padding:30px 24px 44px;}
  .hero .crest{height:84px;margin-bottom:14px;}
  .hero h1{font-size:2.3rem;}
  .hero p.lede{margin-bottom:22px;}
  .hero-info{margin-top:18px;font-size:.88rem;}
}
