/* Valfakta.com — Data-driven political news. Dark navy + electric blue accent */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Playfair+Display:wght@700;800&display=swap');

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#0a1628;--navy-mid:#12203d;--navy-light:#1a2f55;
  --accent:#3b82f6;--accent-light:#60a5fa;--accent-glow:rgba(59,130,246,0.15);
  --text:#e2e8f0;--text-dim:#94a3b8;--text-dark:#1e293b;
  --surface:#111827;--surface-card:#1e293b;--surface-hover:#263450;
  --border:rgba(255,255,255,0.08);--border-accent:rgba(59,130,246,0.3);
  --white:#fff;--red:#ef4444;--green:#22c55e;--yellow:#eab308;
}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--navy);color:var(--text);min-height:100vh;line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased}

/* === NAVIGATION === */
.site-header{position:sticky;top:0;z-index:100;background:rgba(10,22,40,0.92);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.site-header .header-inner{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:64px}
.site-header .logo a{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:800;color:var(--white);text-decoration:none;letter-spacing:-0.5px}
.site-header .logo span{color:var(--accent)}
.site-header nav{display:flex;gap:4px;align-items:center}
.site-header nav a{color:var(--text-dim);text-decoration:none;font-size:0.875rem;font-weight:500;padding:8px 14px;border-radius:8px;transition:all 0.2s}
.site-header nav a:hover,.site-header nav a.active{color:var(--white);background:var(--accent-glow)}
.live-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(239,68,68,0.15);color:var(--red);font-size:0.75rem;font-weight:600;padding:4px 10px;border-radius:20px;margin-left:12px}
.live-badge::before{content:'';width:6px;height:6px;background:var(--red);border-radius:50%;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}

/* === HERO === */
.hero{position:relative;overflow:hidden;padding:80px 24px 60px;text-align:center;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 50%,var(--navy-light) 100%)}
.hero::before{content:'';position:absolute;inset:0;background:url('http://img.b2bpic.net/premium-photo/parliament-building-riksdag-stockholm-sweden_483040-4883.jpg') center/cover no-repeat;opacity:0.12}
.hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 0%,var(--navy) 70%)}
.hero-content{position:relative;z-index:2;max-width:800px;margin:0 auto}
.hero-label{display:inline-flex;align-items:center;gap:8px;background:var(--accent-glow);border:1px solid var(--border-accent);color:var(--accent-light);font-size:0.8rem;font-weight:600;padding:6px 16px;border-radius:20px;margin-bottom:24px;text-transform:uppercase;letter-spacing:0.5px}
.hero h1{font-family:'Playfair Display',serif;font-size:3.2rem;font-weight:800;color:var(--white);line-height:1.15;margin-bottom:20px;letter-spacing:-1px}
.hero p{font-size:1.15rem;color:var(--text-dim);max-width:600px;margin:0 auto;line-height:1.7}

/* === STATS BAR === */
.stats-bar{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:20px 24px}
.stats-bar-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat-item{text-align:center}
.stat-value{font-size:1.8rem;font-weight:800;color:var(--accent-light);font-variant-numeric:tabular-nums}
.stat-label{font-size:0.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-top:4px}

/* === MAIN CONTENT === */
.main-content{max-width:1200px;margin:0 auto;padding:48px 24px}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.section-header h2{font-family:'Playfair Display',serif;font-size:1.6rem;color:var(--white);font-weight:700}
.section-header .view-all{color:var(--accent);font-size:0.875rem;font-weight:500;text-decoration:none}
.section-header .view-all:hover{text-decoration:underline}

/* === ARTICLE GRID === */
.article-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-bottom:48px}
.article-card{background:var(--surface-card);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:all 0.3s ease;text-decoration:none;color:inherit;display:flex;flex-direction:column}
.article-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,0.3);border-color:var(--border-accent)}
.card-image{height:180px;background:linear-gradient(135deg,var(--navy-mid),var(--navy-light));position:relative;overflow:hidden}
.card-image img{width:100%;height:100%;object-fit:cover;opacity:0.7;transition:opacity 0.3s}
.article-card:hover .card-image img{opacity:0.9}
.card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.tag{display:inline-block;font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.8px;padding:4px 10px;border-radius:4px;margin-bottom:12px;width:fit-content}
.tag-opinion{background:rgba(239,68,68,0.15);color:var(--red)}
.tag-guide{background:rgba(59,130,246,0.15);color:var(--accent-light)}
.tag-parti{background:rgba(168,85,247,0.15);color:#c084fc}
.tag-historik{background:rgba(234,179,8,0.15);color:var(--yellow)}
.article-card h3{font-size:1.1rem;font-weight:700;color:var(--white);line-height:1.4;margin-bottom:10px}
.article-card p{font-size:0.9rem;color:var(--text-dim);line-height:1.6;flex:1}
.card-meta{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
.date{font-size:0.8rem;color:var(--text-dim);font-variant-numeric:tabular-nums}
.read-more{color:var(--accent);font-size:0.8rem;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}

/* === FEATURED / LARGE CARD === */
.featured-card{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr;border-radius:16px;overflow:hidden;background:var(--surface-card);border:1px solid var(--border)}
.featured-card .card-image{height:100%;min-height:280px}
.featured-card .card-body{padding:32px;justify-content:center}
.featured-card h3{font-size:1.4rem}

/* === QUOTE BOX === */
.quote-box{background:var(--surface-card);border-left:4px solid var(--accent);padding:28px 32px;margin:40px 0;border-radius:0 12px 12px 0;font-style:italic;color:var(--text-dim);font-size:1.05rem;line-height:1.8}

/* === ARTICLE CONTENT (subpages) === */
.article-content{max-width:760px;margin:0 auto;padding:48px 24px}
.article-content h1{font-family:'Playfair Display',serif;font-size:2.4rem;color:var(--white);line-height:1.2;margin-bottom:16px;letter-spacing:-0.5px}
.article-content h2{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--white);margin:40px 0 16px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.article-content h3{font-size:1.15rem;color:var(--accent-light);margin:28px 0 10px;font-weight:600}
.article-content p{color:var(--text-dim);margin-bottom:18px;font-size:1rem;line-height:1.8}
.article-content ul,.article-content ol{margin:0 0 20px 24px;color:var(--text-dim)}
.article-content li{margin-bottom:8px}
.article-content a{color:var(--accent-light);text-decoration:underline;text-decoration-color:rgba(96,165,250,0.3);text-underline-offset:2px}
.article-content a:hover{text-decoration-color:var(--accent-light)}
.article-content table{width:100%;border-collapse:collapse;margin:24px 0;border-radius:12px;overflow:hidden}
.article-content thead tr{background:var(--navy-light)}
.article-content th{text-align:left;padding:12px 16px;font-size:0.85rem;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:0.5px}
.article-content td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:0.95rem;color:var(--text-dim)}
.article-content tr:hover td{background:rgba(255,255,255,0.02)}
.breadcrumb{font-size:0.85rem;color:var(--text-dim);margin-bottom:24px}
.breadcrumb a{color:var(--text-dim);text-decoration:none}
.breadcrumb a:hover{color:var(--accent-light)}

/* === FOOTER === */
.site-footer{background:var(--surface);border-top:1px solid var(--border);margin-top:80px}
.footer-inner{max-width:1200px;margin:0 auto;padding:48px 24px}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:40px}
.footer-brand .logo{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:800;color:var(--white);margin-bottom:12px}
.footer-brand .logo span{color:var(--accent)}
.footer-brand p{color:var(--text-dim);font-size:0.9rem;line-height:1.6;max-width:300px}
.footer-links h4{color:var(--text);font-size:0.8rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px}
.footer-links a{display:block;color:var(--text-dim);text-decoration:none;font-size:0.9rem;padding:4px 0;transition:color 0.2s}
.footer-links a:hover{color:var(--accent-light)}
.footer-bottom{border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;align-items:center}
.footer-bottom p{color:var(--text-dim);font-size:0.8rem}
.footer-note{font-size:0.75rem;color:var(--text-dim);opacity:0.6}

/* === RESPONSIVE === */
@media(max-width:768px){
  .hero h1{font-size:2rem}
  .hero{padding:60px 20px 40px}
  .stats-bar-inner{grid-template-columns:repeat(2,1fr);gap:16px}
  .featured-card{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .site-header .header-inner{height:56px}
  .site-header .logo a{font-size:1.2rem}
  .site-header nav a{padding:6px 10px;font-size:0.8rem}
  .article-content h1{font-size:1.8rem}
}
@media(max-width:480px){
  .hero h1{font-size:1.6rem}
  .site-header nav{gap:0}
  .site-header nav a{padding:6px 8px;font-size:0.75rem}
  .article-grid{grid-template-columns:1fr}
  .stats-bar-inner{grid-template-columns:repeat(2,1fr)}
}

/* Mobile nav toggle */
.nav-toggle{display:none;background:none;border:none;color:var(--white);font-size:1.5rem;cursor:pointer}
@media(max-width:640px){
  .nav-toggle{display:block}
  .site-header nav{display:none;position:absolute;top:64px;left:0;right:0;background:var(--navy);flex-direction:column;padding:16px;border-bottom:1px solid var(--border)}
  .site-header nav.open{display:flex}
}

/* === INNER PAGE STYLES === */
.content-main { max-width: 860px; margin: 0 auto; padding: 40px 24px 80px; }
.page-hero { background: linear-gradient(135deg, var(--navy-mid) 0%, var(--navy-light) 100%); color: #fff; padding: 60px 24px; margin-bottom: 48px; }
.page-hero-inner { max-width: 860px; margin: 0 auto; }
.page-hero h1 { font-family: 'Playfair Display', serif; font-size: clamp(1.8rem, 4vw, 2.8rem); margin: 0 0 12px; font-weight: 800; }
.page-hero .subtitle { font-size: 1.1rem; opacity: 0.75; margin: 0; max-width: 600px; color: var(--text-dim); }
.article-body { font-size: 1.05rem; line-height: 1.8; color: var(--text-dim); }
.article-body h2 { font-family: 'Playfair Display', serif; font-size: 1.5rem; margin: 40px 0 16px; padding-bottom: 8px; border-bottom: 1px solid var(--border-accent); color: var(--white); }
.article-body h3 { font-size: 1.2rem; margin: 28px 0 12px; color: var(--accent-light); }
.article-body p { margin: 0 0 20px; }
.article-body a { color: var(--accent-light); text-decoration: underline; text-decoration-color: rgba(96,165,250,0.3); text-underline-offset: 2px; }
.article-body a:hover { text-decoration-color: var(--accent-light); }
.article-body ul, .article-body ol { margin: 0 0 20px 24px; color: var(--text-dim); }
.article-body li { margin-bottom: 8px; }
.article-body table { width: 100%; border-collapse: collapse; margin: 24px 0; border-radius: 12px; overflow: hidden; }
.article-body thead tr { background: var(--navy-light); }
.article-body th { text-align: left; padding: 12px 16px; font-size: 0.85rem; font-weight: 600; color: var(--text); text-transform: uppercase; letter-spacing: 0.5px; }
.article-body td { padding: 12px 16px; border-bottom: 1px solid var(--border); font-size: 0.95rem; color: var(--text-dim); }
.article-body tr:hover td { background: rgba(255,255,255,0.02); }
.highlight-quote { border-left: 4px solid var(--accent); padding: 16px 24px; margin: 32px 0; background: rgba(59,130,246,0.06); font-style: italic; font-size: 1.1rem; color: var(--text); border-radius: 0 8px 8px 0; }
.fact-box { background: var(--navy-light); color: #fff; padding: 24px; border-radius: 8px; margin: 32px 0; border: 1px solid var(--border-accent); }
.fact-box h3 { margin: 0 0 12px; font-size: 1rem; text-transform: uppercase; letter-spacing: 0.05em; opacity: 0.8; color: var(--accent-light); }
.fact-box p { margin: 0; font-size: 1.2rem; font-weight: 600; }
.topic-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 20px; margin: 32px 0; }
.topic-card { background: var(--surface-card); border: 1px solid var(--border); border-radius: 10px; padding: 20px; transition: all 0.2s; }
.topic-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,0.3); border-color: var(--border-accent); }
.topic-card h3 { margin: 0 0 8px; font-size: 1rem; color: var(--white); }
.topic-card p { margin: 0; font-size: 0.9rem; color: var(--text-dim); line-height: 1.6; }
.party-color { display: inline-block; width: 4px; height: 100%; border-radius: 4px; margin-right: 12px; }
.topic-card .party-tag { display: inline-block; font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.8px; padding: 3px 8px; border-radius: 4px; margin-bottom: 10px; }
.step-list { counter-reset: step; list-style: none; padding: 0; margin: 32px 0; }
.step-list li { counter-increment: step; position: relative; padding: 20px 20px 20px 64px; margin-bottom: 16px; background: var(--surface-card); border: 1px solid var(--border); border-radius: 10px; }
.step-list li::before { content: counter(step); position: absolute; left: 16px; top: 18px; width: 32px; height: 32px; background: var(--accent); color: var(--white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 0.9rem; }
.cross-link { display: inline-flex; align-items: center; gap: 8px; background: var(--accent-glow); border: 1px solid var(--border-accent); color: var(--accent-light); padding: 12px 20px; border-radius: 8px; text-decoration: none; font-weight: 600; margin: 24px 0; transition: all 0.2s; }
.cross-link:hover { background: var(--accent); color: var(--white); }
