*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--page-max-width: 1440px;--page-padding-x: 24px;--bg: #050505;--surface: #0a0a0a;--surface-2: #111111;--surface-3: #1b1b1b;--surface-hover: #151515;--surface-selected: #171717;--surface-glass: rgba(5, 5, 5, .92);--border: rgba(255, 255, 255, .07);--border-hover: rgba(255, 255, 255, .16);--primary: #75e2e0;--primary-hover: #2cacad;--primary-contrast: #0c1015;--primary-rgb: 117, 226, 224;--primary-dim: rgba(117, 226, 224, .11);--secondary: #e62c95;--secondary-hover: #a60060;--secondary-text: var(--secondary);--secondary-rgb: 230, 44, 149;--secondary-dim: rgba(230, 44, 149, .11);--accent: var(--primary);--accent-dim: var(--primary-dim);--warning: #ffe25a;--warning-rgb: 255, 226, 90;--pattern-sc: #a78bfa;--pattern-sc-rgb: 167, 139, 250;--pattern-mx: #ff4d5d;--pattern-mx-rgb: 255, 77, 93;--pattern-hd: #f59e0b;--pattern-hd-rgb: 245, 158, 11;--pattern-nm: #facc15;--pattern-nm-rgb: 250, 204, 21;--text: #f5f5f5;--text-muted: #8f8f8f;--text-dim: #d8d8d8;--danger: #ff6f7d;--danger-rgb: 255, 111, 125;--danger-dim: rgba(255, 111, 125, .12);--danger-border: rgba(255, 111, 125, .34);--success: #22c55e;--success-rgb: 34, 197, 94;--radius: 8px;--radius-sm: 4px;--shadow: 0 22px 52px rgba(0, 0, 0, .42);--shadow-soft: 0 12px 30px rgba(0, 0, 0, .2);--shadow-glow: 0 0 0 1px rgba(117, 226, 224, .22);--shadow-glow-hover: 0 0 0 1px rgba(117, 226, 224, .34);--t: .18s ease;font-family:Pretendard Variable,Pretendard,ui-sans-serif,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:14px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}[data-theme=light]{--bg: #f7f7f7;--surface: #ffffff;--surface-2: #f1f1f1;--surface-3: #e4e4e4;--surface-hover: #ebebeb;--surface-selected: #e8e8e8;--surface-glass: rgba(255, 255, 255, .9);--border: rgba(0, 0, 0, .08);--border-hover: rgba(0, 0, 0, .18);--primary: #75e2e0;--primary-hover: #2cacad;--primary-contrast: #0c1015;--primary-rgb: 117, 226, 224;--primary-dim: rgba(117, 226, 224, .1);--secondary: #e62c95;--secondary-hover: #a60060;--secondary-text: var(--secondary-hover);--secondary-rgb: 230, 44, 149;--secondary-dim: rgba(230, 44, 149, .09);--accent: var(--primary);--accent-dim: var(--primary-dim);--warning: #b87900;--warning-rgb: 184, 121, 0;--text: #111111;--text-muted: #666666;--text-dim: #2c2c2c;--danger: #d64055;--danger-rgb: 214, 64, 85;--danger-dim: rgba(214, 64, 85, .08);--danger-border: rgba(214, 64, 85, .25);--success: #16a34a;--success-rgb: 22, 163, 74;--shadow: 0 18px 46px rgba(0, 0, 0, .12);--shadow-soft: 0 10px 28px rgba(0, 0, 0, .08);--shadow-glow: 0 0 0 1px rgba(117, 226, 224, .18);--shadow-glow-hover: 0 0 0 1px rgba(117, 226, 224, .26)}body{min-height:100vh;background:var(--bg);transition:background var(--t),color var(--t);overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;transition:background-color var(--t),border-color var(--t),color var(--t),box-shadow var(--t),opacity var(--t)}button:disabled{cursor:default;opacity:.55}button:active{transform:none!important}input,textarea{font-family:inherit;transition:border-color var(--t),background-color var(--t)}input:focus,textarea:focus,button:focus{outline:none}input:focus-visible,textarea:focus-visible,button:focus-visible,a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.song-tab:focus-visible,.song-sort-btn:focus-visible{outline:none;box-shadow:inset 0 0 0 2px rgba(var(--primary-rgb),.56)}.site-header a:focus-visible,.site-header button:focus-visible{outline:none}.site-header-logo,.site-header-nav-link,.site-header-discord,.site-header-feedback,.site-header-theme,.site-header-avatar,.site-header-login,.site-header-dropdown-item{transition:color var(--t),opacity var(--t)}.song-filter-search-label,.site-header-label-compact{display:none}.site-header-nav-link:hover,.site-header-discord:hover,.site-header-feedback:hover,.site-header-theme:hover,.site-header-avatar:hover,.site-header-dropdown-item:hover{background:transparent!important;color:var(--text)!important}.site-header-login:hover{background:var(--primary-hover)!important;color:var(--primary-contrast)!important}::selection{background:var(--primary-dim);color:var(--text)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:99px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes tag-radar-enter{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes tag-radar-dot-pop{0%{filter:drop-shadow(0 0 0 rgba(117,226,224,0));transform:scale(.82)}55%{filter:drop-shadow(0 0 8px rgba(117,226,224,.52));transform:scale(1.36)}to{filter:drop-shadow(0 0 0 rgba(117,226,224,0));transform:scale(1)}}.tag-radar-shell{--tag-radar-color: var(--primary);--tag-radar-rgb: var(--primary-rgb);width:340px;height:318px;flex:0 0 340px;margin-left:auto;color:var(--text-muted)}.tag-radar-shell--with-legend{height:318px}.tag-radar-shell--interactive{cursor:pointer;outline:none}.tag-radar-shell--interactive:focus-visible .tag-radar-svg{filter:drop-shadow(0 0 12px rgba(var(--primary-rgb),.22))}.tag-radar-svg{width:100%;height:300px;overflow:visible;transform-origin:center;animation:tag-radar-enter .42s ease-out both}.tag-radar-ring{fill:none;stroke:#ffffff1a;stroke-width:1}.tag-radar-axis{stroke:#ffffff14;stroke-width:1}.tag-radar-area{fill:url(#tag-radar-fill);stroke:var(--tag-radar-color);stroke-width:2;stroke-linejoin:round;filter:drop-shadow(0 0 12px rgba(var(--tag-radar-rgb),.2))}.tag-radar-overlay-area{fill:rgba(var(--primary-rgb),.12);stroke:var(--primary);stroke-width:2;stroke-linejoin:round;stroke-dasharray:5 5;filter:drop-shadow(0 0 12px rgba(var(--primary-rgb),.18));pointer-events:none}.tag-radar-dot{transform-box:fill-box;transform-origin:center;animation:tag-radar-dot-pop .36s ease-out both}.tag-radar-label{fill:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:0;paint-order:stroke;stroke:var(--surface);stroke-width:3px;stroke-linejoin:round}.tag-radar-legend{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:5px;color:var(--text-muted);font-size:10px;font-weight:700;line-height:1}.tag-radar-legend-item{display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.tag-radar-legend-line{width:18px;height:2px;background:var(--tag-radar-color);border-radius:99px}.tag-radar-legend-line--overlay{background:repeating-linear-gradient(90deg,var(--primary) 0 5px,transparent 5px 8px)}.song-table-row td{transition:background-color var(--t)}.song-table-row:hover td{background:var(--surface-hover)}.activity-row:hover{background:var(--surface-hover)!important}.activity-row:last-child{border-bottom:none!important}.song-detail-layout{--song-detail-main-width: 760px;--song-detail-aside-width: 280px;--song-detail-hero-gap: 24px;--song-detail-hero-main-width: min( var(--song-detail-main-width), calc(100% - var(--song-detail-aside-width) - var(--song-detail-hero-gap)) );display:grid;grid-template-columns:minmax(0,var(--song-detail-hero-main-width)) minmax(260px,var(--song-detail-aside-width)) minmax(0,1fr);grid-template-areas:"header radar ." "main main main";column-gap:var(--song-detail-hero-gap);row-gap:34px;align-items:center;justify-content:start;width:100%;max-width:100%}.song-detail-header{grid-area:header;background:transparent!important;border-radius:0!important;padding:0!important;margin:0!important}.song-detail-header-main{flex:1 1 auto}.song-detail-radar-block{grid-area:radar;width:var(--song-detail-aside-width)!important;align-items:center!important;justify-self:start}.song-detail-radar{width:280px!important;height:260px!important;flex:0 0 260px!important;margin-left:0!important}.song-detail-radar .tag-radar-svg{height:248px!important}.song-detail-main-flow{grid-area:main;display:flex;flex-direction:column;gap:34px;width:100%;max-width:100%}.song-detail-section{width:100%;max-width:100%;background:transparent!important;border-radius:0!important;padding:0!important;margin:0!important}.song-detail-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.song-detail-section-title{color:var(--text);font-size:14px;font-weight:850;letter-spacing:0}.song-detail-section-meta{display:inline-flex;align-items:center;justify-content:center;min-height:24px;color:var(--text-muted);font-size:11px;font-weight:800}.song-detail-form{display:flex;flex-direction:column;gap:8px;width:100%}.song-detail-textarea{display:block;width:100%}.song-detail-actions{display:flex;justify-content:flex-end;align-items:center;margin-top:14px;width:100%}.song-detail-primary-action{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-width:96px;min-height:38px;padding:0 14px;background:var(--primary);color:var(--primary-contrast);border:none;border-radius:6px;font-size:13px;font-weight:800;box-shadow:none;flex:0 0 auto}.song-detail-tag-grid{width:100%;max-width:100%;gap:8px!important}.song-detail-tag-row{grid-template-columns:140px minmax(0,1fr)!important;min-height:32px!important;padding:0!important}.song-detail-tag-pills{display:grid!important;grid-template-columns:repeat(4,42px);gap:8px!important}@media(min-width:721px){.song-detail-comment-list,.song-detail-history-list{gap:14px!important}.song-detail-comment-item,.song-detail-history-item{background:transparent!important;border-radius:0!important;padding:0!important}}@media(max-width:720px){:root{font-size:13px}.site-header-inner{width:100vw!important;max-width:100vw!important;padding:0 14px!important;gap:8px!important;justify-content:flex-start!important}.site-header-left{flex:1 1 auto!important;min-width:0!important;gap:10px!important}.site-header-logo{flex:0 0 auto}.site-header-logo-text,.site-header-label-full{display:none}.site-header-label-compact{display:inline}.site-header-nav{min-width:0!important;max-width:100%!important;overflow-x:auto!important;overflow-y:hidden!important;white-space:nowrap!important;scrollbar-width:none}.site-header-nav::-webkit-scrollbar{display:none}.site-header-nav a{flex:0 0 auto!important;padding:0 9px!important;white-space:nowrap!important}.site-header-actions{position:static!important;flex:0 0 auto!important;gap:6px!important}.site-header-theme{display:none!important}.site-header-login{display:inline-flex!important;width:36px!important;padding:0!important;justify-content:center!important;flex-shrink:0}.site-header-login-label{display:none}.site-header-avatar{width:36px!important;padding:0!important;justify-content:center!important}.site-header-username,.site-header-chevron{display:none!important}.song-list-container{padding:0 14px!important;max-width:100%!important;min-width:0!important;overflow:hidden}.song-command-bar{flex-direction:column!important;align-items:flex-start!important;gap:12px!important;min-width:0!important;max-width:100%!important}.song-control-shell{padding:0!important;background:transparent!important;border-radius:0!important;overflow:visible!important}.song-top-controls{flex-direction:column!important;align-items:stretch!important;min-width:0!important;max-width:100%!important;padding:0!important}.song-tabs{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr));width:100%!important;min-width:0!important;max-width:100%!important;overflow:hidden!important}.song-tab{min-width:0!important;padding:0!important}.song-tab-active,.song-sort-btn-active{background-color:transparent!important;background-image:linear-gradient(to top,var(--primary) 0 2px,transparent 2px)!important;border-radius:0!important}.song-sort-group{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr));width:100%!important;min-width:0!important;max-width:100%!important;overflow:hidden!important}.song-sort-group button{min-width:0!important;padding:0 6px!important;font-size:11px!important}.song-filter-bar{align-items:flex-start!important;padding:0!important}.song-filter-form{display:grid!important;grid-template-columns:1fr auto;width:100%!important;min-width:0!important;max-width:100%!important}.song-filter-form>div{grid-column:1 / -1;min-width:0}.song-filter-form input{width:100%!important}.song-filter-search-btn{width:36px!important;height:36px!important;gap:6px!important;justify-content:center}.song-filter-search-label{display:none}.song-count-badge{align-self:flex-start}.song-table{min-width:920px}.song-title-col{width:168px!important}.song-pattern-col{width:56px!important}.song-difficulty-col{width:68px!important}.song-level-col{width:52px!important}.activity-list-header{display:none!important}.activity-row{grid-template-columns:minmax(0,1fr)!important;gap:8px!important;align-items:stretch!important;min-height:auto!important;padding:12px 14px!important}.activity-event-main,.activity-event-change,.activity-event-side{min-width:0!important}.activity-event-change{padding-left:52px!important;align-items:flex-start!important}.activity-event-side{flex-direction:row!important;justify-content:flex-end!important;gap:8px!important}.management-page-container{padding:0 14px!important;max-width:100%!important;min-width:0!important}.management-command-bar{align-items:flex-start!important;gap:10px!important}.management-toolbar{flex-direction:column!important;align-items:stretch!important}.management-control-shell{padding:10px!important}.suggestions-control-shell,.notes-control-shell{padding:0!important}.admin-layout{grid-template-columns:minmax(0,1fr)!important}.admin-user-list{max-height:none!important}.management-toolbar>div,.management-toolbar form{width:100%!important}.management-toolbar input{width:100%!important}.auth-page{justify-content:flex-start!important;align-items:center!important;width:100vw!important;max-width:100vw!important;min-width:0!important;padding:36px 14px 24px!important}.auth-card{width:calc(100vw - 28px)!important;max-width:380px!important;min-width:0!important;margin:0 auto!important;padding:0!important}.settings-page{width:100vw!important;max-width:100vw!important;min-width:0!important;padding:24px 14px!important;overflow-x:hidden!important}.settings-panel{width:calc(100vw - 28px)!important;max-width:520px!important;min-width:0!important;padding:0!important}.song-detail-header{align-items:flex-start!important;flex-direction:column!important;padding:0!important;margin-bottom:12px!important;background:transparent!important;border-radius:0!important}.song-detail-container{padding:0 14px!important;max-width:100%!important;min-width:0!important;overflow:hidden}.song-detail-layout{display:flex!important;flex-direction:column;align-items:stretch!important;gap:18px;width:100%;max-width:100%}.song-detail-main-flow{width:100%;max-width:100%;gap:28px}.song-detail-header-main{width:100%;gap:12px!important;align-items:center!important}.song-detail-jacket{width:64px!important;height:64px!important;border-radius:5px!important}.song-detail-title{white-space:normal!important;overflow:visible!important;text-overflow:clip!important;font-size:22px!important;line-height:1.12!important}.song-detail-radar-block{display:flex!important;width:100%!important;align-items:center!important;margin-top:10px!important}.song-detail-radar{width:min(280px,100%)!important;height:232px!important;flex:0 0 232px!important;margin:0 auto!important}.song-detail-radar .tag-radar-svg{height:218px!important}.song-detail-radar .tag-radar-label{font-size:9px!important;stroke:var(--bg)!important}.song-detail-radar-controls{flex-wrap:wrap}.song-detail-section{width:100%;max-width:100%;background:transparent!important;border-radius:0!important;padding:0!important;margin:0!important}.song-detail-section-head{margin-bottom:10px!important}.song-detail-tag-grid{gap:4px!important}.song-detail-tag-row{grid-template-columns:minmax(76px,92px) minmax(0,1fr)!important;gap:8px!important;min-height:32px!important;padding:2px 0!important}.song-detail-tag-name{width:auto!important;min-width:0!important;font-size:12px!important}.song-detail-tag-pills{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px!important}.song-detail-tag-pill{min-height:28px!important;min-width:0!important;width:100%!important;border-radius:4px!important}.song-detail-tag-actions,.song-detail-description-form,.song-detail-comment-form,.song-detail-description-actions,.song-detail-comment-actions{max-width:none!important;width:100%!important}.song-detail-comment-list,.song-detail-history-list{gap:14px!important}.song-detail-comment-item,.song-detail-history-item{background:transparent!important;border-radius:0!important;padding:0!important}.tag-radar-shell--with-legend{height:305px}.tag-radar-svg{height:285px}}@media(prefers-reduced-motion:reduce){.tag-radar-svg,.tag-radar-dot{animation:none!important}}
