:root{--bg: var(--tg-theme-bg-color, #0a0a0a);--card: var(--tg-theme-secondary-bg-color, rgba(255, 255, 255, .05));--card-strong: var(--tg-theme-secondary-bg-color, rgba(255, 255, 255, .1));--text: var(--tg-theme-text-color, #ffffff);--muted: var(--tg-theme-hint-color, #aaaaaa);--accent: var(--tg-theme-button-color, #ff6600);--accent-2: var(--tg-theme-link-color, #9d4edd);--accent-bg: var(--tg-theme-button-color, rgba(255, 102, 0, .16));--featured-bg: var(--tg-theme-button-color, rgba(255, 102, 0, .18));--featured-border: var(--tg-theme-button-color, rgba(255, 102, 0, .45));--danger: #ff3333;--danger-bg: rgba(255, 51, 51, .16);--border: var(--tg-theme-hint-color, rgba(255, 255, 255, .1));--shadow: 0 15px 40px rgba(0, 0, 0, .35);--tabbar-height: 72px;--song-search-height: 74px;--tabbar-bg: var(--tg-theme-secondary-bg-color, rgba(8, 8, 8, .78));--tabbar-border: var(--tg-theme-hint-color, rgba(255, 255, 255, .1));--tabbar-active-bg: var(--tg-theme-button-color, rgba(255, 102, 0, .16));--tabbar-active-border: var(--tg-theme-button-color, rgba(255, 102, 0, .4));font-family:Manrope,system-ui,-apple-system,sans-serif;color:var(--text);background:var(--bg)}*,*:before,*:after{box-sizing:border-box}html{width:100%;height:100%;overflow-x:hidden}body{margin:0;min-height:100vh;min-height:100dvh;min-height:var(--tg-viewport-height, 100dvh);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden;overflow-y:auto;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}#app{min-height:100%}img,video,canvas,svg{max-width:100%}a{color:inherit;text-decoration:none}.app-shell{max-width:1200px;width:100%;margin:0 auto;padding:12px clamp(12px,3vw,24px) 24px}.tabbed-layout{min-height:var(--tg-viewport-height, 100dvh)}.tab-content{display:grid;gap:18px;padding-bottom:calc(var(--tabbar-height) + env(safe-area-inset-bottom) + 16px)}.grid{display:grid;gap:8px}.section-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px}.list-row{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,2fr) auto;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.list-row>*{min-width:0}.list-row:last-child{border-bottom:none}.legend{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(280px,100%),1fr));gap:14px;align-items:center;margin-bottom:22px}.legend-visual{height:220px;border-radius:20px;background:radial-gradient(circle at 20% 20%,#9d4edd33,transparent 40%),radial-gradient(circle at 70% 60%,#ff660033,transparent 45%),linear-gradient(135deg,#ffffff0a,#ffffff03);border:1px solid var(--border);box-shadow:var(--shadow);position:relative;overflow:hidden}.pulse{position:absolute;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,rgba(255,102,0,.35),transparent 60%);filter:blur(16px);animation:float 6s ease-in-out infinite alternate}.pulse.secondary{top:40%;left:60%;background:radial-gradient(circle,rgba(157,78,221,.35),transparent 60%);animation-duration:7s}@keyframes float{0%{transform:translateY(-6px) translate(-4px)}to{transform:translateY(6px) translate(6px)}}.tags{display:flex;flex-wrap:wrap;gap:8px}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block}.two-col{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(280px,100%),1fr));gap:16px}.subtle{color:var(--muted)}.scroll-y{max-height:320px;overflow-y:auto}.avatar-small{width:42px;height:42px;border-radius:50%;object-fit:cover;border:1px solid var(--border)}@media(max-width:640px){.list-row{grid-template-columns:1fr;align-items:flex-start}}.tab-bar{position:fixed;left:0;right:0;bottom:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:10px 16px calc(env(safe-area-inset-bottom) + 12px);background:var(--tabbar-bg);border-top:1px solid var(--tabbar-border);-webkit-backdrop-filter:blur(14px) saturate(140%);backdrop-filter:blur(14px) saturate(140%);box-shadow:0 -12px 36px #00000073;z-index:1200}.tab-button{border:none;background:transparent;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 6px;border-radius:14px;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:color .14s ease,transform .14s ease,background .14s ease}.tab-button .tab-icon{font-size:18px}.tab-button .tab-label{font-size:12px}.tab-button.active{color:var(--text);background:var(--tabbar-active-bg);box-shadow:inset 0 0 0 1px var(--tabbar-active-border)}.tab-button:active{transform:translateY(1px)}.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:8px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.card-title{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:-.01em}.pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:var(--card-strong);color:var(--text)}.button{border:none;border-radius:12px;padding:5px 7px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:700;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;box-shadow:0 10px 22px #ff66004d}.button.secondary{background:var(--card-strong);color:var(--text);box-shadow:none}.button.danger{background:linear-gradient(135deg,#f33,#c00);color:#fff}.button:active{transform:translateY(1px) scale(.997)}.song-fab{width:54px;height:54px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:28px;font-weight:700;box-shadow:0 12px 26px #ff660059;cursor:pointer;display:grid;place-items:center}.checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-input{position:absolute;opacity:0;pointer-events:none}.checkbox-box{width:16px;height:16px;border-radius:4px;border:1px solid var(--border);background:var(--bg);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .12s ease,background .12s ease}.checkbox-box:after{content:"";width:6px;height:10px;border:solid var(--accent);border-width:0 2px 2px 0;transform:rotate(45deg);opacity:0;transition:opacity .12s ease}.checkbox-input:checked+.checkbox-box{border-color:var(--accent);background:#ff66001f}.checkbox-input:checked+.checkbox-box:after{opacity:1}.checkbox-input:focus-visible+.checkbox-box{outline:2px solid var(--accent);outline-offset:2px}.checkbox-label{color:var(--text);font-size:14px}.input,.textarea{width:100%;padding:10px 12px;border-radius:12px;background:var(--bg);border:1px solid var(--border);color:var(--text);outline:none;transition:border-color .12s ease,transform .12s ease}.select{width:100%;padding:4px 6px;border-radius:6px;background:var(--bg);border:1px solid var(--border);color:var(--accent-2);outline:none;transition:border-color .12s ease,transform .12s ease}.select option{background:var(--bg);color:var(--text)}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent);transform:translateY(-1px)}.dropdown{position:relative;display:inline-flex}.dropdown-menu{position:absolute;bottom:calc(100% + 8px);right:0;min-width:min(220px,calc(100vw - 24px));max-width:min(320px,calc(100vw - 24px));background:var(--card);border:1px solid var(--border);border-radius:12px;padding:10px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;gap:8px;z-index:20}.modal-backdrop{position:fixed;inset:0;background:#000000b8;display:grid;place-items:center;padding:18px;z-index:2000;-webkit-backdrop-filter:blur(6px) saturate(120%);backdrop-filter:blur(6px) saturate(120%)}.modal-window{width:min(720px,100%);max-height:min(calc(var(--tg-viewport-height, 100dvh) * .82),960px);overflow:hidden;box-shadow:0 20px 60px #0000008c;animation:pop .16s ease}.modal-window .card-title{align-items:center}.modal-window .grid{max-height:none}.modal-window .scroll-area{max-height:calc((var(--tg-viewport-height, 100dvh) * .82) - 80px);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-right:4px}.modal-window .scroll-area::-webkit-scrollbar{width:6px}.modal-window .scroll-area::-webkit-scrollbar-track{background:transparent}.modal-window .scroll-area::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.modal-window .scroll-area::-webkit-scrollbar-thumb:hover{background:var(--muted)}@keyframes pop{0%{transform:translateY(8px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.error-boundary__card{max-width:720px;margin:80px auto}.error-boundary__message{margin-top:12px;color:var(--danger)}.error-boundary__stack{margin-top:12px;white-space:pre-wrap;word-break:break-word;color:var(--muted);font-size:12px}.song-list-screen{position:relative}.song-list-body{padding-bottom:calc(var(--song-search-height) + 20px)}.song-search-bar{position:fixed;left:0;right:0;bottom:calc(var(--tabbar-height) + env(safe-area-inset-bottom));background:var(--bg);border-top:1px solid var(--border);-webkit-backdrop-filter:blur(12px) saturate(140%);backdrop-filter:blur(12px) saturate(140%);z-index:1100}.song-search-bar-inner{max-width:1200px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;width:100%}.song-search-bar-inner .input{flex:1;min-width:220px}.song-fab-wrap{position:fixed;right:10px;bottom:calc(var(--tabbar-height) + var(--song-search-height));display:flex;justify-content:flex-end;pointer-events:none;z-index:1150}.song-fab-wrap>*{pointer-events:auto}.song-create-dialog{position:absolute;bottom:64px;right:0;width:min(420px,calc(100vw - 32px));padding:14px;max-height:min(70vh,520px);overflow-y:auto}.song-list__error{color:var(--danger)}.song-list__load-more{margin-top:12px;display:flex;justify-content:center}.song-list__load-sentinel{height:1px}.song-list__divider{border:1px solid var(--border);margin:3px 0}.song-row{padding:6px;width:100%;text-align:left}.song-row.is-featured{background:var(--featured-bg);border:1px solid var(--featured-border)}.song-row__content{display:flex;justify-content:space-between;gap:4px;align-items:center}.song-row__thumb{width:80px;height:60px;object-fit:cover;border-radius:4px;flex-shrink:0}.song-row__thumb.is-hidden{display:none}.song-row__text{flex:1;min-width:0}.song-row__title{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-row__artist{color:var(--muted);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-row__badge{display:flex;gap:6px;align-items:center;flex-shrink:0}.song-row__count{font-size:18px;padding:2px 6px;border-radius:4px;font-weight:600}.song-row__count.is-open{background-color:var(--bg);color:var(--accent)}.song-row__count.is-full{background-color:var(--danger-bg);color:var(--danger)}.song-modal__artist{color:var(--muted);margin-bottom:10px}.song-modal__thumbnail{width:100%;max-height:240px;object-fit:cover;border-radius:8px;margin-bottom:12px}.song-modal__thumbnail.is-hidden{display:none}.song-modal__description{margin-top:12px;line-height:1.5}.song-modal__section{margin-top:14px}.song-modal__section-title{margin-bottom:8px;gap:8px}.song-modal__section-title--wide{gap:10px}.song-modal__role-count{font-size:12px;padding:2px;border-radius:4px;font-weight:600}.song-modal__role-count.is-open{background-color:var(--bg);color:var(--accent)}.song-modal__role-count.is-full{background-color:var(--danger-bg);color:var(--danger)}.song-modal__role-pill{border-color:var(--border)}.song-modal__role-pill.is-mine{border-color:var(--accent)}.song-modal__role-info{flex:1}.song-modal__role-title{font-weight:700}.song-modal__role-members{font-size:12px;color:var(--muted)}.song-modal__empty{color:var(--muted)}.song-modal__edit{margin-top:16px}.song-modal__edit-form{margin-top:12px}.song-modal__feature-label{display:flex;align-items:center;gap:8px;font-size:14px}.song-modal__edit-actions{display:flex;gap:10px;align-items:center}.create-song-form{gap:10px}.create-song-form__link-row{display:grid;gap:8px;grid-template-columns:1fr 180px}.create-song-form__checkbox{display:flex;align-items:center;gap:8px;font-size:14px}.create-song-form__error,.event-list__error{color:var(--danger)}.event-list__item-button{text-align:left}.event-list__item-title{font-weight:700}.event-list__item-meta{color:var(--muted);font-size:13px}.event-list__item-location{font-size:13px}.event-list__divider{border:1px solid var(--border);margin:16px 0}.event-details__backdrop{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;padding:16px;z-index:900}.event-details__card{max-width:720px;width:100%}.event-details__meta{color:var(--muted);margin-bottom:8px}.event-details__section{margin-top:12px}.event-details__section-title{margin-bottom:6px}.event-details__empty{color:var(--muted)}.event-details__tracklist{padding-left:18px;line-height:1.4}.event-details__form{margin-top:12px}.event-details__checkbox{display:flex;gap:8px;align-items:center}.event-details__tracklist-edit{margin-top:12px}.event-fab-wrap{position:fixed;right:10px;bottom:calc(var(--tabbar-height) + 10px);display:flex;justify-content:flex-end;pointer-events:none;z-index:1150}.event-fab-wrap>*{pointer-events:auto}.event-create-dialog{position:absolute;bottom:64px;right:0;width:min(420px,calc(100vw - 32px));padding:14px;max-height:min(70vh,520px);overflow-y:auto}.create-event-form{gap:10px}.create-event-form__checkbox{display:flex;gap:8px;align-items:center}.create-event-form__error{color:var(--danger)}.hero-card{padding:14px}.profile-card{padding:16px}.profile-summary{display:flex;align-items:center;gap:16px;margin-bottom:16px}.profile-avatar{width:72px;height:72px;border-radius:18px;background:linear-gradient(135deg,#ff66004d,#9d4edd66);border:1px solid rgba(255,255,255,.12);display:grid;place-items:center;font-weight:700;color:#fff;overflow:hidden}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-name{font-size:20px;font-weight:700}.auth-gate__center-card{max-width:400px;margin:80px auto}.auth-gate__card-title{margin-bottom:16px}.auth-gate__spinner-wrap{text-align:center;padding:40px 0}.auth-gate__auth-panel{text-align:center;padding:28px 0}.auth-gate__muted{color:var(--muted)}.auth-gate__muted--spaced{margin-bottom:16px}.auth-gate__muted--large{line-height:1.4;margin-bottom:24px}.auth-gate__info-box{padding:16px;background-color:var(--accent-bg);border:1px solid var(--accent);border-radius:8px;color:var(--text)}.auth-gate__info-title{display:block;margin-bottom:8px}.auth-gate__info-list{margin:0;padding-left:20px;line-height:1.6}.auth-gate__error-box{padding:16px;background-color:var(--danger-bg);border:1px solid var(--danger);border-radius:8px;color:var(--danger);margin-bottom:16px}.auth-gate__spinner{margin-bottom:16px}.auth-gate__tg-actions{margin-top:12px}.auth-gate__error-text{color:var(--danger);margin-top:8px}.auth-gate__error-content{padding:20px;text-align:center}.auth-gate__error-message{color:var(--danger);margin-bottom:16px}.auth-gate__pill{justify-content:space-between}
