/*
 * This is a manifest file that'll be compiled into application.css.
 *
 * With Propshaft, assets are served efficiently without preprocessing steps. You can still include
 * application-wide styles in this file, but keep in mind that CSS precedence will follow the standard
 * cascading order, meaning styles declared later in the document or manifest will override earlier ones,
 * depending on specificity.
 *
 * Consider organizing styles into separate files for maintainability.
 */
/* ============ Design tokens — Dailynews CI ============ */
:root{
  --dn-pink:#E6007E;          /* brand magenta */
  --dn-pink-deep:#C4006B;     /* text-safe magenta */
  --dn-pink-soft:#FDE8F3;
  --green:#0E7A3D;            /* election green (CI headline) */
  --green-deep:#0A5C2E;
  --green-soft:#E7F4EC;
  --ink:#1A2330;
  --muted:#5B6877;
  --line:#E7E2E8;
  --card:#FFFFFF;
  --amber-flash:#FFF3C4;
  --radius:18px;
  --shadow-sm:0 1px 2px rgba(26,35,48,.06),0 2px 8px rgba(26,35,48,.05);
  --shadow-md:0 2px 6px rgba(26,35,48,.07),0 12px 28px rgba(26,35,48,.08);
  --font-display:'Prompt',sans-serif;
  --font-body:'Anuphan',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:
    radial-gradient(900px 420px at 8% -5%, rgba(120,210,235,.22), transparent 60%),
    radial-gradient(900px 460px at 95% -8%, rgba(230,0,126,.10), transparent 55%),
    radial-gradient(700px 500px at 50% 110%, rgba(14,122,61,.06), transparent 60%),
    #FAF8FB;
  min-height:100dvh;
}
::selection{background:var(--dn-pink-soft)}
h1,h2,h3,.num{font-family:var(--font-display)}
.num{font-variant-numeric:tabular-nums}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
svg{display:block}

/* ============ Header ============ */
.site-head{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.site-head .topbar-row{
  max-width:1280px;margin:0 auto;padding:8px 20px 0;
  display:flex;align-items:center;gap:10px;
}
.site-head .topbar-row .topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.site-head .inner{
  max-width:1280px;margin:0 auto;padding:6px 20px 10px;
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:10px;white-space:nowrap}
.brand .logo-img{height:30px;width:auto;display:block}
.brand .logo{
  font-family:var(--font-display);font-weight:800;font-size:21px;
  color:var(--dn-pink);letter-spacing:.5px;
}
.brand .logo span{color:var(--ink)}
.brand .event{
  font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--green);
  border-left:2px solid var(--line);padding-left:10px;
}
.head-status{display:flex;align-items:center;gap:14px;margin-left:auto;flex-wrap:wrap}
.counted{min-width:190px}
.counted .label{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:3px}
.counted .label b{color:var(--ink);font-family:var(--font-display)}
.counted .bar{height:7px;border-radius:99px;background:#EEE8EF;overflow:hidden}
.counted .bar i{display:block;height:100%;width:0;border-radius:99px;
  background:linear-gradient(90deg,var(--green),#27A45C);transition:width .8s cubic-bezier(.2,.8,.2,1)}
.live{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--dn-pink);color:#fff;font-family:var(--font-display);font-weight:700;
  font-size:13px;letter-spacing:1.5px;padding:6px 14px 6px 11px;border-radius:99px;
  box-shadow:0 4px 14px rgba(230,0,126,.35);
}
.live .dot{width:8px;height:8px;border-radius:50%;background:#fff;animation:pulse 1.6s ease-out infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.7)}100%{box-shadow:0 0 0 9px rgba(255,255,255,0)}}

/* ============ Hero band ============ */
.hero{max-width:1280px;margin:0 auto;padding:26px 20px 6px;text-align:center}
.hero .kicker{font-family:var(--font-display);font-weight:600;font-size:clamp(15px,2.2vw,19px);color:var(--green)}
.hero h1{
  font-weight:800;font-size:clamp(24px,4.2vw,40px);line-height:1.25;color:var(--green-deep);
  letter-spacing:-.3px;
}
.hero .meta{margin-top:8px;font-size:13.5px;color:var(--muted);display:flex;gap:8px;justify-content:center;align-items:center;flex-wrap:wrap}
.hero .meta .upd{display:inline-flex;align-items:center;gap:5px}
.hero .meta .upd svg{width:14px;height:14px;stroke:var(--dn-pink-deep)}
.hero .meta b{color:var(--dn-pink-deep);font-family:var(--font-display);font-weight:600}

/* ============ Page grid ============ */
.wrap{max-width:1280px;margin:0 auto;padding:18px 20px 80px;display:grid;gap:18px}
/* mobile-first source order: lead → map → chart → news */
@media(min-width:1024px){
  .wrap{
    grid-template-columns:minmax(0,1.25fr) minmax(380px,1fr);
    grid-template-areas:"map lead" "chart news";
    align-items:start;
  }
  .sec-lead{grid-area:lead}
  .sec-map{grid-area:map}
  .sec-chart{grid-area:chart}
  .sec-news{grid-area:news}
}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card-head{display:flex;align-items:center;gap:9px;padding:16px 18px 0}
.card-head svg{width:19px;height:19px;stroke:var(--dn-pink);flex:none}
.card-head h2{font-size:17px;font-weight:700}
.card-head .hint{margin-left:auto;font-size:12px;color:var(--muted)}

/* ============ Leaderboard ============ */
.podium{display:grid;gap:10px;padding:14px 16px 6px}
.cand{
  position:relative;display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;
  border:1px solid var(--line);border-radius:14px;padding:12px 14px;overflow:hidden;
  background:#fff;transition:transform .2s ease,box-shadow .2s ease;
}
.cand::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--c)}
.cand:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.cand.first{
  padding:16px;border-color:color-mix(in srgb,var(--c) 35%,#fff);
  background:linear-gradient(135deg,color-mix(in srgb,var(--c) 7%,#fff) 0%,#fff 55%);
}
.avatar-wrap{position:relative}
.avatar{
  width:52px;height:52px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--font-display);font-weight:700;font-size:19px;color:#fff;
  background:linear-gradient(145deg,color-mix(in srgb,var(--c) 88%,#fff),var(--c));
  box-shadow:inset 0 -2px 6px rgba(0,0,0,.18);
}
.cand.first .avatar{width:64px;height:64px;font-size:24px}
.cand-no{
  position:absolute;right:-4px;bottom:-4px;width:24px;height:24px;border-radius:50%;
  background:var(--ink);color:#fff;display:grid;place-items:center;
  font-family:var(--font-display);font-weight:700;font-size:12px;border:2px solid #fff;
}
.cand-info{min-width:0}
.rank-chip{
  display:inline-flex;align-items:center;gap:4px;font-family:var(--font-display);font-weight:600;
  font-size:11px;color:var(--green-deep);background:var(--green-soft);
  border-radius:99px;padding:2px 9px;margin-bottom:3px;
}
.rank-chip svg{width:11px;height:11px;stroke:var(--green-deep)}
.cand-info .name{font-family:var(--font-display);font-weight:700;font-size:15.5px;line-height:1.3;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cand.first .name{font-size:18px}
.cand-info .party{font-size:12.5px;color:var(--muted)}
.cand-score{text-align:right}
.cand-score .votes{font-family:var(--font-display);font-weight:700;font-size:18px;font-variant-numeric:tabular-nums;
  border-radius:6px;padding:0 4px;transition:background .2s}
.cand.first .votes{font-size:24px;color:var(--green-deep)}
.cand-score .pct{font-size:12.5px;color:var(--muted);font-variant-numeric:tabular-nums}
.cand-bar{grid-column:1/-1;height:7px;border-radius:99px;background:#F1EDF2;overflow:hidden}
.cand-bar i{display:block;height:100%;border-radius:99px;background:var(--c);width:0;
  transition:width .9s cubic-bezier(.2,.8,.2,1)}
/* minor candidates table */
.minor{padding:6px 16px 16px}
.minor table{width:100%;border-collapse:collapse;font-size:13.5px}
.minor th{font-family:var(--font-display);font-weight:600;font-size:11.5px;color:var(--muted);
  text-align:left;padding:8px 6px;border-bottom:1px solid var(--line)}
.minor th:last-child,.minor td:last-child{text-align:right}
.minor td{padding:9px 6px;border-bottom:1px solid #F3EFF4}
.minor tr:last-child td{border-bottom:none}
.minor .mini-no{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;
  color:#fff;font-family:var(--font-display);font-weight:700;font-size:11px;margin-right:8px;background:var(--c)}
.minor .v{font-family:var(--font-display);font-weight:600;font-variant-numeric:tabular-nums;border-radius:5px;padding:0 4px}

/* ============ Map ============ */
.map-body{padding:14px 16px 16px}
.map-grid{display:grid;grid-template-columns:repeat(11,1fr);gap:4px}
.tile{
  position:relative;aspect-ratio:1;border-radius:7px;border:none;padding:0;
  background:color-mix(in srgb,var(--c) 82%,#fff);
  display:grid;place-items:center;overflow:hidden;
  transition:transform .15s ease,box-shadow .15s ease,background .5s ease;
}
.tile span{
  font-family:var(--font-display);font-weight:600;font-size:9.5px;color:#fff;
  text-shadow:0 1px 2px rgba(0,0,0,.35);line-height:1.1;text-align:center;padding:1px;
  pointer-events:none;
}
.tile:hover{transform:scale(1.12);z-index:2;box-shadow:0 6px 16px rgba(26,35,48,.3)}
.tile.sel{outline:3px solid var(--dn-pink);outline-offset:1px;z-index:1}
.tile.flip{animation:tileflip .7s ease}
@keyframes tileflip{0%{filter:brightness(1.7)}100%{filter:brightness(1)}}
@media(max-width:640px){
  .map-grid{gap:3px}
  .tile{border-radius:5px}
  .tile span{display:block;font-size:6.3px;line-height:1;max-width:100%;padding:0;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.7)}
  /* header เล็กลงบน mobile: tabs+LIVE+theme แถวบน, brand+progress แถวล่าง */
  .site-head .topbar-row{padding:6px 12px 0}
  .site-head .inner{padding:6px 12px 8px;gap:6px 10px}
  .brand .logo-img{height:22px}
  .brand .event{font-size:12px;padding-left:8px}
  .head-status{margin-left:0;width:100%;gap:10px}
  .counted{min-width:0;flex:1}
  .live{font-size:11.5px;letter-spacing:1px;padding:5px 11px 5px 9px}
  .theme-toggle{width:32px;height:32px}
}
.legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:12px;font-size:12.5px;color:var(--muted)}
.legend i{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:5px;vertical-align:-1px}
/* district detail */
.zone-detail{
  margin-top:12px;border:1px dashed var(--line);border-radius:12px;padding:12px 14px;
  background:#FCFAFD;display:none;
}
.zone-detail.show{display:block;animation:fadein .25s ease}
@keyframes fadein{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.zone-detail .zd-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.zone-detail .zd-head h3{font-size:15px;font-weight:700}
.zone-detail .zd-head .zd-counted{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}
.zone-detail .zd-close{margin-left:auto;border:none;background:none;color:var(--muted);
  font-size:18px;line-height:1;padding:2px 6px;border-radius:6px}
.zone-detail .zd-close:hover{background:#EFE9F0}
.zd-row{display:flex;align-items:center;gap:8px;font-size:13px;padding:4px 0}
.zd-row i{width:10px;height:10px;border-radius:3px;flex:none}
.zd-row .zd-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.zd-row .zd-v{font-family:var(--font-display);font-weight:600;font-variant-numeric:tabular-nums}

/* ============ Stats & chart ============ */
.sec-chart .grid{display:grid;gap:14px;padding:14px 16px 16px}
@media(min-width:640px){.sec-chart .grid{grid-template-columns:repeat(3,1fr)}}
.stat{border:1px solid var(--line);border-radius:14px;padding:13px 15px;background:#FDFCFE}
.stat .s-label{font-size:12.5px;color:var(--muted)}
.stat .s-value{font-family:var(--font-display);font-weight:700;font-size:23px;font-variant-numeric:tabular-nums;margin-top:2px}
.stat .s-sub{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}
.stat.t .s-value{color:var(--green-deep)}
.chart-box{padding:4px 16px 18px}
.chart-box .c-title{font-size:13px;color:var(--muted);margin:8px 2px 8px}
.chart-svg{width:100%;height:auto}
.chart-legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12.5px;color:var(--muted);margin-top:8px}
.chart-legend i{display:inline-block;width:14px;height:4px;border-radius:2px;margin-right:6px;vertical-align:2px}

turbo-frame{display:block}
/* ============ News ============ */
.news-list{display:grid;gap:12px;padding:14px 16px 16px}
.news-item{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--line);border-radius:14px;
  padding:12px 14px;background:#fff;transition:transform .2s,box-shadow .2s}
.news-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
.news-thumb{width:72px;height:72px;flex:none;object-fit:cover;border-radius:10px;background:var(--line)}
.news-body{min-width:0}
.news-item h3{font-family:var(--font-display);font-weight:600;font-size:14.5px;line-height:1.45}
.news-item p{margin:5px 0 0;font-size:12.5px;color:var(--muted);line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.news-item time{display:block;margin-top:5px;font-size:12px;color:var(--dn-pink-deep);font-weight:600}
.news-more{display:inline-flex;align-items:center;gap:6px;justify-self:start;margin:2px 16px 16px;
  font-family:var(--font-display);font-weight:600;font-size:13.5px;color:var(--dn-pink-deep)}
.news-more svg{width:15px;height:15px;stroke:var(--dn-pink-deep)}

/* ============ flash on update ============ */
.flash{animation:flash 1.1s ease-out}
@keyframes flash{0%{background:var(--amber-flash)}100%{background:transparent}}


footer{max-width:1280px;margin:0 auto;padding:0 20px 90px;font-size:12px;color:var(--muted);text-align:center}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}

/* ============ Admin & Auth UI ============ */
.flash-stack{position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:300;display:grid;gap:8px;width:min(480px,92vw)}
.flash-msg{font-family:var(--font-display);font-weight:600;font-size:14px;padding:11px 16px;border-radius:12px;box-shadow:var(--shadow-md);animation:fadein .25s ease,fadeaway .5s ease 5s forwards}
.flash-msg.notice{background:var(--green-soft);color:var(--green-deep);border:1px solid #BFE3CD}
.flash-msg.alert{background:#FDECEC;color:#9C1C1C;border:1px solid #F3C2C2}
@keyframes fadeaway{to{opacity:0;visibility:hidden}}

.auth-wrap{min-height:100dvh;display:grid;place-items:center;padding:20px}
.auth-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-md);width:min(420px,100%);padding:32px 30px}
.auth-brand{text-align:center;margin-bottom:22px}
.auth-brand .logo{font-family:var(--font-display);font-weight:800;font-size:26px;color:var(--dn-pink);letter-spacing:.5px}
.auth-brand .logo span{color:var(--ink)}
.auth-brand .sub{font-family:var(--font-display);font-weight:600;font-size:14.5px;color:var(--green);margin-top:2px}
.auth-brand .desc{font-size:12.5px;color:var(--muted);margin-top:6px}
.field{margin-bottom:14px}
.field label{display:block;font-family:var(--font-display);font-weight:600;font-size:13px;margin-bottom:5px}
.field input{width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:10px;font:inherit;font-size:15px;background:#FDFCFE;transition:border-color .15s,box-shadow .15s}
.field input:focus{outline:none;border-color:var(--dn-pink);box-shadow:0 0 0 3px rgba(230,0,126,.12)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-family:var(--font-display);font-weight:600;font-size:14.5px;border:none;border-radius:10px;padding:11px 18px;cursor:pointer;text-decoration:none;color:inherit;transition:transform .12s,box-shadow .15s,background .15s}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--dn-pink);color:#fff;box-shadow:0 4px 14px rgba(230,0,126,.3)}
.btn-primary:hover{background:var(--dn-pink-deep)}
.btn-block{width:100%}
.btn-ghost{background:#F3EFF4;color:var(--ink)}
.btn-danger-ghost{background:#FDECEC;color:#9C1C1C}
.btn-sm{padding:7px 13px;font-size:13px}
.auth-foot{text-align:center;margin-top:16px;font-size:13.5px}
.auth-foot a{color:var(--dn-pink-deep);font-weight:600}

.admin-bar{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.admin-bar .inner{max-width:980px;margin:0 auto;padding:10px 20px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.admin-bar .logo{font-family:var(--font-display);font-weight:800;font-size:18px;color:var(--dn-pink)}
.admin-bar .logo span{color:var(--ink)}
.admin-bar .label{font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--green);border-left:2px solid var(--line);padding-left:10px}
.admin-bar nav{margin-left:auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap}

.admin-wrap{max-width:980px;margin:0 auto;padding:22px 20px 60px;display:grid;gap:16px}
.admin-wrap h1{font-family:var(--font-display);font-size:22px}
.admin-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px}
.admin-card h2{font-family:var(--font-display);font-size:16.5px;margin-bottom:10px}
.admin-table{width:100%;border-collapse:collapse;font-size:14px}
.admin-table th{font-family:var(--font-display);font-weight:600;font-size:12px;color:var(--muted);text-align:left;padding:8px;border-bottom:1px solid var(--line)}
.admin-table td{padding:9px 8px;border-top:1px solid #F3EFF4}
.admin-table .r{text-align:right}
.admin-table .num{font-variant-numeric:tabular-nums}

.mode-line{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.mode-pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:700;font-size:13px;border-radius:99px;padding:6px 14px}
.mode-pill.api{background:var(--green-soft);color:var(--green-deep)}
.mode-pill.manual{background:var(--dn-pink-soft);color:var(--dn-pink-deep)}
.mode-pill .dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:pulse 1.6s ease-out infinite}

.form-row{display:flex;align-items:center;gap:12px;margin-top:9px}
.form-row label{flex:1;font-size:14px}
.form-row input{width:150px;padding:9px 11px;border:1.5px solid var(--line);border-radius:9px;font:inherit;font-variant-numeric:tabular-nums;text-align:right;background:#FDFCFE}
.form-row input:focus{outline:none;border-color:var(--dn-pink);box-shadow:0 0 0 3px rgba(230,0,126,.12)}
.confirm-row{display:flex;gap:10px;align-items:flex-start;margin:14px 0;padding:12px 14px;border:1px dashed var(--line);border-radius:10px;background:#FCFAFD;font-size:13.5px}
.confirm-row input{width:18px;height:18px;margin-top:1px;accent-color:var(--dn-pink)}

/* ============ Dark theme — Midnight Glass (v2) ============ */
.theme-toggle{
  display:grid;place-items:center;width:36px;height:36px;border-radius:50%;
  border:1px solid var(--line);background:transparent;color:var(--ink);
  cursor:pointer;transition:background .2s,transform .15s;flex:none;
}
.theme-toggle:hover{background:rgba(127,127,127,.14);transform:translateY(-1px)}
.theme-toggle svg{width:17px;height:17px;stroke:currentColor}
.theme-toggle .ico-sun{display:none}
html[data-theme="dark"] .theme-toggle .ico-sun{display:block}
html[data-theme="dark"] .theme-toggle .ico-moon{display:none}

html[data-theme="dark"]{
  color-scheme:dark;
  --dn-pink:#FF2D9C;
  --dn-pink-deep:#FF5FB4;
  --dn-pink-soft:rgba(255,45,156,.16);
  --green:#2EE38A;
  --green-deep:#7CEFB6;
  --green-soft:rgba(46,227,138,.14);
  --ink:#F2F5FF;
  --muted:#97A0BC;
  --line:rgba(255,255,255,.13);
  --card:rgba(255,255,255,.055);
  --amber-flash:rgba(255,214,89,.28);
  --shadow-sm:0 10px 30px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.07);
  --shadow-md:0 16px 44px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.09);
}

/* พื้นหลังมืด: มือถือได้เฉดนิ่ง (ประหยัด GPU) — จอใหญ่ได้ aurora เคลื่อนไหว */
html[data-theme="dark"] body{
  background:
    radial-gradient(55vw 55vw at -10% -15%, rgba(255,45,156,.18), transparent 65%),
    radial-gradient(50vw 50vw at 108% -10%, rgba(25,194,113,.16), transparent 65%),
    radial-gradient(55vw 45vw at 50% 115%, rgba(60,107,255,.13), transparent 65%),
    #0A0D1D;
}
@media (min-width:768px) and (prefers-reduced-motion:no-preference){
  html[data-theme="dark"] body::before,
  html[data-theme="dark"] body::after{
    content:"";position:fixed;z-index:-1;border-radius:50%;filter:blur(90px);
    opacity:.4;pointer-events:none;
    animation:aurora-drift 24s ease-in-out infinite alternate;
  }
  html[data-theme="dark"] body::before{
    width:55vw;height:55vw;left:-15vw;top:-18vw;
    background:radial-gradient(circle, rgba(255,45,156,.4), transparent 65%);
  }
  html[data-theme="dark"] body::after{
    width:48vw;height:48vw;right:-12vw;top:-6vw;
    background:radial-gradient(circle, rgba(25,194,113,.36), transparent 65%);
    animation-delay:-9s;
  }
}
@keyframes aurora-drift{to{transform:translate(6vw,4vh) scale(1.15)}}

/* การ์ดกระจก — backdrop-filter เฉพาะจอใหญ่ */
html[data-theme="dark"] .card{background:var(--card);border-color:var(--line)}
@media (min-width:768px){
  html[data-theme="dark"] .card{
    backdrop-filter:blur(20px) saturate(150%);
    -webkit-backdrop-filter:blur(20px) saturate(150%);
  }
}
html[data-theme="dark"] .site-head{
  background:rgba(10,13,29,.78);border-bottom-color:var(--line);
}
html[data-theme="dark"] .counted .bar{background:rgba(255,255,255,.08)}
html[data-theme="dark"] .counted .bar i{
  background:linear-gradient(90deg,#19C271,var(--green),#6FE3FF);
  box-shadow:0 0 14px rgba(46,227,138,.5);position:relative;
}
html[data-theme="dark"] .live{
  background:linear-gradient(120deg,var(--dn-pink),#C4006B);
  box-shadow:0 0 22px rgba(255,45,156,.45), inset 0 1px 0 rgba(255,255,255,.25);
  animation:breathe 2.4s ease-in-out infinite;
}
@keyframes breathe{0%,100%{box-shadow:0 0 12px rgba(255,45,156,.4)}50%{box-shadow:0 0 28px rgba(255,45,156,.55)}}

html[data-theme="dark"] .hero h1{
  background:linear-gradient(95deg,#EAFFF4 10%,#2EE38A 45%,#6FE3FF 90%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 22px rgba(46,227,138,.22));
}

/* leaderboard */
html[data-theme="dark"] .cand{background:rgba(255,255,255,.045);border-color:rgba(255,255,255,.07)}
html[data-theme="dark"] .cand::before{box-shadow:0 0 14px var(--c)}
html[data-theme="dark"] .cand:hover{
  border-color:color-mix(in srgb,var(--c) 55%,transparent);
  box-shadow:0 10px 34px color-mix(in srgb,var(--c) 22%,transparent);
}
html[data-theme="dark"] .cand.first{
  background:rgba(255,255,255,.08);
  border-color:color-mix(in srgb,var(--c) 45%,transparent);
  box-shadow:0 0 0 1px color-mix(in srgb,var(--c) 22%,transparent),
             0 14px 40px color-mix(in srgb,var(--c) 16%,transparent);
}
html[data-theme="dark"] .cand.first .votes{
  color:var(--green);text-shadow:0 0 18px rgba(46,227,138,.45);
}
html[data-theme="dark"] .cand-no{background:#0E1226;border-color:rgba(255,255,255,.25)}
html[data-theme="dark"] .avatar{box-shadow:0 0 16px color-mix(in srgb,var(--c) 45%,transparent)}
html[data-theme="dark"] .rank-chip{
  color:var(--green);background:rgba(46,227,138,.12);border:1px solid rgba(46,227,138,.25);
}
html[data-theme="dark"] .rank-chip svg{stroke:var(--green)}
html[data-theme="dark"] .cand-bar{background:rgba(255,255,255,.07)}
html[data-theme="dark"] .cand-bar i{
  box-shadow:0 0 12px color-mix(in srgb,var(--c) 55%,transparent);position:relative;overflow:hidden;
}
@media (prefers-reduced-motion:no-preference){
  html[data-theme="dark"] .counted .bar i::after,
  html[data-theme="dark"] .cand-bar i::after{
    content:"";position:absolute;inset:0;border-radius:99px;
    background:linear-gradient(100deg,transparent 30%,rgba(255,255,255,.4) 50%,transparent 70%);
    background-size:200% 100%;animation:shine 3s linear infinite;
  }
}
@keyframes shine{0%{background-position:180% 0}100%{background-position:-80% 0}}
html[data-theme="dark"] .minor th,
html[data-theme="dark"] .minor td{border-color:rgba(255,255,255,.07)}
html[data-theme="dark"] .minor tr:hover{background:rgba(255,255,255,.04)}

/* map */
html[data-theme="dark"] .tile{
  background:color-mix(in srgb,var(--c) 36%,rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.07);
}
html[data-theme="dark"] .tile span{color:var(--ink);text-shadow:0 1px 4px rgba(0,0,0,.65)}
html[data-theme="dark"] .tile:hover{
  border-color:color-mix(in srgb,var(--c) 80%,transparent);
  box-shadow:0 0 20px color-mix(in srgb,var(--c) 50%,transparent);
}
html[data-theme="dark"] .tile.sel{
  outline-color:var(--dn-pink);box-shadow:0 0 20px rgba(255,45,156,.45);
}
html[data-theme="dark"] .zone-detail{background:rgba(255,255,255,.04);border-color:var(--line)}
html[data-theme="dark"] .zd-close:hover{background:rgba(255,255,255,.09)}

/* stats + chart */
html[data-theme="dark"] .stat{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.07)}
html[data-theme="dark"] .stat.t .s-value{color:var(--green);text-shadow:0 0 16px rgba(46,227,138,.4)}
html[data-theme="dark"] .chart-svg{filter:drop-shadow(0 1px 8px rgba(0,0,0,.5))}

/* news */
html[data-theme="dark"] .news-item{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.07)}
html[data-theme="dark"] .news-item:hover{border-color:var(--line);box-shadow:0 8px 28px rgba(0,0,0,.35)}

/* admin & auth */
html[data-theme="dark"] .admin-bar{background:rgba(10,13,29,.8);border-bottom-color:var(--line)}
html[data-theme="dark"] .admin-card,
html[data-theme="dark"] .auth-card{background:var(--card);border-color:var(--line)}
@media (min-width:768px){
  html[data-theme="dark"] .admin-card,
  html[data-theme="dark"] .auth-card{
    backdrop-filter:blur(20px) saturate(150%);
    -webkit-backdrop-filter:blur(20px) saturate(150%);
  }
}
html[data-theme="dark"] .field input,
html[data-theme="dark"] .form-row input{
  background:rgba(255,255,255,.06);border-color:var(--line);color:var(--ink);
}
html[data-theme="dark"] .btn-ghost{background:rgba(255,255,255,.1);color:var(--ink)}
html[data-theme="dark"] .btn-danger-ghost{background:rgba(255,80,80,.15);color:#FF9C9C}
html[data-theme="dark"] .admin-table th{border-color:var(--line)}
html[data-theme="dark"] .admin-table td{border-color:rgba(255,255,255,.07)}
html[data-theme="dark"] .confirm-row{background:rgba(255,255,255,.04);border-color:var(--line)}
html[data-theme="dark"] .flash-msg.notice{
  background:rgba(46,227,138,.14);color:#9CF5C8;border-color:rgba(46,227,138,.3);
}
html[data-theme="dark"] .flash-msg.alert{
  background:rgba(255,80,80,.14);color:#FFB3B3;border-color:rgba(255,80,80,.3);
}
.avatar-img{ object-fit:cover; background:#fff; }
.party-logo{ width:18px; height:18px; border-radius:3px; object-fit:contain; vertical-align:-3px; margin-right:4px; }
.zd-photo{ width:28px; height:28px; border-radius:50%; object-fit:cover; flex:0 0 auto; }
.zd-stats{ font-size:12px; color:var(--muted,#6b7280); margin:6px 0 10px; line-height:1.5; }
.zone-detail [data-zone-detail-target="rows"]{ max-height:46vh; overflow-y:auto; }

/* ============ Council seats summary ============ */
.council-seats{display:flex;flex-direction:column;gap:6px;padding:10px 14px 16px;font-size:13.5px}
.seat-row{display:flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:8px 12px}
.seat-row i{display:inline-block;width:12px;height:12px;border-radius:4px;flex:none}
.seat-row .party-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.seat-row b{font-family:var(--font-display);font-weight:700;font-variant-numeric:tabular-nums}
.seat-row .seat-unit{color:var(--muted);font-size:12px;margin-left:3px}
/* หน้า สก: layout 2 คอลัมน์ (desktop) — แผนที่ซ้าย / สรุปพรรคขวา, mobile stack */
.wrap.wrap-plain{display:block}
.council-layout{display:grid;gap:18px}
.page-title{font-weight:800;font-size:clamp(20px,3vw,28px);color:var(--ink);margin:2px 0 2px;letter-spacing:-.3px}
.council-aside .card-head{padding:14px 16px 2px}
@media(min-width:1024px){
  .council-layout{grid-template-columns:minmax(0,1fr) minmax(240px,300px);
    grid-template-areas:"map aside";align-items:start}
  .council-layout .sec-map{grid-area:map}
  .council-layout .council-aside{grid-area:aside}
}
.zd-row.winner{font-weight:700;background:color-mix(in srgb, var(--c,#0E7A3D) 18%, transparent);border-radius:8px}

/* ============ Election tabs ============ */
.election-tabs{display:flex;gap:8px;margin:0}
.election-tabs a{padding:6px 14px;border-radius:8px;text-decoration:none;color:var(--muted,#6b7280)}
.election-tabs a.active{background:var(--c,#0E7A3D);color:#fff;font-weight:700}

/* ============ Council zone-detail scroll cap ============ */
.zone-detail [data-council-target="rows"]{max-height:46vh;overflow-y:auto}

/* ============ Countdown splash ============ */
.countdown-splash{
  position:fixed;inset:0;z-index:1000;
  display:flex;align-items:center;justify-content:center;padding:24px;
  text-align:center;cursor:default;
  background:
    radial-gradient(900px 480px at 50% -8%, rgba(230,0,126,.16), transparent 60%),
    radial-gradient(760px 480px at 50% 112%, rgba(14,122,61,.12), transparent 62%),
    rgba(250,248,251,.97);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  transition:opacity .3s ease;
}
.countdown-splash[hidden]{display:none}
.countdown-splash.is-closing{opacity:0}
html[data-theme="dark"] .countdown-splash{
  background:
    radial-gradient(900px 480px at 50% -8%, rgba(255,45,156,.20), transparent 60%),
    radial-gradient(760px 480px at 50% 112%, rgba(46,227,138,.14), transparent 62%),
    rgba(10,13,29,.975);
}
.cd-inner{max-width:560px;width:100%}
.cd-kicker{font-family:var(--font-display);font-weight:600;font-size:14px;letter-spacing:.02em;color:var(--dn-pink-deep);margin-bottom:10px}
.cd-title{font-family:var(--font-display);font-weight:700;font-size:clamp(22px,5vw,34px);line-height:1.32;color:var(--ink)}
.cd-title .cd-time{color:var(--green-deep)}
.cd-timer{display:flex;align-items:center;justify-content:center;gap:8px;margin:26px 0 16px}
.cd-unit{display:flex;flex-direction:column;align-items:center;min-width:66px;
  background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 10px;box-shadow:var(--shadow-sm)}
.cd-num{font-family:var(--font-display);font-weight:700;font-size:clamp(26px,7vw,40px);line-height:1;color:var(--ink);font-variant-numeric:tabular-nums}
.cd-lbl{font-size:11.5px;color:var(--muted);margin-top:6px}
.cd-sep{font-family:var(--font-display);font-weight:700;font-size:clamp(20px,5vw,30px);color:var(--muted)}
.cd-foot{font-size:13px;color:var(--muted);margin-top:4px}
@media (max-width:420px){
  .cd-unit{min-width:52px;padding:10px 5px}
  .cd-timer{gap:5px}
}

/* ============ Credit footer ============ */
.credits{margin-top:6px;font-size:12px;color:var(--muted)}
.credits a{color:inherit;text-decoration:underline;text-underline-offset:2px}
.credits a:hover{color:var(--dn-pink-deep)}
