/* ============================================================
   Texas Roadhouse Menu Guide — shared stylesheet
   Independent fan/price guide. Branded-iron + roasted-wood theme.
   ============================================================ */
:root{
  --char:#3b1f14;        /* dark roasted wood */
  --char-2:#2a160d;
  --ember:#c0391f;       /* grill ember red */
  --ember-deep:#9a2a14;
  --hide:#e9ddc7;        /* aged paper */
  --hide-2:#f3ebd9;
  --bone:#fbf6ec;        /* off-white plate */
  --brand:#caa24a;       /* branded-iron brass */
  --ink:#241410;
  --muted:#6b574a;
  --line:#d8c7a8;
  --display:"Archivo Black","Arial Black",system-ui,sans-serif;
  --body:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,serif;
  --util:ui-monospace,"SFMono-Regular",Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bone);color:var(--ink);font-family:var(--body);font-size:18px;line-height:1.62;-webkit-font-smoothing:antialiased}
a{color:var(--ember-deep)}
img{max-width:100%;display:block}
.wrap{max-width:1080px;margin:0 auto;padding:0 22px}
.eyebrow{font-family:var(--util);text-transform:uppercase;letter-spacing:.22em;font-size:12px;color:var(--brand)}

/* ---------- top notice ---------- */
.topbar{background:var(--char-2);color:var(--hide);font-family:var(--util);font-size:12px;letter-spacing:.06em}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;padding:9px 22px;flex-wrap:wrap;gap:8px}
.topbar a{color:var(--brand);text-decoration:none}

/* ---------- main nav ---------- */
.nav{background:var(--char);border-bottom:4px solid var(--ember);position:sticky;top:0;z-index:50}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;gap:16px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--bone)}
.brand .mark{width:38px;height:38px;border:2px solid var(--brand);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--display);color:var(--brand);font-size:16px}
.brand b{font-family:var(--display);font-weight:400;font-size:16px;text-transform:uppercase;letter-spacing:.02em;line-height:1}
.brand span{display:block;font-family:var(--util);font-size:9px;letter-spacing:.14em;color:var(--brand);text-transform:uppercase}
.navlinks{display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.navlinks a{color:var(--hide);text-decoration:none;font-family:var(--util);font-size:12px;letter-spacing:.08em;text-transform:uppercase;padding:4px 0;border-bottom:2px solid transparent}
.navlinks a:hover,.navlinks a.active{color:var(--brand);border-color:var(--brand)}
.navtoggle{display:none;background:none;border:1px solid var(--brand);color:var(--brand);font-family:var(--util);font-size:12px;padding:7px 12px;border-radius:3px;cursor:pointer;text-transform:uppercase;letter-spacing:.1em}

/* ---------- buttons ---------- */
.btn{display:inline-block;font-family:var(--util);text-transform:uppercase;letter-spacing:.1em;font-size:13px;padding:14px 22px;border-radius:2px;text-decoration:none;font-weight:700;border:2px solid transparent;transition:transform .12s ease,background .2s ease}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--ember);color:#fff}
.btn-primary:hover{background:var(--ember-deep)}
.btn-ghost{background:transparent;color:var(--brand);border-color:var(--brand)}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}

/* ---------- hero ---------- */
.hero{background:radial-gradient(140% 120% at 80% -10%,rgba(202,162,74,.18),transparent 55%),linear-gradient(180deg,var(--char) 0%,var(--char-2) 100%);color:var(--hide);padding:54px 0 46px;position:relative;overflow:hidden;border-bottom:5px solid var(--ember)}
.hero h1{font-family:var(--display);font-weight:400;line-height:.98;letter-spacing:-.01em;font-size:clamp(32px,6vw,64px);margin:.18em 0 .35em;color:var(--bone);text-transform:uppercase}
.hero h1 .hot{color:var(--brand)}
.hero p.lede{font-size:clamp(17px,2.2vw,21px);max-width:46ch;color:var(--hide);opacity:.95}
.ranges{display:flex;gap:26px;flex-wrap:wrap;margin-top:26px}
.ranges .r{border-left:3px solid var(--ember);padding-left:12px}
.ranges .r b{display:block;font-family:var(--display);font-size:26px;color:var(--brand);line-height:1}
.ranges .r span{font-family:var(--util);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--hide)}

/* page header (inner pages) */
.phead{background:linear-gradient(180deg,var(--char) 0%,var(--char-2) 100%);color:var(--hide);padding:40px 0 34px;border-bottom:5px solid var(--ember)}
.phead h1{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(28px,5vw,48px);color:var(--bone);line-height:1;margin:.2em 0 .3em}
.phead p{max-width:60ch;color:var(--hide);opacity:.94;margin:0}
.crumbs{font-family:var(--util);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);margin-bottom:6px}
.crumbs a{color:var(--brand);text-decoration:none}

/* ---------- disclaimer ---------- */
.disclaimer{background:var(--ember-deep);color:#fff;text-align:center;padding:13px 22px;font-family:var(--util);font-size:13px;letter-spacing:.03em}
.disclaimer strong{color:#ffe7b8}

/* ---------- ad slots ---------- */
.ad{margin:30px auto;max-width:1080px;padding:0 22px}
.ad .inner{border:1px dashed var(--line);background:var(--hide-2);color:var(--muted);font-family:var(--util);font-size:11px;letter-spacing:.14em;text-transform:uppercase;text-align:center;padding:20px;border-radius:3px}

/* ---------- sections ---------- */
section{padding:46px 0}
h2{font-family:var(--display);font-weight:400;text-transform:uppercase;letter-spacing:-.005em;font-size:clamp(24px,3.6vw,38px);line-height:1.04;margin:0 0 6px;color:var(--char)}
h2 .num{font-family:var(--util);font-size:14px;color:var(--ember);vertical-align:super;margin-right:10px;letter-spacing:0}
h3{font-family:var(--display);font-weight:400;font-size:22px;color:var(--char-2);text-transform:uppercase;letter-spacing:0;margin:34px 0 4px}
h4{font-family:var(--display);font-weight:400;font-size:18px;color:var(--char-2);text-transform:uppercase;margin:24px 0 4px}
.section-note{color:var(--muted);font-size:15px;max-width:64ch;margin:0 0 8px}
.divider{height:3px;background:linear-gradient(90deg,var(--ember),var(--brand) 60%,transparent);max-width:120px;margin:14px 0 26px}
.prose p{max-width:70ch}
.prose ul,.prose ol{max-width:68ch}
.prose li{margin:.3em 0}
.drop::first-letter{font-family:var(--display);font-size:62px;float:left;line-height:.7;padding:6px 10px 0 0;color:var(--ember)}

/* ---------- image placeholder (Lovable prompt) ---------- */
.imgprompt{background:repeating-linear-gradient(45deg,var(--hide) 0 12px,var(--hide-2) 12px 24px);border:1px dashed var(--brand);border-radius:4px;padding:16px;color:var(--char-2);font-family:var(--util);font-size:11.5px;line-height:1.5;letter-spacing:.02em}
.imgprompt b{display:block;color:var(--ember-deep);letter-spacing:.12em;margin-bottom:5px;font-size:10px;text-transform:uppercase}
.hero-img{min-height:150px;display:flex;flex-direction:column;justify-content:center;margin-top:8px}

/* ---------- menu cards ---------- */
.price-key{display:flex;gap:18px;flex-wrap:wrap;font-family:var(--util);font-size:12px;color:var(--muted);background:var(--hide-2);border:1px solid var(--line);padding:12px 16px;border-radius:3px;margin:20px 0 28px;letter-spacing:.03em}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.item{background:#fff;border:1px solid var(--line);border-radius:4px;padding:16px;display:flex;flex-direction:column}
.item .imgprompt{margin:-2px 0 12px;min-height:104px}
.item h5{margin:0 0 6px;font-family:var(--display);font-weight:400;font-size:17px;text-transform:uppercase;color:var(--char-2);line-height:1.1}
.item p{margin:0 0 12px;font-size:15px;color:#4a392f;line-height:1.5;flex:1}
.item .meta{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--line);padding-top:10px;gap:10px;flex-wrap:wrap}
.item .price{font-family:var(--display);font-size:18px;color:var(--ember-deep)}
.item .cal{font-family:var(--util);font-size:11px;color:var(--muted);letter-spacing:.05em}
.tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px}
.tag{font-family:var(--util);font-size:9.5px;letter-spacing:.07em;text-transform:uppercase;padding:3px 7px;border-radius:2px;background:var(--hide);color:var(--char-2);border:1px solid var(--line)}
.tag.gf{background:#e8f1e2;border-color:#bcd6ad;color:#3f6b2c}
.tag.spicy{background:#f7e2dc;border-color:#e3b3a6;color:#a8341a}
.tag.share{background:#efe7d2;border-color:#d8c397;color:#8a6b1f}

/* ---------- tables ---------- */
.tbl{width:100%;border-collapse:collapse;margin:18px 0;font-size:15px;background:#fff;border:1px solid var(--line)}
.tbl th,.tbl td{text-align:left;padding:11px 13px;border-bottom:1px solid var(--line);vertical-align:top}
.tbl th{background:var(--char);color:var(--hide);font-family:var(--util);font-size:11px;letter-spacing:.1em;text-transform:uppercase}
.tbl tr:last-child td{border-bottom:none}
.tbl td.p{font-family:var(--display);color:var(--ember-deep);white-space:nowrap}
.tbl tr:nth-child(even) td{background:var(--hide-2)}

/* ---------- callout ---------- */
.callout{background:var(--hide-2);border-left:4px solid var(--ember);padding:16px 18px;border-radius:0 4px 4px 0;margin:22px 0;font-size:16px}
.callout b{color:var(--ember-deep)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.card{background:#fff;border:1px solid var(--line);border-radius:4px;padding:20px}
.card h4{margin-top:0}

/* ---------- media ---------- */
.media-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.frame{position:relative;width:100%;padding-bottom:56%;background:var(--hide-2);border:1px solid var(--line);border-radius:4px;overflow:hidden}
.frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.frame .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--muted);font-family:var(--util);font-size:11px;letter-spacing:.08em;text-align:center;padding:14px}

/* ---------- FAQ ---------- */
details{border:1px solid var(--line);border-radius:4px;background:#fff;margin-bottom:10px;overflow:hidden}
summary{cursor:pointer;padding:15px 18px;font-family:var(--display);font-weight:400;font-size:16px;color:var(--char-2);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";font-family:var(--util);color:var(--ember);font-size:22px;line-height:1}
details[open] summary::after{content:"\2212"}
details .ans{padding:0 18px 18px;font-size:16px;color:#41312a}
details .ans p{margin:.4em 0}

/* ---------- blog ---------- */
.bloglist{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.blogcard{background:#fff;border:1px solid var(--line);border-radius:5px;overflow:hidden;display:flex;flex-direction:column}
.blogcard .imgprompt{min-height:150px;border:none;border-bottom:1px dashed var(--brand);border-radius:0}
.blogcard .body{padding:18px;display:flex;flex-direction:column;flex:1}
.blogcard .cat{font-family:var(--util);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ember)}
.blogcard h3{font-size:19px;margin:6px 0 8px}
.blogcard p{font-size:15px;color:#4a392f;flex:1;margin:0 0 14px}
.blogcard a.more{font-family:var(--util);font-size:12px;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;color:var(--ember-deep);font-weight:700}
.article{max-width:760px;margin:0 auto}
.article .meta-line{font-family:var(--util);font-size:12px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;margin-bottom:18px}
.article p{font-size:18px}
.article h2{font-size:clamp(22px,3vw,30px);margin-top:36px}
.article h3{font-size:20px}

/* ---------- legal ---------- */
.legal h3{color:var(--char-2)}
.legal p,.legal li{font-size:15px;max-width:80ch;color:#3c2c24}

/* ---------- footer ---------- */
.foot{background:var(--char);color:#c4ad96;padding:42px 0 22px;border-top:5px solid var(--ember);font-size:14px}
.foot .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:28px}
.foot h5{font-family:var(--util);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--brand);margin:0 0 12px}
.foot a{color:#d8c8b2;text-decoration:none;display:block;padding:3px 0;font-size:14px}
.foot a:hover{color:var(--brand)}
.foot .about p{font-size:14px;color:#bda893;max-width:34ch}
.foot .legal-note{border-top:1px solid #4a2e20;margin-top:28px;padding-top:18px;font-family:var(--util);font-size:11px;letter-spacing:.03em;color:#a98e78;line-height:1.6}
.foot .legal-note a{display:inline;color:var(--brand)}

@media (max-width:860px){
  .foot .cols{grid-template-columns:1fr 1fr}
  .grid2,.media-grid{grid-template-columns:1fr}
}
@media (max-width:680px){
  body{font-size:17px}
  .navlinks{display:none;width:100%;flex-direction:column;gap:8px;padding-top:10px}
  .navlinks.open{display:flex}
  .nav .wrap{flex-wrap:wrap}
  .navtoggle{display:block}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important}.btn:hover{transform:none}}
:focus-visible{outline:3px solid var(--brand);outline-offset:2px}

/* Generated image sizing for replaced imgprompt placeholders */
.hero-img{display:block;width:100%;max-width:1100px;margin:30px auto 0;border-radius:14px;height:auto;object-fit:cover;aspect-ratio:16/7}
.item-img{display:block;width:100%;height:200px;object-fit:cover;border-radius:10px;margin-bottom:10px;background:#222}
