/**
 * Coffee Insurrection — Global CSS
 * assets/css/global.css
 *
 * Design system: #000 / #fff / #E53935 only.
 * No shadows, no gradients, no border-radius.
 * Mobile-first. System fonts.
 */

/* ── CUSTOM PROPERTIES ─────────────────────────────────────── */
:root {
    --ci-black:       #000;
    --ci-white:       #fff;
    --ci-red:         #E53935;
    --ci-red-dark:    #b71c1c;
    --ci-border:      1px solid #000;
    --ci-border-mid:  1px solid #ccc;
    --ci-border-light:1px solid #e8e8e8;

    --ci-font:        system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --ci-mono:        'Courier New', Courier, monospace;

    --ci-text:        #000;
    --ci-text-muted:  #555;
    --ci-text-faint:  #aaa;

    --ci-space-xs:    .25rem;
    --ci-space-sm:    .5rem;
    --ci-space-md:    1rem;
    --ci-space-lg:    2rem;
    --ci-space-xl:    4rem;

    --ci-max-width:   1200px;
    --ci-content-width: 720px;

    --ci-z-topbar:    100;
    --ci-z-modal:     200;
    --ci-z-toast:     300;
}

/* ── RESET ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
}

body {
    font-family: var(--ci-font);
    font-size: 1rem;
    line-height: 1.65;
    color: var(--ci-black);
    background: var(--ci-white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img, svg { display: block; max-width: 100%; height: auto; }
a { color: var(--ci-black); text-decoration: underline; text-underline-offset: 3px; }
a:hover { color: var(--ci-red); }
button { font-family: inherit; cursor: pointer; }
input, select, textarea { font-family: inherit; }
ul, ol { list-style: none; }
h1, h2, h3, h4, h5, h6 { font-weight: 700; line-height: 1.2; }

/* ── TYPOGRAPHY SCALE ──────────────────────────────────────── */
.ci-h1 { font-size: clamp(1.75rem, 5vw, 3rem); letter-spacing: -.02em; }
.ci-h2 { font-size: clamp(1.25rem, 3vw, 2rem); letter-spacing: -.01em; }
.ci-h3 { font-size: clamp(1rem, 2.5vw, 1.5rem); }
.ci-h4 { font-size: 1.1rem; }
.ci-label-mono {
    font-family: var(--ci-mono);
    font-size: .65rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--ci-text-muted);
}
.ci-body-large  { font-size: 1.125rem; line-height: 1.75; }
.ci-body-small  { font-size: .875rem; }
.ci-caption     { font-size: .75rem; color: var(--ci-text-muted); }

/* ── LAYOUT ────────────────────────────────────────────────── */
.ci-container {
    width: 100%;
    max-width: var(--ci-max-width);
    margin-inline: auto;
    padding-inline: var(--ci-space-md);
}

.ci-content-wrap {
    max-width: var(--ci-content-width);
    margin-inline: auto;
}

.ci-grid {
    display: grid;
    gap: var(--ci-space-md);
}

.ci-grid--2 { grid-template-columns: repeat(2, 1fr); }
.ci-grid--3 { grid-template-columns: repeat(3, 1fr); }
.ci-grid--4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 900px) {
    .ci-grid--4 { grid-template-columns: repeat(2, 1fr); }
    .ci-grid--3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .ci-grid--4,
    .ci-grid--3,
    .ci-grid--2 { grid-template-columns: 1fr; }
}

/* ── BUTTONS ────────────────────────────────────────────────── */
.ci-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    padding: .6rem 1.25rem;
    font-family: var(--ci-font);
    font-size: .82rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    text-decoration: none;
    border: var(--ci-border);
    background: var(--ci-white);
    color: var(--ci-black);
    cursor: pointer;
    border-radius: 0;
    transition: background .12s, color .12s, border-color .12s;
    white-space: nowrap;
    line-height: 1;
}
.ci-btn:hover {
    background: var(--ci-black);
    color: var(--ci-white);
    text-decoration: none;
}
.ci-btn--primary {
    background: var(--ci-red);
    border-color: var(--ci-red);
    color: var(--ci-white);
}
.ci-btn--primary:hover {
    background: var(--ci-black);
    border-color: var(--ci-black);
}
.ci-btn--outline {
    background: transparent;
    border: var(--ci-border);
    color: var(--ci-black);
}
.ci-btn--sm {
    padding: .35rem .75rem;
    font-size: .72rem;
}
.ci-btn--lg {
    padding: .85rem 2rem;
    font-size: .9rem;
}
.ci-btn--icon {
    padding: .5rem;
    width: 40px;
    height: 40px;
}

/* ── SOCIAL / ACTIONS BAR ──────────────────────────────────── */
.ci-actions {
    display: flex;
    align-items: center;
    gap: var(--ci-space-xs);
    flex-wrap: wrap;
}

.ci-action-btn {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .4rem .75rem;
    border: var(--ci-border);
    background: var(--ci-white);
    color: var(--ci-text-muted);
    font-size: .75rem;
    font-family: var(--ci-mono);
    text-transform: uppercase;
    letter-spacing: .06em;
    cursor: pointer;
    border-radius: 0;
    transition: all .12s;
    text-decoration: none;
}
.ci-action-btn:hover {
    color: var(--ci-black);
    border-color: var(--ci-black);
}
.ci-action-btn.ci-action--active {
    background: var(--ci-red);
    border-color: var(--ci-red);
    color: var(--ci-white);
}
.ci-action-btn svg { width: 16px; height: 16px; flex-shrink: 0; }
.ci-action__count {
    font-variant-numeric: tabular-nums;
}

/* ── BADGE / PILL ───────────────────────────────────────────── */
.ci-badge {
    display: inline-block;
    padding: .15rem .55rem;
    border: var(--ci-border);
    font-family: var(--ci-mono);
    font-size: .62rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--ci-red);
    background: var(--ci-white);
    border-radius: 0;
    white-space: nowrap;
}
.ci-badge--insurrection {
    background: var(--ci-red);
    border-color: var(--ci-red);
    color: var(--ci-white);
}
.ci-badge--type {
    color: var(--ci-text-muted);
    border-color: #ccc;
}

/* ── RATING CUPS ────────────────────────────────────────────── */
.ci-rating-cups { display: inline-flex; gap: .15rem; }
.ci-cup { font-size: 1rem; opacity: .2; }
.ci-cup--filled { opacity: 1; }
.ci-rating-unset {
    font-family: var(--ci-mono);
    font-size: .65rem;
    color: var(--ci-text-faint);
    text-transform: uppercase;
    letter-spacing: .08em;
}

/* ── SECTION LABELS ─────────────────────────────────────────── */
.ci-section-label {
    font-family: var(--ci-mono);
    font-size: .62rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    color: var(--ci-text-muted);
    margin-bottom: var(--ci-space-sm);
}

.ci-section-title {
    font-size: clamp(1.1rem, 3vw, 1.5rem);
    font-weight: 700;
    margin-bottom: var(--ci-space-md);
}

.ci-divider {
    border: none;
    border-top: var(--ci-border);
    margin-block: var(--ci-space-lg);
}

/* ── BREADCRUMB ─────────────────────────────────────────────── */
.ci-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .25rem .4rem;
    font-family: var(--ci-mono);
    font-size: .62rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--ci-text-muted);
    padding: var(--ci-space-sm) 0;
    border-bottom: var(--ci-border-light);
    margin-bottom: var(--ci-space-md);
}
.ci-breadcrumb a {
    color: var(--ci-text-muted);
    text-decoration: none;
}
.ci-breadcrumb a:hover { color: var(--ci-red); }
.ci-breadcrumb__sep { color: var(--ci-text-faint); }
.ci-breadcrumb__current { color: var(--ci-black); }

/* ── TAG CHIPS ──────────────────────────────────────────────── */
.ci-tags {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
}
.ci-tag {
    display: inline-block;
    padding: .2rem .55rem;
    border: var(--ci-border-mid);
    font-family: var(--ci-mono);
    font-size: .6rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--ci-text-muted);
    text-decoration: none;
    transition: all .12s;
    border-radius: 0;
    cursor: default;
}
a.ci-tag:hover,
button.ci-tag:hover {
    border-color: var(--ci-red);
    color: var(--ci-red);
    cursor: pointer;
}

/* ── QUICK FACTS TABLE ─────────────────────────────────────── */
.ci-quick-facts {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
    border: var(--ci-border);
}
@media (min-width: 600px) {
    .ci-quick-facts { grid-template-columns: repeat(3, 1fr); }
}
.ci-fact {
    padding: .85rem .9rem;
    border-right: var(--ci-border);
    border-bottom: var(--ci-border);
}
.ci-fact:nth-child(2n) { border-right: none; }
@media (min-width: 600px) {
    .ci-fact:nth-child(3n) { border-right: none; }
    .ci-fact:nth-child(2n) { border-right: var(--ci-border); }
}
.ci-fact__icon { font-size: 1.1rem; margin-bottom: .25rem; }
.ci-fact__label {
    font-family: var(--ci-mono);
    font-size: .58rem;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--ci-text-faint);
    margin-bottom: .15rem;
}
.ci-fact__value {
    font-size: .875rem;
    font-weight: 600;
    color: var(--ci-black);
}
.ci-fact__value--yes { color: var(--ci-black); }
.ci-fact__value--no  { color: var(--ci-text-muted); }

/* ── FAQ (old details/summary style) ───────────────────────── */
.ci-faq { border-top: var(--ci-border); }
.ci-faq-item { border-bottom: var(--ci-border); }
.ci-faq-item__q {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1rem 0;
    font-weight: 700;
    font-size: .95rem;
    cursor: pointer;
    list-style: none;
    user-select: none;
}
.ci-faq-item__q::-webkit-details-marker { display: none; }
.ci-faq-item__icon {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    position: relative;
}
.ci-faq-item__icon::before,
.ci-faq-item__icon::after {
    content: '';
    position: absolute;
    background: var(--ci-black);
    transition: transform .15s;
}
.ci-faq-item__icon::before { top: 50%; left: 0; right: 0; height: 1px; transform: translateY(-50%); }
.ci-faq-item__icon::after  { top: 0; bottom: 0; left: 50%; width: 1px; transform: translateX(-50%); }
details[open] .ci-faq-item__icon::after { transform: translateX(-50%) rotate(90deg); }
.ci-faq-item__a {
    padding: 0 0 1rem;
    font-size: .9rem;
    color: var(--ci-text-muted);
    line-height: 1.75;
}

/* ── FAQ (new ci_faq_render_html classes) ───────────────────── */
.ci-faq__inner { padding: 2rem 0 0; }
.ci-faq__label {
    font-size: .62rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-family: var(--ci-mono);
    color: var(--ci-text-muted);
    margin-bottom: .5rem;
}
.ci-faq__title {
    font-size: clamp(1rem, 2.5vw, 1.3rem);
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--ci-black);
    background: none;
    margin-bottom: 1.5rem;
}
.ci-faq__list { display: flex; flex-direction: column; }
.ci-faq__item { border: var(--ci-border); margin-bottom: -1px; background: var(--ci-white); }
.ci-faq__question { display: flex; justify-content: space-between; align-items: center; width: 100%; }
.ci-faq__trigger {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    background: none;
    border: 0;
    padding: .9rem 1rem;
    font-size: .9rem;
    font-weight: 600;
    color: var(--ci-black);
    cursor: pointer;
    text-align: left;
    gap: 1rem;
    font-family: var(--ci-font);
}
.ci-faq__trigger:hover { background: #f5f5f5; }
.ci-faq__trigger[aria-expanded="true"] { background: var(--ci-black); color: var(--ci-white); }
.ci-faq__trigger[aria-expanded="true"] svg line { stroke: var(--ci-white); }
.ci-faq__icon { flex-shrink: 0; }
.ci-faq__icon-v { transition: transform .2s; }
.ci-faq__trigger[aria-expanded="true"] .ci-faq__icon-v { transform: rotate(90deg); }
.ci-faq__answer {
    padding: .75rem 1rem 1rem;
    font-size: .88rem;
    line-height: 1.65;
    border-top: var(--ci-border);
    color: var(--ci-black);
    background: var(--ci-white);
}
.ci-faq__answer[hidden] { display: none; }
.ci-faq__answer-inner p { margin: 0; }

/* ── DEFINITION BOX (AEO) ──────────────────────────────────── */
.ci-definition-box {
    border: var(--ci-border);
    border-left: 4px solid var(--ci-red);
    padding: 1rem 1.25rem;
    margin-bottom: var(--ci-space-lg);
    background: #fafafa;
}
.ci-definition-box__term {
    font-weight: 700;
    font-size: 1.05rem;
    margin-bottom: .25rem;
}
.ci-definition-box__label {
    font-family: var(--ci-mono);
    font-size: .58rem;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--ci-red);
    margin-bottom: .5rem;
}
.ci-definition-box__body {
    font-size: .9rem;
    color: var(--ci-text-muted);
    line-height: 1.7;
}

/* ── GALLERY ────────────────────────────────────────────────── */
.ci-gallery {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2px;
}
@media (min-width: 600px) {
    .ci-gallery { grid-template-columns: repeat(3, 1fr); }
}
.ci-gallery__item { aspect-ratio: 4/3; overflow: hidden; }
.ci-gallery__item img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .3s;
}
.ci-gallery__item:hover img { transform: scale(1.04); }

/* ── MAP BLOCK ──────────────────────────────────────────────── */
.ci-map-block { border: var(--ci-border); overflow: hidden; }
.ci-map-block__iframe {
    width: 100%;
    height: 320px;
    border: none;
    display: block;
}
@media (min-width: 768px) {
    .ci-map-block__iframe { height: 420px; }
}
.ci-map-block__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .75rem 1rem;
    border-top: var(--ci-border);
    gap: 1rem;
}
.ci-map-block__address {
    font-family: var(--ci-mono);
    font-size: .72rem;
    color: var(--ci-text-muted);
    line-height: 1.5;
}

/* ── TOAST ──────────────────────────────────────────────────── */
#ci-toast {
    position: fixed;
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    background: var(--ci-black);
    color: var(--ci-white);
    padding: .65rem 1.25rem;
    font-family: var(--ci-mono);
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    z-index: var(--ci-z-toast);
    opacity: 0;
    transition: transform .2s, opacity .2s;
    pointer-events: none;
    white-space: nowrap;
    border: var(--ci-border);
}
#ci-toast.ci-toast--visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

/* ── SHORTCODE STYLES ───────────────────────────────────────── */
.ci-shortcode-poi-list { display: grid; gap: var(--ci-space-md); }
.ci-poi-list--card { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }

.ci-poi-list-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .65rem 0;
    border-bottom: var(--ci-border-light);
}
.ci-poi-list-item__name { font-weight: 700; text-decoration: none; color: var(--ci-black); }
.ci-poi-list-item__name:hover { color: var(--ci-red); }
.ci-poi-list-item__city {
    font-family: var(--ci-mono);
    font-size: .65rem;
    color: var(--ci-text-muted);
    text-transform: uppercase;
    letter-spacing: .06em;
}

.ci-shortcode-city-grid {
    display: grid;
    grid-template-columns: repeat(var(--cols, 3), 1fr);
    gap: 0;
    border: var(--ci-border);
}
@media (max-width: 700px) {
    .ci-shortcode-city-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
.ci-city-grid-item {
    padding: 1rem 1.1rem;
    border-right: var(--ci-border);
    border-bottom: var(--ci-border);
    text-decoration: none;
    display: block;
    transition: background .12s;
}
.ci-city-grid-item:hover { background: #f5f5f5; }
.ci-city-grid-item__name { font-weight: 700; font-size: .9rem; display: block; color: var(--ci-black); }
.ci-city-grid-item__count {
    font-family: var(--ci-mono);
    font-size: .6rem;
    color: var(--ci-text-muted);
    text-transform: uppercase;
    letter-spacing: .06em;
}

.ci-shortcode-stats {
    display: flex;
    gap: var(--ci-space-lg);
    flex-wrap: wrap;
}
.ci-stats-item { text-align: center; }
.ci-stats-item__value {
    display: block;
    font-size: 2.5rem;
    font-weight: 800;
    letter-spacing: -.03em;
    color: var(--ci-red);
    line-height: 1;
}
.ci-stats-item__label {
    font-family: var(--ci-mono);
    font-size: .62rem;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--ci-text-muted);
    margin-top: .25rem;
}

.ci-shortcode-related { margin-top: var(--ci-space-xl); padding-top: var(--ci-space-lg); border-top: var(--ci-border); }
.ci-shortcode-related__title { font-size: 1.25rem; font-weight: 700; margin-bottom: var(--ci-space-md); }
.ci-shortcode-related__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: var(--ci-space-md); }

/* ── UTILITY ────────────────────────────────────────────────── */
.ci-visually-hidden {
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0);
    white-space: nowrap; border: 0;
}
.ci-text-center { text-align: center; }
.ci-text-muted   { color: var(--ci-text-muted); }
.ci-text-red     { color: var(--ci-red); }
.ci-mt-sm  { margin-top: var(--ci-space-sm); }
.ci-mt-md  { margin-top: var(--ci-space-md); }
.ci-mt-lg  { margin-top: var(--ci-space-lg); }
.ci-mb-md  { margin-bottom: var(--ci-space-md); }
.ci-mb-lg  { margin-bottom: var(--ci-space-lg); }

/* ── OPENING HOURS ─────────────────────────────────────────── */
.ci-opening-hours__list { display: grid; gap: .35rem; }
.ci-opening-hours__row {
    font-family: var(--ci-mono);
    font-size: .8rem;
    color: var(--ci-text-muted);
    padding: .35rem 0;
    border-bottom: var(--ci-border-light);
}
.ci-opening-hours__row:last-child { border-bottom: none; }

/* ── RESPONSIVE HELPERS ─────────────────────────────────────── */
@media (max-width: 600px) {
    .ci-hide-mobile { display: none !important; }
}
@media (min-width: 601px) {
    .ci-hide-desktop { display: none !important; }
}

/* ── ENTRY CONTENT PROSE TYPOGRAPHY ────────────────────────── */
.entry-content p {
    margin-top: 0;
    margin-bottom: 1.1rem;
    line-height: 1.75;
}
.entry-content p:last-child {
    margin-bottom: 0;
}
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4 {
    font-family: var(--ci-font);
    color: var(--ci-black);
    letter-spacing: .04em;
    line-height: 1.2;
    margin-top: 2rem;
    margin-bottom: .75rem;
}
.entry-content h1 { font-size: clamp(1.3rem, 3vw, 1.8rem); }
.entry-content h2 { font-size: clamp(1.1rem, 2.5vw, 1.4rem); }
.entry-content h3 { font-size: .95rem; }
.entry-content h4 { font-size: .88rem; }
.entry-content > h1:first-child,
.entry-content > h2:first-child,
.entry-content > h3:first-child {
    margin-top: 0;
}
.entry-content ul,
.entry-content ol {
    margin: 0 0 1.1rem 1.4rem;
    line-height: 1.75;
}
.entry-content li {
    margin-bottom: .3rem;
}
.entry-content strong {
    color: var(--ci-black);
    font-weight: 600;
}
.entry-content a {
    color: var(--ci-red);
    text-decoration: underline;
    text-underline-offset: 3px;
}
.entry-content a:hover {
    color: var(--ci-black);
}

/* ── FAQ DARK THEME (guide + interview dark bg) ─────────────── */
[style*="background:var(--ci-black)"] .ci-faq,
[style*="background: var(--ci-black)"] .ci-faq {
    border-top: 1px solid #333;
}
[style*="background:var(--ci-black)"] .ci-faq__label,
[style*="background: var(--ci-black)"] .ci-faq__label {
    display: none;
}
[style*="background:var(--ci-black)"] .ci-faq__title,
[style*="background: var(--ci-black)"] .ci-faq__title {
    color: #fff;
    font-family: var(--font-display, system-ui, sans-serif);
    font-size: clamp(1rem, 2.5vw, 1.3rem);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
    border-bottom: 1px solid #333;
    padding-bottom: 1rem;
    margin-bottom: 1.5rem;
}
[style*="background:var(--ci-black)"] .ci-faq__list,
[style*="background: var(--ci-black)"] .ci-faq__list {
    display: flex;
    flex-direction: column;
    gap: .75rem;
}
[style*="background:var(--ci-black)"] .ci-faq__item,
[style*="background: var(--ci-black)"] .ci-faq__item {
    background: #1e1e1e;
    border: 1px solid #2a2a2a;
    margin-bottom: 0;
}
[style*="background:var(--ci-black)"] .ci-faq__trigger,
[style*="background: var(--ci-black)"] .ci-faq__trigger {
    color: #fff;
    background: none;
    font-size: .95rem;
    font-weight: 600;
    padding: 1rem 1.25rem;
}
[style*="background:var(--ci-black)"] .ci-faq__trigger:hover,
[style*="background: var(--ci-black)"] .ci-faq__trigger:hover {
    background: #252525;
}
[style*="background:var(--ci-black)"] .ci-faq__trigger[aria-expanded="true"],
[style*="background: var(--ci-black)"] .ci-faq__trigger[aria-expanded="true"] {
    background: #1e1e1e;
    color: #fff;
}
/* + icon red, rotates to × when open */
[style*="background:var(--ci-black)"] .ci-faq__icon svg line,
[style*="background: var(--ci-black)"] .ci-faq__icon svg line {
    stroke: var(--ci-red);
    stroke-width: 2;
}
[style*="background:var(--ci-black)"] .ci-faq__trigger[aria-expanded="true"] .ci-faq__icon-v,
[style*="background: var(--ci-black)"] .ci-faq__trigger[aria-expanded="true"] .ci-faq__icon-v {
    transform: rotate(90deg);
}
[style*="background:var(--ci-black)"] .ci-faq__answer,
[style*="background: var(--ci-black)"] .ci-faq__answer {
    background: #1e1e1e;
    border-top: 1px solid #2a2a2a;
    color: #aaa;
    padding: .75rem 1.25rem 1.25rem;
}

/* ── ARTICLE HERO (full-width) ──────────────────────────────── */
.ci-article-hero-wrap {
    width: 100%;
    position: relative;
    overflow: hidden;
    line-height: 0;
    border-bottom: var(--ci-border);
}
.ci-article-hero-wrap--tall { max-height: 520px; }
.ci-hero-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
}
.ci-hero-img--portrait { object-position: center 20%; }
.ci-hero-gradient {
    position: absolute;
    inset: auto 0 0;
    height: 40%;
    background: linear-gradient(to top, rgba(0,0,0,.55), transparent);
    pointer-events: none;
}
.ci-photo-credit {
    position: absolute;
    bottom: .5rem;
    right: .75rem;
    font-size: .65rem;
    color: rgba(255,255,255,.7);
    font-family: var(--ci-mono);
    letter-spacing: .06em;
}

/* ── ARTICLE GRID (content + sidebar) ──────────────────────── */
.ci-article-grid-wrap { padding-block: 2.5rem; }
.ci-article-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    align-items: start;
}
@media (min-width: 768px) {
    .ci-article-grid {
        grid-template-columns: 1fr 280px;
        gap: 3rem;
    }
}

/* ── SIDEBAR ────────────────────────────────────────────────── */
.ci-sidebar {
    border: var(--ci-border);
    padding: 1.25rem;
    background: var(--ci-white);
}
@media (min-width: 768px) {
    .ci-sidebar { position: sticky; top: 5rem; }
}
.ci-sidebar__title {
    font-size: .65rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 700;
    margin: 0 0 1rem;
    padding-bottom: .5rem;
    border-bottom: var(--ci-border);
    color: var(--ci-black);
}
.ci-portrait { margin-bottom: 1rem; border: var(--ci-border); line-height: 0; }
.ci-portrait__img { display: block; width: 100%; height: auto; filter: grayscale(100%); }
.ci-meta-list { font-size: .82rem; }
.ci-meta-list__item { margin-top: .75rem; }
.ci-meta-list__label {
    display: block;
    font-size: .65rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--ci-text-muted);
    margin-bottom: .1rem;
}
.ci-meta-list__value { display: block; font-weight: 600; color: var(--ci-black); }
.ci-meta-list__value--strong { font-weight: 700; }
.ci-meta-list__link { color: var(--ci-red); text-decoration: none; border-bottom: 1px solid var(--ci-red); }
.ci-meta-list__link:hover { opacity: .75; }
.ci-sidebar__footer { margin-top: 1.25rem; padding-top: .75rem; border-top: var(--ci-border); }
.ci-sidebar__back {
    display: inline-block;
    font-size: .75rem;
    color: var(--ci-red);
    text-decoration: none;
    border-bottom: 1px solid var(--ci-red);
}
.ci-sidebar__back:hover { opacity: .75; }

/* ── EYEBROW + ARTICLE TITLE ────────────────────────────────── */
.ci-eyebrow {
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
    margin-bottom: .75rem;
}
.ci-eyebrow__tag {
    font-family: var(--ci-mono);
    font-size: .65rem;
    text-transform: uppercase;
    letter-spacing: .1em;
    background: var(--ci-black);
    color: var(--ci-white);
    padding: .2rem .55rem;
}
.ci-eyebrow__meta {
    font-family: var(--ci-mono);
    font-size: .65rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--ci-text-muted);
}
.ci-article-title {
    font-size: clamp(1.6rem, 5vw, 2.8rem);
    font-weight: 900;
    letter-spacing: -.02em;
    line-height: 1.1;
    color: var(--ci-black);
    margin-bottom: .75rem;
}
.ci-byline { font-size: .9rem; color: var(--ci-black); margin-bottom: 1rem; }
.ci-byline__name { font-weight: 700; }
.ci-byline__link { color: var(--ci-red); text-decoration: none; border-bottom: 1px solid var(--ci-red); }

/* ── ARTICLE FOOTER BAR ─────────────────────────────────────── */
.ci-article-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    padding: 1rem 0;
    margin-top: 2rem;
    border-top: var(--ci-border);
    border-bottom: var(--ci-border);
}
.ci-article-footer__date {
    font-family: var(--ci-mono);
    font-size: .65rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--ci-text-muted);
}

/* ── RELATED POI (under sidebar) ────────────────────────────── */
.ci-related-poi { margin-top: 1.5rem; }
.ci-related-poi__label {
    font-family: var(--ci-mono);
    font-size: .62rem;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--ci-text-muted);
    margin-bottom: .5rem;
}