/* canadaflorida.com — article-city.v1.css
   City file template styles, extends article-firpta.v8.css.
   Adds: identity table, map slot, tax calculator slot, neighborhoods grid,
   traps grid, climate strip. Load AFTER article-firpta.vN.css. */

/* === Identity table (Bloc 1) =========================================== */
.city-id{margin:28px 0 8px;border:1px solid var(--cf-rule);border-radius:12px;background:var(--cf-surface);overflow:hidden}
.city-id-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0}
.city-id-row{display:flex;justify-content:space-between;align-items:baseline;padding:14px 20px;border-bottom:1px solid var(--cf-rule);border-right:1px solid var(--cf-rule);font-size:14.5px;line-height:1.45}
.city-id-row:nth-child(2n){border-right:none}
.city-id-row:nth-last-child(-n+2){border-bottom:none}
.city-id-row .k{font-family:var(--cf-font-mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--cf-muted);flex:0 0 auto;margin-right:14px}
.city-id-row .v{color:var(--cf-ink);font-weight:500;text-align:right}
@media (max-width:760px){.city-id-grid{grid-template-columns:1fr}.city-id-row{border-right:none}.city-id-row:nth-last-child(-n+2){border-bottom:1px solid var(--cf-rule)}.city-id-row:last-child{border-bottom:none}}

/* === Map slot (Bloc 1, S4 deliverable) ================================== */
.city-map-slot{margin:24px 0;padding:0;background:var(--cf-bg-2);border:1px solid var(--cf-rule);border-radius:12px;aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;color:var(--cf-muted);font-family:var(--cf-font-mono);font-size:13px;text-transform:uppercase;letter-spacing:.06em}
.city-map-slot[data-loaded="true"]{padding:0;background:transparent;border:none;aspect-ratio:auto}

/* === Tax calculator slot (Bloc 6b, S4 deliverable) ====================== */
.city-tax-calc{margin:32px 0;padding:28px 24px;background:var(--cf-bg-2);border:1px solid var(--cf-rule);border-radius:12px}
.city-tax-calc .calc-head{font-family:var(--cf-font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--cf-coral);font-weight:600;margin:0 0 6px}
.city-tax-calc h3{font-family:var(--cf-font-display);font-size:22px;font-weight:600;letter-spacing:-.01em;margin:0 0 18px;color:var(--cf-ink)}
.city-tax-calc .calc-row{display:flex;flex-wrap:wrap;gap:16px;margin:14px 0;align-items:center}
.city-tax-calc label{font-size:14px;color:var(--cf-ink-2);min-width:200px}
.city-tax-calc input[type="number"],.city-tax-calc input[type="range"],.city-tax-calc select{font-family:var(--cf-font-sans);font-size:15px;padding:8px 12px;border:1px solid var(--cf-rule);border-radius:6px;background:var(--cf-surface);color:var(--cf-ink)}
.city-tax-calc .calc-out{margin-top:18px;padding:18px 20px;background:var(--cf-surface);border-radius:8px;border:1px solid var(--cf-rule)}
.city-tax-calc .calc-out .big{font-family:var(--cf-font-display);font-size:32px;font-weight:600;color:var(--cf-coral);line-height:1.1;display:block;margin:0 0 4px}
.city-tax-calc .calc-out .small{font-size:13.5px;color:var(--cf-muted)}
.city-tax-calc .calc-disclaimer{margin-top:14px;font-size:12.5px;color:var(--cf-muted);line-height:1.55}

/* === Neighborhoods grid (Bloc 5e) ======================================= */
.neighborhoods{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;margin:18px 0}
.neighborhood{padding:18px 20px;background:var(--cf-surface);border:1px solid var(--cf-rule);border-radius:10px}
.neighborhood h4{font-family:var(--cf-font-display);font-size:17px;font-weight:600;margin:0 0 8px;color:var(--cf-ink)}
.neighborhood p{font-size:14px;line-height:1.55;color:var(--cf-ink-2);margin:0 0 6px}
.neighborhood p:last-child{margin-bottom:0}

/* === Traps grid (Bloc 10) =============================================== */
.traps{display:grid;gap:14px;margin:18px 0}
.trap{padding:18px 22px;background:var(--cf-surface);border-left:3px solid var(--cf-coral);border-radius:0 8px 8px 0}
.trap h4{font-family:var(--cf-font-display);font-size:16.5px;font-weight:600;margin:0 0 6px;color:var(--cf-ink)}
.trap p{font-size:14px;line-height:1.55;color:var(--cf-ink-2);margin:0}
.trap .cost{font-family:var(--cf-font-mono);font-size:12px;color:var(--cf-coral);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-top:6px;display:inline-block}

/* === Climate strip (Bloc 3) ============================================= */
.climate-strip{display:grid;grid-template-columns:repeat(12,1fr);gap:6px;margin:18px 0}
.climate-month{padding:10px 6px;background:var(--cf-surface);border:1px solid var(--cf-rule);border-radius:6px;text-align:center}
.climate-month .m{font-family:var(--cf-font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--cf-muted);font-weight:600}
.climate-month .t{font-family:var(--cf-font-display);font-size:15px;font-weight:600;color:var(--cf-ink);margin-top:3px}
@media (max-width:760px){.climate-strip{grid-template-columns:repeat(6,1fr)}}

/* === Sub-block headings (5a, 5b, 6a, 6b, ...) =========================== */
.subblock{margin:24px 0 12px;padding:0}
.subblock-eyebrow{font-family:var(--cf-font-mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--cf-coral);font-weight:600;margin:0 0 4px}
.subblock h3{font-family:var(--cf-font-display);font-size:21px;font-weight:600;letter-spacing:-.01em;margin:0 0 10px;color:var(--cf-ink)}

/* === Worked example block (Bloc 6a) ==================================== */
.worked-example{margin:18px 0;padding:20px 22px;background:var(--cf-bg-2);border:1px solid var(--cf-rule);border-radius:10px}
.worked-example h4{font-family:var(--cf-font-display);font-size:17px;font-weight:600;margin:0 0 12px;color:var(--cf-ink)}
.worked-example table{width:100%;border-collapse:collapse;font-size:14px}
.worked-example td{padding:6px 10px;border-bottom:1px solid var(--cf-rule)}
.worked-example td:last-child{text-align:right;font-family:var(--cf-font-mono);font-weight:600;color:var(--cf-ink)}
.worked-example tr:last-child td{border-bottom:none;font-weight:700;border-top:2px solid var(--cf-ink);padding-top:10px}

/* === Source inline marker (cite) ======================================== */
.src-inline{font-family:var(--cf-font-mono);font-size:11.5px;color:var(--cf-muted);text-transform:uppercase;letter-spacing:.06em;margin-left:4px}
.src-inline::before{content:"· "}
