@import "https://fonts.googleapis.com/css2?family=Lexend:wght@400;500;600;700&display=swap";.controller-page .queue-actions{flex-wrap:nowrap;flex-shrink:0;align-items:center;gap:6px;display:inline-flex}.controller-page .queue-move,.controller-page .queue-remove{color:#e2e8f0d9;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:1.1rem;line-height:1;transition:color .2s,background .2s;display:inline-flex}.controller-page .queue-move{color:#bae6fd}.controller-page .queue-move:disabled{opacity:.4;cursor:not-allowed}.controller-page .queue-move:hover:not(:disabled),.controller-page .queue-remove:hover{color:#f8fafc;background:#94a3b81f}@media (max-width:768px){.controller-page .queue-actions{gap:4px}.controller-page .queue-move,.controller-page .queue-remove{width:30px;height:30px;font-size:1.1rem}}:root{text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#0b0d12;background-color:#0b1220;font-family:Lexend,Inter,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}body{background:#0b1220;min-height:100vh;margin:0}.controller-shell{color:#f8fafc;background:#0b1220;flex-direction:column;gap:16px;min-height:100vh;padding:24px;display:flex;overflow:hidden}@media (max-width:768px){.controller-shell{min-height:auto;overflow:visible}}.controller-top-grid{grid-template-columns:1.5fr 8.5fr 1.5fr;gap:16px;display:grid}.controller-info-card{background:linear-gradient(145deg,#111c32e6,#0e172af2);border:1px solid #6366f14d;border-radius:16px;flex-direction:column;gap:14px;padding:18px;display:flex;box-shadow:0 4px 16px #0003}.controller-info-header{border-bottom:1px solid #6366f133;align-items:center;gap:12px;padding-bottom:10px;display:flex}.controller-info-icon{color:#a5b4fc;background:#6366f126;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.5rem;transition:background .2s,color .2s,transform .15s;display:flex}.controller-info-icon:hover{color:#f8fafc;background:#6366f140;transform:translate(-2px)}.controller-info-details{flex:1;min-width:0}.controller-info-label{text-transform:uppercase;letter-spacing:.1em;color:#94a3b8;margin:0 0 4px;font-size:.65rem}.controller-room-name{color:#f8fafc;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:1rem;font-weight:600;overflow:hidden}.controller-info-meta{flex-direction:column;gap:8px;display:flex}.controller-meta-item{background:#0f172a99;border-radius:8px;align-items:center;gap:8px;padding:6px 10px;font-size:.85rem;display:flex}.controller-meta-icon{color:#a5b4fc;text-align:center;flex-shrink:0;width:18px;font-size:.9rem}.controller-meta-text{color:#e2e8f0;text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.controller-now-playing-card{background:linear-gradient(145deg,#111c32e6,#0e172af2);border:1px solid #45577d99;border-radius:16px;flex-direction:column;justify-content:center;gap:8px;padding:20px 24px;display:flex;box-shadow:0 4px 16px #0003}.controller-now-playing-card h1{color:#f8fafc;margin:0;font-size:clamp(1.3rem,1.8vw,1.8rem);font-weight:700;line-height:1.3}.controller-now-playing-card .text-muted{color:#a5b4fc;margin:0;font-size:.95rem;font-weight:500}.controller-interactive-card{background:linear-gradient(145deg,#111c32e6,#0e172af2);border:1px solid #6366f14d;border-radius:16px;grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;gap:10px;padding:18px;display:grid;box-shadow:0 4px 16px #0003}.interactive-settings-btn{color:#a5b4fc;cursor:pointer;background:#6366f11f;border:1px solid #6366f140;border-radius:12px;justify-content:center;align-items:center;width:100%;height:100%;min-height:48px;transition:background .2s,color .2s,transform .15s;display:flex}.interactive-settings-btn:hover{color:#f8fafc;background:#6366f140;transform:scale(1.05)}.interactive-settings-btn:active{transform:scale(.95)}.interactive-emoji-group{display:contents}.interactive-emoji-btn{cursor:pointer;-webkit-user-select:none;user-select:none;background:#0f172a99;border:1px solid #94a3b81f;border-radius:12px;justify-content:center;align-items:center;width:100%;height:100%;min-height:48px;font-size:1.5rem;transition:background .2s,transform .15s,border-color .2s;display:flex}.interactive-emoji-btn:hover{background:#6366f126;border-color:#6366f14d;transform:scale(1.12)}.interactive-emoji-btn:active{transform:scale(.9)}@media (max-width:768px){.controller-top-grid{grid-template-columns:1fr;gap:12px}.controller-info-card{flex-direction:row;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px}.controller-info-header{border-bottom:none;flex-direction:row;flex:1;align-items:center;gap:10px;min-width:0;padding-bottom:0}.controller-info-icon{flex-shrink:0;width:48px;height:48px;font-size:1.4rem}.controller-info-details{flex:1;min-width:0}.controller-info-label{margin:0 0 2px;font-size:.6rem}.controller-room-name{max-width:100%;font-size:1rem}.controller-info-meta{flex-direction:column;flex-shrink:0;gap:6px}.controller-meta-item{background:0 0;justify-content:flex-end;padding:4px 0;font-size:.85rem}.controller-meta-icon{width:16px;font-size:.85rem}.controller-meta-text{white-space:nowrap;font-size:.85rem}.controller-now-playing-card{padding:16px 18px}.controller-now-playing-card h1{font-size:1.2rem}.controller-now-playing-card .text-muted{font-size:.85rem}.controller-interactive-card{flex-direction:row;justify-content:center;align-items:center;gap:12px;padding:12px 16px;display:flex}.interactive-settings-btn{width:40px;height:40px;min-height:40px}.interactive-emoji-group{flex-direction:row;gap:8px;display:flex}.interactive-emoji-btn{width:44px;height:44px;min-height:44px;font-size:1.4rem}}.controller-header{background:#0e172a;border:1px solid #45577d99;border-radius:16px;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex}.controller-header h1{margin:6px 0 0;font-size:clamp(1.2rem,1.6vw,1.6rem);font-weight:600}.controller-label{text-transform:uppercase;letter-spacing:.18em;color:#94a3b8;font-size:.6rem}.controller-shell .stack{gap:10px}.controller-shell .stack input.input{min-height:48px}.filter-btn{color:#cbd5e1;cursor:pointer;background:#0f172ab3;border:1px solid #45577d80;border-radius:10px;align-items:center;gap:8px;margin-top:12px;padding:8px 14px;font-family:inherit;font-size:.85rem;font-weight:500;transition:all .2s;display:inline-flex}.filter-btn:hover{color:#e2e8f0;background:#0f172ae6;border-color:#6366f180}.filter-btn svg{flex-shrink:0}.filter-modal{z-index:1000;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.filter-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;position:absolute;inset:0}.filter-content{background:#0f172af2;border:1px solid #6366f14d;border-radius:20px;width:100%;max-width:400px;padding:28px;position:relative;box-shadow:0 24px 60px #00000080}.filter-content h3{color:#f8fafc;margin:0 0 20px;font-size:1.2rem;font-weight:600}.filter-checkbox-label{cursor:pointer;background:#0f172a80;border:1px solid #45577d66;border-radius:12px;align-items:center;gap:12px;margin-bottom:12px;padding:12px 16px;transition:all .2s;display:flex}.filter-checkbox-label:hover{background:#0f172acc;border-color:#6366f166}.filter-checkbox-label input[type=checkbox]{cursor:pointer;accent-color:#6366f1;flex-shrink:0;width:18px;height:18px}.filter-checkbox-label span{color:#e2e8f0;font-size:.95rem;font-weight:500}.filter-close-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border:none;border-radius:12px;width:100%;margin-top:8px;padding:12px;font-family:inherit;font-size:.95rem;font-weight:600;transition:transform .15s,box-shadow .2s}.filter-close-btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px #6366f14d}.controller-code{color:#e2e8f0;background:#111c32;border:1px solid #45577d99;border-radius:999px;padding:8px 12px;font-size:.75rem}.controller-code span{color:#fff;font-weight:600}.controller-grid{flex:1;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:16px;min-height:0;display:grid}@media (max-width:768px){.controller-grid{flex:none;grid-template-columns:1fr;min-height:auto}.controller-search-card{order:2}.controller-upnext-card{order:1}}.controller-card{background:#0e172a;border:1px solid #45577d99;border-radius:16px;flex-direction:column;gap:16px;min-height:0;padding:20px;display:flex;overflow:hidden;box-shadow:0 24px 60px #0f172a73}.controller-card h2{text-transform:uppercase;letter-spacing:.12em;color:#e2e8f0;margin:0;font-size:.8rem}.controller-list{flex-direction:column;flex:1;gap:12px;min-height:0;display:flex;overflow-y:auto}.controller-results-grid{flex:1;grid-template-columns:1fr;gap:12px;min-height:0;display:grid;overflow-y:auto}.scroll-fade{scrollbar-width:thin;position:relative;overflow:auto}.scroll-fade:after{content:"";pointer-events:none;background:linear-gradient(#0e172a00 0%,#0e172ae6 70%,#0e172a 100%);height:72px;position:sticky;bottom:-1px;left:0;right:0}.controller-item{background:linear-gradient(145deg,#111c32e6,#111c3299);border:1px solid #45577d80;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:12px;display:flex;box-shadow:inset 0 1px #ffffff0a}.controller-upnext{align-items:center;gap:10px;display:flex}.controller-upnext-icon{color:#7dd3fc;background:#38bdf826;border-radius:9px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.85rem;display:inline-flex}.controller-upnext-title{color:#e2e8f0;margin:0;font-size:.85rem;line-height:1.3}.controller-queue{background:#0b1426;border:1px solid #1f2b3d;border-radius:12px;flex:1;min-height:0;padding:12px;overflow-y:auto}.controller-queue ul{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.controller-queue li{min-width:0}.queue-item{cursor:grab;touch-action:pan-y;border:1px solid #1f2b3d;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex;background:#111c32!important}.queue-item *{background:0 0}.queue-item-dragging{opacity:.6;cursor:grabbing}.queue-meta{flex:1;align-items:center;gap:8px;min-width:0;font-size:.82rem;display:flex}.queue-index{touch-action:pan-y;color:#bae6fd;background:#38bdf82e;border-radius:8px;justify-content:center;align-items:center;min-width:36px;height:28px;padding:0 8px;font-size:.78rem;font-weight:600;display:inline-flex}.queue-title{text-overflow:ellipsis;white-space:nowrap;color:#e2e8f0;font-size:.85rem;overflow:hidden}.queue-remove{color:#e2e8f0bf;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:4px 6px;font-size:1.1rem;line-height:1;transition:color .2s,background .2s}.queue-remove:hover{color:#f8fafc;background:#94a3b81f}.search-input{box-shadow:none;border:1px solid #45577d99;flex:1;background:#111c32!important}.video-card{background:linear-gradient(145deg,#111c32e6,#111c3299);border:1px solid #45577d80;border-radius:20px;flex-direction:column;height:100%;transition:transform .2s;display:flex;overflow:hidden;box-shadow:inset 0 1px #ffffff0a}.video-card:hover{transform:translateY(-2px)}.video-card-thumbnail{background:#0b1426;flex-shrink:0;width:100%;padding-top:56.25%;position:relative;overflow:hidden}.video-card-thumbnail img{object-fit:cover;width:100%;height:100%;position:absolute;top:0;left:0}.video-card-gradient{pointer-events:none;z-index:1;background:linear-gradient(#0b14261a,#0b142680 45%,#0b1426f2);position:absolute;inset:0}.video-duration{color:#fff;z-index:2;background:#0f172acc;border:1px solid #94a3b840;border-radius:8px;padding:4px 8px;font-size:.75rem;font-weight:600;position:absolute;top:8px;left:8px}.video-card-actions{opacity:0;z-index:2;gap:6px;transition:opacity .2s;display:flex;position:absolute;top:8px;right:8px}.video-card:hover .video-card-actions{opacity:1}.btn-card-action{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;background:#0f172acc;border:1px solid #94a3b840;border-radius:8px;padding:6px 12px;font-size:.75rem;font-weight:600;transition:background .2s}.btn-card-action:hover{background:#0f172af2}.btn-card-add{color:#fff;cursor:pointer;background:#4f46e6;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;font-weight:600;transition:background .2s;display:flex;box-shadow:0 8px 18px #4f46e659}.btn-card-add:hover{background:#6159ed}.video-card-info{z-index:2;background:linear-gradient(#0b142600 0%,#0b14268c 40%,#0b1426f2 100%);flex-direction:column;gap:6px;width:100%;padding:16px;display:flex;position:absolute;bottom:0;left:0}.video-card-title{color:#f8fafc;text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:1.05rem;font-weight:700;line-height:1.3;display:-webkit-box;overflow:hidden}.video-card-artist{color:#e2e8f0d9;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.85rem;overflow:hidden}@media (max-width:960px){.controller-grid{grid-template-columns:1fr}}@media (min-width:768px){.controller-results-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:min-content}.controller-queue ul{grid-template-columns:repeat(3,minmax(0,1fr))}}a{color:inherit;text-decoration:none}#root{min-height:100vh}.controller-page{height:100vh;overflow:hidden}.controller-page.app-shell{max-width:none;height:100%;padding:24px}.controller-page .app-content{flex:1;overflow:hidden}.controller-page .controller-section,.controller-page .section.controller-section{flex:1;min-height:0}.controller-page .card{flex-direction:column;height:100%;display:flex;overflow:hidden}@media (max-width:768px){.controller-page{height:auto;min-height:100vh;overflow:auto}.controller-page .app-content{overflow:visible}.controller-page .card{height:auto;overflow:visible}}.controller-page .list,.controller-page .queue-list{flex:1;min-height:0;overflow-y:auto}.controller-page .app-title{font-size:clamp(1.4rem,2vw,2rem);font-weight:600}.controller-page .app-subtitle{letter-spacing:.18em;font-size:.75rem}.app-shell{flex-direction:column;gap:32px;max-width:1100px;margin:0 auto;padding:48px 24px 96px;display:flex}.app-header{justify-content:space-between;align-items:center;gap:24px;display:flex}.app-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.app-title{margin:0;font-size:clamp(2rem,3vw,3rem)}.app-subtitle{letter-spacing:.1em;text-transform:uppercase;color:#6b7280;margin:0 0 8px;font-size:.9rem}.app-content{flex-direction:column;gap:32px;display:flex}.section{flex-direction:column;gap:16px;display:flex}.section-title{justify-content:space-between;align-items:center;display:flex}.card{background:#fff;border:1px solid #94a3b833;border-radius:20px;padding:24px;box-shadow:0 20px 60px #0f172a14}.card.inset{background:#f9fafb}.card-header{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.hero-card{color:#fff;background:linear-gradient(130deg,#0f172a,#1f2a4a 55%,#1f2937);border-radius:28px;flex-direction:column;gap:24px;padding:40px;display:flex;box-shadow:0 30px 80px #0f172a66}.hero-card h2{margin:0;font-size:clamp(1.8rem,3vw,2.5rem)}.hero-actions{flex-wrap:wrap;gap:12px;display:flex}.eyebrow{text-transform:uppercase;letter-spacing:.2em;color:#ffffffb3;font-size:.7rem}.text-muted{color:#8b95a7}.text-danger{color:#dc2626}.break-all{word-break:break-all}.stack{flex-direction:column;gap:12px;display:flex}.inline{justify-content:space-between;align-items:center;gap:16px;display:flex}.grid-2{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}.divider{background:#94a3b840;width:100%;height:1px;margin:16px 0}.input{color:#e2e8f0;background:linear-gradient(#1a2233f2,#101726f2);border:1px solid #94a3b866;border-radius:14px;padding:14px 16px;font-size:1rem}.input:focus{border-color:#4f46e6;outline:none;box-shadow:0 0 0 3px #4f46e64d}.btn{cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:12px 18px;font-size:.95rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{color:#fff;background:#4f46e5;box-shadow:0 18px 30px #4f46e54d}.btn-secondary{color:#fff;background:#45577d}.btn-ghost{color:#111827;background:#94a3b826}.btn:hover:not(:disabled){transform:translateY(-1px)}.badge{color:#4f46e5;background:#4f46e51f;border-radius:999px;padding:6px 12px;font-size:.8rem;font-weight:600}.chip{color:#0f172a;background:#0f172a14;border-radius:999px;padding:8px 14px;font-size:.85rem;font-weight:600}.chip.large{font-size:1.1rem}.list{flex-direction:column;gap:12px;display:flex}.list-item{background:#f8fafc;border:1px solid #94a3b833;border-radius:16px;justify-content:space-between;align-items:center;gap:16px;padding:16px;display:flex}.list-title{margin:0 0 4px;font-size:.9rem;font-weight:600;line-height:1.3}.media{align-items:center;gap:12px;display:flex}.media img{object-fit:cover;border-radius:12px;width:56px;height:56px}.qr-block{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.queue-list{flex-direction:column;gap:12px;display:flex}.queue-item{background:#f8fafc;border:1px solid #94a3b833;border-radius:16px;justify-content:space-between;gap:16px;padding:16px;display:flex}.queue-item-active{background:#4f46e514;border-color:#4f46e599}.queue-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.button-group{flex-wrap:wrap;gap:8px;display:flex}@media (max-width:720px){.app-header{flex-direction:column;align-items:flex-start}.hero-card{padding:28px}.controller-page{height:auto;min-height:100vh;overflow:auto}.controller-shell{overflow:visible}.controller-results-grid,.controller-queue ul{grid-template-columns:1fr}}.player-shell{color:#fff;background:#0b0d12;flex-direction:column;min-height:100vh;display:flex}.player-header{background:#0f172ab3;border-bottom:1px solid #94a3b833;justify-content:space-between;align-items:center;gap:24px;padding:24px 32px;display:flex}.player-header h2{margin:0 0 8px;font-size:clamp(1.5rem,2.5vw,2.5rem)}.player-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.player-frame{flex:1;width:100%;height:100%}.player-frame iframe,.player-iframe{width:100%;height:100%;position:absolute;top:0;left:0}.player-shell{height:100vh;position:relative}.player-empty{background:radial-gradient(circle at top,#1e293ba6,#0b0d12f2);place-items:center;padding:32px;display:grid;position:absolute;inset:0}.player-empty-card{text-align:left;color:#f8fafc;background:#0f172aeb;border:1px solid #94a3b840;border-radius:22px;flex-direction:column;gap:16px;width:100%;max-width:720px;padding:28px;display:flex;box-shadow:0 24px 60px #0f172a8c}.player-empty-card h2{letter-spacing:-.01em;margin:0;font-size:clamp(1.6rem,2.6vw,2.4rem);font-weight:700}.player-empty-card .text-muted{color:#e2e8f0b3;margin:0;font-size:1rem}.player-empty-card .qr-block{background:#02061780;border:1px solid #94a3b826;border-radius:16px;grid-template-columns:auto 1fr;align-items:center;gap:20px;padding:16px;display:grid}.player-empty-card .qr-block canvas{background:#fff;border-radius:12px;padding:12px;display:block;box-shadow:0 12px 30px #02061773}.player-empty-card .stack p{word-break:break-all;margin:0;font-size:.95rem}@media (max-width:720px){.player-empty-card{text-align:center;padding:20px}.player-empty-card .qr-block{text-align:center;grid-template-columns:1fr;justify-items:center}}.player-join-card{z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);opacity:.85;background:#0f172ae0;border:1px solid #94a3b833;border-radius:14px;align-items:center;gap:12px;padding:10px 14px;transition:opacity .2s;display:flex;position:absolute;bottom:20px;right:20px;box-shadow:0 8px 24px #0006}.player-join-card:hover{opacity:1}.player-join-card canvas{border-radius:6px;display:block}.player-join-card-info{flex-direction:column;gap:2px;display:flex}.player-join-card-label{color:#e2e8f099;text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;font-weight:600}.player-join-card-code{color:#f8fafc;letter-spacing:.08em;font-family:SF Mono,Fira Code,monospace;font-size:1.25rem;font-weight:700}@media (max-width:720px){.player-join-card{gap:8px;padding:8px 10px;bottom:12px;right:12px}.player-join-card canvas{width:52px!important;height:52px!important}.player-join-card-code{font-size:1rem}}.auth-page{background:#0a0c10;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.auth-container{z-index:1;width:100%;max-width:420px;position:relative}.auth-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f141ed9;border:1px solid #ffffff14;border-radius:24px;padding:40px 32px;box-shadow:0 40px 80px #00000080}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 20px;display:flex;box-shadow:0 8px 32px #6366f14d}.auth-logo-icon{color:#fff;font-size:24px}.auth-header h1{color:#f8fafc;letter-spacing:-.02em;margin:0 0 8px;font-size:1.75rem;font-weight:600}.auth-subtitle{color:#94a3b8e6;margin:0;font-size:.95rem}.auth-form{flex-direction:column;gap:20px;display:flex}.auth-error{color:#fca5a5;text-align:center;background:#ef444426;border:1px solid #ef44444d;border-radius:12px;padding:12px 16px;font-size:.9rem}.auth-field{flex-direction:column;gap:8px;display:flex}.auth-field label{color:#e2e8f0d9;letter-spacing:.01em;font-size:.85rem;font-weight:500}.auth-input{color:#f8fafc;background:#0f172a99;border:1px solid #94a3b826;border-radius:12px;outline:none;width:100%;padding:14px 16px;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.auth-input::placeholder{color:#94a3b880}.auth-input:focus{border-color:#6366f199;box-shadow:0 0 0 3px #6366f126}.auth-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border:none;border-radius:12px;justify-content:center;align-items:center;width:100%;min-height:48px;padding:14px 24px;font-family:inherit;font-size:1rem;font-weight:600;transition:transform .15s,box-shadow .2s;display:flex}.auth-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #6366f159}.auth-button:disabled{opacity:.7;cursor:not-allowed}.auth-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-footer{text-align:center;margin-top:24px}.auth-footer p{color:#94a3b8cc;margin:0;font-size:.9rem}.auth-link{color:#818cf8;font-weight:500;text-decoration:none;transition:color .2s}.auth-link:hover{color:#a5b4fc}.auth-ambient{z-index:0;pointer-events:none;background:radial-gradient(80% 50% at 50% -20%,#6366f126,#0000),radial-gradient(60% 40% at 80% 80%,#8b5cf61a,#0000);position:fixed;inset:0}.dashboard-page{color:#f8fafc;background:#0a0c10;min-height:100vh}.dashboard-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:100;background:#0f141e80;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.dashboard-brand{align-items:center;gap:10px;display:flex}.dashboard-logo{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.dashboard-title{letter-spacing:-.01em;font-size:1.1rem;font-weight:600}.brand-logo-text{background:linear-gradient(135deg,#6366f1,#a855f7,#6366f1);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700;display:inline-block}.dashboard-title.brand-logo-text{font-size:1.15rem}.dashboard-user{align-items:center;gap:16px;display:flex;position:relative}.dashboard-menu-btn{color:#e2e8f0;cursor:pointer;background:#0f172ab3;border:1px solid #94a3b833;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;display:none}.dashboard-user-items{align-items:center;gap:16px;display:flex}.dashboard-username{color:#e2e8f0cc;font-size:.9rem}.dashboard-logout,.dashboard-login{color:#818cf8;cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:.9rem;text-decoration:none;transition:color .2s}.dashboard-logout:hover,.dashboard-login:hover{color:#a5b4fc}.dashboard-main{max-width:960px;margin:0 auto;padding:40px 24px 80px}.dashboard-hero{margin-bottom:48px}.dashboard-hero-content h1{letter-spacing:-.025em;background:linear-gradient(135deg,#f8fafc 0%,#cbd5e1 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 12px;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700}.dashboard-hero-subtitle{color:#94a3b8e6;max-width:480px;margin:0;font-size:1.1rem}.dashboard-section{margin-bottom:40px}.dashboard-section-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.dashboard-section-header h2{color:#e2e8f0e6;text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:1rem;font-weight:600}.dashboard-badge{color:#a5b4fc;background:#6366f133;border-radius:999px;padding:4px 10px;font-size:.8rem;font-weight:600}.dashboard-info-card{background:#0f141e99;border:1px solid #ffffff0f;border-radius:20px;flex-direction:column;gap:12px;padding:24px;display:flex}.dashboard-info-label{color:#94a3b8b3;text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:500}.dashboard-info-value{color:#a5b4fc;margin:0;font-size:2.5rem;font-weight:700}.dashboard-info-subtext{color:#94a3b899;font-size:.9rem}.dashboard-card{background:#0f141e99;border:1px solid #ffffff0f;border-radius:20px;padding:24px}.dashboard-create-card{flex-direction:column;gap:16px;display:flex}.dashboard-card-icon{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.dashboard-create-card>.dashboard-card-icon{align-self:flex-start}.dashboard-info-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.dashboard-info-card{text-align:center;background:#0f172ad9;border:1px solid #94a3b826;border-radius:16px;padding:20px}.dashboard-info-label{color:#e2e8f099;margin-bottom:8px;font-size:.85rem}.dashboard-info-value{color:#6366f1;margin-bottom:4px;font-size:2rem;font-weight:700}.dashboard-info-subtext{color:#e2e8f080;margin-bottom:12px;font-size:.8rem}.dashboard-buy-credits-btn,.dashboard-history-btn{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-block}.dashboard-buy-credits-btn:hover,.dashboard-history-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.dashboard-history-btn{color:#e2e8f0cc;background:0 0;border:1px solid #94a3b84d}.dashboard-history-btn:hover{background:#94a3b81a}.dashboard-card-content{width:100%}.dashboard-card-content h3{color:#f8fafc;margin:0 0 4px;font-size:1.1rem;font-weight:600}.dashboard-card-content p{color:#94a3b8cc;margin:0;font-size:.9rem}.dashboard-create-form{flex-wrap:wrap;align-items:center;gap:12px;width:100%;display:flex}.dashboard-input{color:#f8fafc;background:#0f172a99;border:1px solid #94a3b826;border-radius:12px;outline:none;flex:1;min-width:220px;padding:12px 16px;font-family:inherit;font-size:.95rem;transition:border-color .2s}.dashboard-input:focus{border-color:#6366f180}.dashboard-input::placeholder{color:#94a3b880}.dashboard-create-btn{color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border:none;border-radius:12px;padding:12px 24px;font-family:inherit;font-size:.95rem;font-weight:600;transition:transform .15s,box-shadow .2s}.dashboard-create-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px #6366f14d}.dashboard-create-btn:disabled{opacity:.7;cursor:not-allowed}.dashboard-create-error{color:#f87171;background:#ef444426;border:1px solid #ef44444d;border-radius:10px;margin-top:12px;padding:12px 16px;font-size:.9rem}.dashboard-empty{text-align:center;color:#94a3b8b3;padding:40px 24px}.dashboard-rooms-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.dashboard-rooms-actions{align-items:center;gap:10px;display:flex}.dashboard-toggle{color:#e2e8f0d9;cursor:pointer;background:#0f141e99;border:1px solid #94a3b840;border-radius:999px;align-items:center;gap:8px;padding:6px 12px;font-size:.8rem;transition:border-color .2s,color .2s;display:inline-flex}.dashboard-toggle:hover{color:#f8fafc;border-color:#6366f166}.dashboard-toggle-count{color:#a5b4fc;background:#6366f133;border-radius:999px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 6px;font-weight:600;display:inline-flex}.dashboard-room-card{background:#0f141e99;border:1px solid #ffffff0f;border-radius:16px;justify-content:space-between;align-items:center;gap:16px;padding:20px;text-decoration:none;transition:border-color .2s,transform .15s;display:flex}.dashboard-room-card:hover{border-color:#6366f14d;transform:translateY(-2px)}.dashboard-room-card.expired{opacity:.6;cursor:not-allowed}.dashboard-room-card.expired:hover{border-color:#ffffff0f;transform:none}.dashboard-room-info h4{color:#f8fafc;margin:0 0 4px;font-size:1rem;font-weight:600}.dashboard-room-date{color:#94a3b8b3;font-size:.85rem}.dashboard-room-time{color:#4ade80;background:#22c55e1f;border:1px solid #22c55e33;border-radius:999px;width:fit-content;margin-top:6px;padding:3px 8px;font-size:.75rem;display:block}.dashboard-room-time.green{color:#4ade80;background:#22c55e1f;border-color:#22c55e33}.dashboard-room-time.yellow{color:#fbbf24;background:#fbbf241f;border-color:#fbbf2433}.dashboard-room-time.red{color:#f87171;background:#f871711f;border-color:#f8717133}.dashboard-room-time.expired{color:#f87171}.dashboard-room-meta{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.dashboard-room-code{color:#a5b4fc;background:#6366f126;border-radius:8px;padding:6px 12px;font-family:monospace;font-size:.85rem;font-weight:600}.dashboard-room-status{text-transform:uppercase;color:#4ade80;background:#22c55e26;border-radius:6px;padding:4px 10px;font-size:.7rem;font-weight:600}.dashboard-room-status.active{color:#4ade80;background:#22c55e26}.dashboard-room-status.expired{color:#f87171;background:#ef444426}.dashboard-expired-block{gap:12px;margin-top:16px;display:grid}.dashboard-expired-header{color:#e2e8f0b3;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem;font-weight:600}.dashboard-admin-link{color:#a5b4fc;background:#6366f126;border:1px solid #6366f14d;border-radius:8px;padding:8px 16px;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .2s}.dashboard-admin-link:hover{background:#6366f140}.dashboard-auth-prompt{justify-content:center;display:flex}.dashboard-auth-card{text-align:center;background:#0f141e99;border:1px solid #ffffff0f;border-radius:24px;max-width:400px;padding:48px 32px}.dashboard-auth-card h3{color:#f8fafc;margin:0 0 12px;font-size:1.5rem;font-weight:600}.dashboard-auth-card p{color:#94a3b8cc;margin:0 0 28px;font-size:1rem}.dashboard-auth-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.dashboard-btn-primary,.dashboard-btn-secondary{border-radius:12px;padding:12px 28px;font-family:inherit;font-size:.95rem;font-weight:600;text-decoration:none;transition:transform .15s,box-shadow .2s}.dashboard-btn-primary{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border:none}.dashboard-btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 20px #6366f14d}.dashboard-btn-secondary{color:#a5b4fc;background:0 0;border:1px solid #6366f14d}.dashboard-btn-secondary:hover{background:#6366f11a;border-color:#6366f180}.dashboard-loading{justify-content:center;align-items:center;min-height:100vh;display:flex}.guest-welcome-page{background:#0a0c10;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.guest-welcome-container{z-index:1;width:100%;max-width:440px;position:relative}.guest-welcome-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f141ed9;border:1px solid #ffffff14;border-radius:28px;padding:48px 36px;box-shadow:0 40px 80px #00000080}.guest-welcome-header{text-align:center;margin-bottom:36px}.guest-welcome-icon{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-radius:20px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 24px;font-size:28px;display:flex;box-shadow:0 12px 40px #6366f159}.guest-welcome-header h1{color:#f8fafc;letter-spacing:-.02em;margin:0 0 8px;font-size:1.75rem;font-weight:700}.guest-welcome-subtitle{color:#94a3b8d9;margin:0;font-size:1rem}.guest-welcome-form{flex-direction:column;gap:24px;display:flex}.guest-welcome-field{flex-direction:column;gap:10px;display:flex}.guest-welcome-field label{color:#e2e8f0d9;font-size:.9rem;font-weight:500}.guest-welcome-input{color:#f8fafc;background:#0f172a99;border:1px solid #94a3b826;border-radius:14px;outline:none;width:100%;padding:16px 18px;font-family:inherit;font-size:1.05rem;transition:border-color .2s,box-shadow .2s}.guest-welcome-input:focus{border-color:#6366f199;box-shadow:0 0 0 3px #6366f126}.guest-welcome-input:disabled{opacity:.7;cursor:not-allowed}.guest-welcome-input::placeholder{color:#94a3b880}.guest-welcome-hint{color:#818cf8cc;font-size:.85rem}.guest-welcome-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border:none;border-radius:14px;justify-content:center;align-items:center;width:100%;min-height:54px;padding:16px 24px;font-family:inherit;font-size:1.05rem;font-weight:600;transition:transform .15s,box-shadow .2s;display:flex}.guest-welcome-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #6366f166}.guest-welcome-button:disabled{opacity:.6;cursor:not-allowed}.guest-welcome-footer{text-align:center;margin-top:28px}.guest-welcome-code{color:#94a3b8b3;margin:0;font-size:.9rem}.guest-welcome-code strong{color:#a5b4fc;font-family:monospace;font-size:1rem}.guest-welcome-ambient{z-index:0;pointer-events:none;background:radial-gradient(80% 50% at 50% -20%,#6366f11f,#0000),radial-gradient(60% 40% at 80% 80%,#8b5cf614,#0000);position:fixed;inset:0}.join-room-page{background:#0a0c10;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.join-room-container{z-index:1;width:100%;max-width:440px;position:relative}.join-room-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f141ed9;border:1px solid #ffffff14;border-radius:28px;padding:48px 36px;box-shadow:0 40px 80px #00000080}.join-room-back{color:#94a3b8cc;margin-bottom:24px;font-size:.9rem;text-decoration:none;transition:color .2s;display:inline-block}.join-room-back:hover{color:#a5b4fc}.join-room-header{text-align:center;margin-bottom:36px}.join-room-icon{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-radius:20px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 24px;font-size:28px;display:flex;box-shadow:0 12px 40px #6366f159}.join-room-header h1{color:#f8fafc;letter-spacing:-.02em;margin:0 0 8px;font-size:1.75rem;font-weight:700}.join-room-subtitle{color:#94a3b8d9;margin:0;font-size:1rem}.join-room-form{flex-direction:column;gap:24px;display:flex}.join-room-field{flex-direction:column;gap:10px;display:flex}.join-room-field label{color:#e2e8f0d9;font-size:.9rem;font-weight:500}.join-room-input{color:#f8fafc;text-align:center;letter-spacing:.15em;background:#0f172a99;border:1px solid #94a3b826;border-radius:14px;outline:none;width:100%;padding:16px 18px;font-family:monospace;font-size:1.25rem;transition:border-color .2s,box-shadow .2s}.join-room-input:focus{border-color:#6366f199;box-shadow:0 0 0 3px #6366f126}.join-room-input::placeholder{color:#94a3b880;letter-spacing:.05em}.join-room-error{color:#fca5a5;font-size:.85rem}.join-room-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border:none;border-radius:14px;justify-content:center;align-items:center;width:100%;min-height:54px;padding:16px 24px;font-family:inherit;font-size:1.05rem;font-weight:600;transition:transform .15s,box-shadow .2s;display:flex}.join-room-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #6366f166}.join-room-button:disabled{opacity:.6;cursor:not-allowed}.join-room-footer{text-align:center;margin-top:28px}.join-room-footer p{color:#94a3b899;margin:0;font-size:.9rem}.join-room-ambient{z-index:0;pointer-events:none;background:radial-gradient(80% 50% at 50% -20%,#6366f11f,#0000),radial-gradient(60% 40% at 80% 80%,#8b5cf614,#0000);position:fixed;inset:0}.dashboard-join-btn{color:#a5b4fc;background:0 0;border:1px solid #6366f166;border-radius:12px;margin-top:20px;padding:14px 32px;font-family:inherit;font-size:1rem;font-weight:600;text-decoration:none;transition:transform .15s,background .2s,border-color .2s;display:inline-block}.dashboard-join-btn:hover{background:#6366f126;border-color:#6366f199;transform:translateY(-1px)}.controller-header-right{align-items:center;gap:12px;display:flex}.controller-guest-badge{color:#a5b4fc;background:#6366f126;border:1px solid #6366f140;border-radius:999px;align-items:center;gap:8px;padding:8px 14px;font-size:.85rem;display:flex}.controller-guest-icon{font-size:1rem}.queue-singer{color:#a5b4fccc;margin-left:8px;font-size:.75rem}.room-master-page{color:#f8fafc;background:#0a0c10;min-height:100vh}.room-master-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0f141e80;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.room-master-brand{align-items:center;gap:16px;display:flex}.room-master-back{color:#f8fafc;background:#ffffff0d;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;text-decoration:none;transition:background .2s;display:flex}.room-master-back:hover{background:#ffffff1a}.room-master-brand h1{margin:0;font-size:1.2rem;font-weight:600}.room-master-code{color:#a5b4fc;font-family:monospace;font-size:.85rem}.room-master-main{max-width:1000px;margin:0 auto;padding:40px 24px 80px}.room-master-hero{margin-bottom:40px}.room-master-hero-content{margin-bottom:24px}.room-master-eyebrow{text-transform:uppercase;letter-spacing:.15em;color:#818cf8;margin:0 0 12px;font-size:.75rem;font-weight:600}.room-master-hero h2{letter-spacing:-.02em;color:#f8fafc;margin:0 0 12px;font-size:clamp(1.5rem,3vw,2rem);font-weight:700}.room-master-subtitle{color:#94a3b8d9;margin:0;font-size:1rem}.room-master-actions{flex-wrap:wrap;gap:12px;display:flex}.room-master-btn-primary,.room-master-btn-secondary{text-align:center;border-radius:14px;padding:14px 28px;font-family:inherit;font-size:.95rem;font-weight:600;text-decoration:none;transition:transform .15s,box-shadow .2s}.room-master-btn-primary{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%)}.room-master-btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px #6366f159}.room-master-btn-secondary{color:#f8fafc;background:#ffffff0d;border:1px solid #ffffff1a}.room-master-btn-secondary:hover{background:#ffffff1a;border-color:#ffffff26}.room-master-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;display:grid}.room-master-card{background:#0f141e99;border:1px solid #ffffff0f;border-radius:20px;padding:28px}.room-master-card-header{margin-bottom:24px}.room-master-card-header h3{color:#f8fafc;margin:0 0 8px;font-size:1.15rem;font-weight:600}.room-master-card-header p{color:#94a3b8bf;margin:0;font-size:.9rem}.room-master-qr{flex-wrap:wrap;align-items:center;gap:24px;display:flex}.room-master-qr canvas{border-radius:16px;box-shadow:0 12px 32px #0000004d}.room-master-qr-info{flex:1;min-width:200px}.room-master-qr-url{color:#94a3b8cc;word-break:break-all;margin:0 0 16px;font-size:.85rem}.room-master-links{flex-direction:column;gap:12px;display:flex}.room-master-hint{color:#94a3b899;margin:8px 0 0;font-size:.85rem}.room-master-loading{justify-content:center;align-items:center;min-height:100vh;display:flex}.controller-loading{background:#0a0c10;justify-content:center;align-items:center;min-height:100vh;display:flex}.queue-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.queue-info .queue-title{color:#f8fafc;white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;overflow:hidden}.queue-info .queue-singer{color:#a5b4fcb3;white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.admin-page{background:#0a0c10;min-height:100vh;display:flex;overflow-x:hidden}.admin-loading{place-items:center;width:100%;min-height:100vh;display:grid}.admin-loading-content{place-items:center;min-height:400px;display:grid}.admin-sidebar{z-index:100;background:#0f141ef2;border-right:1px solid #ffffff14;flex-direction:column;width:260px;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.admin-sidebar-header{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:20px;display:flex}.admin-sidebar-close{color:#94a3b8;cursor:pointer;background:0 0;border:none;font-size:1.5rem;display:none}.admin-logo{color:#f8fafc;align-items:center;gap:12px;text-decoration:none;display:flex}.admin-logo-icon{background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;display:flex}.admin-logo-text{letter-spacing:-.02em;font-size:1.25rem;font-weight:600}.admin-logo-text.brand-logo-text{font-size:1.25rem}.admin-nav{flex-direction:column;flex:1;gap:4px;padding:16px 12px;display:flex}.admin-nav-item{color:#94a3b8;border-radius:10px;align-items:center;gap:12px;padding:12px 16px;font-size:.95rem;text-decoration:none;transition:all .2s;display:flex}.admin-nav-item:hover{color:#f8fafc;background:#ffffff0d}.admin-nav-item.active{color:#a5b4fc;background:#6366f126}.admin-nav-icon{font-size:1.1rem}.admin-sidebar-footer{border-top:1px solid #ffffff0f;padding:16px 12px}.admin-main{flex-direction:column;flex:1;min-height:100vh;margin-left:260px;display:flex;overflow-x:hidden}.admin-header{z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f141ecc;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:20px 32px;display:flex;position:sticky;top:0}.admin-menu-btn{color:#f8fafc;cursor:pointer;background:0 0;border:none;font-size:1.5rem;display:none}.admin-header-title{color:#f8fafc;margin:0;font-size:1.5rem;font-weight:600}.admin-header-user{align-items:center;gap:16px;display:flex;position:relative}.admin-header-user-items{align-items:center;gap:16px;display:flex}.admin-user-menu-btn{color:#e2e8f0;cursor:pointer;background:#0f172ab3;border:1px solid #94a3b833;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;transition:all .2s;display:none}.admin-user-menu-btn:hover{background:#0f172ae6;border-color:#94a3b84d}@media (max-width:768px){.admin-user-menu-btn{display:flex}.admin-header-user-items{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:1000;background:#0f172afa;border:1px solid #94a3b833;border-radius:12px;flex-direction:column;align-items:stretch;gap:2px;min-width:180px;padding:8px;display:none;position:absolute;top:calc(100% + 8px);right:16px;box-shadow:0 8px 24px #0006,0 2px 8px #0003}.admin-header-user-items.open{display:flex}.admin-user-name{color:#a5b4fc;border-bottom:1px solid #94a3b826;margin-bottom:4px;padding:10px 14px;font-weight:500}.admin-logout-btn{text-align:left;border-radius:8px;width:100%;padding:10px 14px;transition:background .2s}.admin-logout-btn:hover{background:#ef444433}}.admin-content{flex:1;max-width:100%;padding:32px;overflow-x:hidden}.admin-dashboard{flex-direction:column;gap:32px;display:flex}.admin-stats-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;display:grid}.admin-stat-card{background:#0f141ecc;border:1px solid #ffffff14;border-radius:16px;align-items:flex-start;gap:16px;padding:24px;display:flex}.admin-stat-card.active{background:#22c55e14;border-color:#22c55e4d}.admin-stat-card.expired{background:#ef444414;border-color:#ef44444d}.admin-stat-card.pending{background:#fbbf2414;border-color:#fbbf244d}.admin-stat-icon{font-size:1.75rem}.admin-stat-content{flex-direction:column;gap:4px;display:flex}.admin-stat-value{color:#f8fafc;font-size:1.75rem;font-weight:700;line-height:1}.admin-stat-label{color:#94a3b8;font-size:.875rem}.admin-dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;display:grid}.admin-highlight-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:20px;display:grid}.admin-highlight{background:#02061780;border:1px solid #94a3b826;border-radius:12px;flex-direction:column;gap:6px;padding:16px;display:flex}.admin-highlight-label{color:#94a3b8cc;font-size:.85rem}.admin-highlight-value{color:#f8fafc;font-size:1.3rem;font-weight:700}.admin-progress{gap:10px;display:grid}.admin-progress-label{color:#94a3b8cc;font-size:.85rem}.admin-progress-value{color:#f8fafc;margin-left:8px;font-size:1.1rem;font-weight:600}.admin-progress-track{background:#94a3b833;border-radius:999px;height:8px;overflow:hidden}.admin-progress-fill{background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:999px;height:100%;display:block}.admin-recap-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.admin-recap-card{background:#02061780;border:1px solid #94a3b826;border-radius:14px;gap:10px;padding:16px;display:grid}.admin-recap-label{color:#f8fafc;font-weight:600}.admin-recap-metric{color:#e2e8f0cc;justify-content:space-between;align-items:center;font-size:.9rem;display:flex}.admin-recap-metric strong{color:#f8fafc}.admin-chart{gap:12px;margin-top:20px;display:grid}.admin-chart-header{color:#e2e8f0cc;justify-content:space-between;align-items:center;font-size:.9rem;display:flex}.admin-chart-labels{color:#94a3b8cc;gap:10px;font-size:.75rem;display:flex}.admin-chart-bars{background:#02061766;border:1px solid #94a3b826;border-radius:12px;grid-template-columns:repeat(7,minmax(0,1fr));align-items:end;gap:10px;min-height:140px;padding:12px;display:grid}.admin-chart-bar{flex-direction:column;align-items:center;gap:6px;display:flex}.admin-chart-bar-fill{background:linear-gradient(#6366f1e6,#6366f166);border-radius:8px 8px 4px 4px;width:100%;min-height:6px}.admin-chart-bars.is-rooms .admin-chart-bar-fill{background:linear-gradient(#38bdf8e6,#38bdf866)}.admin-chart-bars.is-transactions .admin-chart-bar-fill{background:linear-gradient(#22c55ee6,#22c55e66)}.admin-chart-bars.is-revenue .admin-chart-bar-fill{background:linear-gradient(#eab308f2,#eab30866)}.admin-chart-bar-value{color:#e2e8f0b3;font-size:.75rem}.admin-config-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.admin-config-item{color:#e2e8f0cc;background:#02061780;border:1px solid #94a3b826;border-radius:12px;flex-direction:column;gap:6px;padding:16px;font-size:.9rem;display:flex}.admin-config-item strong{color:#f8fafc;font-weight:600}.admin-card{background:#0f141ecc;border:1px solid #ffffff14;border-radius:16px;padding:28px}.admin-card-title{color:#f8fafc;margin:0 0 8px;font-size:1.25rem;font-weight:600}.admin-card-subtitle{color:#94a3b8;margin:0 0 24px;font-size:.9rem}.admin-settings{flex-direction:column;gap:24px;display:flex}.admin-settings-list{flex-direction:column;gap:20px;display:flex}.admin-setting-item{flex-direction:column;gap:8px;display:flex}.admin-setting-label{color:#e2e8f0;font-size:.9rem;font-weight:500}.admin-setting-control{gap:12px;display:flex}.admin-input{color:#f8fafc;background:#02061780;border:1px solid #ffffff1a;border-radius:10px;outline:none;flex:1;padding:12px 16px;font-size:.95rem;transition:all .2s}.admin-input:focus{border-color:#6366f180;box-shadow:0 0 0 3px #6366f11a}.admin-textarea{resize:vertical;min-height:100px}.admin-info-list{flex-direction:column;gap:16px;display:flex}.admin-info-item{color:#94a3b8;font-size:.9rem;line-height:1.6}.admin-info-item strong{color:#e2e8f0}.admin-btn{color:#f8fafc;cursor:pointer;white-space:nowrap;background:#ffffff14;border:1px solid #ffffff1a;border-radius:10px;padding:10px 20px;font-size:.9rem;font-weight:500;transition:all .2s}.admin-btn:hover{background:#ffffff1f}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-btn-primary{background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border:none}.admin-btn-primary:hover{background:linear-gradient(135deg,#818cf8 0%,#a78bfa 100%)}.admin-btn-success{color:#4ade80;background:#22c55e33;border-color:#22c55e4d}.admin-btn-success:hover{background:#22c55e4d}.admin-btn-danger{color:#f87171;background:#ef444426;border-color:#ef44444d}.admin-btn-danger:hover{background:#ef444440}.admin-btn-sm{padding:6px 12px;font-size:.8rem}.admin-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.admin-filter-tabs{gap:8px;display:flex}.admin-filter-tab{color:#94a3b8;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff14;border-radius:8px;padding:8px 16px;font-size:.85rem;transition:all .2s}.admin-filter-tab:hover{color:#f8fafc;background:#ffffff14}.admin-filter-tab.active{color:#a5b4fc;background:#6366f126;border-color:#6366f14d}.admin-table-container{background:#0f141ecc;border:1px solid #ffffff14;border-radius:16px;overflow:auto hidden}.admin-table{border-collapse:collapse;width:100%}.admin-table th,.admin-table td{text-align:left;padding:16px 20px}.admin-table th{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;background:#02061766;border-bottom:1px solid #ffffff0f;font-size:.8rem;font-weight:600}.admin-table td{color:#e2e8f0;border-bottom:1px solid #ffffff0a;font-size:.9rem}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#ffffff05}.admin-table tr.expired-row td{opacity:.6}.admin-table-empty{text-align:center;color:#64748b;padding:48px 20px!important}.admin-cell-primary{color:#f8fafc;font-weight:500}.admin-cell-secondary{color:#64748b;margin-top:2px;font-size:.8rem}.admin-cell-mono{font-family:SF Mono,Monaco,monospace;font-size:.85rem}.admin-actions{gap:8px;display:flex}.admin-badge{text-transform:uppercase;letter-spacing:.03em;border-radius:6px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-block}.admin-badge.success{color:#4ade80;background:#22c55e26}.admin-badge.danger{color:#f87171;background:#ef444426}.admin-badge.warning{color:#fbbf24;background:#fbbf2426}.admin-badge.info{color:#60a5fa;background:#3b82f626}.admin-badge.muted{color:#94a3b8;background:#64748b26}.admin-credits-badge{color:#a5b4fc;background:#6366f126;border-radius:6px;padding:4px 10px;font-size:.85rem;font-weight:600;display:inline-block}.admin-room-code{color:#e2e8f0;background:#02061766;border-radius:6px;padding:4px 8px;font-family:SF Mono,Monaco,monospace;font-size:.85rem}.admin-time-remaining{color:#4ade80;font-size:.85rem}.admin-time-remaining.expired{color:#f87171}.admin-modal-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.admin-modal{background:#0f141efa;border:1px solid #ffffff1a;border-radius:20px;width:100%;max-width:500px;box-shadow:0 40px 100px #00000080}.admin-modal-header{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:24px 28px;display:flex}.admin-modal-header h3{color:#f8fafc;margin:0;font-size:1.25rem;font-weight:600}.admin-modal-close{color:#64748b;cursor:pointer;background:0 0;border:none;font-size:1.5rem;transition:color .2s}.admin-modal-close:hover{color:#f8fafc}.admin-modal-body{flex-direction:column;gap:20px;padding:28px;display:flex}.admin-form-group{flex-direction:column;gap:8px;display:flex}.admin-form-group label{color:#94a3b8;font-size:.85rem;font-weight:500}.admin-form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.admin-checkbox-label{cursor:pointer;color:#e2e8f0;align-items:center;gap:10px;font-size:.9rem;display:flex}.admin-checkbox-label input{accent-color:#6366f1;width:18px;height:18px}.admin-modal-footer{justify-content:flex-end;gap:12px;padding-top:8px;display:flex}.admin-award-user{background:#02061780;border-radius:12px;justify-content:space-between;align-items:center;padding:16px;display:flex}.admin-award-user-info{flex-direction:column;gap:4px;display:flex}.admin-award-user-info strong{color:#f8fafc}.admin-award-user-info span{color:#64748b;font-size:.85rem}.admin-award-current{color:#94a3b8;font-size:.9rem}.admin-award-current strong{color:#a5b4fc}.admin-error{color:#f87171;background:#ef444426;border:1px solid #ef44444d;border-radius:12px;margin-bottom:20px;padding:16px 20px;font-size:.9rem}@media (max-width:1024px){.admin-sidebar{transform:translate(-100%)}.admin-sidebar.open{transform:translate(0)}.admin-sidebar-close{display:block}.admin-main{margin-left:0}.admin-menu-btn{display:block}}@media (max-width:768px){.admin-content{padding:20px}.admin-header{padding:16px 20px}.admin-header-title{font-size:1.25rem}.admin-stats-grid,.admin-form-row{grid-template-columns:1fr}.admin-table{min-width:600px}}.packages-page{color:#f8fafc;background:linear-gradient(135deg,#0b0d12 0%,#1e293b 50%,#0b0d12 100%);min-height:100vh;padding-bottom:60px}.packages-header{background:#0f172ab3;border-bottom:1px solid #94a3b833;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px;display:flex}.packages-brand{align-items:center;gap:12px;display:flex}.packages-back{color:#e2e8f0cc;font-size:1.2rem;text-decoration:none;transition:color .2s}.packages-back:hover{color:#f8fafc}.packages-logo{background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem}.packages-title{color:#f8fafc;letter-spacing:-.01em;font-size:1.25rem;font-weight:700}.packages-currency{color:#e2e8f0cc;align-items:center;gap:8px;font-size:.9rem;display:flex}.packages-currency-label{color:#e2e8f099}.packages-currency-value{color:#a5b4fc;background:#6366f126;border:1px solid #6366f14d;border-radius:6px;padding:4px 10px;font-weight:600}.packages-hero{text-align:center;background:radial-gradient(at top,#6366f126,#0000 70%);padding:60px 20px 40px}.packages-hero h1{letter-spacing:-.02em;margin:0 0 12px;font-size:clamp(2rem,5vw,3rem);font-weight:800}.packages-hero p{color:#e2e8f0b3;max-width:500px;margin:0 auto 20px;font-size:1.1rem}.packages-currency-info{color:#e2e8f0d9;background:#6366f126;border:1px solid #6366f14d;border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;display:inline-flex}.packages-section{max-width:1200px;margin:0 auto 48px;padding:0 24px}.packages-section h2{letter-spacing:-.01em;margin:0 0 8px;font-size:1.6rem;font-weight:700}.packages-section-desc{color:#e2e8f099;margin:0 0 24px;font-size:.95rem}.package-card.free-plan{background:linear-gradient(145deg,#10b98114,#0f172ad9);border-color:#10b98166}.package-card.free-plan .package-badge.free{background:linear-gradient(135deg,#10b981,#059669)}.package-card.free-plan .package-credits{color:#10b981}.packages-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;display:grid}.package-card{background:#0f172ad9;border:1px solid #94a3b833;border-radius:16px;flex-direction:column;padding:28px;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;position:relative;overflow:hidden}.package-card:hover{border-color:#6366f166;transform:translateY(-4px);box-shadow:0 16px 48px #0006}.package-card.featured{background:linear-gradient(145deg,#0f172af2,#1e293bd9);border-color:#6366f180}.package-badge{color:#fff;text-transform:uppercase;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;padding:4px 10px;font-size:.75rem;font-weight:600;position:absolute;top:12px;right:12px}.package-badge.best-value{background:linear-gradient(135deg,#10b981,#059669)}.package-header{margin-bottom:20px}.package-header h3{margin:0 0 8px;font-size:1.4rem;font-weight:700}.package-credits{color:#6366f1;font-size:2.2rem;font-weight:800}.package-credits span{color:#e2e8f0b3;margin-left:4px;font-size:1rem;font-weight:400}.package-price{border-top:1px solid #94a3b826;border-bottom:1px solid #94a3b826;margin:20px 0;padding:16px 0}.price-main{color:#f8fafc;font-size:1.8rem;font-weight:700}.price-secondary{color:#e2e8f099;margin-top:4px;font-size:.85rem;display:block}.price-per-credit{color:#10b981;margin-top:8px;font-size:.85rem;display:block}.package-features{flex:1;margin:0 0 20px;padding:0;list-style:none}.package-features li{color:#e2e8f0cc;align-items:center;gap:8px;margin-bottom:10px;font-size:.9rem;display:flex}.package-features li:before{content:"✓";color:#10b981;font-weight:600}.package-buy-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:10px;width:100%;padding:14px;font-size:1rem;font-weight:600;transition:all .2s}.package-buy-btn:hover{filter:brightness(1.1);transform:scale(1.02)}.package-card.active-plan{background:linear-gradient(145deg,#10b9811a,#0f172ae6);border:2px solid #10b98199;box-shadow:0 0 24px #10b98126}.package-card.active-plan:hover{border-color:#10b981cc;transform:translateY(-2px);box-shadow:0 0 32px #10b98140}.package-badge.active{background:linear-gradient(135deg,#10b981,#059669)}.package-buy-btn.current{color:#10b981;cursor:default;opacity:.85;background:#10b98126;border:1px solid #10b9814d}.package-buy-btn.current:hover{filter:none;transform:none}.package-buy-btn.downgrade{color:#f87171d9;background:0 0;border:1px solid #f871714d}.package-buy-btn.downgrade:hover{color:#f87171;filter:none;background:#f871711a;border-color:#f8717180;transform:none}.package-buy-btn.downgrade:disabled{opacity:.5;cursor:not-allowed}.packages-faq{max-width:800px;margin:60px auto 0;padding:0 20px}.packages-faq h2{text-align:center;margin-bottom:30px;font-size:1.8rem}.faq-item{background:#0f172a99;border:1px solid #94a3b826;border-radius:12px;margin-bottom:16px;padding:20px}.faq-item h3{color:#f8fafc;margin:0 0 10px;font-size:1rem}.faq-item p{color:#e2e8f0b3;margin:0;font-size:.9rem;line-height:1.6}.packages-loading,.packages-error{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:60vh;display:flex}.checkout-page{color:#f8fafc;background:linear-gradient(135deg,#0b0d12 0%,#1e293b 50%,#0b0d12 100%);min-height:100vh}.checkout-header{background:#0f172ab3;border-bottom:1px solid #94a3b833;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px;display:flex}.checkout-back{color:#e2e8f0cc;align-items:center;gap:8px;font-size:.95rem;text-decoration:none;transition:color .2s;display:flex}.checkout-back:hover{color:#f8fafc}.checkout-steps{gap:24px;font-size:.9rem;display:flex}.checkout-step{color:#e2e8f080;position:relative}.checkout-step.active{color:#6366f1;font-weight:600}.checkout-step.completed{color:#10b981}.checkout-main{max-width:900px;margin:0 auto;padding:40px 20px}.checkout-content{gap:30px;display:grid}.checkout-summary{background:#0f172ad9;border:1px solid #94a3b833;border-radius:16px;padding:24px}.checkout-summary h2{margin:0 0 20px;font-size:1.2rem;font-weight:600}.checkout-package-card{background:#02061780;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px;display:flex}.checkout-package-info h3{margin:0 0 4px;font-size:1.1rem}.checkout-package-info p{color:#e2e8f0b3;margin:0;font-size:.9rem}.checkout-package-price .price-main{font-size:1.4rem}.checkout-package-price .price-usd{color:#e2e8f099;font-size:.8rem;display:block}.checkout-total{border-top:1px solid #94a3b826;justify-content:space-between;align-items:center;padding-top:16px;font-weight:600;display:flex}.checkout-total-amount{color:#6366f1;font-size:1.3rem}.checkout-section{background:#0f172ad9;border:1px solid #94a3b833;border-radius:16px;padding:24px}.checkout-section h2{margin:0 0 20px;font-size:1.2rem;font-weight:600}.checkout-user-info{background:#02061780;border-radius:12px;margin-bottom:20px;padding:16px}.checkout-user-info p{margin:0 0 8px;font-size:.95rem}.checkout-user-info p:last-child{margin-bottom:0}.checkout-continue-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:10px;width:100%;padding:14px;font-size:1rem;font-weight:600;transition:all .2s}.checkout-continue-btn:hover{filter:brightness(1.1)}.checkout-error{color:#fca5a5;background:#ef444426;border:1px solid #ef44444d;border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:.9rem}.checkout-payment-methods{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:24px;display:grid}.payment-method-option{cursor:pointer;background:#02061780;border:2px solid #94a3b833;border-radius:12px;align-items:center;gap:10px;padding:16px;transition:all .2s;display:flex}.payment-method-option input{display:none}.payment-method-option.selected{background:#6366f11a;border-color:#6366f1}.payment-method-icon{font-size:1.5rem}.checkout-card-form,.checkout-bank-form{flex-direction:column;gap:16px;display:flex}.checkout-payment-form .form-group{flex-direction:column;gap:6px;display:flex}.checkout-payment-form .form-group label{color:#e2e8f0cc;font-size:.85rem}.checkout-payment-form .form-group input,.checkout-payment-form .form-group select{color:#f8fafc;background:#020617b3;border:1px solid #94a3b833;border-radius:8px;padding:12px 14px;font-size:1rem}.checkout-payment-form .form-group input:focus,.checkout-payment-form .form-group select:focus{border-color:#6366f1;outline:none}.checkout-payment-form .form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.checkout-bank-info{background:#6366f11a;border:1px solid #6366f133;border-radius:8px;padding:12px}.checkout-bank-info p{color:#e2e8f0cc;margin:0;font-size:.9rem}.checkout-terms{margin:20px 0}.checkout-terms label{color:#e2e8f0cc;cursor:pointer;align-items:flex-start;gap:10px;font-size:.9rem;display:flex}.checkout-terms a{color:#6366f1}.checkout-pay-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:10px;width:100%;padding:16px;font-size:1.1rem;font-weight:700;transition:all .2s}.checkout-pay-btn:hover:not(:disabled){filter:brightness(1.1);transform:scale(1.01)}.checkout-pay-btn:disabled{opacity:.6;cursor:not-allowed}.checkout-processing{text-align:center;padding:60px 20px}.processing-spinner{margin-bottom:20px}.checkout-loading,.checkout-error-page{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:60vh;display:flex}.checkout-back-btn{color:#fff;background:#6366f1;border-radius:8px;padding:12px 24px;font-weight:500;text-decoration:none;display:inline-block}.payment-status-page{color:#f8fafc;background:linear-gradient(135deg,#0b0d12 0%,#1e293b 50%,#0b0d12 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.payment-status-content{text-align:center;background:#0f172ad9;border:1px solid #94a3b833;border-radius:20px;width:100%;max-width:500px;padding:40px}.payment-status-icon{margin-bottom:24px;font-size:4rem}.payment-status-icon.status-success{animation:.5s ease-in-out bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.payment-status-content h1{margin:0 0 12px;font-size:1.8rem;font-weight:700}.payment-status-message{color:#e2e8f0b3;margin:0 0 30px;font-size:1rem}.payment-status-details{text-align:left;background:#02061780;border-radius:12px;margin-bottom:24px;padding:20px}.payment-status-details h2{color:#e2e8f0cc;margin:0 0 16px;font-size:1rem}.payment-detail-row{border-bottom:1px solid #94a3b81a;justify-content:space-between;padding:8px 0;font-size:.9rem;display:flex}.payment-detail-row:last-child{border-bottom:none}.payment-detail-row span:first-child{color:#e2e8f099}.payment-detail-value{color:#f8fafc;word-break:break-all;font-weight:500}.payment-status-pending-info{color:#fbbf24;justify-content:center;align-items:center;gap:8px;margin-bottom:24px;display:flex}.payment-status-success-info{color:#6ee7b7;background:#10b98126;border:1px solid #10b9814d;border-radius:8px;margin-bottom:24px;padding:12px}.payment-status-failed-info{color:#e2e8f0b3;margin-bottom:24px;font-size:.9rem}.payment-status-failed-info a{color:#6366f1}.payment-status-actions{flex-direction:column;gap:12px;display:flex}.payment-status-actions .btn-primary{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:10px;padding:14px 24px;font-weight:600;text-decoration:none;transition:all .2s}.payment-status-actions .btn-primary:hover{filter:brightness(1.1)}.payment-status-actions .btn-secondary{color:#e2e8f0cc;background:0 0;border:1px solid #94a3b84d;border-radius:10px;padding:14px 24px;text-decoration:none;transition:all .2s}.payment-status-actions .btn-secondary:hover{background:#94a3b81a}.payment-status-loading{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:60vh;display:flex}.payment-history-page{color:#f8fafc;background:linear-gradient(135deg,#0b0d12 0%,#1e293b 50%,#0b0d12 100%);min-height:100vh}.payment-history-header{background:#0f172ab3;border-bottom:1px solid #94a3b833;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px;display:flex}.payment-history-title{align-items:center;gap:16px;display:flex}.payment-history-title h1{margin:0;font-size:1.4rem}.back-link{color:#e2e8f0cc;font-size:.9rem;text-decoration:none}.back-link:hover{color:#f8fafc}.btn-buy-credits{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;padding:10px 20px;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .2s}.btn-buy-credits:hover{filter:brightness(1.1)}.payment-history-main{max-width:900px;margin:0 auto;padding:30px 20px}.payment-summary-cards{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:30px;display:grid}.summary-card{background:#0f172ad9;border:1px solid #94a3b833;border-radius:12px;align-items:center;gap:14px;padding:18px;display:flex}.summary-icon{font-size:1.8rem}.summary-info{flex-direction:column;display:flex}.summary-value{font-size:1.5rem;font-weight:700}.summary-label{color:#e2e8f099;font-size:.8rem}.payment-history-filters{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.filter-btn{color:#e2e8f0b3;cursor:pointer;background:0 0;border:1px solid #94a3b833;border-radius:20px;padding:8px 16px;font-size:.85rem;transition:all .2s}.filter-btn:hover{background:#94a3b81a}.filter-btn.active{color:#fff;background:#6366f1;border-color:#6366f1}.transactions-list{flex-direction:column;gap:12px;display:flex}.transaction-item{background:#0f172ad9;border:1px solid #94a3b833;border-radius:12px;justify-content:space-between;align-items:center;padding:16px 20px;transition:border-color .2s;display:flex}.transaction-item:hover{border-color:#6366f14d}.transaction-left{align-items:center;gap:14px;display:flex}.transaction-icon{font-size:1.5rem}.transaction-info h3{margin:0 0 4px;font-size:1rem;font-weight:600}.transaction-id{color:#e2e8f080;margin:0;font-family:monospace;font-size:.75rem}.transaction-date{color:#e2e8f099;margin:2px 0 0;font-size:.8rem}.transaction-right{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.transaction-amount .amount-main{font-size:1.1rem;font-weight:600}.credits-earned{color:#10b981;font-size:.8rem;display:block}.status-badge{text-transform:uppercase;border-radius:12px;padding:4px 10px;font-size:.75rem;font-weight:600}.badge-success{color:#6ee7b7;background:#10b98133}.badge-pending{color:#fbbf24;background:#fbbf2433}.badge-failed{color:#fca5a5;background:#ef444433}.badge-refunded{color:#a5b4fc;background:#6366f133}.payment-history-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-icon{margin-bottom:20px;font-size:4rem}.payment-history-empty h2{margin:0 0 10px;font-size:1.4rem}.payment-history-empty p{color:#e2e8f0b3;margin:0 0 24px}.btn-primary{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;padding:12px 24px;font-weight:600;text-decoration:none;display:inline-block}.btn-retry{color:#6366f1;cursor:pointer;background:0 0;border:1px solid #6366f1;border-radius:8px;padding:10px 20px}.load-more-container{text-align:center;margin-top:24px}.btn-load-more{color:#e2e8f0cc;cursor:pointer;background:0 0;border:1px solid #94a3b84d;border-radius:8px;padding:12px 32px;transition:all .2s}.btn-load-more:hover{background:#94a3b81a}.btn-load-more:disabled{opacity:.6;cursor:not-allowed}.payment-history-loading,.payment-history-error{flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 20px;display:flex}@media (max-width:600px){.checkout-payment-form .form-row{grid-template-columns:1fr}.transaction-item{flex-direction:column;align-items:flex-start;gap:16px}.transaction-right{flex-direction:row;justify-content:space-between;align-items:flex-start;width:100%}}.tv-page{background:linear-gradient(135deg,#0f172a 0%,#1e1b4b 50%,#0f172a 100%);justify-content:center;align-items:flex-start;min-height:150vh;padding:clamp(0px,0vh,0px) clamp(4px,0vw,14px);display:flex;overflow-y:auto}.tv-content{text-align:center;width:100%;max-width:1000px;padding-top:clamp(0px,0vh,2px);padding-bottom:clamp(0px,0vh,0px)}.tv-logo h1{background:linear-gradient(135deg,#6366f1,#a855f7,#6366f1);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(2.5rem,5vw,4rem)}.tv-subtitle{color:#e2e8f0b3;margin-top:8px;font-size:1.2rem}.tv-connect-section{background:#0f172acc;border:1px solid #94a3b833;border-radius:24px;margin-top:48px;padding:clamp(24px,4vw,44px) clamp(24px,5vw,52px)}.tv-card-header{justify-content:space-between;align-items:center;gap:24px;margin-bottom:clamp(18px,3vh,32px);display:flex}.tv-card-logo{align-items:center;gap:14px;display:flex}.tv-card-logo-icon{color:#a855f7;font-size:2rem;line-height:1}.tv-card-logo-text{flex-direction:column;align-items:flex-start;display:flex}.tv-card-logo-title{color:#a5b4fc;letter-spacing:-.01em;font-size:clamp(1.1rem,2.4vw,1.45rem);font-weight:700}.tv-card-logo-title.brand-logo-text{font-size:1.45rem}.tv-card-logo-subtitle{color:#e2e8f0b3;font-size:.95rem}.tv-connect-section h2{color:#f8fafc;letter-spacing:-.02em;text-align:right;max-width:min(520px,60vw);margin:0;font-size:clamp(1.2rem,2.4vw,1.8rem);font-weight:600}.tv-connect-methods{text-align:left;grid-template-columns:auto 1fr;align-items:start;gap:clamp(20px,4vw,44px);display:grid}.tv-qr-section{flex-direction:column;align-items:center;gap:16px;display:flex}.tv-qr-wrapper{background:#fff;border-radius:16px;padding:clamp(10px,2vw,16px);box-shadow:0 8px 32px #0000004d}.tv-steps{flex-direction:column;gap:clamp(14px,2.5vh,24px);display:flex}.tv-step{grid-template-columns:auto 1fr;align-items:start;gap:clamp(10px,2vw,18px);display:grid}.tv-step-number{color:#e2e8f080;letter-spacing:.1em;min-width:80px;padding-top:4px;font-size:clamp(.85rem,1.6vw,1rem);font-weight:700}.tv-step-content h3{color:#f8fafc;letter-spacing:-.01em;margin:0 0 clamp(4px,1vh,8px);font-size:clamp(1.05rem,2.2vw,1.4rem);font-weight:600}.tv-step-url{color:#a5b4fc;margin:0;font-family:SF Mono,Monaco,monospace;font-size:clamp(.95rem,1.8vw,1.1rem)}.tv-short-code{gap:8px;display:flex}.tv-code-char{color:#a5b4fc;background:#6366f126;border:2px solid #6366f166;border-radius:12px;justify-content:center;align-items:center;width:clamp(42px,6vw,56px);height:clamp(52px,7vw,68px);font-family:SF Mono,Monaco,monospace;font-size:clamp(1.2rem,2.4vw,1.8rem);font-weight:700;display:flex}.tv-divider{color:#94a3b880;text-transform:uppercase;align-items:center;font-size:.9rem;display:flex}.tv-code-section{flex-direction:column;align-items:center;gap:16px;display:flex}.tv-code-label{color:#e2e8f0b3;margin:0;font-size:.9rem}.tv-qr-label{color:#e2e8f099;margin:0;font-size:.9rem}.tv-code-hint{color:#94a3b899;margin:0;font-size:.85rem}.tv-status-row{grid-template-columns:1fr;align-items:start;gap:clamp(20px,4vw,44px);display:grid}.tv-status-spacer{width:100%}.tv-status-box{background:#0f172a8c;border:1px solid #94a3b82e;border-radius:16px;justify-content:space-between;align-items:center;gap:16px;padding:clamp(0px,1.8vh,14px) clamp(0px,2.2vw,18px);display:flex}.tv-countdown{color:#e2e8f0cc;justify-content:flex-start;align-items:center;gap:8px;font-size:clamp(.8rem,1.4vw,.95rem);display:flex}.tv-countdown-icon{animation:2s linear infinite spin}.tv-status-wait{color:#e2e8f0b3;align-items:center;gap:10px;font-size:clamp(.8rem,1.4vw,.95rem);display:inline-flex}.tv-pulse{background:#22c55e;border-radius:50%;width:12px;height:12px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.tv-loading,.tv-error{color:#e2e8f0cc;flex-direction:column;align-items:center;gap:16px;display:flex}.tv-retry-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;padding:12px 24px;font-weight:600}.tv-connect-page{background:linear-gradient(135deg,#0f172a 0%,#1e1b4b 50%,#0f172a 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.tv-connect-content{width:100%;max-width:480px}.tv-connect-header{text-align:center;margin-bottom:32px}.tv-connect-header h1{margin:0 0 8px;font-size:1.8rem}.tv-connect-header p{color:#e2e8f0b3;margin:0}.tv-connect-error{color:#fca5a5;text-align:center;background:#ef444426;border:1px solid #ef44444d;border-radius:8px;margin-bottom:16px;padding:12px 16px}.tv-connect-rooms{flex-direction:column;gap:12px;display:flex}.tv-connect-room-btn{cursor:pointer;text-align:left;color:#f8fafc;background:#0f172acc;border:1px solid #94a3b833;border-radius:12px;justify-content:space-between;align-items:center;padding:16px 20px;transition:all .2s;display:flex}.tv-connect-room-btn:hover{background:#6366f126;border-color:#6366f166}.tv-connect-room-btn:disabled{opacity:.6;cursor:not-allowed}.tv-connect-room-info h3{margin:0 0 4px;font-size:1.1rem}.tv-connect-room-code{color:#94a3b8b3;font-family:SF Mono,Monaco,monospace;font-size:.85rem}.tv-connect-room-arrow{color:#94a3b880;font-size:1.2rem}.tv-connect-empty{text-align:center;background:#0f172a99;border-radius:12px;padding:40px 20px}.tv-connect-empty p{color:#e2e8f0b3;margin:0 0 20px}.tv-connect-btn-primary{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;padding:12px 24px;font-weight:600;text-decoration:none;display:inline-block}.tv-connect-footer{text-align:center;margin-top:32px}.tv-connect-back{color:#94a3b8b3;font-size:.9rem;text-decoration:none}.tv-connect-back:hover{color:#a5b4fc}.tv-connect-loading,.tv-connect-success{text-align:center;flex-direction:column;align-items:center;gap:16px;display:flex}.tv-connect-success-icon{font-size:3rem}.tv-connect-success h2{color:#86efac;margin:0}.room-master-tv-card{grid-column:1/-1}.room-master-tv-connect{flex-direction:column;gap:16px;display:flex}.room-master-tv-form{flex-wrap:wrap;gap:8px;display:flex}.room-master-tv-form button{flex-shrink:0;min-width:fit-content}.room-master-tv-input{color:#f8fafc;text-align:center;letter-spacing:.2em;text-transform:uppercase;background:#020617b3;border:1px solid #94a3b833;border-radius:8px;flex:1;padding:12px 16px;font-family:SF Mono,Monaco,monospace;font-size:1.2rem}.room-master-tv-input::placeholder{letter-spacing:normal;text-transform:none;font-size:.9rem}.room-master-tv-input:focus{border-color:#6366f1;outline:none}.room-master-tv-divider{color:#94a3b880;align-items:center;gap:16px;font-size:.85rem;display:flex}.room-master-tv-divider:before,.room-master-tv-divider:after{content:"";background:#94a3b833;flex:1;height:1px}.room-master-scan-btn{justify-content:center;align-items:center;gap:8px;display:flex}.room-master-scan-icon{font-size:1.1rem}.room-master-tv-success{color:#86efac;background:#22c55e26;border:1px solid #22c55e4d;border-radius:8px;align-items:center;gap:8px;padding:12px 16px;display:flex}.room-master-tv-error{color:#fca5a5;background:#ef444426;border:1px solid #ef44444d;border-radius:8px;align-items:center;gap:8px;padding:12px 16px;display:flex}.room-master-scanner{flex-direction:column;align-items:center;gap:16px;display:flex}.room-master-scanner-video{aspect-ratio:1;object-fit:cover;background:#000;border-radius:12px;width:100%;max-width:300px}.room-master-scanner-overlay{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.room-master-scanner-frame{border:2px solid #6366f1cc;border-radius:16px;width:200px;height:200px}.tv-page{height:auto;overflow:visible}.tv-content{max-height:none;display:block;overflow:visible}.tv-connect-section{max-height:none;overflow:visible}.tv-qr-wrapper canvas{width:min(280px,45vw);height:auto}.search-form{align-items:center;gap:12px;display:flex}.search-input{flex:1;min-width:0}.search-btn{flex:none;min-width:48px;padding:12px 16px}.stripe-payment-form{flex-direction:column;gap:16px;display:flex}.checkout-pay-btn{margin-top:12px}@media (max-width:768px){.dashboard-menu-btn{display:inline-flex}.dashboard-user-items{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:1000;background:#0f172afa;border:1px solid #94a3b840;border-radius:12px;flex-direction:column;align-items:stretch;gap:2px;min-width:200px;padding:8px;display:none;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 8px 24px #0006,0 2px 8px #0003}.dashboard-user-items.open{display:flex}.dashboard-admin-link{color:#e2e8f0;border-radius:8px;padding:10px 14px;text-decoration:none;transition:background .2s;display:block}.dashboard-admin-link:hover{background:#6366f126}.dashboard-username{color:#a5b4fc;border-bottom:1px solid #94a3b826;width:100%;margin-bottom:4px;padding:10px 14px;font-weight:500}.dashboard-logout,.dashboard-login{text-align:left;background:0 0;border-radius:8px;width:100%;padding:10px 14px;transition:background .2s}.dashboard-logout:hover,.dashboard-login:hover{background:#6366f126}.admin-user-menu-btn{display:inline-flex}.admin-header-user-items{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:1000;background:#0f172afa;border:1px solid #94a3b840;border-radius:12px;flex-direction:column;align-items:stretch;gap:2px;min-width:200px;padding:8px;display:none;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 8px 24px #0006,0 2px 8px #0003}.admin-header-user-items.open{display:flex}.admin-user-name{text-align:left;color:#a5b4fc;border-bottom:1px solid #94a3b826;width:100%;margin-bottom:4px;padding:10px 14px;font-weight:500}.admin-logout-btn{text-align:left;background:0 0;border-radius:8px;width:100%;padding:10px 14px;transition:background .2s}.admin-logout-btn:hover{background:#ef444433}}@media (max-width:600px){.tv-page{padding:16px}.tv-connect-section{padding:30px 20px}.tv-connect-section h2{text-align:center;max-width:none;margin:0;font-size:1.25rem}.tv-card-header{flex-direction:column;gap:12px;margin-bottom:28px}.tv-card-logo-text{align-items:center}.tv-connect-methods{text-align:center;grid-template-columns:1fr;gap:40px}.tv-qr-wrapper{padding:12px}.tv-qr-wrapper canvas{width:220px!important;height:220px!important}.tv-steps{gap:28px}.tv-step{text-align:center;grid-template-columns:1fr;gap:8px}.tv-step-number{min-width:auto;font-size:.85rem}.tv-step-content h3{font-size:1.15rem}.tv-step-url{word-break:break-all;font-size:.95rem}.tv-short-code{justify-content:center}.tv-status-row{grid-template-columns:1fr;gap:16px;margin-top:22px}.tv-status-spacer{display:none}.tv-status-box{text-align:center;flex-direction:column;align-items:center;gap:8px}.tv-divider{width:100%}.tv-divider:before,.tv-divider:after{content:"";background:#94a3b833;flex:1;height:1px}.tv-code-char{width:48px;height:56px;font-size:1.5rem}.search-form{gap:8px}.search-btn{min-width:44px;padding:10px 12px}}.legal-page{color:#f8fafc;background:#0b0d12;flex-direction:column;min-height:100vh;display:flex}.legal-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;background:#0f172ad9;border-bottom:1px solid #94a3b826;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.legal-brand{align-items:center;gap:12px;display:flex}.legal-back{color:#94a3b8;border-radius:8px;padding:4px 8px;font-size:1.4rem;line-height:1;text-decoration:none;transition:background .2s,color .2s}.legal-back:hover{color:#f8fafc;background:#94a3b826}.legal-logo{font-size:1.5rem}.legal-title{background:linear-gradient(135deg,#6366f1,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.2rem;font-weight:700}.legal-main{width:100%;max-width:800px;margin:0 auto;padding:40px 24px 80px}.legal-main h1{background:linear-gradient(135deg,#f8fafc,#cbd5e1);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 8px;font-size:clamp(1.8rem,4vw,2.4rem);font-weight:800}.legal-updated{color:#64748b;margin:0 0 32px;font-size:.9rem}.legal-section{margin-bottom:32px}.legal-section h2{color:#e2e8f0;margin:0 0 12px;font-size:1.2rem;font-weight:700}.legal-section p{color:#94a3b8;margin:0 0 12px;line-height:1.7}.legal-section ul{color:#94a3b8;margin:0 0 12px;padding-left:24px;line-height:1.7}.legal-section ul li{margin-bottom:8px}.legal-section a{color:#818cf8;text-decoration:none}.legal-section a:hover{text-decoration:underline}.legal-contact{border-top:1px solid #94a3b826;margin-top:48px;padding-top:32px}.legal-contact h2{color:#e2e8f0;margin:0 0 12px;font-size:1.2rem;font-weight:700}.legal-contact p{color:#94a3b8;margin:0 0 8px;line-height:1.7}.legal-contact a{color:#818cf8;text-decoration:none}.legal-contact a:hover{text-decoration:underline}.legal-address{font-size:.9rem;color:#64748b!important;margin-top:8px!important}.faq-list{flex-direction:column;gap:12px;margin-top:24px;display:flex}.faq-item{background:#0f172a99;border:1px solid #94a3b81f;border-radius:12px;transition:border-color .2s;overflow:hidden}.faq-item[open]{border-color:#6366f159}.faq-question{color:#e2e8f0;cursor:pointer;align-items:center;gap:12px;padding:16px 20px;font-weight:600;list-style:none;transition:background .2s;display:flex}.faq-question::-webkit-details-marker{display:none}.faq-question:before{content:"▸";color:#6366f1;flex-shrink:0;font-size:.9rem;transition:transform .2s}.faq-item[open] .faq-question:before{transform:rotate(90deg)}.faq-question:hover{background:#94a3b80f}.faq-answer{color:#94a3b8;margin:0;padding:0 20px 16px;line-height:1.7}.site-footer{background:#0f172ad9;border-top:1px solid #94a3b81f;margin-top:auto;padding:40px 24px}.site-footer-content{text-align:center;flex-direction:column;align-items:center;gap:20px;max-width:960px;margin:0 auto;display:flex}.site-footer-brand{align-items:center;gap:8px;display:flex}.site-footer-logo{font-size:1.4rem}.site-footer-name{background:linear-gradient(135deg,#6366f1,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.1rem;font-weight:700}.site-footer-links{flex-wrap:wrap;justify-content:center;gap:24px;display:flex}.site-footer-links a{color:#94a3b8;font-size:.9rem;text-decoration:none;transition:color .2s}.site-footer-links a:hover{color:#818cf8}.site-footer-contact p{color:#64748b;margin:0 0 4px;font-size:.85rem;line-height:1.5}.site-footer-contact a{color:#818cf8;text-decoration:none}.site-footer-contact a:hover{text-decoration:underline}.site-footer-copy p{color:#475569;margin:0;font-size:.8rem}@media (max-width:600px){.legal-main{padding:24px 16px 60px}.legal-main h1{font-size:1.5rem}.faq-question{padding:14px 16px;font-size:.95rem}.faq-answer{padding:0 16px 14px;font-size:.9rem}.site-footer-links{gap:16px}}.credits-hero{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:32px 0 40px;display:flex}.credits-icon{margin-bottom:4px;font-size:3rem;line-height:1;display:block}.credits-hero h1{text-align:center;margin:0}.credits-tagline{color:#94a3b8;margin:0;font-size:1.05rem}.credits-version{color:#a78bfa;letter-spacing:.03em;background:#a78bfa1a;border:1px solid #a78bfa33;border-radius:20px;margin-top:4px;padding:4px 14px;font-size:.8rem;font-weight:600;display:inline-block}.credits-section{margin-bottom:36px}.credits-section h2{text-transform:uppercase;letter-spacing:.08em;color:#64748b;margin:0 0 16px;font-size:.85rem;font-weight:700}.credits-card{background:#0f172a99;border:1px solid #94a3b81f;border-radius:14px;align-items:center;gap:16px;padding:20px;display:flex}.credits-avatar{color:#fff;background:linear-gradient(135deg,#6366f1,#a78bfa);border-radius:50%;flex-shrink:0;place-items:center;width:52px;height:52px;font-size:1.3rem;font-weight:700;display:grid}.credits-info{flex-direction:column;gap:2px;display:flex}.credits-name{color:#f8fafc;margin:0;font-size:1.1rem;font-weight:700}.credits-email{color:#818cf8;font-size:.9rem;text-decoration:none}.credits-email:hover{text-decoration:underline}.credits-tech-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;display:grid}.credits-tech{color:#cbd5e1;background:#0f172a99;border:1px solid #94a3b81a;border-radius:10px;align-items:center;gap:10px;padding:12px 16px;font-size:.9rem;display:flex}.credits-tech-icon{flex-shrink:0;font-size:1.1rem}.credits-contact-list p{color:#94a3b8;margin:0 0 8px;line-height:1.6}.credits-contact-list a{color:#818cf8;text-decoration:none}.credits-contact-list a:hover{text-decoration:underline}.credits-footer{text-align:center;border-top:1px solid #94a3b81f;margin-top:48px;padding-top:24px}.credits-footer p{color:#475569;margin:0 0 12px;font-size:.85rem}.credits-links{justify-content:center;gap:20px;display:flex}.credits-links a{color:#64748b;font-size:.85rem;text-decoration:none;transition:color .2s}.credits-links a:hover{color:#818cf8}@media (max-width:600px){.credits-tech-grid{grid-template-columns:repeat(2,1fr)}}
