#app{min-height:100%}:root{--bg: #f4f7fc;--bg-alt: #ffffff;--primary: #2f7df6;--primary-soft: rgba(47, 125, 246, .1);--primary-dark: #1854c8;--text-main: #111827;--text-muted: #6b7280;--border-soft: #e5e7eb;--danger: #ff4d4f;--success: #10b981;--chip-yellow: #ffd94a;--chip-green: #4ade80;--chip-purple: #a855f7;--chip-red: #fb7185;--radius-lg: 20px;--radius-md: 14px;--radius-pill: 999px;--shadow-soft: 0 10px 30px rgba(15, 23, 42, .06)}*{box-sizing:border-box;padding:0;margin:0}html,body{height:100%}body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg);color:var(--text-main);-webkit-font-smoothing:antialiased;overflow-x:hidden}button,input,select{font:inherit}#app,.app{max-width:480px;margin:0 auto;min-height:100vh;min-height:100dvh;background-color:var(--bg);display:flex;flex-direction:column;position:relative;padding-bottom:calc(80px + env(safe-area-inset-bottom))}.screen{padding:16px 16px 20px;flex:1}.screen.active{display:block}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.topbar-title{font-size:26px;font-weight:700;letter-spacing:-.02em;margin:0}.icon-btn,.back-btn{width:40px;height:40px;border-radius:999px;background-color:var(--bg-alt);box-shadow:var(--shadow-soft);display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;color:var(--text-main)}.icon-btn svg,.back-btn svg{width:20px;height:20px;stroke:currentColor}.week-strip{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;margin-bottom:8px;-webkit-overflow-scrolling:touch}.week-strip::-webkit-scrollbar{display:none}.week-day{min-width:56px;height:72px;border-radius:999px;background-color:var(--bg-alt);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:13px;color:var(--text-muted);box-shadow:0 6px 18px #0f172a0a;flex-shrink:0;cursor:pointer;border:none}.week-day span.date{font-size:18px;font-weight:600;color:var(--text-main);margin-top:4px}.week-day.active{background-color:var(--primary);color:#fff}.week-day.active span.date{color:#fff}.subheading{margin:8px 0 10px;font-size:16px;font-weight:600}.session-card{background-color:var(--bg-alt);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:14px;box-shadow:var(--shadow-soft);cursor:pointer;display:block;width:100%;text-align:left;border:none}.session-image{height:120px;background-size:cover;background-position:center;position:relative;background-color:#e5e7eb}.session-chip-row{position:absolute;left:12px;bottom:12px;display:flex;gap:6px;flex-wrap:wrap}.session-chip{padding:4px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:600;color:#111827}.chip-level-light{background-color:var(--chip-yellow)}.chip-level-light-plus{background-color:var(--chip-green)}.chip-level-light-pro{background-color:var(--chip-purple);color:#fff}.chip-level-medium{background-color:var(--chip-red);color:#fff}.chip-default{background-color:#e5e7eb}.session-time-pill{position:absolute;left:12px;top:12px;background-color:#111827bf;color:#f9fafb;font-size:12px;padding:4px 10px;border-radius:var(--radius-pill);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.session-body{padding:12px 14px 10px}.session-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.session-title{font-size:15px;font-weight:600;margin:0}.session-trainer-pill{padding:6px 11px;border-radius:var(--radius-pill);background-color:#e0f2fe;color:#0369a1;font-size:12px;font-weight:500;white-space:nowrap}.session-location{font-size:13px;color:var(--text-muted)}.session-footer{padding-top:8px;display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted)}.session-footer svg{width:16px;height:16px;stroke:var(--text-muted)}.filters-bar{margin-top:10px;margin-bottom:6px;display:flex;justify-content:flex-end}.filters-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-pill);border:none;background-color:var(--primary);color:#fff;font-size:13px;font-weight:500;cursor:pointer;box-shadow:var(--shadow-soft)}.filters-btn svg{width:16px;height:16px;stroke:#fff}.rating-tabs{display:flex;gap:10px;margin-top:6px;margin-bottom:14px;overflow-x:auto;padding-bottom:4px}.rating-tab{min-width:90px;padding:10px;border-radius:16px;background-color:var(--bg-alt);display:flex;flex-direction:column;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);cursor:pointer;box-shadow:0 6px 18px #0f172a0a;flex-shrink:0;border:2px solid transparent}.rating-tab.active{border-color:var(--primary);padding:8px;color:var(--text-main)}.rating-tab-icon{width:26px;height:26px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:var(--primary-soft)}.player-card{background-color:var(--bg-alt);border-radius:var(--radius-lg);padding:10px 12px;display:flex;align-items:center;gap:10px;margin-bottom:8px;box-shadow:var(--shadow-soft)}.player-place{width:26px;height:26px;border-radius:999px;background:#f3f4f6;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.player-avatar{width:36px;height:36px;border-radius:999px;border:2px solid #f3f4f6;flex-shrink:0;background-color:#e5e7eb;display:flex;align-items:center;justify-content:center;font-weight:700;color:#11182773;overflow:hidden}.player-avatar-image{width:100%;height:100%;object-fit:cover;display:block}.player-main{flex:1}.player-name{font-size:14px;font-weight:500;margin-bottom:2px}.player-score{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--primary);font-weight:600}.player-score svg{width:14px;height:14px;stroke:var(--primary)}.profile-card{background-color:var(--bg-alt);border-radius:var(--radius-lg);padding:14px;margin-bottom:16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-soft);cursor:pointer;border:none;width:100%;text-align:left}.profile-avatar{width:54px;height:54px;border-radius:999px;background:#e5e7eb;display:flex;align-items:center;justify-content:center;font-size:22px;color:#9ca3af;flex-shrink:0;background-size:cover;background-position:center;overflow:hidden}.profile-avatar-image{width:100%;height:100%;object-fit:cover;display:block}.profile-main{flex:1}.profile-name{font-size:15px;font-weight:600}.profile-sub{font-size:13px;color:var(--text-muted);margin-top:2px}.profile-rating-pill{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;border-radius:var(--radius-pill);background-color:#eff6ff;font-size:12px;color:var(--primary);font-weight:500;white-space:nowrap}.profile-rating-pill svg{width:14px;height:14px;stroke:currentColor}.section-title{font-size:15px;font-weight:600;margin:14px 0 8px}.settings-list{background-color:transparent}.settings-item{background-color:var(--bg-alt);border-radius:var(--radius-lg);padding:12px 14px;display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;box-shadow:var(--shadow-soft);cursor:pointer;border:none;width:100%;text-align:left}.settings-item-left{display:flex;align-items:center;gap:10px}.settings-icon{width:32px;height:32px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.settings-label{font-size:14px;font-weight:500;color:var(--text-main)}.settings-value{font-size:13px;color:var(--text-muted)}.settings-item.logout,.settings-item.logout .settings-label{color:var(--danger)}.settings-item.logout .settings-value{color:#ff4d4fcc}.toggle{width:46px;height:26px;border-radius:999px;background:#e5e7eb;padding:3px;display:flex;align-items:center;transition:background .2s;cursor:pointer;position:relative}.toggle input{position:absolute;opacity:0;width:1px;height:1px;pointer-events:none}.toggle-circle{width:20px;height:20px;border-radius:999px;background:#fff;box-shadow:0 2px 8px #0f172a40;transform:translate(0);transition:transform .2s}.toggle input:checked+.toggle-circle{transform:translate(20px)}.toggle:has(input:checked){background:var(--primary)}.hero-image{position:relative;height:200px;margin:-16px -16px 16px;background-size:cover;background-position:center;background-color:#ccc}.hero-top{position:absolute;top:40px;left:16px;right:16px;display:flex;justify-content:space-between;align-items:center}.hero-bottom-chips{position:absolute;left:16px;bottom:14px;display:flex;gap:6px;flex-wrap:wrap}.hero-time-pill{position:absolute;left:16px;top:96px;background-color:#111827cc;color:#f9fafb;padding:5px 12px;border-radius:var(--radius-pill);font-size:13px}.details-card{background-color:var(--bg-alt);border-radius:var(--radius-lg);padding:14px 14px 12px;margin-bottom:10px;box-shadow:var(--shadow-soft)}.details-title{font-size:17px;font-weight:700;margin-bottom:10px;margin-top:0}.details-list{font-size:14px;color:var(--text-main);line-height:1.5;margin-left:20px}.label-row{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px}.label-muted{color:var(--text-muted)}.label-strong{font-weight:500}.details-note{margin-top:6px;font-size:12px;color:var(--text-muted)}.participants-card{background-color:var(--bg-alt);border-radius:var(--radius-lg);padding:12px 14px;margin-bottom:12px;box-shadow:var(--shadow-soft)}.participants-row{display:flex;justify-content:space-between;font-size:13px;margin-top:6px}.participants-highlight{color:var(--success);font-weight:600}.participants-list-block{margin-top:10px}.participants-list-title{font-size:12px;font-weight:700;color:var(--text-main)}.participants-list{list-style:none;margin-top:6px;display:flex;flex-direction:column;gap:6px}.participants-item{border-radius:10px;background:#11182708;border:1px solid var(--border-soft);overflow:hidden}.participants-item-btn{width:100%;border:none;background:transparent;display:flex;align-items:center;gap:10px;padding:8px 10px;cursor:default;text-align:left}.participants-item-btn.clickable{cursor:pointer}.participants-item-btn:disabled{opacity:1}.participants-avatar{width:32px;height:32px;border-radius:999px;background:#e5e7eb;color:#11182773;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;overflow:hidden}.participants-avatar-image{width:100%;height:100%;object-fit:cover;display:block}.participants-user{display:flex;flex-direction:column;gap:2px;min-width:0}.participants-name{font-size:13px;color:var(--text-main);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.participants-meta{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.participants-empty{margin-top:6px;font-size:12px;color:var(--text-muted)}.hint{margin-top:8px;font-size:12px;text-align:center;color:var(--text-muted)}.primary-btn{width:100%;border-radius:var(--radius-pill);padding:14px 16px;border:none;background-color:var(--primary);color:#fff;font-size:15px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-soft);margin-top:10px}.primary-btn:active{background-color:var(--primary-dark)}.primary-btn:disabled{background-color:#9ca3af;cursor:not-allowed}.secondary-btn{width:100%;border-radius:var(--radius-pill);padding:12px 16px;border:none;background-color:var(--primary);color:#fff;font-size:14px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-soft)}.ghost-btn{width:100%;border-radius:var(--radius-pill);padding:10px 16px;border:none;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer}.modal-backdrop{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:flex-end;justify-content:center;z-index:50;padding-bottom:env(safe-area-inset-bottom)}.modal{width:100%;max-width:480px;background-color:#fff;border-radius:24px 24px 0 0;padding:18px 18px 22px;box-shadow:0 -10px 30px #0f172a3d;max-height:80vh;overflow-y:auto}.modal-title{font-size:17px;font-weight:700;margin-bottom:10px}.modal-text{font-size:13px;color:var(--text-muted);margin-bottom:10px;line-height:1.5}.modal-warning{background-color:#fff1f2;border-radius:var(--radius-lg);padding:10px;font-size:13px;color:#b91c1c;display:flex;gap:8px;margin-bottom:8px}.modal-actions{margin-top:12px;display:flex;flex-direction:column;gap:8px}.tabbar{position:fixed;left:50%;transform:translate(-50%);bottom:0;width:100%;max-width:480px;background-color:#fff;border-top:1px solid rgba(148,163,184,.2);padding:6px 12px calc(10px + env(safe-area-inset-bottom));display:flex;justify-content:space-around;z-index:20}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;font-size:11px;color:var(--text-muted);cursor:pointer;padding:4px 0;background:transparent;border:none}.tab-btn-icon{width:22px;height:22px;border-radius:999px;background:transparent;display:flex;align-items:center;justify-content:center;margin-bottom:2px}.tab-btn.active{color:var(--primary)}.tab-btn.active .tab-btn-icon{background-color:var(--primary-soft)}.tab-btn svg{width:16px;height:16px;stroke:currentColor;fill:none}.empty-state{margin-top:40px;text-align:center;color:var(--text-muted);font-size:14px}.empty-ico{font-size:32px;display:block;margin-bottom:8px}.loader{text-align:center;padding:20px;color:var(--text-muted);font-weight:600}@media(min-width:768px){#app{margin-top:16px;margin-bottom:16px;border-radius:34px;box-shadow:0 18px 60px #0f172a2e;overflow:hidden}.screen{padding-top:20px}.hero-image{margin-top:-20px}.tabbar{border-radius:0 0 34px 34px}}.content{margin-top:10px;display:flex;flex-direction:column;gap:10px}.overlay-screen{position:fixed;inset:0;background:var(--bg);z-index:999;overflow:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(80px + env(safe-area-inset-bottom));display:flex;justify-content:center}.overlay-content{width:100%;max-width:480px;min-height:100%}.filters-badge{margin-left:8px;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:#ffffff38;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;border:1px solid rgba(255,255,255,.28)}.linklike{background:none;border:none;padding:0;margin:0;color:var(--primary);cursor:pointer;font-weight:700;text-align:left}.linklike:disabled{opacity:.5;cursor:default}.filters-section{background:var(--bg-alt);border:1px solid var(--border-soft);border-radius:16px;padding:12px;box-shadow:var(--shadow-soft)}.filters-section h2{margin:0 0 10px;font-size:14px;font-weight:800}.filters-panel{display:flex;flex-direction:column;gap:10px}.filter-option{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:12px;background:#11182708;border:1px solid rgba(17,24,39,.04);cursor:pointer;-webkit-user-select:none;user-select:none}.filter-option span{font-weight:600}.filter-option input{display:none}.checkbox{width:22px;height:22px;border-radius:7px;border:2px solid rgba(17,24,39,.14);display:inline-flex;align-items:center;justify-content:center;background:transparent}.filter-option input:checked+.checkbox{border-color:var(--primary);background:#2f7df624}.actions{display:flex;gap:10px}.actions .secondary-btn,.actions .primary-btn{flex:1}body.theme-dark{--bg: #0b1220;--bg-alt: #101a2e;--text-main: #e6edf7;--text-muted: rgba(230, 237, 247, .7);--border-soft: rgba(255, 255, 255, .1);--primary: #4aa3ff;--primary-soft: rgba(74, 163, 255, .14);--primary-dark: #2d82da;--success: #35d07f;--danger: #ff6b6b;--shadow-soft: 0 10px 30px rgba(0, 0, 0, .25)}body.theme-dark .modal{background-color:var(--bg-alt)}body.theme-dark .tabbar{background-color:var(--bg-alt);border-top-color:#ffffff1a}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}@media(max-width:420px){.form-grid{grid-template-columns:1fr}}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:12px;color:var(--text-muted);font-weight:700}.input,.select{width:100%;border-radius:14px;border:1px solid var(--border-soft);background:#11182708;padding:12px;font-size:14px;color:var(--text-main);outline:none}.input:focus,.select:focus{border-color:#2f7df673;box-shadow:0 0 0 4px #2f7df61a}.toggle .circle{width:20px;height:20px;border-radius:999px;background:#fff;box-shadow:0 2px 8px #0f172a40;transform:translate(0);transition:transform .2s}.toggle input:checked+.circle{transform:translate(20px)}.icon-btn:disabled,.back-btn:disabled{opacity:.65;cursor:not-allowed}.profile-card-lg{align-items:flex-start}.profile-avatar-stack{width:122px;flex-shrink:0}.avatar-lg{width:96px;height:96px;border-radius:999px;overflow:hidden;background:#e5e7eb;border:2px solid rgba(17,24,39,.08)}.avatar-lg-image{width:100%;height:100%;object-fit:cover;display:block}.avatar-lg-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:34px;font-weight:700;color:#1118276b}.avatar-action-btn{margin-top:8px;width:100%}.ban-alert-card{margin-top:10px;background:#ff4d4f14;border:1px solid rgba(255,77,79,.28);border-radius:12px;padding:10px 12px}.ban-alert-title{color:#b4232f;font-size:13px;font-weight:800}.ban-alert-text{margin-top:4px;color:#6b1f26;font-size:12px}.notifications-list{display:flex;flex-direction:column;gap:8px;margin-top:10px}.notification-item{width:100%;border:none;border-radius:var(--radius-lg);background:var(--bg-alt);box-shadow:var(--shadow-soft);padding:12px 14px;text-align:left;cursor:pointer}.notification-item.expanded{border:1px solid rgba(47,125,246,.25)}.notification-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.notification-title-wrap{display:flex;align-items:center;gap:8px;min-width:0}.notification-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.notification-dot.unread{background:var(--primary)}.notification-dot.read{background:#c7cdd8}.notification-title{font-size:14px;font-weight:700;color:var(--text-main);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-date{font-size:12px;color:var(--text-muted);white-space:nowrap}.notification-text{margin-top:8px;color:var(--text-muted);font-size:13px;line-height:1.45;overflow-wrap:anywhere}.notification-text p{margin:0 0 6px}.notification-text p:last-child{margin-bottom:0}.notification-text ul,.notification-text ol{margin:6px 0 6px 18px;padding:0}.notification-text a{color:var(--primary);text-decoration:underline}.notification-text h1,.notification-text h2,.notification-text h3,.notification-text h4,.notification-text h5,.notification-text h6{margin:6px 0;line-height:1.35}.notification-text.collapsed{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.notification-link-wrap{margin-top:10px;display:flex;flex-direction:column;gap:4px}.notification-link-label{font-size:12px;font-weight:700;color:var(--text-main)}.notification-link{font-size:13px;color:var(--primary);text-decoration:underline;overflow-wrap:anywhere}.actions .secondary-btn,.actions .primary-btn{flex:1;margin-top:0;min-height:48px;padding-top:12px;padding-bottom:12px}.richtext-content{display:flex;flex-direction:column;gap:8px}.richtext-line{margin:0;font-size:14px;color:var(--text-main);line-height:1.45}.richtext-link{color:var(--primary);text-decoration:underline;overflow-wrap:anywhere}
