*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--twitch-purple: #9147ff;--twitch-purple-dark: #772ce8;--twitch-purple-darker: #5c16c5;--twitch-bg: #0e0e10;--twitch-bg-alt: #18181b;--twitch-bg-card: #1f1f23;--twitch-bg-hover: #2a2a2e;--twitch-border: #303032;--twitch-text: #efeff1;--twitch-text-muted: #adadb8;--twitch-text-dim: #5a5a62;--twitch-green: #00ff85;--twitch-red: #ff4d4d;--twitch-yellow: #ffc107;--twitch-orange: #ff8800;--radius: 8px;--radius-lg: 12px}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--twitch-bg);color:var(--twitch-text);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--twitch-purple);text-decoration:none}a:hover{color:var(--twitch-purple-dark)}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.page{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:2rem 0}.header{background:var(--twitch-bg-alt);border-bottom:1px solid var(--twitch-border);padding:.75rem 0;position:sticky;top:0;z-index:100}.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 1.5rem}.logo{font-size:1.5rem;font-weight:800;color:var(--twitch-text);display:flex;align-items:center;gap:.5rem}.logo span{color:var(--twitch-purple)}.header-user{display:flex;align-items:center;gap:.75rem}.header-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.header-username{font-size:.875rem;font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:var(--radius);font-family:inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--twitch-purple);color:#fff}.btn-primary:hover:not(:disabled){background:var(--twitch-purple-dark)}.btn-twitch{background:var(--twitch-purple);color:#fff;padding:.875rem 2rem;font-size:1.125rem;border-radius:var(--radius-lg)}.btn-twitch:hover{background:var(--twitch-purple-dark);transform:translateY(-1px)}.btn-danger{background:var(--twitch-red);color:#fff}.btn-danger:hover:not(:disabled){background:#c00}.btn-success{background:var(--twitch-green);color:#0e0e10}.btn-success:hover:not(:disabled){background:#00cc6a}.btn-sm{padding:.375rem .75rem;font-size:.75rem}.btn-outline{background:transparent;border:1px solid var(--twitch-border);color:var(--twitch-text)}.btn-outline:hover:not(:disabled){background:var(--twitch-bg-hover);border-color:var(--twitch-text-dim)}.input{width:100%;padding:.75rem 1rem;background:var(--twitch-bg);border:1px solid var(--twitch-border);border-radius:var(--radius);color:var(--twitch-text);font-family:inherit;font-size:.875rem;transition:border-color .15s ease;outline:none}.input:focus{border-color:var(--twitch-purple)}.input::placeholder{color:var(--twitch-text-dim)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.375rem;font-size:.8125rem;font-weight:600;color:var(--twitch-text-muted);text-transform:uppercase;letter-spacing:.03em}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.card{background:var(--twitch-bg-card);border:1px solid var(--twitch-border);border-radius:var(--radius-lg);padding:1.5rem}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--twitch-border)}.card-title{font-size:1.125rem;font-weight:700}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem}.landing{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:2rem;background:linear-gradient(135deg,var(--twitch-bg) 0%,#1a0a2e 50%,var(--twitch-bg) 100%)}.landing-badge{display:inline-block;background:#9147ff26;color:var(--twitch-purple);padding:.375rem 1rem;border-radius:9999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1.5rem}.landing h1{font-size:3.5rem;font-weight:800;margin-bottom:.75rem;line-height:1.1}.landing h1 span{color:var(--twitch-purple)}.landing-subtitle{font-size:1.25rem;color:var(--twitch-text-muted);max-width:600px;margin-bottom:2rem}.landing-desc{color:var(--twitch-text-dim);max-width:500px;margin-bottom:2.5rem;font-size:.9375rem;line-height:1.6}.landing-stats{display:flex;gap:2.5rem;margin-top:3rem}.stat-item{text-align:center}.stat-number{font-size:2rem;font-weight:800;color:var(--twitch-purple)}.stat-label{font-size:.8125rem;color:var(--twitch-text-dim);margin-top:.25rem}.landing-footer{position:fixed;bottom:1.5rem;color:var(--twitch-text-dim);font-size:.75rem}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:1.75rem;font-weight:800;margin-bottom:.25rem}.dashboard-header p{color:var(--twitch-text-muted);font-size:.9375rem}.episode-status{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .875rem;border-radius:9999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.episode-status.open{background:#00ff851f;color:var(--twitch-green)}.episode-status.closed{background:#ff4d4d1f;color:var(--twitch-red)}.counter{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--twitch-bg);border-radius:var(--radius);font-size:.875rem}.counter-bar{flex:1;height:6px;background:var(--twitch-border);border-radius:9999px;overflow:hidden}.counter-fill{height:100%;background:var(--twitch-purple);border-radius:9999px;transition:width .3s ease}.counter-fill.warning{background:var(--twitch-yellow)}.counter-fill.full{background:var(--twitch-red)}.submission-card{display:flex;gap:1rem;padding:1rem;background:var(--twitch-bg);border-radius:var(--radius);border:1px solid var(--twitch-border);transition:border-color .15s ease}.submission-card:hover{border-color:var(--twitch-text-dim)}.submission-thumb{width:160px;min-height:90px;border-radius:6px;object-fit:cover;flex-shrink:0;background:var(--twitch-bg-alt)}.submission-info{flex:1;min-width:0}.submission-info h3{font-size:.9375rem;font-weight:600;margin-bottom:.375rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.submission-meta{font-size:.75rem;color:var(--twitch-text-dim);display:flex;flex-wrap:wrap;gap:.75rem}.submission-meta span{display:flex;align-items:center;gap:.25rem}.vote-group{display:flex;gap:.375rem}.vote-btn{width:32px;height:32px;border:1px solid var(--twitch-border);border-radius:6px;background:transparent;color:var(--twitch-text-muted);font-size:1rem;font-weight:700;cursor:pointer;transition:all .12s ease;display:flex;align-items:center;justify-content:center}.vote-btn:hover{border-color:var(--twitch-text-dim)}.vote-btn.active-plus{background:#00ff8526;border-color:var(--twitch-green);color:var(--twitch-green)}.vote-btn.active-minus{background:#ff4d4d26;border-color:var(--twitch-red);color:var(--twitch-red)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.875rem}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--twitch-border)}th{font-weight:600;color:var(--twitch-text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;background:var(--twitch-bg)}tr:hover td{background:var(--twitch-bg-hover)}.tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:1px solid var(--twitch-border);padding-bottom:0}.tab{padding:.625rem 1.25rem;border:none;background:transparent;color:var(--twitch-text-muted);font-family:inherit;font-weight:600;font-size:.875rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .12s ease}.tab:hover{color:var(--twitch-text)}.tab.active{color:var(--twitch-purple);border-bottom-color:var(--twitch-purple)}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.1875rem .5rem;border-radius:4px;font-size:.6875rem;font-weight:700}.badge-plus{background:#00ff851f;color:var(--twitch-green)}.badge-minus{background:#ff4d4d1f;color:var(--twitch-red)}.badge-none{background:#5a5a6233;color:var(--twitch-text-dim)}.alert{padding:.75rem 1rem;border-radius:var(--radius);font-size:.875rem;margin-bottom:1rem}.alert-error{background:#ff4d4d1f;color:var(--twitch-red);border:1px solid rgba(255,77,77,.2)}.alert-success{background:#00ff851f;color:var(--twitch-green);border:1px solid rgba(0,255,133,.2)}.alert-info{background:#9147ff1f;color:var(--twitch-purple);border:1px solid rgba(145,71,255,.2)}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}.spinner{width:40px;height:40px;border:3px solid var(--twitch-border);border-top-color:var(--twitch-purple);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal{background:var(--twitch-bg-card);border:1px solid var(--twitch-border);border-radius:var(--radius-lg);padding:1.5rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal h2{font-size:1.25rem;margin-bottom:1rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}@media(max-width:768px){.landing h1{font-size:2.25rem}.landing-subtitle{font-size:1rem}.landing-stats{flex-direction:column;gap:1rem}.grid-2,.grid-3,.form-row{grid-template-columns:1fr}.submission-card{flex-direction:column}.submission-thumb{width:100%;height:auto;aspect-ratio:16/9}.header-inner{flex-wrap:wrap;gap:.5rem}}@media(max-width:480px){.container{padding:0 1rem}.landing h1{font-size:1.75rem}.hero-logo{width:260px;height:auto}}.page-layout{display:flex;flex-direction:column;min-height:100vh}.public-header{background:var(--twitch-bg-alt);border-bottom:1px solid var(--twitch-border);padding:.625rem 0;position:sticky;top:0;z-index:100}.public-header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 1.5rem}.public-logo{display:flex;align-items:center;text-decoration:none}.public-nav{display:flex;gap:1.25rem;align-items:center}.public-nav a,.public-nav a:visited{color:var(--twitch-text-muted);font-size:.875rem;font-weight:500;text-decoration:none;transition:color .15s ease}.public-nav a:hover{color:var(--twitch-text)}.hero{position:relative;overflow:hidden;text-align:center;padding:2rem 1.5rem 3rem}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(145,71,255,.08) 0%,transparent 60%);pointer-events:none}.hero-content{position:relative;max-width:720px;margin:0 auto}.hero-badge{display:inline-block;background:#9147ff26;color:var(--twitch-purple);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;padding:.375rem .875rem;border-radius:999px;margin-bottom:1.5rem}.hero-logo{width:min(300px,75vw);height:auto;display:block;margin:0 auto 1rem}.hero-title{font-size:2.75rem;font-weight:800;margin-bottom:.75rem;background:linear-gradient(135deg,var(--twitch-text) 0%,var(--twitch-purple) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.125rem;color:var(--twitch-text-muted);margin-bottom:.75rem;line-height:1.6}.hero-desc{font-size:.9375rem;color:var(--twitch-text-dim);margin-bottom:1.75rem;line-height:1.6}.btn-hero{font-size:1.0625rem;padding:.875rem 2rem}.hero-auth-note{font-size:.75rem;color:var(--twitch-text-dim);margin-top:.75rem;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.4}.hero-stats{display:flex;justify-content:center;gap:2.5rem;margin-top:2.5rem}.hero-stat{text-align:center}.hero-stat-number{font-size:2rem;font-weight:800;color:var(--twitch-text)}.hero-stat-label{font-size:.8125rem;color:var(--twitch-text-dim);margin-top:.125rem}.section{padding:4rem 1.5rem}.section-alt{background:var(--twitch-bg-alt);border-top:1px solid var(--twitch-border);border-bottom:1px solid var(--twitch-border)}.section-inner{max-width:960px;margin:0 auto}.section-title{text-align:center;font-size:1.75rem;font-weight:700;margin-bottom:.75rem}.section-desc{text-align:center;color:var(--twitch-text-muted);max-width:600px;margin:0 auto 3rem;font-size:.9375rem;line-height:1.6}.section-cta{text-align:center;margin-top:3rem}.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}.step-card{background:var(--twitch-bg-card);border:1px solid var(--twitch-border);border-radius:var(--radius-lg);padding:1.75rem 1.25rem;text-align:center;transition:border-color .2s ease,transform .2s ease}.step-card:hover{border-color:var(--twitch-purple);transform:translateY(-2px)}.step-number{width:44px;height:44px;background:var(--twitch-purple);color:#fff;font-size:1.25rem;font-weight:800;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.step-card h3{font-size:1rem;font-weight:700;margin-bottom:.5rem}.step-card p{font-size:.8125rem;color:var(--twitch-text-muted);line-height:1.5}.security-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.security-card{background:var(--twitch-bg-card);border:1px solid var(--twitch-border);border-radius:var(--radius-lg);padding:1.75rem}.security-icon{margin-bottom:1rem}.security-card h3{font-size:1rem;font-weight:700;margin-bottom:.5rem}.security-card p{font-size:.8125rem;color:var(--twitch-text-muted);line-height:1.5}.public-footer{background:var(--twitch-bg-alt);border-top:1px solid var(--twitch-border);padding:1.5rem 0;margin-top:auto}.footer-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;flex-direction:column;align-items:center;gap:.75rem}.footer-links{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}.footer-links a,.footer-links a:visited{color:var(--twitch-text-dim);font-size:.8125rem;text-decoration:none;transition:color .15s ease}.footer-links a:hover{color:var(--twitch-text)}.footer-copy{font-size:.75rem;color:var(--twitch-text-dim);text-align:center}.public-content{flex:1;padding:2rem 1.5rem}.legal-page{max-width:780px;margin:0 auto}.legal-page h1{font-size:2rem;font-weight:800;margin-bottom:.375rem}.legal-date{color:var(--twitch-text-dim);font-size:.8125rem;margin-bottom:2.5rem}.legal-page section{margin-bottom:2rem}.legal-page h2{font-size:1.25rem;font-weight:700;margin-bottom:.75rem;color:var(--twitch-text)}.legal-page p{font-size:.9375rem;color:var(--twitch-text-muted);line-height:1.7;margin-bottom:.75rem}.legal-page ul,.legal-page ol{margin:.75rem 0 1rem 1.5rem;color:var(--twitch-text-muted);font-size:.9375rem;line-height:1.7}.legal-page li{margin-bottom:.375rem}.legal-footer-nav{display:flex;gap:1.5rem;margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--twitch-border);flex-wrap:wrap}.legal-footer-nav a{font-size:.875rem;font-weight:500}.about-page{max-width:780px;margin:0 auto}.about-page h1{font-size:2rem;font-weight:800;margin-bottom:2rem}.about-section{margin-bottom:2.5rem}.about-section h2{font-size:1.375rem;font-weight:700;margin-bottom:.75rem;color:var(--twitch-text)}.about-section p{font-size:.9375rem;color:var(--twitch-text-muted);line-height:1.7;margin-bottom:.75rem}.about-section ol{margin:.75rem 0 1rem 1.5rem;color:var(--twitch-text-muted);font-size:.9375rem;line-height:1.7}.about-section li{margin-bottom:.375rem}.about-section a{font-weight:500}@media(max-width:768px){.hero-title{font-size:2rem}.hero{padding:3rem 1rem 2rem}.hero-stats{gap:1.5rem}.hero-stat-number{font-size:1.5rem}.section{padding:3rem 1rem}.steps{grid-template-columns:repeat(2,1fr)}.security-grid{grid-template-columns:1fr}.public-nav{display:none}.legal-page h1,.about-page h1{font-size:1.5rem}}@media(max-width:480px){.steps{grid-template-columns:1fr}.hero-title{font-size:1.625rem}}
