@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap");:root{--color-bg:#fef7ff;--color-bg-elevated:#ffffff;--color-bg-surface:#f8f9ff;--color-bg-interactive:#e0e7ff;--color-text-primary:#1e1b4b;--color-text-secondary:#475569;--color-text-tertiary:#64748b;--color-text-inverse:#ffffff;--color-accent-primary:#8b5cf6;--color-accent-primary-hover:#7c3aed;--color-accent-secondary:#06b6d4;--color-accent-secondary-hover:#0891b2;--color-accent-success:#10b981;--color-accent-success-hover:#059669;--color-accent-warning:#f59e0b;--color-accent-warning-hover:#d97706;--color-accent-error:#ef4444;--color-accent-pink:#ec4899;--color-accent-orange:#f97316;--color-card-black:#1e1b4b;--color-card-white:#ffffff;--color-stage-bg:linear-gradient(135deg,#a78bfa,#06b6d4);--color-judge:#f59e0b;--color-submitted:#10b981;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--font-size-xs:12px;--font-size-sm:14px;--font-size-base:16px;--font-size-lg:18px;--font-size-xl:20px;--font-size-2xl:24px;--font-size-3xl:32px;--font-size-4xl:40px;--line-height-tight:1.2;--line-height-normal:1.5;--line-height-relaxed:1.75;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--radius-sm:6px;--radius-base:10px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px rgba(139,92,246,0.1);--shadow-base:0 4px 6px rgba(139,92,246,0.1);--shadow-md:0 10px 15px rgba(139,92,246,0.15);--shadow-lg:0 20px 25px rgba(139,92,246,0.2);--shadow-xl:0 25px 50px rgba(139,92,246,0.25);--card-shadow-black:0 20px 40px rgba(30,27,75,0.3);--card-shadow-white:0 8px 25px rgba(139,92,246,0.1);--card-shadow-white-hover:0 15px 35px rgba(139,92,246,0.2);--transition-fast:150ms ease;--transition-base:250ms ease;--transition-slow:350ms ease;--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-toast:1060}*{box-sizing:border-box}html{line-height:var(--line-height-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body,html{margin:0;padding:0;background:var(--color-bg);color:var(--color-text-primary);font-family:Space Grotesk,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;font-size:var(--font-size-base)}.wrapper{max-width:1200px;margin:0 auto;padding:var(--space-8) var(--space-4)}.layout{display:grid;grid-template-columns:1fr 300px;grid-gap:var(--space-6);gap:var(--space-6);align-items:start}.aside{position:-webkit-sticky;position:sticky;top:var(--space-6);height:-moz-fit-content;height:fit-content}@media (max-width:960px){.layout{grid-template-columns:1fr;gap:var(--space-6)}.aside{position:static;order:-1}.wrapper{padding:var(--space-6) var(--space-4)}}h1,h2,h3,h4,h5,h6{margin:0;line-height:var(--line-height-tight);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}h1{font-size:var(--font-size-4xl);background:linear-gradient(135deg,var(--color-accent-primary),var(--color-accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-4)}h2{font-size:var(--font-size-3xl);margin-bottom:var(--space-3)}h3{font-size:var(--font-size-2xl)}h3,h4{margin-bottom:var(--space-2)}h4{font-size:var(--font-size-xl)}p{margin:0;line-height:var(--line-height-normal);color:var(--color-text-secondary)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-tertiary{color:var(--color-text-tertiary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border:none;border-radius:var(--radius-lg);font-family:inherit;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);line-height:1;text-decoration:none;cursor:pointer;transition:all var(--transition-base);-webkit-tap-highlight-color:transparent;transform:translateY(0)}.btn:focus{outline:3px solid var(--color-accent-primary);outline-offset:2px}.btn:active{transform:translateY(2px)}.btn-primary{background:linear-gradient(135deg,var(--color-accent-primary),var(--color-accent-secondary));color:white;box-shadow:0 8px 20px rgba(139,92,246,.3)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 30px rgba(139,92,246,.4)}.btn-success{background:linear-gradient(135deg,var(--color-accent-success),#34d399);color:white;box-shadow:0 8px 20px rgba(16,185,129,.3)}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 30px rgba(16,185,129,.4)}.btn-warning{background:linear-gradient(135deg,var(--color-accent-warning),var(--color-accent-orange));color:white;box-shadow:0 8px 20px rgba(245,158,11,.3)}.btn-warning:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 30px rgba(245,158,11,.4)}.btn-secondary{background:var(--color-bg-elevated);color:var(--color-text-primary);border:2px solid var(--color-bg-interactive);box-shadow:var(--shadow-base)}.btn-secondary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--color-accent-primary)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn-loading{opacity:.8;pointer-events:none}.input{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-bg-elevated);border:2px solid var(--color-bg-interactive);border-radius:var(--radius-base);font-family:inherit;font-size:var(--font-size-base);color:var(--color-text-primary);transition:all var(--transition-base)}.input:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px rgba(139,92,246,.1)}.input::placeholder{color:var(--color-text-tertiary)}.form-group{margin-bottom:var(--space-4)}.form-group label{display:block;margin-bottom:var(--space-2);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-4);gap:var(--space-4)}@media (max-width:640px){.form-row{grid-template-columns:1fr;gap:var(--space-3)}}.card{border-radius:var(--radius-xl);padding:var(--space-6) var(--space-6);transition:all var(--transition-base)}.card-black{background:linear-gradient(135deg,var(--color-card-black) 0,#312e81 100%);color:var(--color-card-white);border:2px solid #4338ca;box-shadow:var(--card-shadow-black);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);position:relative}.card-black:before{content:"";position:absolute;inset:0;border-radius:var(--radius-xl);background:linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.05));pointer-events:none}.card-black .card-category{display:block;font-size:var(--font-size-xs);font-weight:var(--font-weight-normal);opacity:.8;text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-3);color:#a78bfa}.card-black .placeholder-line{display:inline-block;background:white;height:2px;width:60px;border-radius:1px;margin:0 2px;vertical-align:middle}.card-white{background:var(--color-card-white);color:var(--color-text-primary);border:2px solid #e2e8f0;box-shadow:var(--card-shadow-white);font-size:var(--font-size-base);line-height:var(--line-height-normal)}.card-white-interactive{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.card-white-interactive:hover:not(:disabled){transform:translateY(-4px) rotate(-1deg);box-shadow:var(--card-shadow-white-hover);border-color:var(--color-accent-primary)}.card-white-interactive:active{transform:translateY(-2px) rotate(-.5deg)}.card-white-interactive:disabled{opacity:.5;cursor:not-allowed}.card-white-interactive:disabled:hover{transform:none}.card-selected{border-color:var(--color-accent-primary);box-shadow:0 0 0 4px rgba(139,92,246,.2),var(--card-shadow-white-hover);transform:translateY(-2px)}.card-submitted{border-color:var(--color-submitted);box-shadow:0 0 0 4px rgba(16,185,129,.2),var(--card-shadow-white)}.panel{background:var(--color-bg-elevated);border:2px solid var(--color-bg-interactive);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}.panel-header{padding:var(--space-4) var(--space-6);background:var(--color-bg-surface);border-bottom:2px solid var(--color-bg-interactive)}.panel-content{padding:var(--space-6)}.panel-footer{padding:var(--space-4) var(--space-6);background:var(--color-bg-surface);border-top:2px solid var(--color-bg-interactive)}.panel-primary{background:linear-gradient(135deg,var(--color-accent-primary),var(--color-accent-secondary));color:white;border-color:var(--color-accent-primary)}.panel-primary .panel-footer,.panel-primary .panel-header{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)}.panel-success{background:linear-gradient(135deg,var(--color-accent-success),#34d399);color:white;border-color:var(--color-accent-success)}.panel-success .panel-footer,.panel-success .panel-header{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)}.panel-warning{background:linear-gradient(135deg,var(--color-accent-warning),var(--color-accent-orange));color:white;border-color:var(--color-accent-warning)}.panel-warning .panel-footer,.panel-warning .panel-header{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)}.stage{background:var(--color-stage-bg);border:3px solid white;box-shadow:var(--shadow-xl);padding:var(--space-8);position:relative}.stage,.stage:before{border-radius:var(--radius-2xl)}.stage:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2),rgba(255,255,255,.1));pointer-events:none}.stage .card+.card{margin-top:var(--space-8)}.hand{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))!important;grid-column-gap:var(--space-3)!important;column-gap:var(--space-3)!important;grid-row-gap:4px!important;margin-top:var(--space-6)}.hand,.panel-content .hand{row-gap:4px!important}.hand .card{padding:var(--space-4) var(--space-5)!important;margin:0!important}@media (max-width:640px){.hand{grid-template-columns:1fr!important;column-gap:var(--space-3)!important;row-gap:var(--space-1)!important}}.status-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:linear-gradient(135deg,var(--color-accent-primary),var(--color-accent-secondary));color:white;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 12px rgba(139,92,246,.3)}.status-badge-success{background:linear-gradient(135deg,var(--color-accent-success),#34d399);box-shadow:0 4px 12px rgba(16,185,129,.3)}.status-badge-warning{background:linear-gradient(135deg,var(--color-accent-warning),var(--color-accent-orange));box-shadow:0 4px 12px rgba(245,158,11,.3)}.status-badge-judge{background:linear-gradient(135deg,var(--color-judge),#fbbf24);box-shadow:0 4px 12px rgba(245,158,11,.3)}.progress-bar{width:100%;height:var(--space-3);background:rgba(255,255,255,.2);overflow:hidden;box-shadow:inset 0 2px 4px rgba(0,0,0,.1)}.progress-bar,.progress-fill{border-radius:var(--radius-full)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent-success),#34d399);transition:width var(--transition-slow);box-shadow:0 2px 8px rgba(16,185,129,.4)}.score-pill{display:inline-flex;align-items:center;justify-content:center;min-width:var(--space-10);padding:var(--space-2) var(--space-3);background:linear-gradient(135deg,var(--color-accent-pink),#f472b6);color:white;border-radius:var(--radius-full);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;box-shadow:0 4px 12px rgba(236,72,153,.3)}.toast{position:fixed;bottom:var(--space-8);left:50%;transform:translateX(-50%);background:var(--color-bg-elevated);color:var(--color-text-primary);border:2px solid var(--color-accent-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:var(--space-4) var(--space-6);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);z-index:var(--z-toast)}.waiting-dots{display:inline-flex;align-items:center;gap:var(--space-2)}.waiting-dot{width:var(--space-3);height:var(--space-3);background:var(--color-accent-primary);border-radius:var(--radius-full);animation:waiting-bounce 1.4s ease-in-out infinite}.waiting-dot:nth-child(2){animation-delay:.2s;background:var(--color-accent-secondary)}.waiting-dot:nth-child(3){animation-delay:.4s;background:var(--color-accent-success)}@keyframes waiting-bounce{0%,80%,to{transform:translateY(0) scale(1);opacity:.7}40%{transform:translateY(-8px) scale(1.1);opacity:1}}.pulse{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.navbar{width:100%;background:var(--color-bg-elevated);border-bottom:1px solid var(--color-bg-interactive);box-shadow:0 1px 3px rgba(0,0,0,.05);position:-webkit-sticky;position:sticky;top:0;z-index:var(--z-sticky);margin-bottom:var(--space-6)}.navbar-container{max-width:1200px;margin:0 auto;padding:0 var(--space-6);display:flex;align-items:center;justify-content:space-between;height:70px}.navbar-brand{flex-shrink:0}.navbar-title{background:linear-gradient(135deg,var(--color-accent-primary) 0,var(--color-accent-secondary) 50%,var(--color-accent-pink) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:var(--font-weight-bold);font-size:var(--font-size-2xl);letter-spacing:-.025em;white-space:nowrap}.navbar-nav{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}@media (max-width:768px){.navbar-container{padding:0 var(--space-4);height:60px}.navbar-title{font-size:var(--font-size-xl)}.navbar-nav{gap:var(--space-2)}.navbar-nav .btn{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs)}}@media (max-width:480px){.navbar-title{font-size:var(--font-size-lg)}.navbar-nav .btn span{display:none}}.hero-title{text-align:center;margin-bottom:var(--space-8)}.hero-description{color:var(--color-text-primary);font-weight:var(--font-weight-medium);line-height:var(--line-height-relaxed)}.hero-button{font-weight:var(--font-weight-bold);text-shadow:0 1px 2px rgba(0,0,0,.1)}.step-content{background:rgba(255,255,255,.9);padding:var(--space-4);border-radius:var(--radius-base);box-shadow:0 2px 8px rgba(0,0,0,.1)}.step-content p{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.step-content strong{color:var(--color-text-primary);font-weight:var(--font-weight-bold)}.hero-cards{display:flex;gap:var(--space-6);justify-content:center;align-items:flex-start;margin:var(--space-8) 0}.hero-card{max-width:200px;transform:rotate(-2deg)}.hero-card:nth-child(2){transform:rotate(2deg) translateY(var(--space-4))}.hero-card:nth-child(3){transform:rotate(-1deg) translateY(var(--space-2))}@media (max-width:768px){.hero-cards{flex-direction:column;align-items:center}.hero-card{transform:none!important;max-width:280px}}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.flex-wrap{flex-wrap:wrap}.rounded-lg{border-radius:var(--radius-lg)}.font-medium{font-weight:var(--font-weight-medium)}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-secondary{color:var(--color-text-secondary)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.space-y-2>*+*{margin-top:var(--space-2)}.checkbox-card{display:block;position:relative;cursor:pointer;padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-elevated);transition:all var(--transition-fast);-webkit-user-select:none;-moz-user-select:none;user-select:none}.checkbox-card:hover{border-color:var(--color-accent-primary);background:var(--color-bg-interactive);transform:translateY(-2px);box-shadow:0 8px 25px rgba(139,92,246,.15)}.checkbox-card input[type=checkbox]{position:absolute;top:var(--space-3);right:var(--space-3);width:20px;height:20px;margin:0;cursor:pointer;accent-color:var(--color-accent-primary)}.checkbox-card input[type=checkbox]:checked+.checkbox-content{color:var(--color-accent-primary)}.checkbox-card:has(input:checked){border-color:var(--color-accent-primary);background:linear-gradient(135deg,rgba(139,92,246,.05),rgba(139,92,246,.1));box-shadow:0 8px 25px rgba(139,92,246,.2)}.checkbox-content{padding-right:var(--space-6);transition:color var(--transition-fast)}.checkbox-title{font-weight:600;font-size:1.1rem;margin-bottom:var(--space-1)}.checkbox-description{font-size:.9rem;color:var(--color-text-secondary);transition:color var(--transition-fast)}.checkbox-card:has(input:checked) .checkbox-description{color:var(--color-accent-primary);opacity:.8}.room-code-display{font-family:var(--font-mono);font-size:2.5rem;font-weight:700;letter-spacing:.25em;color:var(--color-accent-primary);background:linear-gradient(135deg,rgba(139,92,246,.1),rgba(6,182,212,.1));padding:var(--space-4) var(--space-6);border-radius:var(--radius-lg);border:2px solid var(--color-accent-primary);text-transform:uppercase;-webkit-user-select:all;-moz-user-select:all;user-select:all}.qr-container{display:inline-block;padding:var(--space-3);background:white;border-radius:var(--radius-lg);box-shadow:0 4px 20px rgba(0,0,0,.1)}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.focus\:ring:focus{outline:3px solid var(--color-accent-primary);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}