:root{--bg:#0d1b2a;--surface:#162233;--surface2:#1d2e42;--brand:#0a8fd4;--brand-dark:#0772ab;--brand-glow:#0a8fd440;--ok:#22c55e;--err:#ef4444;--text:#f0f6ff;--text-dim:#94a3b8;--border:#ffffff14;--radius:18px;--radius-sm:12px}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);width:100%;height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:Poppins,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow-x:hidden}main.app-shell{flex-direction:column;width:100%;max-width:480px;min-height:100dvh;margin:0 auto;display:flex}.topbar{border-bottom:1px solid var(--border);background:linear-gradient(135deg,#0e4a6e 0%,#07304a 100%);align-items:center;gap:10px;padding:16px 20px 14px;display:flex}.topbar-logo{flex-shrink:0;width:30px;height:30px}.topbar-title{color:#fff;flex:1;font-size:1rem;font-weight:600}.topbar-actions{align-items:center;gap:10px;display:flex}.topbar-action{color:#fff;cursor:pointer;touch-action:manipulation;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background:#ffffff1f;border:1px solid #ffffff2e;border-radius:999px;min-height:36px;padding:6px 14px;font-family:inherit;font-size:.8rem;font-weight:600}.topbar-action:active{background:#fff3}.page{flex-direction:column;flex:1;gap:14px;padding:20px 20px 36px;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:14px;padding:20px;display:flex}.login-wrap{flex-direction:column;flex:1;justify-content:center;gap:28px;padding:32px 20px 48px;display:flex}.login-header{text-align:center;flex-direction:column;align-items:center;gap:10px;display:flex}.login-logo{width:72px;height:72px;box-shadow:0 0 40px var(--brand-glow);border-radius:18px}.login-header h1{font-size:1.3rem;font-weight:700}.login-header p{color:var(--text-dim);font-size:.88rem}.login-form{flex-direction:column;gap:12px;display:flex}.input-group{flex-direction:column;gap:5px;display:flex}.input-group label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);padding-left:4px;font-size:.75rem;font-weight:600}input{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface2);width:100%;color:var(--text);touch-action:manipulation;outline:none;padding:13px 16px;font-family:inherit;font-size:16px;transition:border-color .15s,box-shadow .15s}input::placeholder{color:var(--text-dim);opacity:.5}input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow)}button{cursor:pointer;touch-action:manipulation;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;border:none;border-radius:999px;min-height:48px;padding:13px 20px;font-family:inherit;font-size:.95rem;font-weight:600;transition:filter .12s,transform .1s}button:active{filter:brightness(.85);transform:scale(.97)}button.primary{background:linear-gradient(135deg, var(--brand), var(--brand-dark));color:#fff;box-shadow:0 4px 20px var(--brand-glow);width:100%}button.danger{color:#fff;background:linear-gradient(135deg,#ef4444,#b91c1c);flex:1}button.success{color:#fff;background:linear-gradient(135deg,#22c55e,#16a34a);flex:1}.status{border-radius:var(--radius-sm);border:1px solid #0000;padding:12px 14px;font-size:.88rem;font-weight:500;line-height:1.45}.status.info{color:#7dd3fc;background:#0a8fd41f;border-color:#0a8fd433}.status.success{color:#86efac;background:#22c55e1f;border-color:#22c55e33}.status.error{color:#fca5a5;background:#ef44441f;border-color:#ef444433}#reader{border-radius:var(--radius-sm);background:var(--surface2);border:1px solid var(--border);width:100%;overflow:hidden}.action-row{gap:10px;display:flex}.section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);font-size:.72rem;font-weight:700}.muted{color:var(--text-dim);font-size:.88rem;line-height:1.5}.splash{min-height:100dvh;color:var(--text-dim);flex-direction:column;justify-content:center;align-items:center;gap:14px;font-size:.9rem;display:flex}.splash-logo{opacity:.6;border-radius:16px;width:64px;height:64px}.install-screen{text-align:center;background:radial-gradient(ellipse at top, #0e2a40 0%, var(--bg) 70%);flex-direction:column;justify-content:center;align-items:center;gap:14px;min-height:100dvh;padding:40px 28px;display:flex}.install-icon{width:100px;height:100px;box-shadow:0 8px 40px var(--brand-glow);border-radius:24px;margin-bottom:4px}.install-title{font-size:1.5rem;font-weight:700}.install-tagline{color:var(--text-dim);max-width:260px;font-size:.92rem}.install-instructions{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-width:320px;color:var(--text-dim);margin-top:4px;padding:22px 24px;font-size:.92rem;line-height:1.7}.install-instructions strong{color:var(--text)}.install-btn{width:100%;max-width:280px;margin-top:4px;padding:14px 36px;font-size:1rem}main.app-shell.admin-shell{max-width:1280px}.admin-topbar{justify-content:space-between;gap:16px}.admin-topbar-brand{align-items:center;gap:12px;min-width:0;display:flex}.topbar-subtitle{color:#ffffffb3;margin-top:2px;font-size:.82rem}.admin-page{gap:18px}.admin-page-single{justify-content:center}.admin-panel-card{gap:18px}.admin-card-head{justify-content:space-between;align-items:center;gap:16px;display:flex}.admin-title,.admin-section-title{font-size:1.2rem;font-weight:700}.admin-stat-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.admin-stat{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:4px;padding:16px;display:flex}.admin-stat-value{font-size:1.6rem;font-weight:700}.admin-stat-label{color:var(--text-dim);font-size:.85rem}.admin-grid{grid-template-columns:minmax(320px,1.1fr) minmax(320px,.9fr);align-items:start;gap:18px;display:grid}.admin-form-stack{gap:18px;display:grid}.admin-form{flex-direction:column;gap:14px;display:flex}.admin-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.player-list{flex-direction:column;gap:10px;max-height:720px;display:flex;overflow-y:auto}.player-list-item{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface2);text-align:left;flex-direction:column;align-items:flex-start;gap:8px;width:100%;padding:14px 16px;display:flex}.player-list-item.selected{box-shadow:0 0 0 3px var(--brand-glow);border-color:#0a8fd499}.player-list-head,.player-meta,.player-badges{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;width:100%;display:flex}.player-list-email,.player-list-id,.player-meta{color:var(--text-dim);font-size:.84rem}.player-badge{color:#7dd3fc;background:#0a8fd41f;border:1px solid #0a8fd433;border-radius:999px;padding:5px 10px;font-size:.76rem;font-weight:600}.attendance-table-wrap{overflow-x:auto}.attendance-table{border-collapse:collapse;table-layout:fixed;width:100%;min-width:820px}.player-table th:nth-child(6),.player-table td:nth-child(6){width:80px}.attendance-table th,.attendance-table td{text-overflow:ellipsis;white-space:nowrap;border-bottom:1px solid var(--border);text-align:left;vertical-align:top;padding:12px 10px;overflow:hidden}.attendance-table th{color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;font-size:.76rem}.attendance-subvalue{color:var(--text-dim);margin-top:4px;font-size:.78rem}.attendance-empty{color:var(--text-dim)}.wrap-row{flex-wrap:wrap}@media (max-width:900px){.admin-grid{grid-template-columns:1fr}}@media (max-width:640px){.admin-topbar,.admin-card-head,.stack-on-mobile{flex-direction:column;align-items:stretch}.topbar-actions{width:100%}.topbar-actions .topbar-action{flex:1}.admin-form-grid,.admin-stat-row{grid-template-columns:1fr}}.icon-btn{width:32px;height:32px;min-height:auto;color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:1rem;transition:color .15s,background .15s;display:flex}.icon-btn.edit{color:var(--brand)}.icon-btn.edit:hover:not(:disabled){color:#7dd3fc;background:#0a8fd41f}.icon-btn.save{color:var(--ok)}.icon-btn.save:hover:not(:disabled){background:#22c55e1f}.icon-btn.cancel{color:var(--err)}.icon-btn.cancel:hover:not(:disabled){background:#ef44441f}.icon-btn:disabled{opacity:.5;cursor:not-allowed}.row-actions{justify-content:center;gap:6px;display:flex}.editing-row td{padding:8px 4px}.editing-row input{width:100%;min-height:auto;padding:6px 8px;font-size:.85rem}.pagination-controls{justify-self:end;align-items:center;gap:12px;display:flex}.pagination-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;min-height:auto;padding:8px 12px;font-size:.85rem;transition:background .15s,border-color .15s}.pagination-btn:hover:not(:disabled){background:var(--brand);border-color:var(--brand);color:#fff}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{color:var(--text-dim);white-space:nowrap;font-size:.85rem}.admin-view-switcher{flex-wrap:wrap;gap:10px;display:flex}.view-tab{border:1px solid var(--border);background:var(--surface2);color:var(--text);border-radius:var(--radius-sm);letter-spacing:.02em;cursor:pointer;min-height:auto;padding:8px 14px;font-size:.86rem;font-weight:700}.view-tab.active{background:var(--brand);border-color:var(--brand);color:#fff}.import-errors{color:var(--err);flex-direction:column;gap:4px;margin:.5rem 0 0;padding-left:1.25rem;font-size:.82rem;display:flex}
