:root{
  --yellow:#FFE400; --yellow-d:#EAC700;
  --ink:#111; --ink-2:#2b2b2b; --muted:#6f6f6f;
  --line:#ededed; --bg:#fafafa; --card:#fff; --green:#1E8C5A; --red:#d9482b;
  --radius:16px; --shadow:0 14px 40px rgba(0,0,0,.12);
  --font:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{font-family:var(--font);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
.oa{border-radius:9px;display:block;flex-shrink:0}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:14px}
.btn{border:none;border-radius:11px;font-weight:700;font-size:14px;padding:11px 16px;display:inline-flex;align-items:center;gap:8px;justify-content:center;text-decoration:none;color:var(--ink);background:#fff;border:1px solid var(--line)}
.btn.solid{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn.yellow{background:var(--yellow);color:#111;border-color:var(--yellow)}
.btn.danger{color:var(--red);border-color:#f3c9c0}
.btn:active{transform:scale(.98)}
.tag{display:inline-block;font-size:10px;font-weight:800;padding:3px 8px;border-radius:7px;background:#f0f0f0;color:var(--ink-2);letter-spacing:.3px}
.tag.live{background:var(--yellow);color:#111}.tag.p{background:#111;color:var(--yellow)}.tag.gold{background:rgba(255,228,0,.32);color:#7a5d00}.tag.match{background:rgba(30,140,90,.12);color:var(--green)}
.langtog{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:#fff;font-weight:800;font-size:11px}
.langtog b{padding:5px 9px;color:var(--muted)}.langtog b.on{background:var(--ink);color:#fff}
.avatar{border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:800;flex-shrink:0}

/* ===== Attendee app (mobile full-screen PWA) ===== */
.app{max-width:480px;margin:0 auto;min-height:100vh;min-height:100dvh;background:var(--bg);display:flex;flex-direction:column;position:relative}
.appbar{position:sticky;top:0;z-index:20;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px;padding:12px 14px;padding-top:max(12px,env(safe-area-inset-top))}
.appbar .oa{width:36px;height:36px}
.appbar .ttl{flex:1;min-width:0}.appbar .ttl b{font-size:15px;display:block;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.appbar .ttl small{color:var(--muted);font-size:11px}
.appbar .ic{width:34px;height:34px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;background:#fff;font-size:15px;position:relative}
.appbar .ic .dot{position:absolute;top:6px;right:7px;width:7px;height:7px;border-radius:50%;background:var(--yellow);box-shadow:0 0 0 2px #fff}
.scroll{flex:1;overflow-y:auto;padding:14px 14px 90px}
.view{display:none}.view.on{display:block;animation:f .2s ease}
@keyframes f{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
h2.scr{font-size:21px;margin:4px 2px 6px}.sub{color:var(--muted);font-size:13px;margin:0 2px 14px}
.back{color:var(--ink);font-weight:800;font-size:13px;margin:0 0 12px;background:none;border:none;padding:4px 0}
.hero{border-radius:18px;padding:18px;color:#fff;background:linear-gradient(135deg,#1c1c1c,#000 60%,#1c1c1c);position:relative;overflow:hidden}
.hero .k{position:absolute;right:-30px;top:-30px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(255,228,0,.6),transparent 70%)}
.hero h3{font-size:18px;position:relative;z-index:1}.hero p{font-size:12.5px;opacity:.85;position:relative;z-index:1;margin-top:4px}
.hero .slg{position:relative;z-index:1;color:var(--yellow);font-weight:800;font-style:italic;font-size:11.5px;margin-top:9px}
.seg{display:flex;gap:6px;margin:14px 0}
.seg button{flex:1;border:1px solid var(--line);background:#fff;border-radius:10px;padding:8px 0;font-weight:700;font-size:11.5px}
.seg button.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin-bottom:11px}
.evc{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;margin-bottom:12px;cursor:pointer}
.evc .top{height:72px;display:flex;align-items:flex-end;padding:10px 12px;color:#fff;position:relative}
.evc .top b{position:relative;z-index:1;font-size:14.5px;text-shadow:0 1px 6px rgba(0,0,0,.4)}
.evc .top .st{position:absolute;top:10px;right:10px;font-size:9.5px;font-weight:800;padding:3px 9px;border-radius:999px}
.st.live{background:var(--yellow);color:#111}.st.upcoming{background:#fff;color:#111}.st.past{background:rgba(255,255,255,.25);color:#fff}
.evc .bd{padding:11px 13px}.evc .r1{font-size:11.5px;color:var(--muted);font-weight:600}.evc .th{font-size:12px;color:var(--ink-2);margin-top:5px}
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:13px}
.tile{background:#fff;border:1px solid var(--line);border-radius:14px;padding:13px;cursor:pointer}
.tile .ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-size:19px;margin-bottom:8px;background:#FFF4BF}
.tile b{font-size:13px;display:block}.tile small{color:var(--muted);font-size:10.5px}
.row{display:flex;gap:11px;align-items:center}
.row .av{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px;flex-shrink:0}
.row .m{flex:1;min-width:0}.row .m b{font-size:14px;display:block}.row .m small{color:var(--muted);font-size:11.5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.score{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:12px;color:var(--green);background:conic-gradient(var(--green) var(--p,90%),#e9efe9 0);position:relative;flex-shrink:0}
.score::after{content:"";position:absolute;inset:4px;background:#fff;border-radius:50%}.score span{position:relative;z-index:1}
.sec{display:flex;justify-content:space-between;align-items:center;margin:18px 2px 10px}.sec b{font-size:14.5px}
.ses{display:flex;gap:12px;padding:13px 0;border-bottom:1px solid var(--line)}
.ses .t{width:54px;font-weight:800;font-size:12px;flex-shrink:0}.ses .t small{display:block;color:var(--muted);font-weight:600;font-size:10px}
.ses .b b{font-size:13.5px;display:block;line-height:1.25}.ses .b small{color:var(--muted);font-size:11.5px}
.ses .trk{display:inline-block;font-size:9.5px;font-weight:800;padding:2px 7px;border-radius:6px;margin-top:5px}
.ses .star{margin-left:auto;font-size:24px;color:#cfc8bd;background:none;border:none;padding:8px;min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:rgba(255,228,0,.3)}.ses .star.on{color:var(--yellow-d)}.ses .star:active{transform:scale(.9)}
.day-tabs{display:flex;gap:7px;margin:2px 0 12px}
.day-tabs button{flex:1;border:1px solid var(--line);background:#fff;border-radius:11px;padding:9px 0;font-weight:700;font-size:12px}
.day-tabs button.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.notif{display:flex;gap:11px;padding:12px 2px;border-bottom:1px solid var(--line)}
.notif .ni{width:36px;height:36px;border-radius:10px;background:#FFF4BF;display:grid;place-items:center;font-size:16px;flex-shrink:0}
.notif b{font-size:12.5px}.notif small{color:var(--muted);font-size:11px;display:block}
.chips{display:flex;gap:7px;flex-wrap:wrap;justify-content:center;margin:12px 0}
.chips span{background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:11.5px;font-weight:700}
.tabbar{position:sticky;bottom:0;background:#fff;border-top:1px solid var(--line);display:flex;padding:8px 6px;padding-bottom:max(10px,env(safe-area-inset-bottom))}
.tabbar button{flex:1;border:none;background:none;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--muted);font-size:10px;font-weight:700}
.tabbar button .gi{font-size:19px}.tabbar button.on{color:var(--ink)}.tabbar button.on .gi{filter:drop-shadow(0 3px 0 var(--yellow))}
.toast{position:fixed;left:50%;bottom:90px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:11px 18px;border-radius:12px;font-size:12.5px;font-weight:600;opacity:0;transition:.3s;z-index:60;box-shadow:var(--shadow);max-width:90%}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}
.banner{background:#111;color:#fff;border-radius:14px;padding:11px 14px;font-size:12px;display:flex;gap:10px;align-items:center;margin-bottom:12px}
.banner a{color:var(--yellow);font-weight:800}
#thread{display:flex;flex-direction:column}
.bub{max-width:80%;padding:9px 13px;border-radius:15px;font-size:13px;line-height:1.35;margin-bottom:8px}
.bub.them{background:#fff;border:1px solid var(--line);border-bottom-left-radius:5px;align-self:flex-start}
.bub.me{background:var(--ink);color:#fff;border-bottom-right-radius:5px;align-self:flex-end}
.bub small{display:block;font-size:9.5px;opacity:.6;margin-top:3px}
.chatbar{display:flex;gap:8px;position:sticky;bottom:0;background:var(--bg);padding:8px 0 4px}
.chatbar input{flex:1;border:1px solid var(--line);border-radius:999px;padding:11px 15px;font-size:14px;background:#fff}
.chatbar button{border:none;background:var(--ink);color:#fff;width:44px;border-radius:50%;font-size:16px}
.modepill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;padding:4px 10px;border-radius:999px;background:#f0f0f0;color:var(--muted)}
.modepill.live{background:rgba(30,140,90,.12);color:var(--green)}
/* login gate (mode réel uniquement) */
.authgate{position:fixed;inset:0;z-index:100;background:linear-gradient(135deg,#1c1c1c,#000);display:none;align-items:center;justify-content:center;padding:22px}
.authgate.on{display:flex}
.authcard{background:#fff;border-radius:20px;padding:26px 22px;max-width:380px;width:100%;text-align:center;box-shadow:var(--shadow)}
.authcard .oa{width:64px;height:64px;margin:0 auto 14px}
.authcard h2{font-size:22px;margin-bottom:6px}.authcard p{color:var(--muted);font-size:13px;margin-bottom:16px}
.authcard input{width:100%;border:1px solid var(--line);border-radius:11px;padding:12px 14px;margin-bottom:10px;font-size:15px;text-align:center}
.authcard .btn{width:100%}
.authcard .msg{font-size:12.5px;color:var(--muted);margin-top:10px;min-height:16px}
.authcard .slg{color:var(--yellow-d);font-weight:800;font-style:italic;font-size:11.5px;margin-top:14px}

/* ===== Admin console ===== */
.admin{min-height:100vh;display:flex;flex-direction:column}
.adbar{background:#111;color:#fff;display:flex;align-items:center;gap:12px;padding:12px 18px;position:sticky;top:0;z-index:20}
.adbar .oa{width:34px;height:34px}.adbar b{font-size:15px}.adbar small{color:#bbb;font-size:11px;display:block}
.adbar .right{margin-left:auto;display:flex;align-items:center;gap:12px}
.adwrap{max-width:1080px;margin:0 auto;width:100%;padding:20px;flex:1}
.adnav{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.adnav button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:9px 16px;font-weight:700;font-size:13px}
.adnav button.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:22px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px}
.kpi b{font-size:30px;display:block}.kpi small{color:var(--muted);font-weight:700;font-size:12px}
.kpi .bar{height:6px;border-radius:6px;background:#f0f0f0;margin-top:10px;overflow:hidden}.kpi .bar i{display:block;height:100%;background:var(--yellow)}
.panel{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;margin-bottom:18px}
.panel h3{font-size:16px;margin-bottom:4px}.panel .desc{color:var(--muted);font-size:13px;margin-bottom:14px}
.adpage{display:none}.adpage.on{display:block}
.field{margin-bottom:12px}.field label{display:block;font-size:12px;font-weight:700;color:var(--ink-2);margin-bottom:5px}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:#fff}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.li{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:12px;margin-bottom:9px}
.li .m{flex:1;min-width:0}.li .m b{font-size:14px;display:block}.li .m small{color:var(--muted);font-size:12px}
.login{max-width:360px;margin:60px auto;background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px;text-align:center;box-shadow:var(--shadow)}
.login .oa{width:64px;height:64px;margin:0 auto 14px}
.adtoast{position:fixed;right:20px;bottom:20px;background:var(--ink);color:#fff;padding:12px 18px;border-radius:12px;font-weight:600;font-size:13px;opacity:0;transform:translateY(12px);transition:.3s;z-index:60}
.adtoast.on{opacity:1;transform:none}
.empty{color:var(--muted);font-size:13px;padding:14px;text-align:center}
@media(max-width:620px){.grid2{grid-template-columns:1fr}}
