/* Chicago Gangsters & Ghosts — "Bauhaus" design system (from chicago.md)
   Flat, geometric, Archivo, single red accent, 0px radius, no shadows, no gradients. */
:root{
  --primary:#121212;     /* headlines & core text */
  --secondary:#585858;   /* borders, captions, metadata */
  --tertiary:#E53935;    /* the sole interaction accent — reserve it */
  --neutral:#F4EFE4;     /* page foundation */
  --surface:#FFFFFF;
  --ink:#121212;
  --muted:#585858;
  --line:#121212;
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Archivo",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--primary);background:var(--neutral);line-height:1.55;font-size:17px;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section-pad{padding:48px 22px 64px}
img{max-width:100%}

h1,h2,h3,h4{font-family:"Archivo",sans-serif;color:var(--primary);font-weight:800;letter-spacing:-0.03em;line-height:1.08;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,5vw,3.4rem);font-weight:900}
h2{font-size:clamp(1.5rem,3.2vw,2.3rem);margin-top:1.5em;text-transform:none}
h3{font-size:1.2rem;font-weight:800}
p{margin:0 0 1.1em}
a{color:var(--tertiary);text-decoration:none}
a:hover{text-decoration:underline}
strong{font-weight:800}

/* Buttons — red is the single action driver */
.btn{display:inline-block;background:var(--tertiary);color:#fff;font-weight:800;padding:13px 24px;border-radius:0;text-decoration:none;border:2px solid var(--tertiary);cursor:pointer;font-size:.95rem;letter-spacing:.02em;text-transform:uppercase;transition:background .12s,color .12s}
.btn:hover{background:#121212;border-color:#121212;color:#fff;text-decoration:none}
.btn-ghost{background:transparent;color:var(--primary);border:2px solid var(--primary)}
.btn-ghost:hover{background:var(--primary);color:#fff}

/* Header */
.site-head{position:sticky;top:0;z-index:50;background:var(--neutral);border-bottom:2px solid var(--primary)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;min-height:66px;gap:16px}
.logo{display:flex;align-items:center;gap:10px;font-weight:900;font-size:1.05rem;letter-spacing:-.02em;color:var(--primary);text-transform:uppercase}
.logo:hover{text-decoration:none}
.logo .dot{width:14px;height:14px;background:var(--tertiary);display:inline-block}
.nav{display:flex;align-items:center;gap:22px}
.nav a{color:var(--primary);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.nav a:hover{color:var(--tertiary);text-decoration:none}
.nav .btn{padding:9px 16px;font-size:.78rem;color:#fff}
.nav .btn:hover{color:#fff}
.nav-toggle{display:none;background:none;border:2px solid var(--primary);color:var(--primary);font-size:1.2rem;padding:2px 9px;cursor:pointer}
@media(max-width:860px){
  .nav-toggle{display:block}
  .nav{display:none;position:absolute;top:66px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background:var(--neutral);border-bottom:2px solid var(--primary);padding:8px 22px 16px}
  .nav.open{display:flex}
  .nav a{padding:11px 0;width:100%;border-top:1px solid var(--line)}
  .nav .btn{margin-top:10px}
}

/* Hero — flat black plane with a muted image, no gradient */
.hero{position:relative;background:var(--primary);color:#fff;overflow:hidden;border-bottom:2px solid var(--primary)}
.hero::after{content:"";position:absolute;inset:0;background:url('/images/hero-chicago.jpg') center/cover;opacity:.38}
.hero .wrap{position:relative;z-index:2;padding:78px 22px 82px;max-width:880px}
.hero .label{color:var(--tertiary);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;font-weight:800;margin:0 0 14px}
.hero h1{color:#fff}
.hero p.lede{font-size:1.18rem;color:#ECE7DB;max-width:660px;font-weight:500}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.hero-trust{margin-top:22px;font-size:.85rem;color:#c9c4ba;text-transform:uppercase;letter-spacing:.05em}
.hero-trust b{color:#fff}

/* Answer box — flat, red left bar */
.answer-box{background:var(--surface);border:2px solid var(--primary);border-left:8px solid var(--tertiary);padding:22px 26px;margin:0 0 28px;font-size:1.05rem}
.answer-box strong{color:var(--primary)}

/* Two-col panels */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:0;margin:24px 0;border:2px solid var(--primary)}
.two-col .panel{padding:24px 26px}
.two-col .panel:first-child{border-right:2px solid var(--primary)}
@media(max-width:760px){.two-col{grid-template-columns:1fr}.two-col .panel:first-child{border-right:none;border-bottom:2px solid var(--primary)}}
.panel h3{margin-top:0}
ul.check{list-style:none;margin:0;padding:0}
ul.check li{position:relative;padding:0 0 .55em 26px;margin:0}
ul.check li::before{content:"";position:absolute;left:0;top:8px;width:12px;height:12px;background:var(--tertiary)}

/* Steps */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin:24px 0;border:2px solid var(--primary)}
.steps .step{counter-increment:step;padding:22px 20px;border-right:2px solid var(--primary)}
.steps .step:last-child{border-right:none}
.steps .step::before{content:counter(step,decimal-leading-zero);display:block;font-weight:900;font-size:1.5rem;color:var(--tertiary);margin-bottom:8px;letter-spacing:-.03em}
.steps .step h3{margin:0 0 6px;font-size:1.02rem}
.steps .step p{margin:0;font-size:.92rem;color:var(--muted)}
@media(max-width:760px){.steps{grid-template-columns:1fr}.steps .step{border-right:none;border-bottom:2px solid var(--primary)}.steps .step:last-child{border-bottom:none}}

/* Gallery — sharp flat tiles */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:24px 0}
.gallery figure{margin:0;position:relative;aspect-ratio:4/3;overflow:hidden;border:2px solid var(--primary);background:var(--primary)}
.gallery img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.15) contrast(1.05)}
.gallery figcaption{position:absolute;left:0;bottom:0;background:var(--primary);color:#fff;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:6px 10px}
@media(max-width:760px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:430px){.gallery{grid-template-columns:1fr}}

/* GYG widget frame */
.gyg-frame{margin:24px 0;min-height:120px}

/* Disclosure */
.disclosure{background:var(--surface);border:1px solid var(--secondary);padding:14px 18px;font-size:.85rem;color:var(--muted);margin:24px 0}

/* Inner-page banner */
.page-hero{margin:0 0 26px;overflow:hidden;aspect-ratio:21/9;background:var(--primary);border:2px solid var(--primary)}
.page-hero img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.15) contrast(1.05)}

/* Tables */
.prose table,.section-pad table{width:100%;border-collapse:collapse;margin:1.2em 0;font-size:.96rem;border:2px solid var(--primary)}
.prose th,.prose td,.section-pad th,.section-pad td{border:1px solid var(--primary);padding:11px 13px;text-align:left;vertical-align:top}
.prose th,.section-pad th{background:var(--primary);color:#fff;font-weight:800;text-transform:uppercase;letter-spacing:.03em;font-size:.84rem}

/* Tour cards — bordered flat blocks */
.tours-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:24px 0}
@media(max-width:900px){.tours-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.tours-grid{grid-template-columns:1fr}}
.tour{background:var(--surface);border:2px solid var(--primary);display:flex;flex-direction:column}
.tour .thumb{position:relative;aspect-ratio:3/2;overflow:hidden;background:var(--primary);border-bottom:2px solid var(--primary)}
.tour .thumb img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.15) contrast(1.05)}
.tour .badge{position:absolute;top:0;left:0;background:var(--tertiary);color:#fff;font-size:.7rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px}
.tour-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.tour-body h3{margin:0 0 8px;font-size:1.08rem}
.tour .rate{font-size:.86rem;color:var(--muted);margin-bottom:6px;font-weight:600}
.tour .rate .star{color:var(--tertiary)}
.tour .price{font-weight:900;font-size:1.3rem;color:var(--primary);margin:6px 0 16px;letter-spacing:-.02em}
.tour .price span{font-size:.82rem;color:var(--muted);font-weight:600;letter-spacing:0}
.tour .btn{margin-top:auto;text-align:center}

/* Classified filler tile — decorative, flat Bauhaus */
.classified{background:var(--primary);border:2px solid var(--primary);display:flex;flex-direction:column;position:relative;overflow:hidden;min-height:240px}
.classified .cl-art{flex:1;display:flex;align-items:center;justify-content:center;padding:26px 24px 14px}
.classified .cl-art svg{width:100%;height:auto;max-width:240px;display:block}
.classified .cl-cap{border-top:2px solid var(--tertiary);padding:14px 20px 16px;color:var(--neutral)}
.classified .cl-cap span{display:block;font-size:.7rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--tertiary);margin-bottom:4px}
.classified .cl-cap strong{font-size:1.05rem;font-weight:800;letter-spacing:-.01em;color:#fff}
@media(max-width:560px){.classified{min-height:220px}}

/* Reviews band */
.reviews-band{background:var(--surface);border:2px solid var(--primary);padding:26px;margin:24px 0}
.reviews-head{display:flex;align-items:center;gap:18px;margin-bottom:6px}
.reviews-head .big{font-size:3rem;font-weight:900;color:var(--tertiary);line-height:1;letter-spacing:-.04em}
.reviews-head .stars{color:var(--tertiary);letter-spacing:2px}

/* Inline article figures (embedded guide) */
.guide-fig{margin:1.7em 0;border:2px solid var(--primary);background:var(--primary);overflow:hidden}
.guide-fig img{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;filter:grayscale(.15) contrast(1.05)}
.guide-fig figcaption{color:#cbc6bb;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:9px 13px}

/* Prose / honest guide */
.prose{max-width:760px;margin:0 auto}
.prose ul,.prose ol{margin:0 0 1.2em;padding-left:1.3em}
.prose li{margin-bottom:.5em}
.honest-guide{margin-top:1.4em}
.honest-guide h3{font-size:1.25rem;margin:1.7em 0 .4em}
.honest-guide p.lead{font-size:1.1rem;border-left:8px solid var(--tertiary);padding-left:16px;margin:.6em 0 1.4em;font-weight:600}

/* Breadcrumb */
.crumb{font-size:.78rem;color:var(--muted);padding:0 0 14px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.crumb a{color:var(--muted)}
.crumb a:hover{color:var(--tertiary)}

/* FAQ */
.faq{margin:14px 0 0;border-top:2px solid var(--primary)}
.faq details{border-bottom:2px solid var(--primary)}
.faq summary{cursor:pointer;font-weight:800;padding:16px 2px;list-style:none;display:flex;justify-content:space-between;gap:14px;font-size:1.04rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--tertiary);font-weight:900;font-size:1.3rem;line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq .faq-body{padding:0 2px 18px;color:var(--ink)}
.faq .faq-body p{margin:0}

/* Footer — flat black plane */
.site-foot{background:var(--primary);color:#cbc6bb;margin-top:56px;padding:46px 0 26px;font-size:.92rem;border-top:6px solid var(--tertiary)}
.site-foot a{color:#cbc6bb}
.site-foot a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:28px}
.foot-grid h4{color:#fff;font-size:.92rem;margin:0 0 12px;text-transform:uppercase;letter-spacing:.05em}
.foot-grid ul{list-style:none;margin:0;padding:0}
.foot-grid li{margin-bottom:8px}
@media(max-width:720px){.foot-grid{grid-template-columns:1fr}}
.foot-guides{margin-top:30px;border-top:1px solid rgba(255,255,255,.18);padding-top:24px}
.foot-guides h4{color:#fff;font-size:.92rem;margin:0 0 14px;text-transform:uppercase;letter-spacing:.05em}
.foot-guides ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:10px 36px}
.foot-guides li a{color:#cbc6bb;font-size:.93rem}
.foot-guides li a:hover{color:#fff}
@media(max-width:560px){.foot-guides ul{grid-template-columns:1fr}}
.foot-facts{margin-top:26px;padding-top:22px;border-top:1px solid rgba(255,255,255,.18)}
.foot-facts h4{color:#fff;font-size:.92rem;margin:0 0 14px;text-transform:uppercase;letter-spacing:.05em}
.foot-facts dl{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 36px;margin:0}
.foot-facts dl>div{display:flex;flex-direction:column}
.foot-facts dt{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:#8d8880;margin-bottom:3px;font-weight:700}
.foot-facts dd{margin:0;font-size:.92rem;color:#ECE7DB}
.foot-facts dd a{color:#cbc6bb}
.foot-facts dd a:hover{color:#fff}
@media(max-width:560px){.foot-facts dl{grid-template-columns:repeat(2,1fr)}}
.foot-bottom{border-top:1px solid rgba(255,255,255,.18);margin-top:28px;padding-top:18px;font-size:.8rem;color:#8d8880;text-transform:uppercase;letter-spacing:.04em}
