/* ============================================================
   DayPilot — World Cup 2026 AI Predictor
   Design system + components. Mobile-first, dark.
   ============================================================ */
:root{
  --bg:#05080F; --bg2:#0A0F1A; --bg3:#101725;
  --card:#0B1220; --card2:#0F1828;
  --border:rgba(150,180,220,.10); --border2:rgba(150,180,220,.18);
  --text:#EAF1FB; --muted:#5F718E; --muted2:#8194B0;
  --accent:#B8FF3A;                /* lime — energy / brand (used for fills) */
  --ink:#B8FF3A;                   /* accent used as TEXT (darkens in light mode) */
  --glass:rgba(5,8,15,.86); --glass2:rgba(5,8,15,.92);   /* sticky bar backgrounds */
  --acc-dim:rgba(184,255,58,.08); --acc-mid:rgba(184,255,58,.22);
  --cyan:#36D8FF; --cyan-dim:rgba(54,216,255,.10);
  --win:#3DDC84; --draw:#FFC53D; --lose:#FF4D6A;
  --wa:#25D366; --tw:#1DA1F2;
  --mono:'Space Mono',ui-monospace,monospace;
  --display:'Space Grotesk','Noto Sans SC',sans-serif;
  --body:'Inter','Noto Sans SC',system-ui,sans-serif;
  --maxw:720px;
}

/* ── LIGHT THEME ── keeps the lime brand for fills; accent-as-text uses a deep green */
[data-theme="light"]{
  --bg:#F1F5FA; --bg2:#FFFFFF; --bg3:#E9EFF6;
  --card:#FFFFFF; --card2:#F6F9FD;
  --border:rgba(20,40,80,.12); --border2:rgba(20,40,80,.20);
  --text:#0C1626; --muted:#64748B; --muted2:#46566F;
  --ink:#3C8A0E;
  --glass:rgba(255,255,255,.82); --glass2:rgba(255,255,255,.9);
  --acc-dim:rgba(120,180,30,.14); --acc-mid:rgba(120,180,30,.30);
}
[data-theme="light"] .m-status.LIVE{color:#C81E4A}
[data-theme="light"] .pred-why{color:var(--muted2)}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:var(--body);font-size:15px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100vh}
/* clearance so the fixed Ko-fi "Support" button never covers the last items on small screens */
@media(max-width:560px){ footer{padding-bottom:calc(70px + env(safe-area-inset-bottom)) !important} }
h1,h2,h3{font-family:var(--display);letter-spacing:-.5px}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
img{max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 16px}
.hide{display:none!important}
.spin{width:14px;height:14px;border:2px solid var(--acc-mid);border-top-color:var(--ink);
  border-radius:50%;animation:spin .7s linear infinite;display:inline-block;vertical-align:-2px}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── TOP BAR ── */
header{position:sticky;top:0;z-index:60;background:var(--glass);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);padding-top:env(safe-area-inset-top)}
.bar{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;
  height:54px;padding:0 16px}
.brand{display:flex;align-items:center;gap:9px}
.brand .mark{width:30px;height:30px;display:flex;align-items:center;justify-content:center}
.brand .mark svg{width:29px;height:29px;display:block}
.brand b{font-family:var(--display);font-weight:800;font-size:16px;letter-spacing:-.4px}
.brand small{display:block;font-family:var(--mono);font-size:8.5px;color:var(--muted);letter-spacing:1.5px;margin-top:-3px}
.bar-r{display:flex;align-items:center;gap:8px}
.myt{font-family:var(--mono);font-size:11px;color:var(--muted)}
.theme-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;font-size:15px;
  background:var(--bg2);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:.15s;line-height:1}
.theme-btn:hover{border-color:var(--acc-mid);background:var(--acc-dim)}
.lang{display:flex;gap:2px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:3px}
.lang button{background:none;border:none;color:var(--muted);font-family:var(--mono);font-size:10.5px;font-weight:700;
  padding:4px 7px;border-radius:5px;cursor:pointer;transition:.15s}
.lang button.active{background:var(--accent);color:#05080F}

/* ── PAGE NAV (scrollable tabs) ── */
.pagenav{position:sticky;top:54px;z-index:55;background:var(--glass2);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border)}
.pagenav-in{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;justify-content:center;
  gap:6px;padding:9px 12px}
.pagenav a{flex:0 0 auto;font-size:12.5px;font-weight:600;color:var(--muted);padding:6px 13px;border-radius:999px;
  border:1px solid transparent;white-space:nowrap;transition:.15s;display:flex;align-items:center;gap:6px}
.pagenav a:hover{color:var(--text)}
.pagenav a.active{color:var(--ink);background:var(--acc-dim);border-color:var(--acc-mid)}
.pagenav a .soon{font-family:var(--mono);font-size:8px;color:var(--muted);border:1px solid var(--border);
  border-radius:4px;padding:1px 4px}

/* ── HERO / STATS ── */
.hero{padding:26px 0 6px;text-align:center;animation:rise .4s}
.eyebrow{font-family:var(--mono);font-size:10px;color:var(--ink);letter-spacing:2.5px;text-transform:uppercase;
  margin-bottom:10px;display:inline-flex;align-items:center;gap:8px}
.eyebrow::before,.eyebrow::after{content:'';width:18px;height:1px;background:var(--acc-mid)}
.hero h1{font-size:clamp(30px,8vw,46px);font-weight:800;line-height:1.02}
.hero h1 em{color:var(--ink);font-style:normal}
.hero p{color:var(--muted2);margin:10px auto 0;max-width:440px;font-size:13.5px}
.statsbar{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:20px 0 6px}
.stat{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:11px 6px;text-align:center}
.stat b{display:block;font-family:var(--display);font-size:22px;font-weight:800;color:var(--ink);line-height:1}
.stat span{display:block;font-family:var(--mono);font-size:8.5px;color:var(--muted);letter-spacing:1px;
  text-transform:uppercase;margin-top:5px}

/* ── COUNTDOWN ── */
.countdown{background:linear-gradient(135deg,var(--card2),var(--card));border:1px solid var(--border2);
  border-radius:16px;padding:16px;text-align:center;margin:14px 0;position:relative;overflow:hidden}
.countdown::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% -20%,var(--acc-dim),transparent 60%)}
.cd-label{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase}
.cd-time{font-family:var(--display);font-size:34px;font-weight:800;letter-spacing:2px;color:var(--ink);margin:6px 0}
.cd-match{font-size:12.5px;color:var(--muted2)}
.countdown.is-live{border-color:rgba(255,77,106,.5)}
.countdown.is-live .cd-label,.countdown.is-live .cd-time{color:var(--lose)}

/* ── DAY TABS (date filter) ── */
.daytabs{display:flex;gap:7px;overflow-x:auto;padding:4px 0 2px;scrollbar-width:none;margin-bottom:6px}
.daytabs::-webkit-scrollbar{display:none}
.daytab{flex:0 0 auto;border:1px solid var(--border);background:var(--card);color:var(--muted2);border-radius:10px;
  padding:7px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:.15s;text-align:center;line-height:1.3}
.daytab small{display:block;font-family:var(--mono);font-size:9px;color:var(--muted)}
.daytab.active{background:var(--accent);color:#05080F;border-color:var(--ink)}
.daytab.active small{color:rgba(5,8,15,.65)}

/* ── FILTER ROW ── */
.filterbar{display:flex;align-items:center;gap:8px;margin:6px 0 2px;flex-wrap:wrap}
.watch-hub{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--card);border:1px solid var(--border2);border-radius:12px;padding:11px 13px;margin:12px 0 8px}
.watch-hub b{display:block;font-size:12.5px}.watch-hub small{display:block;color:var(--muted);font-size:9.5px;margin-top:3px;line-height:1.35}
.watch-hub-links{display:flex;gap:7px;flex:0 0 auto}.watch-hub-links a{border:1px solid var(--border2);border-radius:8px;padding:7px 9px;color:var(--cyan);font-size:10.5px;font-weight:700;white-space:nowrap}
@media(max-width:520px){.watch-hub{align-items:flex-start;flex-direction:column}.watch-hub-links{width:100%}.watch-hub-links a{flex:1;text-align:center}}
.data-alert{border:1px solid var(--border2);background:var(--card);color:var(--muted2);border-radius:10px;padding:10px 12px;margin:10px 0;font-size:12px;line-height:1.5}
.data-alert.demo{border-color:var(--draw);color:var(--draw);background:rgba(255,178,62,.08)}
.data-alert.error{border-color:rgba(255,77,106,.35);color:var(--lose);background:rgba(255,77,106,.07)}
.data-fresh{font-family:var(--mono);font-size:9px;color:var(--muted);text-align:right;margin:5px 0}
.chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:var(--card);
  color:var(--muted2);border-radius:999px;padding:6px 11px;font-size:11.5px;font-weight:600;cursor:pointer;transition:.15s}
.chip:hover{color:var(--text);border-color:var(--border2)}
.chip.on{color:var(--cyan);border-color:var(--cyan);background:var(--cyan-dim)}
.chip .x{font-size:13px;line-height:1;opacity:.7}

/* ── DAY HEADER ── */
.day-h{font-family:var(--mono);font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);
  margin:20px 0 10px;display:flex;align-items:center;gap:10px}
.day-h::after{content:'';flex:1;height:1px;background:var(--border)}

/* ── MATCH CARD ── */
.matches{display:grid;grid-template-columns:1fr;gap:11px}
@media(min-width:560px){.matches{grid-template-columns:1fr 1fr}}
.match{background:var(--card);border:1px solid var(--border);border-radius:15px;overflow:hidden;
  transition:border-color .2s;animation:rise .35s}
.match:hover{border-color:var(--border2)}
.m-top{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;border-bottom:1px solid var(--border)}
.m-meta{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;color:var(--muted)}
.m-stage{background:var(--acc-dim);color:var(--ink);border-radius:5px;padding:2px 6px;font-weight:700;letter-spacing:.5px}
.m-status{font-family:var(--mono);font-size:9.5px;font-weight:700;padding:2px 8px;border-radius:999px;letter-spacing:.5px}
.m-status.LIVE{background:rgba(255,77,106,.14);color:var(--lose);animation:pulse 1.8s infinite}
.m-status.FINISHED{background:rgba(255,255,255,.05);color:var(--muted)}
.m-status.SCHEDULED{color:var(--cyan)}
.m-fav{margin-left:auto;background:none;border:none;cursor:pointer;font-size:14px;line-height:1;opacity:.5;transition:.15s;padding:2px}
.m-fav:hover{opacity:1;transform:scale(1.15)}
.m-fav.on{opacity:1}
.m-body{display:flex;align-items:center;justify-content:space-between;padding:15px 14px;gap:8px}
.m-team{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;text-align:center;min-width:0}
.team-fav{background:none;border:0;color:var(--muted);cursor:pointer;font-size:16px;line-height:1;padding:0}
.team-fav.on{color:var(--draw)}
.m-flag{font-size:32px;line-height:1}
.m-name{font-size:12.5px;font-weight:600;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.m-mid{flex:0 0 76px;text-align:center}
.m-score{font-family:var(--display);font-size:30px;font-weight:800;letter-spacing:1px;line-height:1}
.m-periods{display:flex;justify-content:center;gap:7px;margin-top:6px;font-family:var(--mono);font-size:8.5px;color:var(--muted);white-space:nowrap}
.m-vs{font-family:var(--mono);font-size:16px;color:var(--muted);font-weight:700}
.m-time{display:block;font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:4px}
.m-foot{padding:0 14px 14px}
.predict-btn{width:100%;background:var(--acc-dim);border:1px solid var(--acc-mid);color:var(--ink);
  border-radius:10px;padding:10px;font-weight:700;font-size:12.5px;cursor:pointer;transition:.16s;
  display:flex;align-items:center;justify-content:center;gap:7px}
.predict-btn:hover:not(:disabled){background:var(--acc-mid)}
.predict-btn:disabled{opacity:.55;cursor:default}

/* ── PREDICTION PANEL ── */
.pred{margin-top:13px;animation:rise .3s}
.pred-bars{display:grid;grid-template-columns:1fr 1fr 1fr;gap:7px;margin-bottom:11px}
.pb{background:var(--bg3);border-radius:9px;padding:9px 5px;text-align:center;position:relative;overflow:hidden}
.pb .fill{position:absolute;left:0;bottom:0;height:3px;border-radius:3px}
.pb.h .fill{background:var(--win)} .pb.d .fill{background:var(--draw)} .pb.a .fill{background:var(--lose)}
.pb strong{display:block;font-family:var(--display);font-size:18px;font-weight:800;line-height:1}
.pb.h strong{color:var(--win)} .pb.d strong{color:var(--draw)} .pb.a strong{color:var(--lose)}
.pb span{display:block;font-size:9.5px;color:var(--muted);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pred-score{text-align:center;font-family:var(--display);font-size:17px;font-weight:800;color:var(--ink);margin:4px 0 8px}
.pred-score small{font-family:var(--mono);font-size:9px;color:var(--muted);display:block;font-weight:400;letter-spacing:1px;text-transform:uppercase}
.pred-meta{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:9px}
.pmeta{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;color:var(--muted2);background:var(--bg3);
  border:1px solid var(--border);border-radius:999px;padding:4px 9px}
.pmeta i{font-style:normal;font-size:11px}
.pmeta b{color:var(--text);font-weight:600}
.pmeta.conf.high b{color:var(--win)} .pmeta.conf.med b{color:var(--draw)} .pmeta.conf.low b{color:var(--lose)}
.pred-why{font-size:12px;color:var(--muted2);line-height:1.6;border-left:2px solid var(--acc-mid);padding-left:10px;margin-bottom:11px}
.share-row{display:flex;gap:8px}
.pred-perma{display:inline-block;margin-top:10px;font-size:11.5px;color:var(--ink);font-weight:600}
.pred-perma:hover{text-decoration:underline}
.share{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;color:#fff;border:none;
  border-radius:9px;padding:9px;font-size:12px;font-weight:700;cursor:pointer;transition:.15s}
.share svg{width:15px;height:15px;fill:currentColor}
.share.wa{background:var(--wa)} .share.wa:hover{filter:brightness(1.08)}
.share.tw{background:var(--tw)} .share.tw:hover{filter:brightness(1.08)}

/* ── GENERIC / EMPTY / PLACEHOLDER ── */
.loading,.empty{color:var(--muted);text-align:center;padding:46px 16px;font-size:14px}
.empty .ico{font-size:42px;display:block;margin-bottom:10px}
.placeholder{text-align:center;padding:60px 20px;animation:rise .4s}
.placeholder .ico{font-size:54px;display:block;margin-bottom:16px}
.placeholder h2{font-size:24px;margin-bottom:8px}
.placeholder p{color:var(--muted2);max-width:380px;margin:0 auto;font-size:13.5px}
.placeholder .tag{display:inline-block;margin-top:16px;font-family:var(--mono);font-size:10px;color:var(--ink);
  border:1px solid var(--acc-mid);border-radius:999px;padding:4px 12px;letter-spacing:1px}

/* ── SECTION HEADER (standings / knockout) ── */
.sec-head{padding:24px 0 6px;animation:rise .4s}
.sec-head h2{font-size:clamp(24px,6vw,34px);font-weight:800}
.sec-head p{color:var(--muted2);font-size:13px;margin-top:6px;max-width:520px}
.legend{display:flex;flex-wrap:wrap;gap:12px;margin:14px 0 4px}
.legend span{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--muted2)}
.legend i{width:10px;height:10px;border-radius:3px;display:inline-block}
.legend i.q{background:var(--win)} .legend i.t{background:var(--draw)} .legend i.o{background:var(--border2)}

/* ── STANDINGS ── */
.groups{display:grid;grid-template-columns:1fr;gap:16px;margin-top:8px}
@media(min-width:620px){.groups{grid-template-columns:1fr 1fr}}
.grp{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;animation:rise .35s}
.grp-h{font-family:var(--display);font-weight:800;font-size:14px;padding:11px 14px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px}
.grp-h .dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}
table.std{width:100%;border-collapse:collapse;font-size:12.5px}
table.std th{font-family:var(--mono);font-size:9.5px;color:var(--muted);font-weight:700;text-transform:uppercase;
  letter-spacing:.5px;padding:7px 4px;text-align:center}
table.std th.team{text-align:left;padding-left:14px}
table.std td{padding:8px 4px;text-align:center;border-top:1px solid var(--border)}
table.std td.team{text-align:left;padding-left:14px;display:flex;align-items:center;gap:8px}
table.std td.team .pos{font-family:var(--mono);font-size:10px;color:var(--muted);width:16px;flex:0 0 16px}
table.std td.team .fl{font-size:16px}
table.std td.team .nm{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
table.std td.pts{font-family:var(--display);font-weight:800;color:var(--text)}
table.std td.gd{color:var(--muted2)}
table.std tr.q{box-shadow:inset 3px 0 0 var(--win)}
table.std tr.t{box-shadow:inset 3px 0 0 var(--draw)}
table.std tr.q td.team .pos{color:var(--win)} table.std tr.t td.team .pos{color:var(--draw)}
.thirds{margin-top:24px}.thirds h3{font-size:18px}.thirds>p{font-size:11px;color:var(--muted);margin:5px 0 10px}
.thirds small{color:var(--muted);font-weight:400}

/* ── KNOCKOUT BRACKET ── */
.bracket-scroll{overflow-x:auto;padding:8px 0 18px;scrollbar-width:thin;-webkit-overflow-scrolling:touch}
.bracket{display:flex;gap:18px;min-width:max-content;padding:4px}
.round{display:flex;flex-direction:column;justify-content:space-around;gap:10px;min-width:150px}
.round-h{font-family:var(--mono);font-size:9.5px;letter-spacing:1px;text-transform:uppercase;color:var(--ink);
  text-align:center;margin-bottom:2px;position:sticky;top:0}
.tie{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.tie .slot{display:flex;align-items:center;gap:7px;padding:7px 9px;font-size:11.5px}
.tie .slot+.slot{border-top:1px solid var(--border)}
.tie .slot .fl{font-size:14px;width:18px;text-align:center}
.tie .slot .nm{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted2)}
.tie .slot.tbd .nm{color:var(--muted);font-style:italic}
.tie .slot .sc{font-family:var(--mono);font-weight:700;color:var(--text)}
.tie .slot.win .nm{color:var(--text);font-weight:700}
.tie .slot.win{background:var(--acc-dim)}
.champ{display:flex;flex-direction:column;justify-content:center;align-items:center;min-width:150px;text-align:center}
.champ .cup{font-size:40px;margin-bottom:8px}
.champ .lbl{font-family:var(--mono);font-size:9.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink)}
.champ .who{font-family:var(--display);font-weight:800;font-size:16px;color:var(--muted);margin-top:4px}

/* ── WATCH / HIGHLIGHTS LINK ── */
.watch{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:8px;padding:8px;border-radius:9px;
  border:1px solid var(--border2);color:var(--muted2);font-size:12px;font-weight:600;transition:.15s}
.watch:hover{color:var(--text);border-color:var(--cyan);background:var(--cyan-dim)}
.watch.live{color:var(--lose);border-color:rgba(255,77,106,.3)}
.watch.live:hover{background:rgba(255,77,106,.1)}
.watch-row{display:flex;align-items:center;gap:6px;margin-top:8px}
.watch-lbl{font-size:10.5px;color:var(--muted);font-family:var(--mono);flex:0 0 auto}
.watch-row .watch{margin-top:0;flex:1;padding:7px}

/* ── SUBTABS ── */
.subtabs{display:flex;gap:8px;margin:14px 0}
.subtab{flex:1;border:1px solid var(--border);background:var(--card);color:var(--muted2);border-radius:11px;
  padding:10px;font-size:12.5px;font-weight:700;cursor:pointer;transition:.15s}
.subtab.on{background:var(--acc-dim);color:var(--ink);border-color:var(--acc-mid)}

/* ── RANK TABLE (players) ── */
table.rank{width:100%;border-collapse:collapse;font-size:13px}
table.rank th{font-family:var(--mono);font-size:9.5px;color:var(--muted);font-weight:700;text-transform:uppercase;
  padding:9px 8px;text-align:center}
table.rank th.pl{text-align:left}
table.rank td{padding:9px 8px;text-align:center;border-top:1px solid var(--border)}
table.rank td.rk{font-family:var(--mono);font-size:11px;color:var(--muted);width:24px}
table.rank td.pl{text-align:left}
table.rank td.pl span.fl{font-size:18px;margin-right:9px;vertical-align:middle}
table.rank td.pl b{font-weight:600}
table.rank td.pl small{display:block;color:var(--muted);font-size:10.5px}
table.rank td.big{font-family:var(--display);font-weight:800;font-size:17px;color:var(--ink)}
.ycard,.rcard{display:inline-block;width:15px;height:20px;border-radius:3px;color:#000;font-size:11px;font-weight:800;line-height:20px}
.ycard{background:var(--draw)} .rcard{background:var(--lose);color:#fff}

/* ── LEARN ── */
.offside-box{margin:8px 0 4px;border-radius:12px;overflow:hidden;border:1px solid var(--border)}
.offside{display:block;width:100%;height:auto}
.off-cap{font-size:12px;color:var(--muted2);text-align:center;margin:10px 0 4px;font-style:italic}
.offside .atk{animation:atkRun 6s ease-in-out infinite}
.offside .ball{animation:ballPass 6s ease-in-out infinite}
.offside .flag{opacity:0}
.offside .flag.onside{animation:flagOn 6s ease-in-out infinite}
.offside .flag.offside{animation:flagOff 6s ease-in-out infinite}
@keyframes atkRun{0%{transform:translateX(0)}35%{transform:translateX(60px)}70%,100%{transform:translateX(140px)}}
@keyframes ballPass{0%,45%{transform:translate(0,0);opacity:0}50%{opacity:1}70%,100%{transform:translate(240px,60px);opacity:1}}
@keyframes flagOn{0%,40%{opacity:1}45%,100%{opacity:0}}
@keyframes flagOff{0%,72%{opacity:0}80%,100%{opacity:1}}
.lessons{display:grid;grid-template-columns:1fr;gap:11px;margin-top:14px}
.lesson{display:flex;gap:13px;background:var(--card);border:1px solid var(--border);border-radius:13px;padding:15px}
.lesson .ico{font-size:26px;line-height:1.1;flex:0 0 auto}
.lesson h3{font-size:15px;margin-bottom:5px}
.lesson p{font-size:12.5px;color:var(--muted2);line-height:1.6}

/* ── NEWS + SIGNUP ── */
.signup{background:linear-gradient(135deg,var(--card2),var(--card));border:1px solid var(--border2);border-radius:14px;padding:16px;margin:14px 0}
.signup-h{font-size:14px;margin-bottom:6px}
.signup p{font-size:12.5px;color:var(--muted2);margin-bottom:11px}
.signup-form{display:flex;gap:8px}
.signup-form input{flex:1;min-width:0;background:var(--bg);border:1px solid var(--border2);color:var(--text);
  border-radius:9px;padding:10px 12px;font-size:13px;font-family:inherit}
.signup-form input:focus{outline:none;border-color:var(--ink)}
.signup-form button{background:var(--accent);color:#05080F;border:none;border-radius:9px;padding:10px 16px;
  font-weight:700;font-size:13px;cursor:pointer;white-space:nowrap}
.signup-msg{font-size:12px;margin-top:9px;min-height:16px}
.consent{display:flex;align-items:flex-start;gap:7px;color:var(--muted);font-size:10.5px;line-height:1.4;margin-top:9px}
.consent input{margin-top:2px;accent-color:var(--accent)}
.signup-msg.ok{color:var(--win)} .signup-msg.err{color:var(--lose)}
.news-list{display:grid;grid-template-columns:1fr;gap:10px;margin-top:6px}
.news-item{display:block;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;transition:border-color .15s}
.news-item:hover{border-color:var(--border2)}
.news-meta{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:10px;color:var(--muted);margin-bottom:7px}
.news-tag{background:var(--acc-dim);color:var(--ink);border-radius:5px;padding:2px 7px;font-weight:700}
.news-title{font-size:14px;font-weight:600;line-height:1.4}

/* ── FUND ── */
.fund{background:var(--card);border:1px solid var(--acc-mid);border-radius:16px;padding:18px;position:relative;overflow:hidden}
.fund::before{content:'';position:absolute;top:-60px;right:-40px;width:200px;height:200px;background:radial-gradient(circle,var(--acc-dim),transparent 65%)}
.fund-h{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.fund-amt{font-family:var(--display);font-size:24px;font-weight:800}
.fund-amt small{font-family:var(--body);font-size:12px;color:var(--muted);font-weight:400}
.fund-state{font-family:var(--mono);font-size:10px;font-weight:700;padding:4px 10px;border-radius:999px;
  background:rgba(255,178,62,.12);color:var(--draw)}
.fund-state.on{background:rgba(61,220,132,.12);color:var(--win)}
.fbar{height:9px;background:var(--bg3);border-radius:999px;overflow:hidden;margin-bottom:14px}
.fbar-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--win));transition:width 1s cubic-bezier(.22,1,.36,1)}
.kofi-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--accent);
  color:#05080F;border-radius:11px;padding:12px;font-weight:800;font-size:14px;margin-bottom:10px;transition:.15s}
.kofi-btn:hover{filter:brightness(1.06)}
.give{display:flex;gap:8px;flex-wrap:wrap}
.give button{flex:1;min-width:62px;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text);
  border-radius:10px;padding:11px 6px;font-family:var(--mono);font-weight:700;font-size:13px;cursor:pointer;transition:.16s}
.give button:hover{border-color:var(--ink);background:var(--acc-dim);color:var(--ink)}
.fund-msg{display:none;font-size:12px;color:var(--muted2);margin-top:10px}
.fund-msg.show{display:block}
.fund-c-h{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin:18px 0 9px}
.contribs{display:flex;flex-wrap:wrap;gap:6px}
.contribs span{font-family:var(--mono);font-size:10px;color:var(--muted2);border:1px solid var(--border);border-radius:999px;padding:4px 9px}

/* ── FOOTER ── */
footer{border-top:1px solid var(--border);padding:24px 16px 34px;text-align:center;color:var(--muted);font-size:11.5px;margin-top:30px}
footer a{color:var(--ink)}
footer .disc{margin-top:8px;font-size:10px;color:#33425c}

@media(max-width:480px){
  .floatingchat-container-wrap,.floatingchat-container-wrap-mobi,
  iframe.floatingchat-container,iframe.floatingchat-container-mobi{display:none!important}
}
