/* ═══ RESET & VARIABLES ═══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#fafaf9;--surface:#fff;--border:#e7e5e4;
  --text:#1c1917;--text-secondary:#78716c;--text-tertiary:#a8a29e;
  --accent:#e11d48;--accent-soft:#fff1f2;--accent-hover:#be123c;
  --green:#16a34a;
  --radius:12px;--radius-sm:8px;
  --shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 12px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.04);
  --shadow-lg:0 8px 30px rgba(0,0,0,.1);
  --max-w:1160px;
}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}

/* ═══ NAV ═══ */
.nav{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200;backdrop-filter:blur(12px);background:rgba(255,255,255,.95)}
.nav-inner{max-width:var(--max-w);margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:var(--accent);letter-spacing:-.3px}
.logo span{color:var(--text)}
.nav-menu{display:flex;gap:4px;align-items:center}
.nav-item{position:relative;padding:8px 16px;font-size:14px;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all .2s;cursor:pointer}
.nav-item:hover{background:var(--bg);color:var(--text)}
.nav-item svg{width:12px;height:12px;margin-left:4px;vertical-align:middle;opacity:.5}
.nav-dropdown{position:absolute;top:100%;left:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:16px;min-width:280px;display:none;z-index:300}
.nav-item:hover .nav-dropdown{display:block}
.nav-dropdown-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-tertiary);padding:4px 8px;margin-bottom:8px}
.nav-dropdown a{display:block;padding:8px 12px;font-size:13px;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all .15s}
.nav-dropdown a:hover{background:var(--accent-soft);color:var(--accent)}
.nav-dropdown-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.nav-cta{background:var(--accent);color:#fff;padding:8px 20px;border-radius:80px;font-size:13px;font-weight:600;transition:background .2s;margin-left:12px}
.nav-cta:hover{background:var(--accent-hover)}

/* ═══ BANNER ═══ */
.banner{background:linear-gradient(135deg,#1c1917,#292524,#1c1917);color:#fff;position:relative;overflow:hidden}
.banner::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 75% 50%,rgba(225,29,72,.12),transparent 55%)}
.banner-inner{max-width:var(--max-w);margin:0 auto;padding:48px 24px 56px;position:relative;z-index:1}
.breadcrumb{font-size:13px;color:rgba(255,255,255,.4);display:flex;gap:8px;margin-bottom:24px}
.breadcrumb a{color:rgba(255,255,255,.6);transition:color .2s}
.breadcrumb a:hover{color:#fff}
.banner-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.85);font-size:12px;font-weight:600;padding:6px 14px;border-radius:80px;margin-bottom:16px;text-transform:uppercase;letter-spacing:.5px}
.banner h1{font-family:'Playfair Display',serif;font-size:clamp(32px,4.5vw,48px);font-weight:700;line-height:1.12;letter-spacing:-.5px;margin-bottom:14px}
.banner h1 em{font-style:normal;color:var(--accent)}
.banner>div>p{font-size:16px;color:rgba(255,255,255,.55);max-width:580px;line-height:1.7;margin-bottom:28px}
.banner-btns{display:flex;gap:12px;flex-wrap:wrap}
.banner-btn{padding:12px 26px;border-radius:80px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex;align-items:center;gap:6px}
.banner-btn-primary{background:var(--accent);color:#fff}
.banner-btn-primary:hover{background:var(--accent-hover)}
.banner-btn-secondary{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.2)}
.banner-btn-secondary:hover{background:rgba(255,255,255,.15)}
.banner-facts{display:flex;gap:36px;margin-top:36px;padding-top:28px;border-top:1px solid rgba(255,255,255,.08);flex-wrap:wrap}
.banner-fact-num{font-family:'Playfair Display',serif;font-size:26px;font-weight:700}
.banner-fact-label{font-size:12px;color:rgba(255,255,255,.4);margin-top:2px}

/* ═══ SECTIONS ═══ */
.section{max-width:var(--max-w);margin:0 auto;padding:64px 24px}
.section-header{margin-bottom:36px;display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px}
.section-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin-bottom:8px}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(22px,3vw,30px);font-weight:700;letter-spacing:-.3px}
.section-subtitle{font-size:15px;color:var(--text-secondary);margin-top:8px;max-width:520px}
.section-link{font-size:13px;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:4px;transition:gap .2s;white-space:nowrap}
.section-link:hover{gap:8px}
.divider{border:none;border-top:1px solid var(--border);max-width:var(--max-w);margin:0 auto}

/* ═══ DEMOGRAPHICS BAR ═══ */
.demo-bar{max-width:var(--max-w);margin:0 auto;padding:0 24px 48px}
.demo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}
.demo-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center}
.demo-num{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;color:var(--accent)}
.demo-label{font-size:12px;color:var(--text-secondary);margin-top:4px;line-height:1.3}

/* ═══ CHARTS ═══ */
.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:var(--max-w);margin:0 auto;padding:0 24px 64px}
.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px}
.chart-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;margin-bottom:24px}
.bar-chart{display:flex;flex-direction:column;gap:14px}
.bar-row{display:flex;align-items:center;gap:12px}
.bar-label{width:100px;font-size:12px;font-weight:600;color:var(--text-secondary);text-align:right;flex-shrink:0}
.bar-track{flex:1;height:28px;background:var(--bg);border-radius:80px;overflow:hidden}
.bar-fill{height:100%;border-radius:80px;display:flex;align-items:center;justify-content:flex-end;padding-right:10px;font-size:11px;font-weight:700;color:#fff;min-width:40px;transition:width .8s ease}
.bar-fill.c1{background:linear-gradient(90deg,#e11d48,#f43f5e)}
.bar-fill.c2{background:linear-gradient(90deg,#7c3aed,#8b5cf6)}
.bar-fill.c3{background:linear-gradient(90deg,#0891b2,#06b6d4)}
.bar-fill.c4{background:linear-gradient(90deg,#059669,#10b981)}
.bar-fill.c5{background:linear-gradient(90deg,#d97706,#f59e0b)}
.bar-fill.c6{background:linear-gradient(90deg,#dc2626,#ef4444)}
.bar-fill.c7{background:linear-gradient(90deg,#4f46e5,#6366f1)}
.donut-wrap{display:flex;align-items:center;gap:32px}
.donut-svg{width:160px;height:160px;flex-shrink:0}
.donut-legend{display:flex;flex-direction:column;gap:10px}
.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}
.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.legend-item strong{color:var(--text);font-weight:700}

/* ═══ PROFILES — 4 columns fixed, hover swap ═══ */
.profiles-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.profile-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .25s;cursor:pointer}
.profile-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:transparent}
.profile-img{width:100%;aspect-ratio:3/3.5;position:relative;overflow:hidden}
.profile-img .img-main{position:absolute;inset:0;background-size:cover;background-position:center;transition:opacity .35s ease}
.profile-img .img-hover{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .35s ease}
.profile-card:hover .img-main{opacity:0}
.profile-card:hover .img-hover{opacity:1}
.profile-online{position:absolute;top:12px;right:12px;width:10px;height:10px;background:var(--green);border-radius:50%;border:2px solid var(--surface);box-shadow:0 0 0 3px rgba(22,163,74,.2);z-index:2}
.profile-badge{position:absolute;top:12px;left:12px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:80px;text-transform:uppercase;letter-spacing:.5px;z-index:2}
.profile-body{padding:16px}
.profile-name-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.profile-name{font-size:16px;font-weight:700}
.profile-age{font-size:14px;color:var(--text-tertiary);font-weight:500}
.profile-location{font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:4px}
.profile-location svg{width:12px;height:12px;color:var(--text-tertiary);flex-shrink:0}
.profile-cta{display:block;width:100%;text-align:center;padding:10px;background:var(--accent-soft);color:var(--accent);font-size:13px;font-weight:600;border-top:1px solid var(--border);transition:all .2s}
.profile-card:hover .profile-cta{background:var(--accent);color:#fff}

/* ═══ DATING SITES ═══ */
.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}
.ds-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .25s;position:relative}
.ds-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--accent)}
.ds-medal{position:absolute;top:16px;left:16px;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;z-index:2}
.ds-medal.gold{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#78350f}
.ds-medal.silver{background:linear-gradient(135deg,#94a3b8,#cbd5e1);color:#334155}
.ds-medal.bronze{background:linear-gradient(135deg,#d97706,#f59e0b);color:#78350f}
.ds-top{padding:32px 24px 20px;text-align:center}
.ds-logo{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;margin-bottom:4px}
.ds-rating{display:flex;align-items:center;justify-content:center;gap:4px;margin-bottom:8px}
.ds-stars{color:#f59e0b;font-size:14px;letter-spacing:1px}
.ds-score{font-size:14px;font-weight:700;color:var(--text)}
.ds-type{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-tertiary)}
.ds-stats{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--border)}
.ds-stat{padding:14px 16px;text-align:center;border-right:1px solid var(--border)}
.ds-stat:last-child{border-right:none}
.ds-stat-num{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:var(--accent)}
.ds-stat-label{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.ds-cta{display:block;text-align:center;padding:14px;background:var(--accent);color:#fff;font-size:14px;font-weight:600;transition:background .2s}
.ds-card:hover .ds-cta{background:var(--accent-hover)}

/* ═══ CITIES ═══ */
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.city-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;display:flex;align-items:center;justify-content:space-between;transition:all .2s}
.city-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-1px)}
.city-info h3{font-size:16px;font-weight:700;margin-bottom:2px}
.city-info p{font-size:12px;color:var(--text-tertiary)}
.city-card .arrow{color:var(--text-tertiary);font-size:18px;transition:color .2s}
.city-card:hover .arrow{color:var(--accent)}

/* ═══ SEO TEXT — full width like other sections ═══ */
.seo-section{max-width:var(--max-w);margin:0 auto;padding:64px 24px}
.seo-content h2{font-family:'Playfair Display',serif;font-size:26px;font-weight:700;margin-bottom:14px;margin-top:40px;letter-spacing:-.3px}
.seo-content h2:first-child{margin-top:0}
.seo-content h3{font-size:18px;font-weight:700;margin-top:28px;margin-bottom:10px}
.seo-content p{font-size:15px;color:var(--text-secondary);line-height:1.8;margin-bottom:16px}
.seo-content ul{margin:0 0 16px 20px;color:var(--text-secondary);font-size:15px;line-height:1.8}
.seo-content li{margin-bottom:6px}

/* ═══ FAQ ═══ */
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.faq-q{padding:20px 24px;font-weight:600;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:color .2s}
.faq-q:hover{color:var(--accent)}
.faq-q span{transition:transform .2s;font-size:20px;color:var(--text-tertiary)}
.faq-item.open .faq-q span{transform:rotate(45deg)}
.faq-a{padding:0 24px 20px;font-size:14px;color:var(--text-secondary);line-height:1.7;display:none}
.faq-item.open .faq-a{display:block}

/* ═══ INTERNAL LINKS ═══ */
.il{max-width:var(--max-w);margin:0 auto;padding:48px 24px}
.il-title{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:16px}
.il-grid{display:flex;flex-wrap:wrap;gap:10px}
.il-grid a{font-size:13px;padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:80px;color:var(--text-secondary);font-weight:500;transition:all .2s}
.il-grid a:hover{border-color:var(--accent);color:var(--accent)}

/* ═══ FOOTER ═══ */
.footer{background:var(--text);color:rgba(255,255,255,.5);margin-top:40px}
.footer-inner{max-width:var(--max-w);margin:0 auto;padding:48px 24px 28px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
.footer-brand{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:#fff;margin-bottom:12px}
.footer-brand-desc{font-size:13px;line-height:1.6}
.footer-col-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.7);margin-bottom:16px}
.footer-col a{display:block;font-size:13px;padding:4px 0;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{max-width:var(--max-w);margin:0 auto;padding:20px 24px;border-top:1px solid rgba(255,255,255,.08);font-size:12px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}

/* ═══ CITY PAGE: TWO-COLUMN LAYOUT ═══ */
.layout{max-width:var(--max-w);margin:0 auto;padding:56px 24px;display:grid;grid-template-columns:1fr 340px;gap:48px;align-items:start}

/* Article */
.article-body h2{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;margin-bottom:14px;margin-top:44px;letter-spacing:-.3px}
.article-body h2:first-child{margin-top:0}
.article-body h3{font-size:17px;font-weight:700;margin-top:28px;margin-bottom:10px}
.article-body p{font-size:15px;color:var(--text-secondary);line-height:1.75;margin-bottom:16px}
.article-body ul,.article-body ol{margin:0 0 16px 20px;color:var(--text-secondary);font-size:15px;line-height:1.75}
.article-body li{margin-bottom:6px}

/* Sidebar */
.sidebar{position:sticky;top:84px}
.sidebar-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;margin-bottom:20px}
.sidebar-card-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--accent);margin-bottom:12px}
.sidebar-card h3{font-size:17px;font-weight:700;margin-bottom:8px}
.sidebar-card p{font-size:13px;color:var(--text-secondary);line-height:1.6;margin-bottom:16px}
.sidebar-cta{display:block;text-align:center;background:var(--accent);color:#fff;padding:12px 20px;border-radius:80px;font-size:14px;font-weight:600;transition:background .2s;margin-bottom:10px}
.sidebar-cta:hover{background:var(--accent-hover)}
.sidebar-card .rating{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}
.sidebar-card .rating strong{color:var(--text)}
.sidebar-card .stars{color:#f59e0b;letter-spacing:1px}

/* Nearby cities */
.nearby-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.nearby-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;transition:all .2s;font-size:14px;font-weight:600}
.nearby-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}
.nearby-card .dist{font-size:12px;color:var(--text-tertiary);font-weight:400}

/* ═══ RESPONSIVE ═══ */
@media(max-width:900px){
  .layout{grid-template-columns:1fr}
  .sidebar{position:static;order:1}
}
@media(max-width:768px){
  .nav-menu{display:none}
  .profiles-grid{grid-template-columns:1fr}
  .sites-grid{grid-template-columns:1fr}
  .charts-grid{grid-template-columns:1fr}
  .donut-wrap{flex-direction:column;align-items:center}
  .footer-inner{grid-template-columns:1fr 1fr}
  .banner-facts{gap:20px}
  .section-header{flex-direction:column;align-items:flex-start}
  .demo-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .footer-inner{grid-template-columns:1fr}
  .demo-grid{grid-template-columns:1fr 1fr}
}
