/*
Theme Name: PRU16 Theme
Text Domain: pru16-theme
Version: 1.0.0
*/

:root{
	--color-ink:#2D3748;
	--color-primary:#003399;
	--color-accent:#00A3C4;
	--color-bg:#F7FAFC;
	--color-surface:#FFFFFF;
	--color-border:#E2E8F0;
	--shadow-card:0 4px 12px rgba(45,55,72,.12);
	--radius:14px;
	--container:1200px;
	--font:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Arial;
}

html{box-sizing:border-box}
*,*:before,*:after{box-sizing:inherit}
body{
	margin:0;
	font-family:var(--font);
	color:var(--color-ink);
	background:var(--color-bg);
	line-height:1.55;
}
a{color:inherit}
a:hover{color:var(--color-accent)}
img{max-width:100%;height:auto}
input,button,select,textarea{font:inherit}

.container{max-width:var(--container);margin:0 auto;padding:0 18px}

.site-header{
	position:sticky;
	top:0;
	z-index:20;
	background:var(--color-ink);
	color:#fff;
	box-shadow:0 2px 10px rgba(0,0,0,.12);
}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}
.site-title{margin:0;font-size:18px;letter-spacing:.3px}
.site-title a{text-decoration:none;color:#fff}
.site-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:14px;flex-wrap:wrap}
.site-nav a{text-decoration:none;color:#fff;opacity:.92}
.site-nav a:hover{opacity:1;color:#fff}

.lang-toggle{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.06)}
.lang-toggle__btn{border:0;background:transparent;color:#fff;opacity:.88;cursor:pointer;padding:2px 4px;border-radius:8px}
.lang-toggle__btn:hover{opacity:1;background:rgba(255,255,255,.10)}
.lang-toggle__btn.is-active{opacity:1;background:rgba(0,163,196,.22)}
.lang-toggle__sep{opacity:.45}

.main{padding:24px 0 60px}

.grid{display:grid;gap:16px}
.grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid--4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media(max-width:980px){.grid--3,.grid--4{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:680px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}

.card{
	background:var(--color-surface);
	border:1px solid var(--color-border);
	box-shadow:var(--shadow-card);
	border-radius:var(--radius);
	padding:20px;
}
.card__title{margin:0 0 10px;font-size:18px}
.muted{opacity:.75}
.pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--color-border);padding:6px 10px;border-radius:999px;background:#fff}
.kbd{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas; font-size:12px;border:1px solid var(--color-border);padding:2px 6px;border-radius:8px;background:#fff}

.candidate-head{display:flex;gap:14px;align-items:center}
.candidate-head__avatar img{width:66px;height:66px;border-radius:16px;object-fit:cover;border:1px solid var(--color-border);background:#fff}
.candidate-head__main{min-width:0}

.pru16-party-logo{
	height:22px;
	width:auto;
	vertical-align:middle;
	margin-left:8px;
}

.candidate-mini{display:flex;gap:12px;align-items:center;margin-bottom:10px}
.candidate-mini__avatar img{width:44px;height:44px;border-radius:14px;object-fit:cover;border:1px solid var(--color-border);background:#fff}
.candidate-mini__main{min-width:0}

.btn{
	display:inline-flex;
	align-items:center;
	justify-content:center;
	gap:8px;
	border-radius:999px;
	border:1px solid var(--color-border);
	padding:10px 14px;
	background:#fff;
	color:var(--color-ink);
	cursor:pointer;
	transition:transform .06s ease,opacity .15s ease,background .15s ease,border-color .15s ease;
	user-select:none;
	text-decoration:none;
}
.btn:active{transform:translateY(1px)}
.btn--accent{background:var(--color-primary);border-color:rgba(0,51,153,.35);color:#fff}
.btn--accent:hover{background:#002b80}
.btn--data{background:var(--color-accent);border-color:rgba(0,163,196,.35);color:#fff}
.btn--data:hover{background:#0094b1}
.btn[disabled]{cursor:not-allowed;opacity:.6;transform:none}
.btn__spinner{
	width:14px;
	height:14px;
	border-radius:999px;
	border:2px solid rgba(255,255,255,.55);
	border-top-color:#fff;
	animation:spin .9s linear infinite;
	display:none;
}
.btn.is-loading .btn__spinner{display:inline-block}
.btn.is-loading .btn__label{opacity:.9}
@keyframes spin{to{transform:rotate(360deg)}}

.field{display:flex;flex-direction:column;gap:8px}
.field__label{font-size:13px;opacity:.8}
.field__input{
	border:1px solid var(--color-border);
	border-radius:12px;
	padding:11px 12px;
	background:#fff;
	outline:none;
}
.field__input:focus{border-color:rgba(0,163,196,.55);box-shadow:0 0 0 3px rgba(0,163,196,.14)}
.field__input--search{padding-left:40px}

.searchbox{position:relative}
.searchbox__icon{
	position:absolute;
	left:14px;
	top:50%;
	transform:translateY(-50%);
	width:18px;
	height:18px;
	background:rgba(45,55,72,.55);
	-webkit-mask:url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20viewBox%3D%270%200%2024%2024%27%3E%3Cpath%20fill%3D%27%23000%27%20d%3D%27M10%202a8%208%200%201%200%205.293%2014.293l4.707%204.707a1%201%200%200%200%201.414-1.414l-4.707-4.707A8%208%200%200%200%2010%202m0%202a6%206%200%201%201%200%2012a6%206%200%200%201%200-12%27/%3E%3C/svg%3E") center/contain no-repeat;
	mask:url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20viewBox%3D%270%200%2024%2024%27%3E%3Cpath%20fill%3D%27%23000%27%20d%3D%27M10%202a8%208%200%201%200%205.293%2014.293l4.707%204.707a1%201%200%200%200%201.414-1.414l-4.707-4.707A8%208%200%200%200%2010%202m0%202a6%206%200%201%201%200%2012a6%206%200%200%201%200-12%27/%3E%3C/svg%3E") center/contain no-repeat;
	opacity:.9;
}

.search-dropdown{
	position:absolute;
	left:0;
	right:0;
	top:calc(100% + 8px);
	background:#fff;
	border:1px solid var(--color-border);
	border-radius:14px;
	box-shadow:0 10px 24px rgba(45,55,72,.14);
	padding:6px;
	display:none;
	z-index:40;
}
.search-dropdown.is-open{display:block}
.search-dropdown__item{
	display:grid;
	grid-template-columns:70px 1fr auto;
	gap:10px;
	align-items:center;
	padding:10px 10px;
	border-radius:12px;
	text-decoration:none;
	color:var(--color-ink);
}
.search-dropdown__item:hover{background:rgba(0,163,196,.08)}
.search-dropdown__code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas;font-size:12px;opacity:.82}
.search-dropdown__title{font-weight:650}
.search-dropdown__state{font-size:12px;opacity:.72}

.pill-row{display:flex;flex-wrap:wrap;gap:10px}
.pill--action{cursor:pointer}
.pill--action.is-active{border-color:rgba(0,163,196,.55);box-shadow:0 0 0 3px rgba(0,163,196,.14)}
.pill--action:hover{border-color:rgba(0,163,196,.40)}

.hero{
	width:100vw;
	margin-left:calc(50% - 50vw);
	margin-right:calc(50% - 50vw);
	background:linear-gradient(135deg,#EDF2F7,#F7FAFC);
	border-top:1px solid var(--color-border);
	border-bottom:1px solid var(--color-border);
	padding:34px 0;
}
.hero__inner{display:flex;flex-direction:column;gap:10px}
.hero__title{font-size:26px;font-weight:800;letter-spacing:.2px}
.hero__subtitle{max-width:780px;opacity:.78}

.card--featured{background:linear-gradient(135deg,rgba(45,55,72,.04),rgba(0,163,196,.06))}
.card--featured-candidate{border-color:rgba(234,179,8,.75);box-shadow:0 4px 18px rgba(234,179,8,.12)}
.home-map{display:grid;grid-template-columns:1.25fr .75fr;gap:16px;align-items:stretch}
.home-map--compact{grid-template-columns:1fr}
.home-map__art{min-height:200px;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.7)}
.home-map__actions{display:flex;flex-direction:column;justify-content:space-between}
.home-map__actions--full{gap:14px;justify-content:flex-start}
.home-map__cta{display:flex;justify-content:flex-start}
@media(max-width:980px){.home-map{grid-template-columns:1fr}.home-map__art{min-height:180px}}

.msia-map__region{
	fill:rgba(255,255,255,.72);
	stroke:rgba(45,55,72,.22);
	stroke-width:1;
	transition:fill .15s ease,transform .15s ease;
	transform-origin:center;
}
.msia-map__region:hover{fill:var(--color-accent);transform:scale(1.01)}

.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.stat-card{background:#fff;border:1px solid var(--color-border);border-radius:16px;padding:14px;box-shadow:0 4px 12px rgba(45,55,72,.08)}
.stat-card__label{font-size:13px;opacity:.76}
.stat-card__value{margin-top:6px;font-size:22px;font-weight:800;color:var(--color-accent);letter-spacing:.2px}
.stat-card__suffix{font-size:12px;color:rgba(45,55,72,.6);margin-left:6px;font-weight:600}
@media(max-width:980px){.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:520px){.stat-grid{grid-template-columns:1fr}}

.table{width:100%;border-collapse:separate;border-spacing:0}
.table th,.table td{padding:12px 10px;border-bottom:1px solid var(--color-border);text-align:left}
.table th{font-size:13px;opacity:.8}
.table tr:last-child td{border-bottom:0}

.progress{
	height:10px;
	background:rgba(45,55,72,.10);
	border-radius:999px;
	overflow:hidden;
}
.progress__bar{
	height:100%;
	width:0%;
	background:linear-gradient(90deg,var(--color-accent),#33c2dc);
	border-radius:999px;
	transition:width .25s ease;
}

.split{display:flex;gap:16px;align-items:flex-start}
.split__main{flex:3;min-width:0}
.split__side{flex:1;max-width:360px;width:100%}
@media(max-width:980px){.split{flex-direction:column}.split__side{width:100%}}

.ticker{overflow:hidden;position:relative}
.ticker__track{display:flex;gap:16px;white-space:nowrap;will-change:transform}
.ticker__item{display:inline-flex;gap:10px;align-items:center;padding:10px 12px;border-radius:999px;border:1px solid var(--color-border);background:#fff}

.livefeed{display:flex;flex-direction:column;gap:12px}
.livefeed__head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.livefeed__badge{display:inline-flex;align-items:center;gap:10px}
.livefeed__title{font-weight:800;letter-spacing:.2px}
.live-dot{
	width:10px;
	height:10px;
	border-radius:999px;
	background:#22c55e;
	box-shadow:0 0 0 0 rgba(34,197,94,.55);
	animation:blink 1.2s ease-in-out infinite;
}
@keyframes blink{
	0%{opacity:.9;transform:scale(1);box-shadow:0 0 0 0 rgba(34,197,94,.45)}
	50%{opacity:.35;transform:scale(.85);box-shadow:0 0 0 6px rgba(34,197,94,0)}
	100%{opacity:.9;transform:scale(1);box-shadow:0 0 0 0 rgba(34,197,94,0)}
}
.livefeed__list{display:flex;flex-direction:column;gap:10px}
.livefeed__item{
	padding:12px 12px;
	border-radius:14px;
	border:1px solid var(--color-border);
	background:#fff;
	opacity:0;
	transform:translateY(10px);
}
.livefeed__item.is-in{animation:livein .45s ease forwards}
@keyframes livein{to{opacity:1;transform:translateY(0)}}

.comment-list{display:flex;flex-direction:column;gap:10px}
.comment-item{border:1px solid var(--color-border);border-radius:14px;background:#fff;padding:12px;opacity:0;transform:translateY(10px)}
.comment-item.is-in{animation:livein .45s ease forwards}
.comment-item__meta{display:flex;gap:10px;justify-content:space-between;align-items:center;margin-bottom:6px}
.comment-item__author{font-weight:700}
.comment-item__time{font-size:12px;opacity:.7}
.comment-item__content{white-space:pre-wrap}

.rating-row{border:1px solid var(--color-border);border-radius:14px;padding:12px;background:#fff}
.rating-row__head{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:10px}
.rating-row__label{font-weight:800}
.rating-row__scores{display:flex;flex-wrap:wrap;gap:8px}
.rating-score{width:32px;height:32px;border-radius:10px;border:1px solid var(--color-border);background:#fff;color:var(--color-ink);cursor:pointer}
.rating-score:hover{border-color:rgba(0,51,153,.55);box-shadow:0 0 0 3px rgba(0,51,153,.10)}

.issue-feedback{margin-top:12px;display:none}
.issue-feedback.is-open{display:block}

.notice{padding:10px 12px;border-radius:12px;border:1px solid rgba(0,163,196,.30);background:rgba(0,163,196,.08)}
.notice--warn{border-color:rgba(240,82,82,.28);background:rgba(240,82,82,.08)}

.footer{padding:26px 0 40px;color:rgba(255,255,255,.92);background:var(--color-ink)}
.footer a{color:#fff;text-decoration:none}
.footer a:hover{text-decoration:underline}
