:root{--bg: #f4f6f8;--surface: #ffffff;--surface-alt: #eef3f7;--text: #163041;--muted: #66808f;--border: #d7e0e8;--accent: #0f7b72;--accent-dark: #0b5d56;--danger: #bb3e3e;--warning: #d98324;--success: #247a45;--shadow: 0 16px 40px rgba(22, 48, 65, .08);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:var(--text);background:linear-gradient(180deg,#f4f6f8,#ebf1f5)}:root[data-theme=dark]{--bg: #111923;--surface: #182431;--surface-alt: #223244;--text: #e8f0f6;--muted: #98afc0;--border: #324657;--accent: #21a68d;--accent-dark: #16816e;--danger: #d35d5d;--warning: #f2a13d;--success: #4fc47e;--shadow: 0 18px 40px rgba(0, 0, 0, .28)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,#163041,#0f2230);color:#fff;padding:24px 18px}:root[data-theme=dark] .sidebar{background:linear-gradient(180deg,#101923,#0a1118)}.sidebar h2{margin:0 0 8px;font-size:1.35rem}.sidebar p{margin:0 0 24px;color:#ffffffb8;font-size:.9rem}.sidebar-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px}.sidebar-brand-logo{width:38px;height:38px;flex-shrink:0;border-radius:10px;background:#ffffff29;padding:4px}.sidebar-brand h2{margin:0 0 4px}.sidebar-brand p{margin:0}.sidebar nav{display:flex;flex-direction:column;gap:18px}.sidebar-group{display:grid;gap:8px}.sidebar-group-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0 10px;border:none;background:transparent;color:inherit;text-align:left}.sidebar-group-title{font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#ffffff7a}.sidebar-group-arrow{color:#ffffff94;transition:transform .2s ease;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px}.sidebar-group-arrow.open{transform:rotate(180deg)}.sidebar-group-arrow-icon{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.sidebar-group-links{display:grid;gap:8px}.sidebar-link{padding:12px 14px;border-radius:12px;color:#ffffffdb;transition:background .2s ease,transform .2s ease}.sidebar-link:hover,.sidebar-link.active{background:#ffffff1f;color:#fff;transform:translate(2px)}.content-shell{display:flex;flex-direction:column;min-width:0}.topbar{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;background:#ffffffd6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}:root[data-theme=dark] .topbar{background:#141d26e0}.topbar-brand{display:inline-flex;align-items:center;gap:10px;margin-right:6px}.topbar-brand-logo{width:30px;height:30px;border-radius:8px}.topbar-brand-text{font-weight:700;letter-spacing:.01em}.page-content{padding:24px;width:100%;min-width:0}.page-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}.page-header h1,.page-header h2,.page-header h3{margin:0}.modal-content .page-header h3{font-size:1.083rem;font-weight:700;line-height:1.2}.muted{color:var(--muted)}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.card,.panel,.metric-card,.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow)}.panel{padding:20px;margin-bottom:20px}.metric-card{padding:18px}.metric-card h3{margin:0 0 10px;font-size:.95rem;color:var(--muted)}.metric-card strong{font-size:1.65rem}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top left,rgba(15,123,114,.28),transparent 35%),radial-gradient(circle at bottom right,rgba(22,48,65,.2),transparent 28%),linear-gradient(135deg,#e9f1f3,#f8fbfc 55%,#eef4f5)}.auth-card{width:min(440px,100%);padding:28px}.auth-brand{display:flex;justify-content:center;margin-bottom:18px}.auth-logo{width:min(280px,100%);max-height:120px;object-fit:contain;display:block}.auth-card h1{margin-top:0}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.field{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.field label{font-size:.92rem;color:var(--muted)}.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text)}.searchable-select{position:relative}.searchable-select-trigger{width:100%;min-height:46px;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text);display:flex;align-items:center;justify-content:space-between;gap:12px;text-align:left}.searchable-select-trigger.open{border-color:var(--accent);box-shadow:0 0 0 3px #0f7b721f}.searchable-select-trigger:disabled{background:var(--surface-alt);color:var(--muted)}.searchable-select-value{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.searchable-select-value.placeholder{color:var(--muted)}.searchable-select-chevron{color:var(--muted);font-size:.9rem;line-height:1;flex:0 0 auto}.searchable-select-popover{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:25;display:grid;gap:10px;padding:10px;border:1px solid var(--border);border-radius:14px;background:var(--surface);box-shadow:var(--shadow)}.searchable-select-search{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--surface-alt);color:var(--text)}.searchable-select-options{display:grid;gap:6px;max-height:260px;overflow-y:auto}.searchable-select-option{width:100%;border:none;border-radius:10px;padding:10px 12px;background:transparent;color:var(--text);display:flex;align-items:center;justify-content:space-between;gap:12px;text-align:left}.searchable-select-option:hover,.searchable-select-option:focus-visible{background:var(--surface-alt)}.searchable-select-option.selected{background:#0f7b721f;color:var(--accent-dark)}:root[data-theme=dark] .searchable-select-option.selected{background:#21a68d2e;color:#b8f1e3}.searchable-select-selected{color:var(--muted);font-size:.82rem}.searchable-select-empty{padding:12px;color:var(--muted)}.field textarea{min-height:100px;resize:vertical}.button-row,.inline-actions{display:flex;gap:10px;flex-wrap:wrap}.btn{border:none;border-radius:12px;padding:11px 16px;background:var(--accent);color:#fff;font-weight:600}.btn:hover{background:var(--accent-dark)}.btn.secondary{background:var(--surface-alt);color:var(--text)}.btn.danger{background:var(--danger)}.btn.warning{background:var(--warning)}.btn:disabled{opacity:.6;cursor:not-allowed}.topbar-icon-btn{width:42px;height:42px;padding:0;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.topbar-icon-btn svg{width:20px;height:20px;color:var(--text)}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:12px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top;white-space:nowrap}.data-table th{color:var(--muted);font-weight:600;background:var(--surface-alt)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.8rem;font-weight:600;background:var(--surface-alt)}.badge.success{background:#dff3e6;color:var(--success)}.badge.warning{background:#fff2df;color:var(--warning)}.badge.danger{background:#fbe1e1;color:var(--danger)}.running-grid,.split-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.dashboard-running-grid{grid-template-columns:repeat(auto-fit,minmax(180px,220px));justify-content:start}.dashboard-running-grid .snooker-table-card.compact{padding:0;overflow:hidden;border-radius:16px}.snooker-table-compact-link{display:block;color:inherit;text-decoration:none;outline:none}.snooker-table-compact-link:focus-visible .snooker-table-card.compact,.snooker-table-compact-link:hover .snooker-table-card.compact{transform:translateY(-2px)}.dashboard-running-grid .snooker-table-compact{position:relative;min-height:214px;padding:14px;display:flex;flex-direction:column;justify-content:flex-end;gap:12px;background-color:#0a8f2d;background-size:cover;background-position:center;background-repeat:no-repeat}.dashboard-running-grid .snooker-table-compact:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#05190a1a,#05190ab8)}.dashboard-running-grid .snooker-table-compact-overlay{position:relative;z-index:1;display:grid;gap:6px;width:100%;color:#fff}.dashboard-running-grid .snooker-table-compact-overlay h3{margin:0;font-size:1.02rem;line-height:1.15}.dashboard-running-grid .snooker-table-thumb-wrap{position:relative;z-index:1;width:100%;height:96px;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.16);background:#ffffff0f;box-shadow:0 12px 24px #0000002e}.dashboard-running-grid .snooker-table-thumb{display:block;width:100%;height:100%;object-fit:cover}.dashboard-running-grid .snooker-table-compact-overlay p{margin:0;font-size:.86rem;color:#ffffffdb}.dashboard-running-grid .snooker-table-compact .snooker-table-type{color:#ffffffbd}.dashboard-running-grid .snooker-table-compact .snooker-table-timer{width:fit-content;padding:7px 10px;border-radius:12px;background:#ffffff29;border:1px solid rgba(255,255,255,.18);color:#fff;font-size:.92rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}:root[data-theme=dark] .dashboard-running-grid .snooker-table-compact:before{background:linear-gradient(180deg,#050c1214,#050c12c2)}.dashboard-running-grid .snooker-table-footer{margin-top:10px}.running-table-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.running-table-card{width:100%;border-radius:12px;padding:16px}.running-table-media{margin-bottom:12px}.running-table-image{width:100%;height:140px;object-fit:cover;border-radius:10px;border:1px solid var(--border);background:var(--surface-alt)}.running-table-image-placeholder{display:grid;place-items:center;color:var(--muted);font-size:.88rem}.running-table-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.running-table-grid-stats{margin-top:10px;display:grid;gap:6px;color:var(--muted)}.action-buttons{display:flex;flex-wrap:wrap;gap:8px}.table-responsive{width:100%;overflow-x:auto}.running-card,.table-card{padding:18px}.running-card h3,.table-card h3{margin-top:0}.table-showcase-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px}.snooker-table-card{background:linear-gradient(180deg,#fffdf7,#f4eee2);border:1px solid #d9c6a1;border-radius:24px;padding:14px;box-shadow:0 18px 36px #46311024}:root[data-theme=dark] .snooker-table-card{background:linear-gradient(180deg,#1d2834,#17212b);border-color:#445767}.snooker-table-action{display:block;width:100%;border:none;padding:0;background:transparent;text-align:left}.snooker-table-action.disabled{cursor:not-allowed}.snooker-table-visual{position:relative;min-height:255px;border-radius:18px;overflow:hidden;border:8px solid #8f5725;background:radial-gradient(circle at 50% 50%,rgba(43,194,72,.3),transparent 50%),linear-gradient(90deg,#0a8f2d,#24cb4f,#068725);background-size:cover;background-position:center;box-shadow:inset 0 0 0 2px #ffe6ae59,inset 0 18px 34px #ffffff1f,inset 0 -20px 30px #0000002e;display:flex;justify-content:space-between;gap:16px;padding:18px;transition:transform .18s ease,box-shadow .18s ease}.snooker-table-action:not(.disabled):hover .snooker-table-visual{transform:translateY(-3px);box-shadow:inset 0 0 0 2px #ffe6ae59,inset 0 18px 34px #ffffff1f,inset 0 -20px 30px #0000002e,0 20px 30px #1830142e}.snooker-table-left{position:relative;z-index:1;color:#f5fff2;display:flex;flex-direction:column;align-items:flex-start;gap:8px;max-width:48%}.snooker-table-left h3{margin:4px 0 0;font-size:1.62rem;color:#fff}.snooker-table-left p{margin:0;color:#f3fff4d6}.snooker-table-type{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:#ffffffbd}.snooker-table-panel{position:relative;z-index:1;align-self:center;width:min(220px,60%);background:#f8fbf8e6;border-radius:18px;padding:16px 14px;display:grid;gap:8px;text-align:center;border:1px solid rgba(255,255,255,.56);box-shadow:0 12px 28px #0b2a0e2e}:root[data-theme=dark] .snooker-table-panel{background:#16222eeb;border-color:#ffffff14}.snooker-table-panel strong{font-size:1.05rem}.snooker-table-panel span{color:var(--muted)}.snooker-table-stats{display:grid;gap:4px;font-size:.84rem}.snooker-table-total{color:var(--text);font-size:.84rem;font-weight:700}.snooker-table-hint{display:inline-block;width:100%;text-align:center;color:#3f5d44;font-weight:600}:root[data-theme=dark] .snooker-table-hint{color:#9fceb0}.snooker-table-timer{padding:10px 12px;border-radius:14px;background:linear-gradient(180deg,#fff,#ecf3ea);border:1px solid #d5e1d3;font-size:1.1rem;font-weight:700;color:#26412b}.snooker-pocket{position:absolute;width:16px;height:16px;border-radius:50%;background:#111;box-shadow:inset 0 2px 4px #ffffff1f}.pocket-top-left{top:4px;left:4px}.pocket-top-center{top:4px;left:50%;transform:translate(-50%)}.pocket-top-right{top:4px;right:4px}.pocket-bottom-left{bottom:4px;left:4px}.pocket-bottom-center{bottom:4px;left:50%;transform:translate(-50%)}.pocket-bottom-right{bottom:4px;right:4px}.snooker-ball{position:absolute;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,#f4f4f4 44%,#d7d7d7);box-shadow:0 8px 14px #0000002e}.ball-one{width:34px;height:34px;bottom:28px;left:10px}.ball-two{width:22px;height:22px;bottom:16px;left:48px}.snooker-table-footer{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:14px;padding:4px 4px 2px}.snooker-table-meta{display:flex;flex-direction:column;gap:4px;color:#7a6a49;font-size:.85rem}:root[data-theme=dark] .snooker-table-meta{color:#b2c0cb}.snooker-table-card.running-session .snooker-table-visual{box-shadow:inset 0 0 0 2px #c8ffb070,inset 0 18px 34px #ffffff24,inset 0 -20px 30px #0003}.snooker-table-card.paused-session .snooker-table-visual{filter:saturate(.95) contrast(.98);box-shadow:inset 0 0 0 2px #ffeab170,inset 0 18px 34px #ffffff1f,inset 0 -20px 30px #0003}.running-table-actions{flex-wrap:nowrap;overflow-x:auto;width:100%;padding-bottom:2px}.running-table-actions .btn{flex:0 0 auto;white-space:nowrap}.session-btn-pause{background:#254c73;color:#fff}.session-btn-pause:hover{background:#1d3d5d}.session-btn-complete{background:#2f8c52;color:#fff}.session-btn-complete:hover{background:#256f41}.session-btn-cancel{background:#b94040;color:#fff}.session-btn-cancel:hover{background:#983131}.list-reset{list-style:none;padding:0;margin:0}.notice{padding:12px 14px;border-radius:12px;margin-bottom:14px;background:#e8f4f3;color:var(--accent-dark)}.notice.error{background:#fbe1e1;color:var(--danger)}:root[data-theme=dark] .notice{background:#1e3b3a}:root[data-theme=dark] .notice.error{background:#402124}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#09141c73;display:grid;place-items:center;padding:20px;z-index:30}.modal-content{width:min(640px,100%);background:var(--surface);border-radius:18px;border:1px solid var(--border);box-shadow:var(--shadow);padding:22px}.summary-list{display:grid;gap:10px}.summary-item{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px dashed var(--border)}.chart-block{display:grid;grid-template-columns:minmax(180px,240px) 1fr;gap:20px;align-items:center}.pie-chart-wrap{display:flex;justify-content:center}.pie-chart{width:min(240px,100%);height:auto;overflow:visible}.chart-center-label{font-size:5px;fill:var(--muted)}.chart-center-value{font-size:6px;font-weight:700;fill:var(--text)}.chart-legend{display:grid;gap:10px}.chart-legend-item{display:grid;grid-template-columns:14px minmax(0,1fr) auto;gap:10px;align-items:center;padding-bottom:10px;border-bottom:1px dashed var(--border)}.chart-swatch{width:14px;height:14px;border-radius:999px}.bar-chart{display:grid;gap:14px}.bar-chart-row{display:grid;gap:8px}.bar-chart-head{display:flex;justify-content:space-between;gap:12px}.bar-chart-track{height:14px;border-radius:999px;background:var(--surface-alt);overflow:hidden}.bar-chart-fill{height:100%;border-radius:inherit}.mobile-sidebar-toggle,.sidebar-overlay{display:none}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.sidebar.mobile-open{display:block;position:fixed;inset:0 auto 0 0;width:min(280px,calc(100vw - 44px));z-index:50;overflow-y:auto}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;border:none;background:#08121880;z-index:45}.mobile-sidebar-toggle{display:inline-flex}}@media(max-width:640px){.page-content,.topbar{padding:16px}.topbar{flex-direction:row;align-items:center;justify-content:space-between;gap:8px;flex-wrap:nowrap}.topbar>.button-row{width:auto;min-width:0;flex-wrap:nowrap;align-items:center}.topbar>.button-row:first-child{flex:1 1 auto;justify-content:flex-start}.topbar>.button-row:last-child{flex:0 0 auto;justify-content:flex-end}.topbar-brand-text{display:none}.topbar .btn{width:auto;max-width:none}.mobile-sidebar-toggle{padding:10px 12px}.page-header{flex-direction:column;align-items:flex-start}.form-grid{grid-template-columns:1fr}.button-row,.action-buttons{width:100%;align-items:stretch}.btn{width:100%;max-width:100%}.topbar-icon-btn{width:42px;min-width:42px;height:42px;padding:0}.table-showcase-grid{grid-template-columns:1fr;gap:16px}.snooker-table-visual,.snooker-table-footer{flex-direction:column}.dashboard-running-grid .snooker-table-compact{min-height:202px}.dashboard-running-grid .snooker-table-thumb-wrap{height:84px}.snooker-table-left,.snooker-table-panel{max-width:100%;width:100%}.snooker-table-visual{min-height:220px}.snooker-table-footer{align-items:stretch}.snooker-table-footer .button-row{width:100%}.snooker-table-footer .btn{flex:1 1 100%}.running-table-actions{flex-wrap:nowrap;overflow-x:auto}.running-table-actions .btn{width:auto;flex:0 0 auto}.running-table-image{height:120px}.summary-item{gap:10px;flex-wrap:wrap}.chart-block{grid-template-columns:1fr}.modal-overlay{padding:12px}.modal-content{padding:16px;max-height:calc(100vh - 24px);overflow-y:auto}.field input[type=checkbox]{width:22px!important;height:22px!important}}
