:root{color-scheme:light;--bg:#f4f1ea;--surface:rgba(255,255,255,0.86);--surface-strong:#ffffff;--line:rgba(36,34,30,0.08);--text:#171512;--muted:#6e685f;--accent:#1f6b57;--accent-soft:rgba(31,107,87,0.12);--danger:#9f4f4f;--danger-soft:rgba(159,79,79,0.12);--shadow:0 18px 50px rgba(39,34,23,0.08)}*{box-sizing:border-box}html{min-height:100%;background:radial-gradient(circle at top left,rgba(31,107,87,.12),transparent 28%),radial-gradient(circle at top right,rgba(173,125,58,.12),transparent 24%),var(--bg)}body{margin:0;color:var(--text);font-family:Pretendard Variable,Pretendard,Noto Sans KR,sans-serif}button,input{font:inherit}button{cursor:pointer}.shell{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:32px 0 56px}.hero-card,.panel{border:1px solid var(--line);background:var(--surface);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow)}.hero-card{display:flex;justify-content:space-between;gap:24px;padding:28px;border-radius:28px}.hero-copy h1,.panel-heading h2,.song-header h3{margin:0;letter-spacing:-.03em}.hero-copy h1{font-size:clamp(2rem,4vw,3.4rem)}.empty-panel p,.hero-copy p,.modal-song-row p,.panel-heading p,.song-header p,.summary-card p{margin:0;color:var(--muted);line-height:1.5}.rule-chip,.status-badge,.summary-empty,.summary-tag{display:inline-flex;align-items:center;border-radius:999px}.summary-empty,.summary-tag{padding:10px 14px;background:rgba(255,255,255,.8);border:1px solid var(--line);color:var(--text)}.composer-panel,.empty-panel,.room-sidebar,.scene-card,.song-card{border-radius:22px;padding:24px}.field,.field-grid,.modal-song-list,.panel-heading,.song-list,.summary-stack{display:grid;grid-gap:16px;gap:16px}.panel-heading{gap:8px}.field-grid{margin-top:22px}.field span,.summary-label{font-size:.95rem;font-weight:700}input{width:100%;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.9);padding:15px 16px;outline:none;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}input:focus{border-color:rgba(31,107,87,.4);box-shadow:0 0 0 4px rgba(31,107,87,.1);transform:translateY(-1px)}.session-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));grid-gap:10px;gap:10px}.primary-button,.secondary-button,.session-button,.vote-button{border:1px solid var(--line);border-radius:14px;transition:transform .18s ease,border-color .18s ease,background .18s ease}.session-button{padding:14px 16px;background:rgba(255,255,255,.72);color:var(--text)}.session-button.active{border-color:rgba(31,107,87,.45);background:var(--accent-soft);color:var(--accent)}.scene-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}.primary-button,.secondary-button{padding:14px 18px}.primary-button{background:var(--accent);border-color:var(--accent);color:white}.secondary-button{background:rgba(255,255,255,.76);color:var(--text)}.secondary-button.compact{width:-moz-fit-content;width:fit-content;padding:10px 12px;margin-top:12px}.room-grid{display:grid;grid-template-columns:minmax(280px,340px) minmax(0,1fr);grid-gap:18px;gap:18px;margin-top:22px}.room-main{display:grid;grid-gap:16px;gap:16px}.summary-card{display:grid;grid-gap:10px;gap:10px;padding:18px;border-radius:16px;background:rgba(255,255,255,.7);border:1px solid var(--line)}.invite-card{background:linear-gradient(180deg,rgba(31,107,87,.1),rgba(255,255,255,.84));border-color:rgba(31,107,87,.18)}.invite-card strong{display:block;padding:14px 16px;border-radius:14px;border:1px solid rgba(31,107,87,.16);background:rgba(255,255,255,.92);font-size:.96rem;word-break:break-all}.summary-tags{display:flex;flex-wrap:wrap;gap:8px}.summary-tag-wrapper{position:relative;z-index:0}.summary-tag-wrapper:focus-within,.summary-tag-wrapper:hover{z-index:18}.summary-hover-card{position:absolute;left:0;top:calc(100% + 10px);z-index:20;min-width:220px;max-width:min(320px,calc(100vw - 56px));display:grid;grid-gap:10px;gap:10px;padding:14px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.96);box-shadow:0 18px 40px rgba(39,34,23,.14);opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .16s ease,transform .16s ease,visibility .16s ease}.summary-tag-wrapper:focus-within .summary-hover-card,.summary-tag-wrapper:hover .summary-hover-card{opacity:1;visibility:visible;transform:translateY(0)}.summary-hover-title{font-size:.92rem;font-weight:700;color:var(--text)}.summary-hover-tags{display:flex;flex-wrap:wrap;gap:8px}.summary-hover-tag{display:inline-flex;align-items:center;padding:8px 10px;border-radius:999px;font-size:.9rem;border:1px solid rgba(31,107,87,.18);background:rgba(31,107,87,.07);color:var(--accent)}.vote-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:16px 18px;border-radius:16px;border:1px solid rgba(31,107,87,.22);background:linear-gradient(90deg,rgba(31,107,87,.15),rgba(255,255,255,.82));color:var(--text)}.composer-form{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;grid-gap:12px;gap:12px;margin-top:18px}.song-section{display:grid;grid-gap:14px;gap:14px}.song-section-header{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:4px 2px}.song-section-header h3,.song-section-header p{margin:0}.song-section-header h3{font-size:1.12rem;letter-spacing:-.03em}.song-section-header p{color:var(--muted);margin-top:4px}.song-section-header.playable h3{color:var(--accent)}.song-section-header.unplayable h3{color:var(--danger)}.section-count{display:inline-flex;align-items:center;justify-content:center;min-width:68px;padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.85);font-weight:700}.section-count.playable{color:var(--accent);border-color:rgba(31,107,87,.22)}.section-count.unplayable{color:var(--danger);border-color:rgba(159,79,79,.22)}.song-card{position:relative;z-index:0;display:grid;grid-gap:18px;gap:18px;overflow:visible}.song-card.playable{border-color:rgba(31,107,87,.24);background:linear-gradient(180deg,rgba(31,107,87,.08),rgba(255,255,255,.84))}.song-card.unplayable{border-color:rgba(159,79,79,.2);background:linear-gradient(180deg,rgba(159,79,79,.06),rgba(255,255,255,.86))}.song-card:focus-within,.song-card:hover{z-index:12}.inline-vote-row,.modal-song-row,.song-header,.song-status-row,.vote-counts{display:flex;align-items:center}.song-header{justify-content:space-between;gap:16px}.song-status-row{gap:10px;margin-bottom:10px}.status-badge{padding:8px 12px;background:rgba(255,255,255,.9);color:var(--muted);border:1px solid var(--line)}.status-badge.active{background:var(--accent-soft);border-color:rgba(31,107,87,.24);color:var(--accent)}.status-badge.blocked{background:var(--danger-soft);border-color:rgba(159,79,79,.24);color:var(--danger)}.song-time{color:var(--muted);font-size:.92rem}.inline-vote-row,.vote-counts{gap:10px}.vote-counts span{padding:10px 12px;border-radius:12px;background:rgba(255,255,255,.84);border:1px solid var(--line);font-weight:700}.session-rule-grid{display:flex;flex-wrap:wrap;gap:10px}.rule-chip-wrapper{position:relative;z-index:0}.rule-chip-wrapper:focus-within,.rule-chip-wrapper:hover{z-index:24}.rule-chip{gap:8px;padding:10px 14px;border:1px solid var(--line);background:rgba(255,255,255,.82)}.rule-chip.pass{color:var(--accent);border-color:rgba(31,107,87,.24)}.rule-chip.fail{color:var(--danger);border-color:rgba(159,79,79,.2);background:var(--danger-soft)}.rule-hover-card{position:absolute;left:0;top:calc(100% + 10px);z-index:20;width:min(360px,calc(100vw - 56px));display:grid;grid-gap:12px;gap:12px;padding:14px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.96);box-shadow:0 18px 40px rgba(39,34,23,.14);opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .16s ease,transform .16s ease,visibility .16s ease}.rule-chip-wrapper:focus-within .rule-hover-card,.rule-chip-wrapper:hover .rule-hover-card{opacity:1;visibility:visible;transform:translateY(0)}.hover-section{display:grid;grid-gap:8px;gap:8px}.hover-label{font-size:.9rem;font-weight:700}.hover-label.yes{color:var(--accent)}.hover-label.no{color:var(--danger)}.hover-tags{display:flex;flex-wrap:wrap;gap:8px}.hover-empty,.hover-tag{display:inline-flex;align-items:center;padding:8px 10px;border-radius:999px;font-size:.9rem;border:1px solid var(--line);background:rgba(255,255,255,.92)}.hover-tag.yes{color:var(--accent);border-color:rgba(31,107,87,.22)}.hover-tag.no{color:var(--danger);border-color:rgba(159,79,79,.22)}.hover-empty{color:var(--muted)}.vote-button{min-width:76px;padding:12px 14px;background:rgba(255,255,255,.86)}.vote-button.yes.active{background:var(--accent-soft);border-color:rgba(31,107,87,.28);color:var(--accent)}.vote-button.no.active{background:var(--danger-soft);border-color:rgba(159,79,79,.28);color:var(--danger)}.empty-panel{text-align:center}.modal-backdrop{position:fixed;inset:0;display:grid;place-items:center;padding:24px;background:rgba(22,18,14,.28);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-sheet{width:min(760px,100%);max-height:min(82vh,900px);overflow:auto;padding:24px;border-radius:28px;background:var(--surface-strong);border:1px solid var(--line);box-shadow:var(--shadow)}.modal-song-row{justify-content:space-between;gap:18px;padding:16px 0;border-bottom:1px solid var(--line)}.modal-song-row.stacked{display:grid;align-items:stretch}.modal-song-main{display:flex;align-items:center;justify-content:space-between;gap:16px}.modal-voter-row{display:grid;grid-gap:8px;gap:8px;margin-top:10px}.mini-voter-line{color:var(--muted);font-size:.92rem}.modal-song-row:last-child{border-bottom:0}.primary-button:hover,.secondary-button:hover,.session-button:hover,.vote-button:hover{transform:translateY(-1px)}@media (max-width:920px){.hero-card,.modal-song-row,.song-header,.vote-banner{flex-direction:column;align-items:flex-start}.composer-form,.modal-song-main,.room-grid{grid-template-columns:1fr}.modal-song-main{display:grid}.song-section-header{align-items:flex-start;flex-direction:column}}@media (max-width:640px){.shell{width:min(100% - 20px,100%);padding-top:20px}.composer-panel,.hero-card,.modal-sheet,.room-sidebar,.scene-card,.song-card{padding:18px;border-radius:20px}}