/* 18.Network City Pages — Conversion-Optimized Dark Theme v2 */
:root {
    --e18-bg: #0a0a0a;
    --e18-surface: #111;
    --e18-surface-2: #1a1a1a;
    --e18-surface-3: #222;
    --e18-border: #2a2a2a;
    --e18-pink: #ff2d55;
    --e18-pink-dark: #cc2244;
    --e18-pink-glow: rgba(255,45,85,.15);
    --e18-green: #22c55e;
    --e18-gold: #f59e0b;
    --e18-purple: #8b5cf6;
    --e18-text: #f0f0f0;
    --e18-text-muted: #999;
    --e18-text-dim: #666;
    --e18-radius: 12px;
    --e18-radius-sm: 8px;
    --e18-max-w: 960px;
}

/* ── Reset ─────────────────────────────────────── */
.e18-city-page { margin:0; padding:0; background:var(--e18-bg); color:var(--e18-text); font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif; line-height:1.6; -webkit-font-smoothing:antialiased; }
.e18-city-page * { box-sizing:border-box; }
.e18-city-page a { color:var(--e18-pink); text-decoration:none; transition:color .2s; }
.e18-city-page a:hover { color:#ff6b8a; }

/* ── Header ────────────────────────────────────── */
.e18-city-header { background:rgba(10,10,10,.97); backdrop-filter:blur(16px); border-bottom:1px solid var(--e18-border); position:sticky; top:0; z-index:100; }
.e18-city-header-inner { max-width:1200px; margin:0 auto; padding:14px 24px; display:flex; align-items:center; justify-content:space-between; }
.e18-city-logo { font-size:20px; font-weight:800; color:var(--e18-pink) !important; letter-spacing:1px; }
.e18-city-nav { display:flex; gap:24px; }
.e18-city-nav a { color:var(--e18-text-muted); font-weight:500; font-size:14px; padding:6px 0; border-bottom:2px solid transparent; transition:all .2s; }
.e18-city-nav a:hover, .e18-city-nav a.active { color:var(--e18-text); border-bottom-color:var(--e18-pink); }

/* ── Hero ──────────────────────────────────────── */
.e18-city-hero { position:relative; padding:80px 24px 60px; background-size:cover; background-position:center; background-color:var(--e18-surface); min-height:380px; display:flex; align-items:flex-end; }
.e18-city-hero-overlay { position:absolute; inset:0; background:linear-gradient(180deg, rgba(10,10,10,.6) 0%, rgba(10,10,10,.95) 100%); }
.e18-hero-ai .e18-city-hero-overlay { background:linear-gradient(135deg, rgba(10,10,40,.85) 0%, rgba(30,10,30,.95) 100%); }
.e18-city-hero-content { position:relative; z-index:1; max-width:var(--e18-max-w); margin:0 auto; width:100%; }
.e18-city-breadcrumb { font-size:13px; color:var(--e18-text-dim); margin-bottom:16px; }
.e18-city-breadcrumb a { color:var(--e18-text-dim); }
.e18-city-breadcrumb a:hover { color:var(--e18-pink); }
.e18-city-breadcrumb span { color:var(--e18-text-muted); }
.e18-city-title { font-size:clamp(26px,5vw,44px); font-weight:800; margin:0 0 14px; line-height:1.15; }
.e18-city-subtitle { font-size:17px; color:var(--e18-text-muted); max-width:700px; margin:0 0 24px; }

/* Hero CTA */
.e18-hero-cta-wrap { display:flex; flex-direction:column; align-items:flex-start; gap:10px; }
.e18-cta-hero-btn { font-size:18px; padding:16px 32px; }
.e18-cta-friction { font-size:13px; color:var(--e18-text-dim); }

/* ── Social Proof Strip ────────────────────────── */
.e18-social-proof-strip { background:var(--e18-surface-2); border-bottom:1px solid var(--e18-border); padding:12px 24px; }
.e18-proof-ai { background:linear-gradient(90deg, rgba(139,92,246,.08) 0%, rgba(10,10,10,0) 100%); }
.e18-proof-inner { max-width:var(--e18-max-w); margin:0 auto; display:flex; align-items:center; justify-content:center; gap:8px; flex-wrap:wrap; font-size:13px; color:var(--e18-text-muted); }
.e18-proof-item strong { color:var(--e18-green); }
.e18-proof-divider { color:var(--e18-text-dim); }

/* ── Main ──────────────────────────────────────── */
.e18-city-main { padding:48px 24px; }
.e18-city-container { max-width:var(--e18-max-w); margin:0 auto; }
.e18-section-sub { color:var(--e18-text-muted); font-size:15px; margin:-8px 0 24px; }

/* ── Model Showcase ────────────────────────────── */
.e18-model-showcase { margin-bottom:48px; }
.e18-model-showcase h2 { font-size:24px; font-weight:700; margin:0 0 8px; }
.e18-model-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(150px, 1fr)); gap:12px; margin-bottom:20px; }
.e18-model-placeholder { display:contents; }
.e18-placeholder-card { background:var(--e18-surface-2); border:1px solid var(--e18-border); border-radius:var(--e18-radius-sm); aspect-ratio:3/4; animation:e18-pulse 1.5s ease-in-out infinite; }
@keyframes e18-pulse { 0%,100%{opacity:.4} 50%{opacity:.7} }
.e18-model-cta { text-align:center; margin-top:16px; }

/* ── Content ───────────────────────────────────── */
.e18-city-content { margin-bottom:40px; }
.e18-city-content h2 { font-size:24px; font-weight:700; margin:40px 0 14px; color:var(--e18-text); }
.e18-city-content h3 { font-size:19px; font-weight:600; margin:28px 0 10px; }
.e18-city-content p { color:#bbb; font-size:16px; line-height:1.75; margin:0 0 16px; }
.e18-city-content ul, .e18-city-content ol { color:#bbb; padding-left:24px; margin:0 0 16px; }
.e18-city-content li { margin-bottom:10px; line-height:1.6; }
.e18-city-content strong { color:var(--e18-text); }
.e18-city-content em { color:var(--e18-text-muted); font-style:italic; }

/* ── CTA Blocks ────────────────────────────────── */
.e18-cta-button { display:inline-block; background:var(--e18-pink); color:#fff !important; padding:14px 32px; border-radius:var(--e18-radius-sm); font-weight:700; font-size:16px; transition:all .25s; border:none; cursor:pointer; text-align:center; }
.e18-cta-button:hover { background:var(--e18-pink-dark); transform:translateY(-2px); box-shadow:0 8px 32px rgba(255,45,85,.3); color:#fff !important; }
.e18-cta-large { padding:18px 40px; font-size:18px; }
.e18-cta-secondary { background:transparent; border:2px solid var(--e18-pink); color:var(--e18-pink) !important; }
.e18-cta-secondary:hover { background:var(--e18-pink); color:#fff !important; }

.e18-cta-block { margin:40px 0; }
.e18-cta-inner { background:linear-gradient(135deg, #1a0a20 0%, #0a0a1e 50%, #1a0020 100%); border:1px solid rgba(255,45,85,.15); border-radius:var(--e18-radius); padding:36px 32px; text-align:center; }
.e18-cta-inner h3 { font-size:22px; margin:0 0 10px; font-weight:700; }
.e18-cta-sub { color:var(--e18-text-muted); font-size:15px; margin:0 0 20px; }

/* ── How It Works ──────────────────────────────── */
.e18-how-it-works { margin:48px 0; }
.e18-how-it-works h2 { font-size:24px; font-weight:700; margin:0 0 28px; text-align:center; }
.e18-steps { display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; }
.e18-step { background:var(--e18-surface-2); border:1px solid var(--e18-border); border-radius:var(--e18-radius); padding:28px 24px; text-align:center; }
.e18-step-num { width:48px; height:48px; background:var(--e18-pink); color:#fff; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:20px; font-weight:800; margin-bottom:16px; }
.e18-step h3 { font-size:17px; font-weight:600; margin:0 0 8px; }
.e18-step p { font-size:14px; color:var(--e18-text-muted); margin:0; line-height:1.5; }

/* ── Stats ─────────────────────────────────────── */
.e18-city-stats { margin:48px 0; background:var(--e18-surface-2); border:1px solid var(--e18-border); border-radius:var(--e18-radius); padding:32px; }
.e18-city-stats h2 { font-size:22px; margin:0 0 16px; }
.e18-stats-content ul { list-style:none; padding:0; margin:0; }
.e18-stats-content li { padding:10px 0; border-bottom:1px solid var(--e18-border); font-size:15px; color:#bbb; display:flex; align-items:center; gap:10px; }
.e18-stats-content li:last-child { border-bottom:none; }
.e18-stats-content strong { color:var(--e18-text); }

/* ── Comparison Table ──────────────────────────── */
.e18-comparison { margin:48px 0; }
.e18-comparison h2 { font-size:24px; font-weight:700; margin:0 0 24px; }
.e18-comparison-table { display:grid; grid-template-columns:repeat(3, 1fr); gap:16px; }
.e18-compare-card { background:var(--e18-surface-2); border:1px solid var(--e18-border); border-radius:var(--e18-radius); padding:28px 20px; text-align:center; position:relative; }
.e18-compare-featured { border-color:var(--e18-pink); box-shadow:0 0 24px var(--e18-pink-glow); }
.e18-compare-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--e18-gold); color:#000; font-size:12px; font-weight:700; padding:4px 14px; border-radius:20px; white-space:nowrap; }
.e18-compare-card h3 { font-size:20px; margin:8px 0 6px; }
.e18-compare-stars { color:var(--e18-gold); font-size:18px; margin-bottom:16px; letter-spacing:2px; }
.e18-compare-card ul { list-style:none; padding:0; margin:0 0 20px; text-align:left; }
.e18-compare-card li { font-size:14px; color:var(--e18-text-muted); padding:5px 0; padding-left:20px; position:relative; }
.e18-compare-card li::before { content:"✓"; position:absolute; left:0; color:var(--e18-green); font-weight:700; }
.e18-compare-card .e18-cta-button { width:100%; padding:12px; font-size:15px; }

/* ── Cross-link ────────────────────────────────── */
.e18-city-crosslink { margin:48px 0; }
.e18-crosslink-inner { display:flex; align-items:center; gap:24px; background:linear-gradient(135deg, var(--e18-surface-2) 0%, rgba(139,92,246,.06) 100%); border:1px solid var(--e18-border); border-radius:var(--e18-radius); padding:28px 32px; }
.e18-crosslink-content { flex:1; }
.e18-crosslink-label { font-size:12px; text-transform:uppercase; letter-spacing:1.5px; color:var(--e18-purple); font-weight:600; }
.e18-crosslink-inner h3 { font-size:20px; margin:6px 0 6px; color:var(--e18-text); }
.e18-crosslink-inner p { font-size:14px; color:var(--e18-text-muted); margin:0; }
.e18-crosslink-btn { flex-shrink:0; background:var(--e18-purple); color:#fff !important; padding:12px 28px; border-radius:var(--e18-radius-sm); font-weight:600; font-size:15px; transition:all .2s; }
.e18-crosslink-btn:hover { background:#7c3aed; transform:translateY(-1px); }

/* ── FAQ ───────────────────────────────────────── */
.e18-faq { margin:48px 0; }
.e18-faq h2 { font-size:24px; font-weight:700; margin:0 0 20px; }
.e18-faq-list { }
.e18-faq-item { border:1px solid var(--e18-border); border-radius:var(--e18-radius-sm); margin-bottom:8px; overflow:hidden; }
.e18-faq-q { background:var(--e18-surface-2); padding:16px 20px; font-weight:600; font-size:15px; cursor:pointer; display:flex; justify-content:space-between; align-items:center; }
.e18-faq-q::after { content:"▼"; font-size:11px; color:var(--e18-text-dim); transition:transform .2s; }
.e18-faq-q.open::after { transform:rotate(180deg); }
.e18-faq-a { padding:0 20px; max-height:0; overflow:hidden; transition:all .3s; }
.e18-faq-a.open { padding:16px 20px; max-height:500px; }
.e18-faq-a p { font-size:15px; color:var(--e18-text-muted); margin:0; line-height:1.6; }

/* ── Final CTA ─────────────────────────────────── */
.e18-final-cta { margin:48px 0; }
.e18-final-cta-inner { background:linear-gradient(135deg, #1a0515 0%, #150520 50%, #0a0a20 100%); border:1px solid rgba(255,45,85,.2); border-radius:16px; padding:48px 32px; text-align:center; }
.e18-final-cta-ai .e18-final-cta-inner { background:linear-gradient(135deg, #0a0a2e 0%, #150520 50%, #1a0020 100%); border-color:rgba(139,92,246,.2); }
.e18-final-cta-inner h2 { font-size:28px; margin:0 0 10px; }
.e18-final-cta-inner p { color:var(--e18-text-muted); font-size:16px; margin:0 0 24px; }
.e18-final-cta-inner .e18-cta-friction { display:block; margin-top:12px; }

/* ── Nearby Cities Grid ────────────────────────── */
.e18-city-nearby { margin:48px 0; }
.e18-city-nearby h2 { font-size:22px; font-weight:700; margin:0 0 20px; }
.e18-city-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(180px, 1fr)); gap:12px; }
.e18-city-card { background:var(--e18-surface-2); border:1px solid var(--e18-border); border-radius:var(--e18-radius-sm); padding:18px 16px; transition:all .2s; display:block; }
.e18-city-card:hover { border-color:var(--e18-pink); transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,.3); }
.e18-city-card-title { font-size:15px; font-weight:600; margin:0 0 3px; color:var(--e18-text); }
.e18-city-card-state { font-size:13px; color:var(--e18-text-muted); }
.e18-city-card-pop { font-size:12px; color:var(--e18-text-dim); display:block; margin-top:6px; }

/* ── AI Embed ──────────────────────────────────── */
.e18-ai-embed { margin-bottom:48px; }
.e18-ai-embed h2 { font-size:24px; font-weight:700; margin:0 0 16px; }
.e18-ai-iframe-wrap { position:relative; background:var(--e18-surface-2); border:1px solid var(--e18-border); border-radius:var(--e18-radius); overflow:hidden; }
.e18-ai-loading { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:var(--e18-text-muted); font-size:15px; z-index:1; }
.e18-ai-iframe { width:100%; height:600px; border:none; position:relative; z-index:2; }

/* ── Sticky Mobile CTA ─────────────────────────── */
.e18-sticky-cta { position:fixed; bottom:0; left:0; right:0; z-index:200; transform:translateY(100%); transition:transform .3s ease; background:var(--e18-bg); border-top:1px solid var(--e18-border); padding:10px 16px; }
.e18-sticky-cta.e18-sticky-visible { transform:translateY(0); }
.e18-sticky-cta a { display:block; background:var(--e18-pink); color:#fff !important; text-align:center; padding:14px; border-radius:var(--e18-radius-sm); font-weight:700; font-size:15px; }
.e18-sticky-cta a:hover { background:var(--e18-pink-dark); }
.e18-sticky-ai a { background:var(--e18-purple); }
.e18-sticky-ai a:hover { background:#7c3aed; }

/* ── Footer ────────────────────────────────────── */
.e18-city-footer { border-top:1px solid var(--e18-border); padding:20px 24px; text-align:center; }
.e18-city-footer p { color:var(--e18-text-dim); font-size:13px; margin:0; }

/* ── Archive ───────────────────────────────────── */
.e18-city-archive { margin:0; padding:0; background:var(--e18-bg); color:var(--e18-text); font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif; }
.e18-city-archive * { box-sizing:border-box; }
.e18-city-archive a { color:var(--e18-pink); text-decoration:none; }
.e18-city-empty { text-align:center; color:var(--e18-text-muted); padding:60px 24px; }

/* ── Responsive ────────────────────────────────── */
@media (max-width:768px) {
    .e18-city-hero { padding:60px 16px 40px; min-height:auto; }
    .e18-city-main { padding:32px 16px; }
    .e18-steps { grid-template-columns:1fr; }
    .e18-comparison-table { grid-template-columns:1fr; }
    .e18-crosslink-inner { flex-direction:column; text-align:center; gap:16px; }
    .e18-crosslink-btn { width:100%; text-align:center; }
    .e18-city-grid { grid-template-columns:repeat(2, 1fr); }
    .e18-ai-iframe { height:400px; }
    .e18-city-header-inner { padding:12px 16px; }
    .e18-proof-inner { font-size:12px; gap:6px; }
    .e18-proof-divider { display:none; }
    .e18-proof-inner { flex-direction:column; gap:4px; }
    .e18-cta-hero-btn { width:100%; text-align:center; }
    .e18-final-cta-inner { padding:36px 20px; }
    .e18-final-cta-inner h2 { font-size:22px; }
    .e18-cta-inner h3 { font-size:18px; }
    .e18-compare-card { padding:24px 16px; }
    /* Make room for sticky CTA */
    .e18-city-footer { padding-bottom:70px; }
}
@media (max-width:480px) {
    .e18-city-grid { grid-template-columns:1fr; }
    .e18-model-grid { grid-template-columns:repeat(2, 1fr); }
}

/* Desktop: hide sticky CTA */
@media (min-width:769px) {
    .e18-sticky-cta { display:none; }
}

/* ═══════════════════════════════════════════════
   Live Model Cards v3.1
   ═══════════════════════════════════════════════ */
.e18-model-card {
    position: relative;
    display: block;
    border-radius: var(--e18-radius);
    overflow: hidden;
    background: var(--e18-surface-2);
    border: 1px solid var(--e18-border);
    transition: all 0.25s ease;
    aspect-ratio: 3/4;
    text-decoration: none;
}

.e18-model-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(255, 45, 85, 0.2);
    border-color: var(--e18-pink);
}

.e18-model-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.e18-model-live-badge {
    position: absolute;
    top: 10px;
    left: 10px;
    background: var(--e18-green);
    color: #000;
    font-size: 11px;
    font-weight: 800;
    padding: 4px 10px;
    border-radius: 20px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    z-index: 2;
    animation: e18-live-pulse 2s ease-in-out infinite;
}

@keyframes e18-live-pulse {
    0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.4); }
    50% { opacity: 0.9; box-shadow: 0 0 0 8px rgba(34, 197, 94, 0); }
}

.e18-model-info {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 40px 12px 12px;
    background: linear-gradient(to top, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.5) 60%, transparent 100%);
    z-index: 1;
}

.e18-model-name {
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.e18-model-meta {
    color: var(--e18-text-muted);
    font-size: 12px;
    margin-top: 2px;
}

/* ═══════════════════════════════════════════════
   Venues Section v3.1
   ═══════════════════════════════════════════════ */
.e18-venues {
    margin: 48px 0;
    background: var(--e18-surface-2);
    border: 1px solid var(--e18-border);
    border-radius: var(--e18-radius);
    padding: 32px;
}

.e18-venues .e18-city-content {
    margin-bottom: 0;
}

.e18-venues h2 {
    font-size: 24px;
    font-weight: 700;
    margin: 0 0 20px;
    color: var(--e18-text);
}

.e18-venues h3 {
    font-size: 19px;
    font-weight: 600;
    margin: 24px 0 10px;
    color: var(--e18-pink);
}

.e18-venues h3:first-of-type {
    margin-top: 0;
}

/* ═══════════════════════════════════════════════
   Affairs Section v3.1
   ═══════════════════════════════════════════════ */
.e18-affairs-section {
    margin: 48px 0;
    background: linear-gradient(135deg, var(--e18-surface-2) 0%, rgba(26, 0, 32, 0.5) 100%);
    border: 1px solid rgba(255, 45, 85, 0.15);
    border-radius: var(--e18-radius);
    padding: 36px 32px;
}

.e18-affairs-section .e18-city-content {
    margin-bottom: 24px;
}

.e18-affairs-section h2 {
    font-size: 24px;
    font-weight: 700;
    margin: 0 0 20px;
    color: var(--e18-text);
}

.e18-affairs-section h3 {
    font-size: 19px;
    font-weight: 600;
    margin: 24px 0 10px;
    color: var(--e18-gold);
}

.e18-affairs-section h3:first-of-type {
    margin-top: 0;
}

.e18-affairs-cta {
    text-align: center;
    padding-top: 8px;
}

.e18-cta-affairs {
    background: linear-gradient(135deg, #8b0000 0%, #4a0000 100%);
    border: 1px solid rgba(255, 45, 85, 0.3);
}

.e18-cta-affairs:hover {
    background: linear-gradient(135deg, #a00000 0%, #5a0000 100%);
    box-shadow: 0 8px 32px rgba(139, 0, 0, 0.4);
}

/* Hide placeholder when live models load */
.e18-model-grid:has(.e18-model-card) .e18-model-placeholder {
    display: none;
}

/* Neighborhoods */
.e18-neighborhoods { margin:48px 0; }
.e18-neighborhoods h2 { font-size:24px; font-weight:700; margin:0 0 16px; }
.e18-neighborhoods h3 { font-size:18px; color:var(--e18-pink); margin:24px 0 8px; }

/* Dating Apps */
.e18-dating-apps { margin:48px 0; }
.e18-dating-apps h2 { font-size:24px; font-weight:700; margin:0 0 16px; }
.e18-dating-apps table { width:100%; border-collapse:collapse; margin:16px 0; }
.e18-dating-apps th { background:var(--e18-surface-2); color:var(--e18-pink); padding:12px 16px; text-align:left; font-size:14px; border-bottom:2px solid var(--e18-border); }
.e18-dating-apps td { padding:12px 16px; border-bottom:1px solid var(--e18-border); font-size:14px; color:#bbb; }
.e18-dating-apps tr:hover td { background:var(--e18-surface-2); }

/* Trends */
.e18-trends { margin:48px 0; }
.e18-trends h2 { font-size:24px; font-weight:700; margin:0 0 16px; }

/* Dating Pulse */
.e18-dating-pulse { margin:48px 0; background:var(--e18-surface-2); border:1px solid var(--e18-border); border-radius:var(--e18-radius); padding:32px; }
.e18-dating-pulse h2 { font-size:22px; font-weight:700; margin:0 0 20px; }
.e18-pulse-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.e18-pulse-item { background:var(--e18-surface-3); border:1px solid var(--e18-border); border-radius:var(--e18-radius-sm); padding:20px; text-align:center; }
.e18-pulse-emoji { font-size:28px; margin-bottom:8px; display:block; }
.e18-pulse-label { font-size:12px; color:var(--e18-text-muted); text-transform:uppercase; letter-spacing:1px; display:block; margin-bottom:4px; }
.e18-pulse-value { font-size:18px; font-weight:700; color:var(--e18-text); }
@media(max-width:768px) { .e18-pulse-grid { grid-template-columns:1fr; } }

/* Schema/LLM */
.e18-city-schema { display:none; }

/* ── Internal Profile Cards ────────────────────── */
.e18-internal-profiles { margin:48px 0; }
.e18-internal-profiles h2 { font-size:24px; font-weight:700; margin:0 0 8px; }
.e18-profile-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(140px, 1fr)); gap:12px; margin-top:16px; }
.e18-profile-card { display:block; border-radius:var(--e18-radius-sm); overflow:hidden; background:var(--e18-surface-2); border:1px solid var(--e18-border); transition:all .2s; text-decoration:none; }
.e18-profile-card:hover { border-color:var(--e18-pink); transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.4); }
.e18-profile-img-wrap { position:relative; }
.e18-profile-img-wrap img { width:100%; aspect-ratio:3/4; object-fit:cover; display:block; }
.e18-profile-badge { position:absolute; top:6px; left:6px; background:var(--e18-green); color:#fff; font-size:9px; font-weight:700; padding:2px 7px; border-radius:10px; text-transform:uppercase; letter-spacing:.5px; }
.e18-profile-hd { position:absolute; top:6px; right:6px; background:rgba(0,0,0,.6); color:#fff; font-size:9px; font-weight:600; padding:2px 5px; border-radius:4px; }
.e18-profile-info { padding:10px; }
.e18-profile-name { font-size:13px; font-weight:600; color:var(--e18-text); display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.e18-profile-meta { font-size:11px; color:var(--e18-text-muted); display:block; margin-top:2px; }

/* ── Reverse City Links (on model single pages) ── */
.e18-reverse-city-links { margin:32px 0; padding:24px; background:var(--e18-surface-2, #111); border:1px solid var(--e18-border, #2a2a2a); border-radius:12px; }
.e18-reverse-label { font-size:15px; font-weight:600; color:#f0f0f0; margin:0 0 12px; }
.e18-reverse-links { display:flex; flex-wrap:wrap; gap:8px; }
.e18-reverse-link { display:inline-block; background:rgba(255,45,85,.1); border:1px solid rgba(255,45,85,.2); color:#ff2d55; padding:8px 16px; border-radius:8px; font-size:13px; font-weight:600; text-decoration:none; transition:all .2s; }
.e18-reverse-link:hover { background:rgba(255,45,85,.2); border-color:#ff2d55; transform:translateY(-1px); }

/* ═══════════════════════════════════════════════
   HUB PAGES - Country & State Overview
   ═══════════════════════════════════════════════ */

/* Hub Page Layout */
.e18-hub-page { }
.e18-hub-hero { min-height:320px; }
.e18-hub-section { margin:48px 0; }
.e18-hub-section h2 { font-size:26px; font-weight:700; margin:0 0 12px; }

/* Hub Overview */
.e18-hub-overview { margin:48px 0; }
.e18-hub-overview h2 { font-size:24px; font-weight:700; margin:0 0 16px; }
.e18-hub-overview h3 { font-size:19px; font-weight:600; margin:28px 0 10px; color:var(--e18-pink); }

/* Hub Cities Grid */
.e18-hub-cities { margin:48px 0; }
.e18-hub-city-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(200px, 1fr)); gap:16px; }
.e18-hub-city-card { background:var(--e18-surface-2); border:1px solid var(--e18-border); border-radius:var(--e18-radius); padding:20px; transition:all .2s; display:block; text-decoration:none; }
.e18-hub-city-card:hover { border-color:var(--e18-pink); transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.3); }

/* Country Grid */
.e18-hub-country-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(220px, 1fr)); gap:16px; }
.e18-hub-country-card { background:var(--e18-surface-2); border:1px solid var(--e18-border); border-radius:var(--e18-radius); padding:24px; display:flex; align-items:center; gap:16px; transition:all .2s; text-decoration:none; }
.e18-hub-country-card:hover { border-color:var(--e18-pink); transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,.3); }
.e18-hub-country-flag { font-size:32px; }
.e18-hub-country-name { font-size:16px; font-weight:600; color:var(--e18-text); flex:1; }
.e18-hub-country-count { font-size:13px; color:var(--e18-text-muted); }

/* State Grid/List */
.e18-hub-state-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); gap:12px; }
.e18-hub-state-list { display:flex; flex-wrap:wrap; gap:10px; }
.e18-hub-state-card { background:var(--e18-surface-2); border:1px solid var(--e18-border); border-radius:var(--e18-radius-sm); padding:16px 20px; display:flex; align-items:center; justify-content:space-between; transition:all .2s; text-decoration:none; }
.e18-hub-state-card:hover { border-color:var(--e18-pink); background:var(--e18-surface-3); }
.e18-hub-state-item { display:inline-flex; align-items:center; gap:12px; background:var(--e18-surface-2); border:1px solid var(--e18-border); border-radius:var(--e18-radius-sm); padding:12px 16px; transition:all .2s; text-decoration:none; }
.e18-hub-state-item:hover { border-color:var(--e18-pink); }
.e18-hub-state-name { font-size:15px; font-weight:600; color:var(--e18-text); }
.e18-hub-state-meta { font-size:13px; color:var(--e18-text-muted); }
.e18-hub-state-arrow { color:var(--e18-pink); font-size:18px; }

/* Nearby States */
.e18-hub-nearby { margin:48px 0; }

/* Cross Links */
.e18-hub-crosslinks { margin:48px 0; }
.e18-hub-crosslink-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); gap:16px; margin-top:20px; }
.e18-hub-crosslink-card { background:var(--e18-surface-2); border:1px solid var(--e18-border); border-radius:var(--e18-radius); padding:24px; transition:all .2s; text-decoration:none; display:block; }
.e18-hub-crosslink-card:hover { border-color:var(--e18-pink); transform:translateY(-2px); }
.e18-hub-crosslink-icon { font-size:32px; display:block; margin-bottom:12px; }
.e18-hub-crosslink-card h4 { font-size:17px; font-weight:600; margin:0 0 6px; color:var(--e18-text); }
.e18-hub-crosslink-card p { font-size:14px; color:var(--e18-text-muted); margin:0; }

/* Featured Cards */
.e18-featured-card { position:relative; }
.e18-featured-card::before { content:"⭐"; position:absolute; top:10px; right:10px; font-size:16px; }

/* Enhanced Archive */
.e18-archive-enhanced .e18-city-container { padding:48px 24px; }

/* Responsive */
@media (max-width:768px) {
    .e18-hub-city-grid { grid-template-columns:repeat(2, 1fr); }
    .e18-hub-country-grid { grid-template-columns:1fr; }
    .e18-hub-state-grid { grid-template-columns:1fr; }
    .e18-hub-section h2 { font-size:22px; }
    .e18-hub-overview h2 { font-size:20px; }
}

@media (max-width:480px) {
    .e18-hub-city-grid { grid-template-columns:1fr; }
    .e18-hub-country-card { padding:16px; }
}
