/* ============================================
   BALLZEED — Pixel-Perfect Reproduction
   ============================================ */

*{margin:0;padding:0;box-sizing:border-box;font-family:'IBM Plex Sans Thai','Prompt',sans-serif}
:root{
  --bg:#0d1219;
  --bg-2:#10171f;
  --bg-3:#161e2a;
  --bg-row:#1a2330;
  --border:#1c2533;
  --green:#c0ff00;
  --green-2:#a3d900;
  --green-soft:rgba(192,255,0,.12);
  --red:#e53935;
  --text:#e6e9ee;
  --text-2:#9aa5b3;
  --text-3:#6b7686;
  --white:#fff;
  --font-head:'Anuphan','Prompt',sans-serif;
  --font-body:'IBM Plex Sans Thai','Prompt',sans-serif;
  --font-num:'Inter','IBM Plex Sans Thai',sans-serif;
}
html,body{background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;letter-spacing:.1px}
h1,h2,h3,h4,h5{font-family:var(--font-head);letter-spacing:.2px}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{max-width:100%;display:block}
.container{max-width:1300px;margin:0 auto;padding:0 20px}
.dim{color:var(--text-3);font-weight:300}

/* ============ BUTTONS ============ */
.btn{padding:11px 26px;border-radius:8px;font-size:14px;font-weight:500;transition:.15s;display:inline-flex;align-items:center;gap:6px;letter-spacing:.2px}
.btn-ghost{background:transparent;color:var(--white);border:1px solid #2a3441;font-weight:500}
.btn-ghost:hover{background:#1a212d;border-color:var(--green)}
.btn-green{background:var(--green);color:#0a0e14;font-weight:700;border:none;padding:10px 22px;border-radius:8px;font-size:14px;transition:.15s;letter-spacing:.2px}
.btn-green:hover{background:var(--green-2)}
.btn-green.sm{padding:7px 16px;font-size:12px;font-weight:600}
.btn-green.xs{padding:8px 20px;font-size:13px;font-weight:700}

.btn-line{display:flex;align-items:center;justify-content:center;width:100%;padding:11px;background:transparent;border:1px solid var(--green);color:var(--green);border-radius:8px;font-size:13px;font-weight:600;transition:.15s;margin-top:6px;letter-spacing:.2px}
.btn-line:hover{background:var(--green-soft)}
.btn-line.wide{margin-top:14px}

/* ============ HEADER ============ */
.header{background:#101720;border-bottom:1px solid var(--border)}
.header-row{display:flex;justify-content:space-between;align-items:center;padding:16px 20px}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{flex-shrink:0;display:flex;align-items:center;justify-content:center}
.brand-text h1{color:var(--white);font-family:var(--font-head);font-size:26px;font-weight:800;line-height:1;letter-spacing:2.5px}
.brand-text span{color:var(--text-3);font-size:11px;font-weight:400;display:block;margin-top:4px;letter-spacing:.3px}
.brand.sm .brand-text h1{font-size:22px}

.header-actions{display:flex;gap:10px}

.topnav{background:#101720;border-bottom:1px solid var(--border)}
.topnav ul{display:flex;gap:0}
.topnav li{position:relative}
.topnav li a{display:block;padding:15px 22px;color:#9aa5b3;font-size:14px;font-weight:500;transition:.15s;border-bottom:2px solid transparent;letter-spacing:.2px}
.topnav li.on a{color:var(--green);border-bottom-color:var(--green);font-weight:600}
.topnav li:not(.on) a:hover{color:#cbd5e1}

/* ============ LAYOUT ============ */
.layout{display:grid;grid-template-columns:290px 1fr 308px;gap:16px;padding:16px 20px;align-items:start}
.col-left,.col-right,.col-center{display:flex;flex-direction:column;gap:16px}

.panel{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:16px}
.panel-head h3{color:var(--white);font-family:var(--font-head);font-size:18px;font-weight:700;letter-spacing:.3px}
.panel-head p{color:var(--text-3);font-size:12px;font-weight:400;margin-top:4px;letter-spacing:.2px}
.panel-head.row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.see-all{color:var(--green);font-size:12px;font-weight:500;letter-spacing:.2px}
.see-all:hover{text-decoration:underline}

/* ============ TIPS SIDEBAR ============ */
.tip{display:flex;gap:10px;padding:12px;background:#162030;border:1px solid #1f2a3a;border-radius:10px;margin-top:14px;align-items:center}
.tip:first-of-type{margin-top:14px}
.tip-icon{position:relative;display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:46px}
.tip-tag{background:var(--green);color:#0a0e14;font-size:9px;padding:2px 6px;border-radius:3px;font-weight:600;white-space:nowrap;margin-top:-6px;position:relative;z-index:2}
.tip-body{flex:1;min-width:0}
.tip-body h4{color:var(--white);font-family:var(--font-head);font-weight:700;font-size:15px;margin-bottom:5px;letter-spacing:.2px}
.tip-body .league{color:var(--text-3);font-size:11px;margin-bottom:3px;font-weight:400}
.tip-body .match{color:#cbd5e1;font-size:11px;margin-bottom:3px;font-weight:400}
.tip-body .match em{color:var(--green);font-style:normal;font-weight:600;margin:0 3px}
.tip-body .time{color:var(--text-3);font-size:11px;font-weight:400}
.odds-pill{background:var(--green);color:#0a0e14;padding:6px 12px;border-radius:6px;font-weight:700;font-size:12px;white-space:nowrap;align-self:center;font-family:var(--font-num);letter-spacing:.3px}
.tip-tag{font-family:var(--font-num);letter-spacing:.3px}

/* ============ PLAYER ============ */
.player{background:#000;border-radius:12px;overflow:hidden;position:relative;border:1px solid var(--border)}
.player-top{position:absolute;top:14px;left:14px;right:14px;display:flex;justify-content:space-between;align-items:center;z-index:5}
.player-top-left{display:flex;gap:8px;align-items:center}
.badge-live{background:var(--red);color:#fff;padding:5px 12px;border-radius:4px;font-size:12px;font-weight:700;display:inline-flex;align-items:center;gap:6px;letter-spacing:1px;line-height:1;font-family:var(--font-num)}
.badge-live .d{width:6px;height:6px;background:#fff;border-radius:50%;animation:blink 1.4s infinite;display:inline-block}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}
.viewers{color:#fff;background:rgba(0,0,0,.55);padding:5px 10px;border-radius:4px;font-size:12px;display:inline-flex;align-items:center;gap:6px;line-height:1;font-family:var(--font-num);font-weight:500;letter-spacing:.3px}

.player-screen{position:relative;aspect-ratio:16/9;background:#000;overflow:hidden}
.screen-bg{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(0,30,15,.1) 0,rgba(0,0,0,0) 35%,rgba(0,0,0,0) 65%,rgba(0,0,0,.7) 100%),
  url('img/stadium.jpg');
  background-size:cover;background-position:center;background-repeat:no-repeat}

/* SCOREBOARD */
.scoreboard{position:absolute;left:50%;bottom:82px;transform:translateX(-50%);background:rgba(13,18,24,.95);backdrop-filter:blur(12px);border:1px solid #2a3441;border-radius:12px;padding:14px 32px 16px;min-width:600px;max-width:92%}
.sb-live-row{text-align:center;margin-bottom:10px}
.sb-live{display:inline-block;background:var(--red);color:#fff;padding:4px 16px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:1.2px;line-height:1.4;font-family:var(--font-num)}
.sb-row{display:flex;align-items:center;justify-content:space-between;gap:24px}
.sb-team{display:flex;align-items:center;gap:12px;flex:1}
.sb-team.r{justify-content:flex-end}
.sb-team.l{justify-content:flex-start}
.sb-name{color:#fff;font-family:var(--font-head);font-weight:600;font-size:16px;white-space:nowrap;letter-spacing:.2px}
.sb-logo{flex-shrink:0;width:38px;height:38px;display:flex;align-items:center;justify-content:center}
.sb-mid{text-align:center;min-width:140px}
.sb-score{color:#fff;font-family:var(--font-num);font-size:34px;font-weight:800;line-height:1;letter-spacing:2px}
.sb-time{color:var(--red);font-family:var(--font-num);font-size:15px;font-weight:700;margin-top:8px;letter-spacing:.5px}

/* CONTROLS */
.player-controls{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.95),rgba(0,0,0,0));padding:14px 18px 14px;z-index:4}
.bar{height:3px;background:rgba(255,255,255,.18);border-radius:2px;overflow:hidden;margin-bottom:10px}
.bar span{display:block;height:100%;background:var(--red)}
.ctrl-row{display:flex;justify-content:space-between;align-items:center}
.ctrl-l,.ctrl-r{display:flex;align-items:center;gap:14px}
.ic{padding:2px;color:#fff;font-size:13px}
.live-text{color:#fff;font-size:12px;font-weight:700;display:inline-flex;align-items:center;gap:6px;letter-spacing:1px;font-family:var(--font-num)}
.live-text .d{width:7px;height:7px;background:var(--red);border-radius:50%;display:inline-block;animation:blink 1.4s infinite}

/* ============ QUICK ACTIONS ============ */
.quick-row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.qa{background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:13px 14px;display:flex;align-items:center;gap:11px;cursor:pointer;transition:.15s}
.qa:hover{border-color:var(--green);transform:translateY(-1px)}
.qa-ico{width:36px;height:36px;background:var(--green-soft);border:1px solid rgba(192,255,0,.3);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.qa div{display:flex;flex-direction:column;line-height:1.25}
.qa b{color:var(--white);font-family:var(--font-head);font-weight:700;font-size:14px;letter-spacing:.2px}
.qa i{color:var(--text-3);font-size:11px;font-style:normal;margin-top:3px;font-weight:400}

/* ============ MATCHES ============ */
.filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;align-items:center}
.chip{background:#162030;border:1px solid var(--border);color:#cbd5e1;padding:7px 14px;border-radius:6px;font-size:12px;display:inline-flex;align-items:center;gap:6px;transition:.15s;font-weight:500;letter-spacing:.2px}
.chip.on{background:var(--green);color:#0a0e14;border-color:var(--green);font-weight:700}
.chip:not(.on):hover{border-color:var(--green);color:var(--green)}
.dot-r{width:6px;height:6px;background:var(--red);border-radius:50%;display:inline-block;animation:blink 1.4s infinite}

.select-wrap{margin-left:auto;position:relative}
.select-wrap.full{margin:8px 0 12px;width:100%}
.select-wrap select{background:#162030;border:1px solid var(--border);color:#cbd5e1;padding:7px 30px 7px 12px;border-radius:6px;font-size:12px;font-family:inherit;cursor:pointer;appearance:none;-webkit-appearance:none}
.select-wrap.full select{width:100%}
.select-wrap::after{content:"▾";position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:10px;pointer-events:none}

.tbl-wrap{overflow-x:auto}
.match-tbl{width:100%;border-collapse:collapse}
.match-tbl th{text-align:left;color:var(--text-3);font-size:12px;font-weight:500;padding:11px 8px;border-bottom:1px solid var(--border);letter-spacing:.2px}
.match-tbl th:first-child{padding-left:6px}
.match-tbl th:nth-child(n+4),.match-tbl td:nth-child(n+4){text-align:center}
.match-tbl td{padding:14px 8px;border-bottom:1px solid #15202d;font-size:13px;vertical-align:middle}
.match-tbl tr:last-child td{border-bottom:none}
.match-tbl td:first-child{padding-left:6px;min-width:88px;color:#cbd5e1;font-weight:500;font-size:13px}
.time-c{color:#cbd5e1;font-weight:500}

.live-pill{background:var(--red);color:#fff;padding:5px 9px;border-radius:4px;font-size:10px;font-weight:700;white-space:nowrap;letter-spacing:.8px;line-height:1;display:inline-block;font-family:var(--font-num)}
.match-c{min-width:180px;padding-right:20px !important}
.match-c div{display:flex;align-items:center;gap:9px;color:#e6e9ee;padding:3px 0;font-size:13px}
.score-c{text-align:center !important;color:#cbd5e1;font-size:13px}
.score-c div{padding:2px 0;display:flex;align-items:center;justify-content:center;gap:4px}
.score-c i{color:var(--text-3);font-style:normal;font-size:11px}
.match-tbl td:nth-child(4),.match-tbl td:nth-child(5),.match-tbl td:nth-child(6){color:#fff;font-family:var(--font-num);font-weight:600;font-size:13px;width:60px;letter-spacing:.3px}
.time-c,.match-tbl td:first-child{font-family:var(--font-num);font-weight:600;letter-spacing:.3px}
.match-tbl td:last-child{width:100px;text-align:center}

/* ============ LOGO DOTS (team mini logos) ============ */
.logo-dot{width:24px;height:24px;border-radius:50%;flex-shrink:0;display:inline-block;vertical-align:middle;background-size:cover;background-position:center;position:relative}
.logo-dot.mc{background:radial-gradient(circle,#6CABDD 30%,#1c5aa8 90%);border:1.5px solid #fff}
.logo-dot.wh{background:radial-gradient(circle,#7A263A 30%,#3d1219 90%);border:1.5px solid #F3D459}
.logo-dot.by{background:radial-gradient(circle,#DC052D 30%,#7a0319 90%);border:1.5px solid #fff}
.logo-dot.wf{background:radial-gradient(circle,#65B32E 30%,#2c5012 90%);border:1.5px solid #fff}
.logo-dot.rm{background:radial-gradient(circle,#fff 40%,#e2e2e2 90%);border:1.5px solid #FFC107}
.logo-dot.rb{background:radial-gradient(circle,#0BB363 30%,#055f33 90%);border:1.5px solid #fff}
.logo-dot.juv{background:linear-gradient(90deg,#000 50%,#fff 50%);border:1.5px solid #fff}
.logo-dot.ac{background:linear-gradient(90deg,#FB090B 50%,#000 50%);border:1.5px solid #fff}
.logo-dot.psg{background:radial-gradient(circle,#004170 30%,#001f3a 90%);border:1.5px solid #DA291C}
.logo-dot.ly{background:radial-gradient(circle,#003d7c 30%,#001f42 90%);border:1.5px solid #DA291C}
.logo-dot.ars{background:radial-gradient(circle,#EF0107 30%,#7c0103 90%);border:1.5px solid #fff}
.logo-dot.liv{background:radial-gradient(circle,#C8102E 30%,#640816 90%);border:1.5px solid #00B2A9}
.logo-dot.av{background:radial-gradient(circle,#670E36 30%,#3d0820 90%);border:1.5px solid #95BFE5}
.logo-dot.tot{background:radial-gradient(circle,#fff 40%,#fff 90%);border:1.5px solid #132257}

/* ============ ANALYSIS ============ */
.analysis-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.acard{display:flex;flex-direction:column}
.acard-img{aspect-ratio:16/11;border-radius:8px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background-size:cover;background-position:center}
.acard-img::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,40,90,.3),rgba(0,0,0,.3));pointer-events:none}
.acard-img .play{width:40px;height:40px;background:rgba(192,255,0,.95);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;z-index:2;padding-left:3px;box-shadow:0 4px 14px rgba(0,0,0,.4)}
.tag-tdt{position:absolute;top:8px;right:8px;background:var(--green);color:#0a0e14;font-size:10px;padding:3px 8px;border-radius:4px;font-weight:600;z-index:3}
.a1{background-image:url('img/match1.jpg')}
.a2{background-image:url('img/match2.jpg')}
.a3{background-image:url('img/match3.jpg')}
.a4{background-image:url('img/match4.jpg')}
.acard h5{color:var(--text);font-family:var(--font-head);font-size:13px;font-weight:600;padding:10px 2px 8px;line-height:1.45;letter-spacing:.1px}
.acard-meta{display:flex;justify-content:space-between;padding:0 2px;color:var(--text-3);font-size:11px;font-weight:400}

/* ============ RIGHT: HIGHLIGHTS ============ */
.hl{display:flex;gap:10px;padding:12px 0;border-bottom:1px solid var(--border)}
.hl:last-of-type{border-bottom:none;padding-bottom:0}
.hl:first-of-type{padding-top:4px}
.hl-thumb{width:100px;height:64px;border-radius:6px;flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;background-size:cover;background-position:center;overflow:hidden}
.hl-thumb::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.3)}
.t1{background-image:url('img/match1.jpg')}
.t2{background-image:url('img/match2.jpg')}
.t3{background-image:url('img/match3.jpg')}
.hl-play{width:26px;height:26px;background:rgba(192,255,0,.95);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;z-index:2;padding-left:2px}
.hl-dur{position:absolute;bottom:4px;right:4px;background:rgba(0,0,0,.85);color:#fff;font-size:10px;padding:1px 5px;border-radius:3px;z-index:2;font-weight:500}
.hl-info{flex:1;min-width:0}
.hl-info h5{color:var(--text);font-family:var(--font-head);font-size:13px;font-weight:600;line-height:1.4;margin-bottom:5px;letter-spacing:.1px}
.hl-info p{color:#9aa5b3;font-size:11px;margin-bottom:3px;font-weight:400}
.hl-date{color:var(--text-3);font-size:10px;font-family:var(--font-num);font-weight:500;letter-spacing:.2px}
.hl-dur{font-family:var(--font-num);font-weight:600;letter-spacing:.3px}

/* ============ PROMO ============ */
.promo{background:linear-gradient(135deg,#0d2a14,#1a4427 50%,#0d2a14);border:1px solid rgba(192,255,0,.25);border-radius:12px;padding:18px 20px;position:relative;overflow:hidden;display:flex;justify-content:space-between;align-items:center;min-height:230px}
.promo::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 25% 50%,rgba(192,255,0,.2),transparent 60%);pointer-events:none}
.promo::after{content:"";position:absolute;top:0;right:0;width:60%;height:100%;background:radial-gradient(circle at 80% 50%,rgba(192,255,0,.18),transparent 70%);pointer-events:none}
.promo-body{position:relative;z-index:3}
.p-s{color:#e8f5e9;font-size:13px;font-weight:400;margin-bottom:3px;letter-spacing:.2px}
.p-m{color:#fff;font-family:var(--font-head);font-size:20px;font-weight:700;line-height:1.2;letter-spacing:.3px}
.p-xl{color:var(--green);font-family:var(--font-num);font-size:58px;font-weight:800;line-height:1;margin:6px 0 6px;text-shadow:0 0 32px rgba(192,255,0,.6),0 0 8px rgba(192,255,0,.45);letter-spacing:-2px}
.p-s b{color:var(--green);font-weight:700;font-family:var(--font-num)}
.promo-body .btn-green{margin-top:14px}
.promo-img{position:absolute;right:0;bottom:0;top:0;width:55%;z-index:1;background-image:url('img/player.jpg');background-size:cover;background-position:center;mask-image:linear-gradient(to left,#000 50%,transparent 95%);-webkit-mask-image:linear-gradient(to left,#000 50%,transparent 95%);opacity:.9}

/* ============ STANDINGS ============ */
.stand-tbl{width:100%;border-collapse:collapse;margin:4px 0 10px}
.stand-tbl th{text-align:left;color:var(--text-3);font-size:11px;font-weight:500;padding:8px 4px;border-bottom:1px solid var(--border);letter-spacing:.2px}
.stand-tbl td{padding:11px 4px;border-bottom:1px solid #15202d;font-size:12px;color:var(--text);vertical-align:middle}
.stand-tbl tr:last-child td{border-bottom:none}
.stand-tbl td:first-child,.stand-tbl th:first-child{color:var(--text-3);width:24px;text-align:left;font-family:var(--font-num);font-weight:600}
.stand-tbl td:nth-child(n+3),.stand-tbl th:nth-child(n+3){text-align:center;width:42px;font-family:var(--font-num)}
.stand-tbl td:nth-child(2){display:flex;align-items:center;gap:8px;font-weight:500}
.stand-tbl td:last-child{color:var(--green);font-weight:700;font-family:var(--font-num)}

/* ============ FOOTER ============ */
.footer{background:#0a0f17;border-top:1px solid var(--border);margin-top:30px;padding:38px 0 0}
.ft-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr 1.4fr;gap:30px;padding:0 20px 32px}
.ft-col h4{color:var(--white);font-family:var(--font-head);font-size:15px;font-weight:700;margin-bottom:16px;letter-spacing:.3px}
.ft-col ul li{margin-bottom:10px;color:#9aa5b3;font-size:13px;font-weight:400}
.ft-col ul li a{color:#9aa5b3;transition:.15s}
.ft-col ul li a:hover{color:var(--green)}
.ft-desc{color:var(--text-3);font-size:12px;line-height:1.75;margin:14px 0 16px;font-weight:400}
.ft-sub{color:var(--text-3);font-size:11px;margin-bottom:10px;font-weight:400}

.socials{display:flex;gap:8px}
.sc{width:34px;height:34px;background:#162030;border:1px solid var(--border);color:#cbd5e1;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.15s}
.sc:hover{background:var(--green);color:#0a0e14;border-color:var(--green)}

.ft-contact li{display:flex;align-items:center;gap:8px;font-size:12px;color:#9aa5b3}

.ft-app{display:flex;gap:10px;align-items:flex-end;margin-top:6px}
.app-col{display:flex;flex-direction:column;gap:8px;flex:1}
.store-btn{background:#0a0e14;border:1px solid #2a3441;color:#fff;padding:8px 12px;border-radius:8px;display:flex;align-items:center;gap:10px;transition:.15s}
.store-btn:hover{border-color:var(--green)}
.store-btn span{display:flex;flex-direction:column;line-height:1.2;text-align:left}
.store-btn small{font-size:9px;opacity:.75;font-weight:400;letter-spacing:.3px;font-family:var(--font-num)}
.store-btn b{font-size:13px;font-weight:700;font-family:var(--font-head);letter-spacing:.2px}
.phone{flex-shrink:0}

.ft-bottom{border-top:1px solid var(--border);background:#0a0f17}
.ft-bottom-inner{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;color:var(--text-3);font-size:12px}
.ft-bottom-inner a{color:var(--text-3)}
.ft-bottom-inner a:hover{color:var(--green)}

/* ============ RESPONSIVE ============ */
@media(max-width:1200px){
  .layout{grid-template-columns:260px 1fr 280px}
  .scoreboard{min-width:auto;width:90%;padding:12px 16px}
  .sb-score{font-size:24px}
  .sb-name{font-size:13px}
  .sb-logo{width:32px;height:32px}
  .sb-logo svg{width:32px;height:32px}
}
@media(max-width:1024px){
  .layout{grid-template-columns:1fr}
  .quick-row{grid-template-columns:repeat(3,1fr)}
  .analysis-grid{grid-template-columns:repeat(2,1fr)}
  .ft-grid{grid-template-columns:repeat(2,1fr)}
  .topnav ul{overflow-x:auto;white-space:nowrap}
}
@media(max-width:640px){
  .header-row{flex-direction:column;gap:12px}
  .quick-row{grid-template-columns:repeat(2,1fr)}
  .ft-grid{grid-template-columns:1fr}
  .analysis-grid{grid-template-columns:1fr}
  .sb-row{gap:10px}
  .sb-score{font-size:20px}
  .filter-row{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}
  .ft-bottom-inner{flex-direction:column;gap:8px;text-align:center}
}


/* ============ HERO SECTION ============ */
.hero { position: relative; margin: 18px 0 0; padding: 44px 0 40px; background: radial-gradient(ellipse 80% 60% at 85% 50%, rgba(192,255,0,0.10), transparent 60%), linear-gradient(180deg, #0c1219 0%, #10171f 100%); border-top: 1px solid rgba(192,255,0,0.08); border-bottom: 1px solid rgba(255,255,255,0.04); overflow: hidden; }
.hero::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(circle at 1.5px 1.5px, rgba(192,255,0,0.06) 1px, transparent 0); background-size: 28px 28px; opacity: 0.45; pointer-events: none; mask-image: linear-gradient(90deg, transparent 0%, #000 40%, #000 100%); -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 40%, #000 100%); }
.hero::after { content: ""; position: absolute; right: -120px; top: 50%; transform: translateY(-50%); width: 380px; height: 380px; background: radial-gradient(circle, rgba(192,255,0,0.18) 0%, transparent 70%); pointer-events: none; filter: blur(40px); }
.hero-inner { position: relative; z-index: 1; max-width: 1300px; margin: 0 auto; padding: 0 20px; }
.hero-text { max-width: 720px; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; color: #c0ff00; background: rgba(192,255,0,0.06); padding: 6px 14px; border-radius: 100px; border: 1px solid rgba(192,255,0,0.18); letter-spacing: 0.5px; margin-bottom: 18px; }
.hero-eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: #c0ff00; box-shadow: 0 0 8px rgba(192,255,0,0.7); animation: pulseDot 1.4s ease-in-out infinite; }
.hero-title { font-family: "Anuphan","Prompt",sans-serif; font-weight: 800; font-size: clamp(28px, 4.2vw, 52px); line-height: 1.08; color: #fff; margin-bottom: 16px; letter-spacing: -0.5px; }
.hero-title .lime { background: linear-gradient(180deg, #c0ff00 0%, #9ee600 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; text-shadow: 0 0 32px rgba(192,255,0,0.25); }
.hero-sub { font-size: 16px; color: #9aa5b3; margin-bottom: 26px; max-width: 560px; line-height: 1.55; }
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 36px; }
.hero-cta .btn { padding: 13px 30px !important; font-size: 14px !important; letter-spacing: 0.3px; }
.hero-btn-primary { box-shadow: 0 6px 22px rgba(192,255,0,0.3) !important; }
.hero-stats { display: flex; gap: 36px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,0.06); flex-wrap: wrap; }
.hero-stats > div { display: flex; flex-direction: column; gap: 3px; }
.hero-stats b { font-family: "Inter",sans-serif; font-size: 24px; font-weight: 800; color: #fff; letter-spacing: -0.5px; line-height: 1; font-variant-numeric: tabular-nums; }
.hero-stats b::after { content: ""; display: inline-block; width: 4px; height: 4px; border-radius: 50%; background: #c0ff00; margin-left: 6px; vertical-align: middle; box-shadow: 0 0 6px rgba(192,255,0,0.6); }
.hero-stats span { font-size: 11px; color: #6b7686; letter-spacing: 0.4px; text-transform: uppercase; font-weight: 500; }

@media (max-width: 720px) {
  .hero { padding: 28px 0 24px; }
  .hero-title { font-size: 28px !important; line-height: 1.15 !important; }
  .hero-sub { font-size: 14px; margin-bottom: 20px; }
  .hero-cta { gap: 8px; margin-bottom: 24px; }
  .hero-cta .btn { padding: 11px 20px !important; font-size: 13px !important; }
  .hero-stats { gap: 20px; padding-top: 18px; }
  .hero-stats b { font-size: 18px; }
  .hero-stats span { font-size: 10px; }
}
@media (max-width: 480px) {
  .hero-cta { flex-direction: column; align-items: stretch; }
  .hero-cta .btn { width: 100%; text-align: center; justify-content: center; }
  .hero-stats { gap: 14px; }
  .hero-stats > div { flex: 1 1 calc(50% - 7px); }
}

/* ============ LOADING / EMPTY STATES ============ */
.loading-state { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; padding: 32px 16px; opacity: 0.8; }
.loading-state .spinner { width: 36px; height: 36px; border: 3px solid rgba(192,255,0,0.12); border-top-color: #c0ff00; border-radius: 50%; animation: spin 0.9s linear infinite; }
.loading-state::after { content: "กำลังโหลดข้อมูล..."; font-size: 12px; color: #6b7686; letter-spacing: 0.5px; }
@keyframes spin { to { transform: rotate(360deg); } }

.empty-state { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; padding: 48px 20px 40px; text-align: center; }
.empty-state-icon { width: 72px; height: 72px; border-radius: 50%; background: radial-gradient(circle, rgba(192,255,0,0.08), transparent 70%); display: flex; align-items: center; justify-content: center; font-size: 32px; border: 1px solid rgba(192,255,0,0.1); }
.empty-state h4 { color: #cbd5e1; font-size: 15px; font-weight: 600; margin: 0; }
.empty-state p { color: #6b7686; font-size: 12px; margin: 0; max-width: 280px; line-height: 1.5; }


/* ============ HERO MASCOTS ============ */
.hero { position: relative; }
.hero-inner { position: relative; min-height: 360px; }
.hero-mascots { position: absolute; right: 0px; bottom: 12px; width: clamp(320px, 38vw, 540px); pointer-events: none; z-index: 1; filter: drop-shadow(0 12px 32px rgba(0,0,0,0.5)) drop-shadow(0 0 38px rgba(192,255,0,0.18)); animation: heroMascotsIn 1.1s cubic-bezier(.16,1,.3,1) .15s both; }
.hero-mascots img { width: 100%; height: auto; display: block; }
.hero-text { position: relative; z-index: 2; }

@keyframes heroMascotsIn {
  from { opacity: 0; transform: translateY(20px) scale(0.96); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@media (max-width: 1024px) {
  .hero-mascots { width: 34vw; right: 0; bottom: 18px; opacity: 0.95; }
  .hero-inner { min-height: 320px; }
}
@media (max-width: 820px) {
  .hero-mascots { width: 30vw; opacity: 0.55; bottom: 12px; right: -10px; }
  .hero-text { max-width: 100%; }
}
@media (max-width: 600px) {
  .hero-mascots { 
    position: relative;
    right: auto;
    bottom: auto;
    width: 92%;
    max-width: 360px;
    margin: 4px auto -8px;
    opacity: 1;
    display: block;
    z-index: 1;
  }
  .hero-inner { min-height: 0; }
  .hero-text { text-align: left; }
}

/* Light theme: keep mascot glow but softer */
html[data-theme="light"] .hero-mascots { filter: drop-shadow(0 8px 24px rgba(0,0,0,0.18)) drop-shadow(0 0 28px rgba(107,163,0,0.20)); }
