:root{--bg: #ffffff;--bg-alt: #f6f7fb;--text: #0f172a;--muted: #64748b;--line: #e5e7eb;--brand: #0f172a;--radius: 16px;--shadow: 0 6px 20px rgba(2, 6, 23, .06)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";color:var(--text);background:var(--bg)}.container{max-width:1120px;margin:0 auto;padding:0 20px}.center{text-align:center}.small{font-size:14px;color:var(--muted)}.mt8{margin-top:2rem}.page{display:flex;flex-direction:column;min-height:100vh}.section{padding:64px 0;border-top:1px solid var(--line)}.section.alt{background:var(--bg-alt)}.footer{border-top:1px solid var(--line);padding:40px 0;margin-top:auto}.header{position:sticky;top:0;z-index:10;background:#ffffffd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}.header-inner{height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px}.brand{display:flex;align-items:center;gap:12px}.brand-logo{width:40px;height:40px;border-radius:12px;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:800;box-shadow:var(--shadow);text-decoration:none}.brand-title{font-weight:700}.brand-sub{font-size:12px;color:var(--muted);margin-top:-2px}.nav{display:none;gap:20px}.nav a{color:#475569;text-decoration:none}.nav a:hover{color:var(--text)}.actions{display:flex;gap:12px;align-items:center}.btn{display:inline-block;padding:10px 16px;border-radius:12px;font-weight:700;font-size:14px;text-decoration:none;transition:all .15s ease}.btn.solid{background:var(--brand);color:#fff;box-shadow:var(--shadow)}.btn.solid:hover{transform:translateY(-1px)}.btn.ghost{color:#0f172a}.btn.outline{border:1px solid var(--line);color:var(--text)}.btn.outline:hover{border-color:#cbd5e1}.hero{padding:64px 0}.hero-grid{display:grid;grid-template-columns:1fr;gap:28px}.hero-title{font-size:38px;line-height:1.1;margin:0;font-weight:900}.highlight{color:var(--brand)}.hero-sub{margin-top:16px;color:var(--muted);font-size:18px}.hero-ctas{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}.hero-note{margin-top:8px;font-size:12px;color:var(--muted)}.collage{display:grid;grid-template-columns:1fr 1fr;gap:12px}.collage img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;border-radius:16px;box-shadow:var(--shadow)}.grid-3,.grid-2{display:grid;grid-template-columns:1fr;gap:18px}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.card-icon{width:44px;height:44px;border-radius:12px;background:var(--brand);color:#fff;display:grid;place-items:center;margin-bottom:10px}.card-title{margin:0;font-size:18px;font-weight:700}.card-text{margin-top:8px;color:var(--muted);line-height:1.6}.step-badge{width:36px;height:36px;border-radius:999px;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:800;margin-bottom:10px}.faq-q{font-weight:700}.h3{font-size:24px;margin:0}@media(min-width:880px){.nav{display:flex}.hero-grid{grid-template-columns:1.1fr .9fr;align-items:center}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.hero-title{font-size:48px}}.kiosk{display:flex;flex-direction:column;height:100vh;width:100vw;background:#000;color:#fff;overflow:hidden}.kiosk-topbar{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;border-bottom:1px solid rgba(255,255,255,.12);background:#0006;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.kiosk-brand{display:flex;align-items:center;gap:12px}.kiosk-badge{width:36px;height:36px;border-radius:10px;background:#fff;color:#111;display:grid;place-items:center;font-weight:900;text-decoration:none}.kiosk-brand-text .kiosk-title{font-weight:800;line-height:1}.kiosk-brand-text .kiosk-sub{font-size:12px;color:#cbd5e1;margin-top:2px}.kiosk-actions{display:flex;gap:8px}.kbtn{background:#ffffff14;color:#fff;border:1px solid rgba(255,255,255,.14);border-radius:10px;padding:8px 12px;cursor:pointer}.kbtn:hover{background:#ffffff29}.kiosk-body{display:grid;grid-template-columns:320px 1fr;gap:0;flex:1;min-height:0}.k-sidebar{display:flex;flex-direction:column;height:100%;border-right:1px solid rgba(255,255,255,.12);background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.k-sidebar-title{font-weight:800;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.12)}.k-queue{padding:10px;height:100%;overflow:auto}.k-empty{color:#cbd5e1;font-size:14px;padding:10px}.k-item{display:flex;gap:10px;align-items:flex-start;background:#ffffff0d;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:10px;margin-bottom:10px}.k-item.playing{border-color:#22d3ee;background:#22d3ee1f}.k-mode{font-size:20px;line-height:1}.k-meta{min-width:0;flex:1}.k-title{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.k-artist{font-size:12px;color:#cbd5e1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.k-pos{font-size:12px;color:#94a3b8;margin-top:6px}.k-badge{display:inline-block;margin-top:6px;padding:2px 8px;border-radius:999px;background:#22d3ee;color:#0b1220;font-weight:800;font-size:12px}.k-sidebar-footer{padding:12px;border-top:1px solid rgba(255,255,255,.12);text-align:center}.k-qr{width:140px;height:140px;border-radius:12px;background:#fff;padding:6px}.k-qr-caption{font-size:12px;color:#cbd5e1;margin-top:6px}.k-player{position:relative;background:#000;min-width:0}.yt-frame{position:absolute;inset:0}.yt-frame iframe{width:100%;height:100%}.now-overlay{position:absolute;left:16px;top:16px;background:#00000080;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:12px;padding:12px 14px;max-width:52vw}.now-title{font-weight:800}.now-mode{font-size:12px;color:#cbd5e1;margin-top:2px}.progress-wrap{position:absolute;left:0;right:0;bottom:0;height:6px;background:#ffffff1f}.progress{height:100%;background:#22d3ee}.kiosk-idle{position:absolute;inset:0;display:grid;place-items:center;gap:24px}.kiosk-idle-text{text-align:center;max-width:720px}.kiosk-idle-big{font-size:36px;font-weight:900}.kiosk-idle-sub{margin-top:6px;color:#cbd5e1}.kiosk-bullets{list-style:disc;margin:12px auto 0;max-width:540px;text-align:left;color:#cbd5e1}.kiosk-qr{width:180px;height:180px;border-radius:14px;background:#fff;padding:10px}.vote-overlay{position:absolute;inset:0;display:grid;place-items:center;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.vote-box{background:#111827e6;border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:20px 24px;text-align:center;min-width:320px}.vote-title{font-weight:900;font-size:20px}.vote-sub{color:#cbd5e1;margin-top:2px}.vote-timer{margin-top:10px;font-size:28px;font-weight:800}.vote-qr-note{margin-top:6px;font-size:12px;color:#cbd5e1}.k-toast{position:fixed;left:50%;bottom:18px;transform:translate(-50%);background:#000000d9;color:#fff;border:1px solid rgba(255,255,255,.18);padding:10px 14px;border-radius:12px;font-weight:700;box-shadow:0 8px 24px #00000059;z-index:40}@media(max-width:1024px){.kiosk-body{grid-template-columns:260px 1fr}.k-qr{width:120px;height:120px}.kiosk-qr{width:160px;height:160px}}@media(max-width:720px){.kiosk-body{grid-template-columns:1fr}.k-sidebar{display:none}}.stage-overlay{position:absolute;inset:0;display:grid;place-items:center;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:28}.stage-box{background:#111827f2;border:1px solid rgba(255,255,255,.18);border-radius:18px;padding:24px 28px;text-align:center;min-width:420px;max-width:80vw}.stage-title{font-weight:900;font-size:18px;color:#cbd5e1;letter-spacing:.04em;text-transform:uppercase}.stage-name{font-size:40px;font-weight:900;margin-top:8px}.stage-song{margin-top:6px;color:#cbd5e1}.stage-timer{margin-top:12px;font-size:28px;font-weight:800}.stage-timer.hold{color:#fbbf24}.stage-actions{display:flex;gap:10px;justify-content:center;margin-top:14px;flex-wrap:wrap}.stage-hint{margin-top:8px;font-size:12px;color:#94a3b8}.sound-overlay{position:absolute;inset:0;display:grid;place-items:center;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:30}.sound-box{background:#111827f2;border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:22px 26px;text-align:center;min-width:340px}.sound-title{font-weight:900;font-size:20px}.sound-sub{color:#cbd5e1;margin-top:6px;margin-bottom:14px}.kbtn-big{padding:12px 18px;font-size:16px;border-radius:12px}
