:root{--brand: #17507b;--brand-2: #2a79b5;--brand-grad: linear-gradient(135deg, #17507b 0%, #2a79b5 100%);--bg: #eef3f8;--surface: #ffffff;--text: #0e1f2e;--muted: #6b7a8d;--line: #e7eef5;--field: #f1f5fa;--danger: #c0392b;--ok: #1a7f3c;--radius: 16px;--radius-lg: 22px;--shadow-sm: 0 2px 8px rgba(16,40,70,.06);--shadow: 0 10px 30px rgba(16,40,70,.1);--shadow-lg: 0 20px 50px rgba(16,40,70,.16)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:var(--brand)}h2.page-title{margin:6px 0 2px;font-size:22px;font-weight:800;letter-spacing:-.3px}.page-sub{margin:0 0 20px;color:var(--muted);font-size:14px}.mobile{max-width:480px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;background:var(--bg)}.topbar{background:#fff;color:var(--text);padding:8px 18px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;border-bottom:1px solid var(--line)}.topbar .brand-logo{display:flex;align-items:center}.topbar .brand-logo img{height:40px}.topbar .links{display:flex;align-items:center;gap:6px}.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;color:var(--brand);background:transparent;border:none;cursor:pointer;transition:.15s;text-decoration:none}.iconbtn:hover,.iconbtn.active{background:var(--field)}.content{flex:1;padding:46px 22px 40px}.login-wrap{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fff;padding:20px 22px 64px}.login-logo{width:174px;max-width:48%;height:auto;object-fit:contain;display:block;margin-bottom:44px}.login-logo.placeholder{color:var(--brand);font-size:42px;font-weight:800;margin-bottom:44px}.login-center{width:100%;display:flex;justify-content:center}.login-box{width:100%;max-width:380px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:26px 24px;box-shadow:var(--shadow);text-align:left}.sponsors{width:100%;max-width:380px;margin-top:44px;text-align:center}.sponsors .by{font-style:italic;color:var(--muted);font-size:13px;margin-bottom:14px}.sponsors .row{display:flex;align-items:center;justify-content:space-between;gap:14px}.sponsors .row img{flex:1;max-width:32%;max-height:44px;object-fit:contain}.field{margin-bottom:26px}.field>label{display:block;font-size:13.5px;font-weight:600;color:var(--muted);margin-bottom:11px}.input,.prefixed input,select{width:100%;padding:16px;border:1.5px solid var(--line);border-radius:13px;font-size:16px;font-family:inherit;outline:none;background:#fff;color:var(--text);transition:.15s}.input::placeholder,.prefixed input::placeholder{color:#9aa8b6}.input:focus,.prefixed input:focus,select:focus{border-color:var(--brand-2);box-shadow:0 0 0 4px #2a79b524}.prefixed{display:flex;align-items:stretch;background:#fff;border:1.5px solid var(--line);border-radius:13px;overflow:hidden;transition:.15s}.prefixed:focus-within{border-color:var(--brand-2);box-shadow:0 0 0 4px #2a79b524}.prefixed .pfx{color:var(--brand);font-weight:700;padding:16px 6px 16px 16px;display:flex;align-items:center;font-size:16px}.prefixed input{background:transparent;border:none;border-radius:0;padding-left:4px}.prefixed input:focus{box-shadow:none}.btn{width:100%;background:var(--brand-grad);color:#fff;border:none;padding:15px;border-radius:12px;font-size:16px;font-weight:700;font-family:inherit;cursor:pointer;text-decoration:none;text-align:center;display:inline-block;box-shadow:0 8px 20px #17507b47;transition:transform .12s,box-shadow .12s,opacity .12s}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 26px #17507b57}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn.secondary{background:#fff;color:var(--brand);border:1.5px solid var(--line);box-shadow:var(--shadow-sm)}.btn.ghost{background:transparent;color:var(--brand);border:none;width:auto;padding:8px;box-shadow:none;font-weight:600}.error{color:var(--danger);font-size:13.5px;margin:10px 0}.gender{display:flex;gap:6px;background:#fff;border:1.5px solid var(--line);border-radius:13px;padding:6px}.gender button{flex:1;padding:14px;border-radius:9px;border:none;background:transparent;font-size:15px;font-weight:600;color:var(--muted);cursor:pointer;transition:.15s;font-family:inherit}.gender button.on{background:var(--brand-grad);color:#fff;box-shadow:0 6px 16px #17507b47}.photo-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;border:2px dashed #cdd9e5;border-radius:14px;padding:30px 22px;min-height:120px;text-align:center;color:var(--muted);font-size:14px;cursor:pointer;background:var(--surface);transition:.15s}.photo-drop:hover{border-color:var(--brand-2);background:#fafcff}.photo-drop .ico{font-size:26px;margin-bottom:6px}.photo-drop img{max-height:130px;border-radius:12px;box-shadow:var(--shadow-sm)}.hint{color:var(--muted);font-size:12.5px;margin:8px 2px 0}.photo-set{display:flex;align-items:center;gap:16px}.photo-circle{width:104px;height:104px;border-radius:50%;object-fit:cover;border:3px solid var(--line);box-shadow:var(--shadow-sm)}.photo-actions{display:flex;flex-direction:column;gap:8px}.photo-actions .btn{text-align:center}.crop-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#081421b8;display:flex;flex-direction:column;justify-content:center;padding:18px}.crop-head{color:#fff;text-align:center;font-weight:600;margin-bottom:12px}.crop-area{position:relative;width:100%;max-width:420px;aspect-ratio:1;margin:0 auto;background:#111;border-radius:14px;overflow:hidden}.crop-modal .zoom{width:100%;max-width:420px;margin:16px auto 0;accent-color:var(--brand-2)}.crop-controls{width:100%;max-width:420px;margin:14px auto 0;display:flex;gap:12px}.crop-controls .btn{flex:1}.note{margin-top:18px;padding:14px 16px;border-radius:12px;background:#eef5fb;border:1px solid #d6e6f3;color:#2c4a63;font-size:13.5px;line-height:1.55;text-align:center}.lyrics-box{background:linear-gradient(180deg,#f5f9fd,#eef4fa);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin:20px 0}.lyrics-box h4{margin:0 0 10px;color:var(--brand);font-size:13px;text-transform:uppercase;letter-spacing:.6px}.lyrics-box p{margin:4px 0;font-size:14.5px;line-height:1.6;color:#2c3e50}.processing{text-align:center;padding-top:24px}.spinner{width:56px;height:56px;border:5px solid #e4edf6;border-top-color:var(--brand);border-radius:50%;margin:24px auto;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.video-preview{width:100%;border-radius:var(--radius);background:#000;margin:16px 0;box-shadow:var(--shadow)}.steps{list-style:none;padding:0;text-align:left;max-width:300px;margin:18px auto}.steps li{margin:12px 0;color:var(--muted);font-size:15px;display:flex;align-items:center;gap:10px}.steps li.done{color:var(--ok);font-weight:600}.steps li.active{color:var(--text);font-weight:700}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm)}.card .meta{font-size:13px;color:var(--muted);margin-top:3px}.badge{font-size:12px;font-weight:600;padding:5px 11px;border-radius:999px;background:#eaf1f8;color:var(--brand);text-decoration:none}.badge.ready{background:#e7f6ec;color:var(--ok)}.badge.failed{background:#fdecea;color:var(--danger)}.admin{display:flex;min-height:100vh;background:var(--bg)}.sidebar{width:240px;background:var(--surface);border-right:1px solid var(--line);padding:24px 16px}.sidebar .logo{font-weight:800;color:var(--brand);margin-bottom:26px;font-size:18px;padding:0 8px}.sidebar a{display:block;padding:11px 14px;border-radius:10px;text-decoration:none;color:var(--text);margin-bottom:4px;font-weight:500;transition:.15s;cursor:pointer}.sidebar a:hover{background:var(--field)}.sidebar a.active{background:var(--brand-grad);color:#fff;font-weight:600}.admin-main{flex:1;padding:30px 36px}.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:20px 0 26px}.statcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}.statcard.brand{background:var(--brand-grad);color:#fff;border:none;box-shadow:var(--shadow)}.statcard .label{font-size:13px;opacity:.85;font-weight:500}.statcard .value{font-size:34px;font-weight:800;margin:8px 0 2px;letter-spacing:-.5px}.statcard .sub{font-size:12.5px;opacity:.8}.cols3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}.panel h3{margin:0 0 16px;font-size:16px}.bar-row{margin-bottom:15px}.bar-row .top{display:flex;justify-content:space-between;font-size:14px}.bar-row .top .name{font-weight:600}.bar-row .top .num{color:var(--muted)}.bar{height:7px;background:var(--field);border-radius:5px;margin-top:7px;overflow:hidden}.bar>span{display:block;height:100%;background:var(--brand-grad);border-radius:5px}table{width:100%;border-collapse:collapse;font-size:14px}th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line)}th{color:var(--muted);font-weight:600;font-size:13px}tr.clickable:hover{background:var(--field);cursor:pointer}.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.toolbar h1{font-size:24px;font-weight:800;letter-spacing:-.4px}.muted{color:var(--muted)}
