:root{--app-font: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"}*{box-sizing:border-box}body{margin:0;font-family:var(--app-font);color:#0f172a;background:#f8fafc}input,select,textarea,button{font-family:inherit}#root{min-height:100vh}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 15% 20%,#e8f0ff,#eef4ff 34%,#f8fbff 70%)}.login-layout{width:min(1080px,100%);min-height:620px;border-radius:18px;overflow:hidden;display:grid;grid-template-columns:1.1fr .9fr;box-shadow:0 30px 70px #0f172a33;background:#fffffff5}.brand-panel{padding:56px 48px;color:#e5e7eb;background:linear-gradient(135deg,#0f172a,#1d4ed8 55%,#2563eb);display:flex;flex-direction:column;justify-content:center}.brand-badge{display:inline-flex;width:fit-content;font-size:12px;letter-spacing:.08em;text-transform:uppercase;padding:6px 10px;border-radius:999px;border:1px solid rgba(191,219,254,.5);background:#94a3b82e;margin-bottom:16px}.brand-title{margin:0 0 16px;font-size:38px;line-height:1.1;color:#fff}.brand-copy{margin:0;max-width:420px;line-height:1.55}.brand-points{margin:24px 0 0;padding-left:18px;display:grid;gap:10px;color:#dbeafe}.login-card{padding:56px 44px;display:flex;flex-direction:column;justify-content:center;background:linear-gradient(180deg,#fff,#f8fafc)}.login-title{margin:0 0 10px;font-size:28px;color:#0f172a}.login-subtitle{margin:0 0 20px;color:#64748b}.form{display:grid;gap:12px}label{display:grid;gap:6px;font-size:14px;color:#374151}input{border:1px solid #d1d5db;border-radius:8px;padding:10px 12px;font-size:14px;background:#fff}input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f629}button{border:0;border-radius:10px;padding:11px 14px;background:linear-gradient(135deg,#3b82f6,#1a56db);color:#fff;font-weight:600;cursor:pointer}button.secondary{background:#e2e8f0;color:#1f2937}.error-text{margin:0;color:#b91c1c;font-size:13px}.helper-text{margin-top:14px;color:#64748b;font-size:13px}.login-alt-action{margin:16px 0 0;font-size:14px}.login-alt-action a{color:#2563eb;font-weight:600;text-decoration:none}.login-alt-action a:hover{text-decoration:underline}.success-text{margin:0;color:#047857;font-size:13px}.add-institute-page{--ai-accent: #2563eb;--ai-accent-soft: #dbeafe;--ai-surface: #ffffff;--ai-muted: #64748b;display:flex;flex-direction:column;gap:clamp(20px,4vw,28px);padding:0 clamp(16px,4vw,28px) 48px;max-width:760px;margin-left:auto;margin-right:auto}.add-institute-alert{display:flex;gap:14px;align-items:flex-start;padding:14px 16px;border-radius:12px;border:1px solid transparent;font-size:14px;line-height:1.5}.add-institute-alert--warn{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#fcd34d;color:#78350f}.add-institute-alert-icon{flex-shrink:0;width:32px;height:32px;display:grid;place-items:center;border-radius:8px;background:#fbbf2459;font-size:16px}.add-institute-alert strong{display:block;margin-bottom:4px;color:#92400e}.add-institute-alert p{margin:0;color:#92400e;opacity:.95}.add-institute-intro{display:flex;align-items:stretch;justify-content:space-between;gap:24px;padding:clamp(22px,4vw,30px) clamp(22px,4vw,32px);border-radius:16px;background:linear-gradient(125deg,#0f172a,#1e3a8a 48%,#1d4ed8);color:#f8fafc;box-shadow:0 20px 50px #1e40af59;overflow:hidden;position:relative}.add-institute-intro:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 100% 0%,rgba(255,255,255,.12) 0%,transparent 45%);pointer-events:none}.add-institute-intro-copy{position:relative;z-index:1;max-width:28rem}.add-institute-kicker{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#bfdbfe;margin-bottom:10px}.add-institute-heading{margin:0 0 10px;font-size:clamp(1.35rem,3vw,1.75rem);font-weight:700;letter-spacing:-.02em;line-height:1.2}.add-institute-lede{margin:0;font-size:14px;line-height:1.55;color:#cbd5e1}.add-institute-intro-visual{position:relative;z-index:1;flex-shrink:0;width:min(120px,22vw);display:flex;align-items:center;justify-content:center}.add-institute-intro-orbit{font-size:clamp(2.5rem,6vw,3.25rem);line-height:1;padding:18px;border-radius:20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.add-institute-form-shell{width:100%}.add-institute-form-card{padding:clamp(22px,3.5vw,32px);border-radius:16px;border:1px solid #e2e8f0;background:var(--ai-surface);box-shadow:0 4px 6px #0f172a0a,0 16px 40px #0f172a14;position:relative}.add-institute-form-card:before{content:"";position:absolute;top:0;left:24px;right:24px;height:3px;border-radius:0 0 6px 6px;background:linear-gradient(90deg,var(--ai-accent),#38bdf8);opacity:.9}.add-institute-form{display:flex;flex-direction:column;gap:0;padding-top:8px}.add-institute-section{padding:8px 0 4px}.add-institute-section-head{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px}.add-institute-section-icon{flex-shrink:0;width:44px;height:44px;display:grid;place-items:center;border-radius:12px;font-size:1.35rem;line-height:1}.add-institute-section-icon--inst{background:linear-gradient(145deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe}.add-institute-section-icon--admin{background:linear-gradient(145deg,#f5f3ff,#ede9fe);border:1px solid #ddd6fe}.add-institute-section-title{margin:0 0 4px;font-size:1.05rem;font-weight:700;color:#0f172a}.add-institute-section-desc{margin:0;font-size:13px;color:var(--ai-muted);line-height:1.45}.add-institute-fields{display:grid;gap:16px}.add-institute-fields--2{grid-template-columns:repeat(2,minmax(0,1fr))}.add-institute-fields--optional{margin-top:14px;padding-top:14px;border-top:1px dashed #e2e8f0}.add-institute-label{display:flex;flex-direction:column;gap:7px}.add-institute-label-text{font-size:13px;font-weight:600;color:#334155}.add-institute-optional-tag{font-weight:600;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:#94a3b8;vertical-align:middle}.add-institute-input{width:100%;border:1px solid #cbd5e1;border-radius:10px;padding:11px 13px;font-size:14px;background:#fafafa;color:#0f172a;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.add-institute-input::placeholder{color:#94a3b8}.add-institute-input:hover{border-color:#94a3b8;background:#fff}.add-institute-input:focus{outline:none;border-color:var(--ai-accent);background:#fff;box-shadow:0 0 0 4px #2563eb24}.add-institute-input-file{padding:8px 13px;cursor:pointer}.add-institute-logo-preview{margin-top:8px;height:56px;width:auto;max-width:180px;object-fit:contain;border-radius:8px;border:1px solid #e2e8f0;background:#fff}.add-institute-divider{height:1px;margin:10px 0 22px;background:linear-gradient(90deg,transparent,#e2e8f0 15%,#e2e8f0 85%,transparent)}.add-institute-feedback{margin-top:20px}.add-institute-feedback-msg{margin:0;padding:12px 14px;border-radius:10px;font-size:14px;line-height:1.45}.add-institute-feedback-msg--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.add-institute-feedback-msg--success{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46}.add-institute-footer{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end;align-items:center;margin-top:26px;padding-top:22px;border-top:1px solid #f1f5f9}.add-institute-btn{font-family:inherit;font-size:14px;font-weight:600;padding:11px 20px;border-radius:10px;cursor:pointer;border:none;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.add-institute-btn:active:not(:disabled){transform:translateY(1px)}.add-institute-btn--ghost{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.add-institute-btn--ghost:hover:not(:disabled){background:#e2e8f0;border-color:#cbd5e1}.add-institute-btn--primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 4px 14px #2563eb59}.add-institute-btn--primary:hover:not(:disabled){box-shadow:0 6px 20px #2563eb6b}.add-institute-btn--primary:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}@media (max-width: 640px){.add-institute-intro{flex-direction:column;align-items:stretch}.add-institute-intro-visual{width:100%;justify-content:flex-start}.add-institute-fields--2{grid-template-columns:1fr}.add-institute-footer{flex-direction:column-reverse;align-items:stretch}.add-institute-btn{width:100%;justify-content:center;text-align:center}}.optional-label{font-weight:400;color:#94a3b8;font-size:12px}button:disabled{opacity:.65;cursor:not-allowed}.institutions-page{display:flex;flex-direction:column;gap:16px}.institutions-hint{margin:0;padding:12px 14px;border-radius:10px;background:#fffbeb;border:1px solid #fcd34d;color:#92400e;font-size:14px;line-height:1.45}.institutions-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.institutions-loading{margin:0;color:#64748b;font-size:14px}.institutions-table-wrap{overflow-x:auto;border-radius:12px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 8px 24px #0f172a0f}.institutions-table{width:100%;border-collapse:collapse;font-size:14px}.institutions-table th,.institutions-table td{padding:12px 14px;text-align:left;border-bottom:1px solid #eef2f7}.institutions-table th{background:#f8fafc;color:#475569;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.institutions-table tbody tr:last-child td{border-bottom:none}.institutions-logo-thumb{height:32px;width:auto;max-width:80px;object-fit:contain;border-radius:4px;vertical-align:middle}.institutions-no-logo{color:#94a3b8}.institutions-empty{color:#64748b;text-align:center;padding:28px 14px!important}.institutions-th-actions{text-align:right;min-width:220px;width:220px;white-space:nowrap}.institutions-actions-cell{vertical-align:middle;min-width:220px;width:220px}.institutions-row-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.institutions-btn{font-family:inherit;font-size:12px;font-weight:700;padding:7px 12px;border-radius:8px;cursor:pointer;border:1px solid transparent;transition:background .15s ease,border-color .15s ease,opacity .15s ease}.institutions-btn:disabled{opacity:.45;cursor:not-allowed}.institutions-btn-edit{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.institutions-btn-edit:hover:not(:disabled){background:#dbeafe}.institutions-btn-delete{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.institutions-btn-delete:hover:not(:disabled){background:#fee2e2}.inst-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;place-items:center;padding:24px;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.inst-modal{width:min(440px,100%);max-height:min(90vh,560px);overflow-y:auto;padding:24px 26px 22px;border-radius:16px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 24px 48px #0f172a2e}.inst-modal--narrow{width:min(400px,100%)}.inst-modal-title{margin:0 0 4px;font-size:1.2rem;font-weight:700;color:#0f172a}.inst-modal-sub{margin:0 0 18px;font-size:13px;color:#64748b}.inst-modal-body{margin:0 0 12px;font-size:15px;line-height:1.45;color:#334155}.inst-modal-muted{font-weight:400;color:#64748b}.inst-modal-warning{margin:0 0 20px;padding:10px 12px;border-radius:10px;font-size:13px;line-height:1.45;background:#fffbeb;border:1px solid #fde68a;color:#92400e}.inst-modal-form{display:flex;flex-direction:column;gap:14px}.inst-modal-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;margin-top:8px}.institutions-delete-confirm{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;box-shadow:0 4px 14px #b91c1c59}.institutions-delete-confirm:hover:not(:disabled){box-shadow:0 6px 18px #b91c1c6b}.institutions-delete-confirm:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.dashboard-shell{min-height:100vh;padding:0 0 42px;background:radial-gradient(circle at 0% 0%,#eff6ff,#f3f4f6 36%,#f3f4f6)}.dashboard-wrapper{width:min(1120px,100%);margin:18px auto 0;padding:0}.dashboard-topbar{width:100%;margin:0;padding:0 24px;border-bottom:1px solid #dbe3ef;background:#fff;box-shadow:0 8px 24px #0f172a0a}.dashboard-topbar-inner{width:100%;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 0}.dashboard-brand{display:flex;align-items:center;gap:12px}.dashboard-brand-badge{width:42px;height:42px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;letter-spacing:.06em;color:#fff;background:linear-gradient(145deg,#2563eb,#1d4ed8)}.dashboard-user{margin:0;font-size:13px;color:#64748b;font-weight:500}.dashboard-header-actions{display:flex;align-items:center;gap:12px}.header-logout-btn{border:1px solid #dbe3ef;border-radius:10px;background:#f8fafc;color:#334155;font-size:13px;font-weight:700;padding:9px 14px}.header-logout-btn:hover{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.dashboard-title{margin:0;font-size:24px;font-weight:700;color:#111827;line-height:1.05;text-transform:uppercase}.dashboard-subtitle{margin:5px 0 0;font-size:13px;color:#8a94a6}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(200px,1fr));gap:12px}.stat-card{background:#fff;border:1px solid #d8dde6;border-radius:13px;padding:12px 14px;box-shadow:0 1px #0f172a05,0 8px 18px #0f172a0a;transition:transform .18s ease,box-shadow .2s ease,border-color .2s ease}.stat-card:hover{transform:translateY(-1px);border-color:#c7d6ec;box-shadow:0 1px #0f172a05,0 12px 22px #0f172a14}.stat-card h3{margin:0 0 6px;color:#8a94a6;font-size:11px;font-weight:500;text-transform:none}.stat-card p{margin:0;font-size:34px;line-height:1;font-weight:700}.value-dark{color:#0f172a}.value-blue{color:#2563eb}.value-orange{color:#ea580c}.value-green{color:#16a34a}.module-grid{margin-top:18px;display:flex;flex-wrap:wrap;justify-content:center;gap:12px}.module-grid--super-admin{max-width:560px;margin-left:auto;margin-right:auto;justify-content:stretch}.module-grid--super-admin .module-card{flex:1 1 100%;max-width:100%}.dashboard-empty-role{margin:28px auto 0;max-width:420px;text-align:center;padding:16px 18px;border-radius:12px;font-size:14px;color:#64748b;background:#f8fafc;border:1px solid #e2e8f0}.module-card{flex:0 1 calc((100% - 24px) / 3);max-width:calc((100% - 24px) / 3);min-width:260px;border:1px solid #d8dde6;border-radius:14px;background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:0 1px #0f172a05,0 8px 20px #0f172a0a;padding:18px 16px 16px;transition:transform .18s ease,box-shadow .2s ease,border-color .2s ease}.module-card-wide{flex-basis:calc((100% - 12px)/2);max-width:calc((100% - 12px)/2)}.module-card:hover{transform:translateY(-2px);border-color:#bfdbfe;box-shadow:0 1px #0f172a05,0 14px 26px #1e40af1f}.module-card-clickable{cursor:pointer}.module-icon{width:34px;height:34px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;font-size:17px;margin-bottom:12px}.module-icon-blue{background:linear-gradient(180deg,#3b82f6,#2563eb)}.module-icon-orange{background:linear-gradient(180deg,#f97316,#ea580c)}.module-icon-green{background:linear-gradient(180deg,#22c55e,#16a34a)}.module-icon-light{background:#eef2f7}.module-card h3{margin:0 0 6px;font-size:20px;line-height:1.2;color:#111827}.module-card p{margin:0;font-size:13px;line-height:1.4;color:#8a94a6}.token-page-wrap{display:grid;gap:14px;padding-bottom:24px}.token-audio-controls{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px 14px;padding:12px 14px;border:1px solid #dbe3ef;border-radius:12px;background:#fff}.token-audio-title{margin:0;font-size:14px;font-weight:700;color:#334155}.token-audio-options{display:flex;flex-wrap:wrap;gap:8px 12px}.token-audio-option{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border:1px solid #e2e8f0;border-radius:999px;background:#f8fafc;font-size:13px;color:#334155}.token-audio-option input{margin:0}.token-public-access{padding:12px 14px;border:1px solid #dbe3ef;border-radius:12px;background:#fff}.token-public-label{display:grid;gap:6px;max-width:240px;font-size:13px;font-weight:600;color:#334155}.token-card{border-radius:14px;border:1px solid #d8dde6;overflow:hidden;background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:0 1px #0f172a05,0 8px 20px #0f172a0a}.token-card-top{display:flex;justify-content:space-between;align-items:flex-start;padding:16px;gap:14px}.token-card-top h3{margin:0;font-size:24px;color:#0f172a;line-height:1.2}.token-card-top p{margin:2px 0 10px;color:#64748b;font-size:13px}.token-meta{display:flex;gap:16px;color:#64748b;font-size:13px;flex-wrap:wrap}.token-meta strong{color:#0f172a;font-size:15px}.token-card-blue .token-meta strong:first-child{color:#2563eb}.token-card-orange .token-meta strong:first-child{color:#ea580c}.token-generate-btn{border:0;border-radius:12px;color:#fff;font-size:16px;font-weight:700;padding:12px 20px;min-width:140px;box-shadow:0 8px 18px #0f172a24}.token-generate-btn-blue{background:linear-gradient(145deg,#3b82f6,#2563eb)}.token-generate-btn-orange{background:linear-gradient(145deg,#f97316,#ea580c)}.token-latest{text-align:center;color:#fff;padding:10px 16px 12px}.token-latest p{margin:0;font-size:13px;opacity:.92}.token-latest strong{display:block;margin-top:2px;font-size:22px;line-height:1;letter-spacing:.02em}.token-latest-blue{background:#2f6ccc}.token-latest-orange{background:#df520f}.tg-page{position:fixed;top:0;left:0;right:0;bottom:0;padding:12px;background:#0f172a;box-sizing:border-box;display:flex;flex-direction:column}.tg-alert{margin:0 0 8px;padding:10px 16px;border-radius:10px;font-size:14px;font-weight:500;line-height:1.4;text-align:center;flex-shrink:0}.tg-alert-warn{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.tg-alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.tg-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#94a3b8;font-size:20px;text-align:center}.tg-empty-icon{display:block;font-size:64px;margin-bottom:18px}.tg-empty p{margin:4px 0}.tg-grid{flex:1;display:flex;flex-direction:column;min-height:0}.tg-tile{flex-shrink:0;border:1px solid rgba(255,255,255,.08);border-bottom:6px solid rgba(0,0,0,.35);border-radius:20px;color:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:stretch;justify-content:space-between;padding:18px 22px;box-sizing:border-box;position:relative;overflow:hidden;transform:translateY(0);transition:transform .1s ease,border-bottom-width .1s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;text-align:center}.tg-tile:before{content:"";position:absolute;top:0;left:0;right:0;height:45%;background:linear-gradient(180deg,rgba(255,255,255,.2) 0%,rgba(255,255,255,.05) 60%,transparent 100%);pointer-events:none;border-radius:inherit}.tg-tile:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;border:1px solid rgba(255,255,255,.1);border-bottom:none;pointer-events:none}.tg-tile:active:not(:disabled){transform:translateY(4px);border-bottom-width:2px}.tg-tile:active:not(:disabled) .tg-tile-cta{background:#ffffff80;transform:scale(.96)}.tg-tile:disabled{opacity:.5;cursor:not-allowed;box-shadow:none!important;border-bottom-color:#00000026}.tg-tile-top{display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}.tg-tile-icon{width:46px;height:46px;background:#ffffff26;border:1px solid rgba(255,255,255,.12);border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:23px;flex-shrink:0;margin-right:14px}.tg-tile-name{font-size:21px;font-weight:700;letter-spacing:.01em;text-shadow:0 1px 4px rgba(0,0,0,.2)}.tg-tile-center{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;position:relative;min-height:0;padding:4px 0}.tg-tile-token{font-size:56px;font-weight:900;line-height:1;letter-spacing:-.02em;text-shadow:0 3px 12px rgba(0,0,0,.2),0 1px 2px rgba(0,0,0,.15)}.tg-tile-token-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;opacity:.55;margin-top:6px}.tg-tile-bottom{display:flex;align-items:center;justify-content:center;gap:16px;position:relative;flex-shrink:0}.tg-tile-stat{display:flex;flex-direction:column;align-items:center;min-width:58px;background:#0000001f;border-radius:10px;padding:6px 10px}.tg-tile-stat-num{font-size:21px;font-weight:800;line-height:1.2;text-shadow:0 1px 3px rgba(0,0,0,.12)}.tg-tile-stat-lbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;opacity:.55;margin-top:2px}.tg-tile-cta{background:#ffffff4d;border:2px solid rgba(255,255,255,.5);padding:12px 28px;border-radius:14px;font-size:15px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;text-shadow:0 1px 3px rgba(0,0,0,.12);box-shadow:0 2px 8px #0000001f,inset 0 1px #fff3;transition:background .1s ease,transform .1s ease}.tg-tile-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:20px;font-weight:700}.tg-tile-loading .tg-spinner{margin-bottom:14px}@keyframes tg-spin{to{transform:rotate(360deg)}}.tg-spinner{width:34px;height:34px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:tg-spin .7s linear infinite}@media (min-width: 1024px){.tg-page{padding:16px}.tg-tile{padding:24px 30px;border-radius:24px;border-bottom-width:7px}.tg-tile-icon{width:54px;height:54px;font-size:27px}.tg-tile-name{font-size:27px}.tg-tile-token{font-size:72px}.tg-tile-token-label{font-size:13px}.tg-tile-stat{padding:8px 14px}.tg-tile-stat-num{font-size:25px}.tg-tile-stat-lbl{font-size:10px}.tg-tile-cta{padding:14px 38px;font-size:17px;border-radius:16px}}@media (max-width: 540px){.tg-page{padding:8px}.tg-tile{padding:14px 16px;border-radius:16px;border-bottom-width:5px}.tg-tile-icon{width:38px;height:38px;font-size:19px;border-radius:10px;margin-right:10px}.tg-tile-name{font-size:17px}.tg-tile-token{font-size:40px}.tg-tile-stat{padding:4px 8px;min-width:48px}.tg-tile-stat-num{font-size:17px}.tg-tile-cta{padding:10px 20px;font-size:12px;border-radius:10px}}.manage-counters-page{display:grid;gap:16px}.manage-counter-card{padding-bottom:14px;overflow:visible}.manage-counter-tabs{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid #dbe3ef;border-radius:12px;padding:6px}.manage-counter-tab{border:0;background:transparent;color:#475569;font-size:13px;font-weight:700;border-radius:8px;padding:8px 12px;cursor:pointer}.manage-counter-tab-active{background:#e0ebff;color:#1d4ed8}.settings-tab-content{margin-top:20px;background:#fff;border:1px solid #dbe3ef;border-radius:14px;padding:40px 24px}.settings-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:300px;color:#64748b}.settings-placeholder-icon{font-size:48px;margin-bottom:16px;display:block}.settings-placeholder h3{margin:0 0 8px;font-size:20px;font-weight:700;color:#1e293b}.settings-placeholder p{margin:0;font-size:14px;line-height:1.5;color:#94a3b8;max-width:360px}.settings-form-section{max-width:520px}.settings-section-title{margin:0 0 6px;font-size:17px;font-weight:700;color:#1e293b}.settings-section-desc{margin:0 0 18px;font-size:13px;color:#64748b;line-height:1.5}.settings-language-options{display:flex;gap:12px;margin-bottom:20px}.settings-language-card{flex:1;display:flex;align-items:center;gap:10px;padding:14px 18px;border:2px solid #dbe3ef;border-radius:10px;cursor:pointer;transition:border-color .15s,background .15s;background:#f8fafc}.settings-language-card:hover{border-color:#93c5fd;background:#eff6ff}.settings-language-card-active{border-color:#3b82f6;background:#eff6ff}.settings-language-card input[type=radio]{accent-color:#3b82f6;width:18px;height:18px;margin:0}.settings-language-label{font-size:15px;font-weight:600;color:#1e293b}.settings-save-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 28px;font-size:14px;font-weight:700;color:#fff;background:linear-gradient(180deg,#3b82f6,#2563eb);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s,transform .1s}.settings-save-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px)}.settings-save-btn:disabled{opacity:.5;cursor:not-allowed}.settings-msg{margin:0 0 14px;font-size:13px;font-weight:600;padding:8px 14px;border-radius:8px}.settings-msg-success{color:#166534;background:#dcfce7}.settings-msg-error{color:#991b1b;background:#fee2e2}.counter-staff-settings{max-width:none;width:100%}.counter-staff-settings .institutions-table-wrap{width:100%}.counter-staff-actions-col{width:1%;white-space:nowrap}.counter-staff-actions{display:inline-flex;flex-wrap:nowrap;align-items:center;gap:8px}.counter-staff-action-btn{flex-shrink:0;padding:7px 12px;font-size:12px}.counter-staff-subheading{margin:1.25rem 0 .75rem;font-size:1rem;font-weight:700;color:#0f172a}.counter-staff-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:.25rem}.counter-staff-header .settings-section-title{margin-bottom:.35rem}.counter-staff-header .settings-section-desc{margin-bottom:0}.counter-staff-add-btn{flex-shrink:0;margin-top:0;white-space:nowrap}.counter-staff-drawer-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100}.counter-staff-drawer-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a59;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.counter-staff-drawer{position:absolute;top:0;right:0;display:flex;flex-direction:column;width:min(420px,100%);height:100%;background:#fff;border-left:1px solid #e2e8f0;box-shadow:-12px 0 40px #0f172a24;animation:counter-staff-drawer-in .24s ease-out}@keyframes counter-staff-drawer-in{0%{transform:translate(100%)}to{transform:translate(0)}}.counter-staff-drawer-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:22px 24px 18px;border-bottom:1px solid #e2e8f0}.counter-staff-drawer-header .inst-modal-title{margin-bottom:6px}.counter-staff-drawer-header .inst-modal-sub{margin:0}.counter-staff-drawer-close{flex-shrink:0;width:36px;height:36px;border:0;border-radius:10px;background:#f1f5f9;color:#475569;font-size:1.5rem;line-height:1;cursor:pointer}.counter-staff-drawer-close:hover{background:#e2e8f0;color:#0f172a}.counter-staff-drawer-body{flex:1;overflow-y:auto;padding:24px}.counter-staff-drawer-footer{margin-top:auto;padding-top:8px}.counter-staff-settings .settings-save-btn{margin-top:.75rem}@media (max-width: 640px){.counter-staff-header{flex-direction:column;align-items:stretch}.counter-staff-add-btn{width:100%}}.manage-counter-form{padding:0 16px 16px;display:grid;gap:14px}.manage-counter-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.manage-counter-label{display:grid;gap:8px}.manage-counter-label-wide{grid-column:1 / -1}.manage-counter-label-text{font-size:13px;font-weight:600;color:#1e293b}.manage-counter-input{width:100%;min-height:42px;border:1px solid #dbe3ef;border-radius:10px;padding:10px 12px;font-size:14px;color:#0f172a;background:#fff}.manage-counter-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f;outline:none}.manage-counter-submit{justify-self:flex-start}.manage-counter-form-actions{display:flex;align-items:center;gap:10px}.manage-counter-multi-select{min-height:130px}.manage-counter-picker{position:relative;z-index:20}.manage-counter-picker-trigger{width:100%;min-height:44px;border:1px solid #dbe3ef;border-radius:10px;background:#fff;padding:10px 12px;font-size:14px;color:#0f172a;display:flex;justify-content:space-between;align-items:center;cursor:pointer}.manage-counter-picker-arrow{color:#64748b;font-size:11px}.manage-counter-selected-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.manage-counter-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;background:#e0ebff;color:#1e40af;font-size:12px;font-weight:700}.manage-counter-chip button{border:0;background:transparent;color:#1e3a8a;font-weight:700;cursor:pointer;padding:0;line-height:1}.manage-counter-picker-menu{position:absolute;z-index:10;top:calc(100% + 8px);left:0;right:0;max-height:220px;overflow-y:auto;border:1px solid #dbe3ef;border-radius:10px;background:#fff;box-shadow:0 14px 30px #0f172a1f;padding:6px}.manage-counter-picker-option{display:flex;align-items:center;gap:8px;padding:8px;border-radius:8px;cursor:pointer}.manage-counter-picker-option:hover{background:#f8fafc}.manage-counter-picker-option input{margin:0}.manage-counter-picker-option span{display:flex;justify-content:space-between;width:100%;gap:8px;font-size:13px;color:#1e293b}.manage-counter-picker-option em{font-style:normal;color:#64748b;text-transform:capitalize}.manage-counter-picker-empty{margin:0;padding:10px;color:#64748b;font-size:13px}.manage-counter-table-wrap{padding:0 16px 10px;overflow-x:auto}.manage-counter-table{width:100%;border-collapse:collapse;min-width:420px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden}.manage-counter-table th,.manage-counter-table td{text-align:left;padding:12px 14px;border-bottom:1px solid #edf2f7;font-size:14px;color:#1e293b}.manage-counter-table th{background:#f8fafc;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#64748b}.manage-counter-table tbody tr:last-child td{border-bottom:0}.manage-counter-delete-btn{border:1px solid #fecaca;background:#fff1f2;color:#9f1239;border-radius:8px;padding:6px 10px;font-size:12px;font-weight:700;cursor:pointer}.manage-counter-delete-btn:hover:not(:disabled){background:#ffe4e6}.manage-counter-delete-btn:disabled{opacity:.7;cursor:not-allowed}.manage-counter-edit-btn{border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;border-radius:8px;padding:6px 10px;font-size:12px;font-weight:700;cursor:pointer}.manage-counter-edit-btn:hover:not(:disabled){background:#dbeafe}.manage-counter-edit-btn:disabled{opacity:.7;cursor:not-allowed}.manage-counter-row-actions{display:inline-flex;gap:8px}.manage-counter-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;text-transform:capitalize}.manage-counter-badge-active{background:#dcfce7;color:#166534}.manage-counter-badge-inactive{background:#fee2e2;color:#991b1b}.manage-counter-empty{margin:0;padding:0 16px 14px;font-size:14px;color:#64748b}.counter-queue-page{display:grid;gap:18px}.counter-queue-card{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #d9e2ef;border-radius:18px;box-shadow:0 14px 34px #0f172a14;overflow:hidden}.counter-queue-card-header{background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff;font-size:18px;font-weight:700;padding:14px 20px}.counter-queue-card-header-inner{display:flex;justify-content:space-between;align-items:center;gap:12px}.counter-queue-card-title{font-size:18px;font-weight:700}.counter-queue-card-body{padding:20px;display:grid;gap:14px}.counter-queue-top-controls{display:flex;justify-content:flex-end;align-items:center;gap:16px}.counter-queue-counter-select{display:grid;gap:6px;color:#475569;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.counter-queue-counter-select select{min-width:240px;border:1px solid #dbe3ef;border-radius:10px;padding:9px 12px;font-size:14px;color:#0f172a;background:#fff}.counter-queue-counter-select-header{color:#e2e8f0}.counter-queue-counter-select-header span{color:#dbeafe}.counter-queue-sound-toggle{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:#475569;background:#f1f5f9;border:1px solid #dbe3ef;border-radius:999px;padding:6px 10px}.counter-queue-now-serving-label{margin:0;text-align:center;color:#6b7280;font-size:11px;letter-spacing:.12em;font-weight:700;text-transform:uppercase}.counter-queue-now-serving-value{margin:10px auto 0;text-align:center;font-size:72px;font-weight:900;letter-spacing:.02em;line-height:1;color:#1e40af;padding:20px 40px;background:#eff6ff;border:3px solid #bfdbfe;border-radius:18px;box-shadow:0 4px 16px #1e40af1a}.counter-queue-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;width:550px;margin:0 auto}.counter-queue-actions button{border-radius:12px;font-size:16px;font-weight:700;padding:12px}.counter-queue-actions button:nth-child(1){background:#2f6ecf}.counter-queue-actions button:nth-child(2){background:#e6a323;color:#1f2937}.counter-queue-actions button:nth-child(3){background:#33a038}.counter-queue-actions button:disabled{opacity:.7;cursor:not-allowed}.counter-queue-skipped-inline{border-top:1px solid #e5e7eb;padding-top:10px;display:grid;gap:8px}.counter-queue-skipped-inline p{margin:0;color:#6b7280;font-size:12px;font-weight:700}.counter-queue-skip-chips{display:flex;flex-wrap:wrap;gap:8px}.counter-queue-skip-chips button{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;border-radius:999px;padding:6px 12px;font-size:14px;font-weight:700}.counter-queue-skip-chips span{color:#9ca3af;font-size:13px}.counter-queue-lists{display:grid;grid-template-columns:repeat(3,minmax(200px,1fr));gap:16px}.counter-queue-list-card{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #d7e1ef;border-radius:16px;padding:14px;box-shadow:0 8px 18px #0f172a0d;display:grid;gap:10px;align-content:start}.counter-queue-list-card-waiting h4{color:#1e3a8a;border-bottom-color:#dbeafe}.counter-queue-list-card-skipped{background:linear-gradient(180deg,#fff,#fffaf3);border-color:#f4dfba}.counter-queue-list-card-skipped h4{color:#9a3412;border-bottom-color:#fde7c3}.counter-queue-list-card-completed{background:linear-gradient(180deg,#fff,#f5fbf7);border-color:#cce6d6}.counter-queue-list-card-completed h4{color:#166534;border-bottom-color:#d8f0e0}.counter-queue-lists article h4{margin:0;color:#334155;font-size:15px;font-weight:800;letter-spacing:.04em;padding:0 2px 8px;border-bottom:1px solid #e5edf8}.counter-queue-token-list{display:grid;gap:8px;height:380px;max-height:380px;overflow-y:auto;padding-right:6px;align-content:start;align-items:start;justify-items:stretch}.counter-queue-token-list::-webkit-scrollbar{width:8px}.counter-queue-token-list::-webkit-scrollbar-track{background:#edf2f9;border-radius:999px}.counter-queue-token-list::-webkit-scrollbar-thumb{background:#c4d2e8;border-radius:999px}.counter-queue-token-list::-webkit-scrollbar-thumb:hover{background:#aebfdc}.counter-queue-token-row{width:100%;border:1px solid #e4eaf4;border-radius:10px;background:#fff;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;color:#0f172a;box-shadow:0 1px #0f172a05;transition:transform .14s ease,border-color .18s ease,box-shadow .18s ease}.counter-queue-token-row:hover{border-color:#cbd8eb;box-shadow:0 5px 12px #0f172a0f;transform:translateY(-1px)}.counter-queue-token-row strong{font-size:18px;letter-spacing:.02em}.counter-queue-token-row span{color:#64748b;font-size:12px}.counter-queue-token-row-button{text-align:left;cursor:pointer}.counter-queue-token-row-button span{color:#64748b;font-weight:500}.counter-queue-list-card-skipped .counter-queue-token-row{border-color:#f3e2c5;background:#fffdf9}.counter-queue-list-card-skipped .counter-queue-token-row:hover{border-color:#efcf9a}.counter-queue-list-card-skipped .counter-queue-token-row strong{color:#92400e}.counter-queue-list-card-completed .counter-queue-token-row{border-color:#d7eadf;background:#fbfefc}.counter-queue-list-card-completed .counter-queue-token-row:hover{border-color:#b8dbc7}.counter-queue-list-card-completed .counter-queue-token-row strong{color:#166534}.counter-queue-empty{margin:0;color:#94a3b8;font-size:14px;padding:8px 2px 2px}@media (max-width: 980px){.login-layout{grid-template-columns:1fr;min-height:auto}.brand-panel,.login-card{padding:36px 28px}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.module-grid{justify-content:stretch}.dashboard-title{font-size:24px}.dashboard-subtitle,.dashboard-user{font-size:12px}.token-card-top h3{font-size:24px}.token-card-top p,.token-meta{font-size:13px}.token-generate-btn{font-size:15px;min-width:130px;padding:10px 16px}.token-latest p{font-size:13px}.token-latest strong{font-size:20px}.dashboard-wrapper{padding:0}.manage-counter-form-grid{grid-template-columns:1fr}.counter-queue-top-controls,.counter-queue-card-header-inner{flex-direction:column;align-items:flex-start}.counter-queue-now-serving-value{font-size:48px}}.tv-display-page{display:grid;gap:16px}.tv-display-live-link{display:inline-block;text-decoration:none;text-align:center;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;border-radius:10px;padding:9px 14px;font-size:13px;font-weight:700;line-height:1;cursor:pointer;white-space:nowrap;width:auto;min-width:170px;transition:all .18s ease}.tv-display-live-link:hover{background:#dbeafe;border-color:#93c5fd}.tv-display-live-link:active{transform:translateY(1px)}.tv-display-source-cell{width:120px;min-width:120px;max-width:120px;word-break:break-all}.success-message{margin-top:10px;color:#0f7f3d;font-weight:600}.tv-display-thumb-btn{width:96px;height:70px;border:0;background:transparent;padding:0;cursor:pointer;overflow:hidden;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;vertical-align:middle}.tv-display-thumb{width:100%;height:70px;object-fit:cover;border-radius:0;border:0;display:block}.tv-display-toast{position:fixed;right:18px;bottom:18px;z-index:1200;background:#0f7f3d;color:#fff;padding:10px 14px;border-radius:10px;box-shadow:0 8px 24px #0000002e;font-weight:600}.tv-display-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#111827a6;z-index:1300;display:flex;align-items:center;justify-content:center;padding:16px}.tv-display-preview-modal{position:relative;background:#fff;border-radius:12px;padding:12px;max-width:min(920px,96vw);max-height:90vh}.tv-display-preview-close{position:absolute;right:8px;top:8px;width:30px;height:30px;border:0;border-radius:50%;background:#111827;color:#fff;cursor:pointer}.tv-display-preview-image{display:block;max-width:min(880px,90vw);max-height:82vh;object-fit:contain;border-radius:10px}.tv-live-page{position:relative;height:100vh;width:100%;overflow:hidden;background:#f0f3f7}.tv-live-layout{height:100%;width:100%;display:flex;gap:0}.tv-live-media-panel{width:70%;height:100%;position:relative;overflow:hidden;background:#c8ced6;border-right:6px solid #edf2f7}.tv-live-media-head{position:absolute;top:20px;left:20px;right:20px;z-index:10;display:flex;align-items:center;justify-content:space-between;background:transparent;border-bottom:none}.tv-live-brand{display:flex;align-items:center;gap:14px;background:#ffffffeb;padding:10px 24px;border-radius:18px;box-shadow:0 5px 20px #00000014}.tv-live-logo{height:auto;width:auto;max-width:none;object-fit:contain;border-radius:8px;flex-shrink:0}.tv-live-title{color:#0f172a;font-size:34px;font-weight:700;letter-spacing:0;text-transform:none}.tv-live-clock{color:#0f172a;font-weight:600;font-size:24px;font-variant-numeric:tabular-nums;background:#ffffffeb;padding:14px 22px;border-radius:18px;box-shadow:0 5px 20px #00000014}.tv-live-media-stage{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:#fff}.tv-live-media-image,.tv-live-media-video,.tv-live-media-youtube{width:100%;height:100%;object-fit:cover;border:0;display:block}.tv-live-media-youtube{position:absolute;top:0;right:0;bottom:0;left:0;width:70%;height:90%;margin:auto}.tv-live-media-caption{position:absolute;left:14px;bottom:58px;margin:0;padding:8px 11px;border-radius:10px;background:#0f172ac7;color:#fff;font-size:14px;font-weight:600;letter-spacing:.01em}.tv-live-media-empty{height:100%;background:#b8bec7}.tv-live-ticker{position:absolute;bottom:0;width:100%;background:#0f172ae6;color:#fff;padding:14px 0;overflow:hidden;white-space:nowrap;z-index:11}.tv-live-ticker span{display:inline-block;padding-left:100%;animation:tv-live-ticker-scroll 20s linear infinite;font-size:24px;font-weight:500}@keyframes tv-live-ticker-scroll{0%{transform:translate(0)}to{transform:translate(-100%)}}.tv-live-serving-panel{width:30%;height:100%;background:#eef2f6;padding:12px 12px 10px;display:flex;flex-direction:column;box-shadow:none}.tv-live-serving-head{background:#fff;border-radius:16px;padding:12px;margin-bottom:12px;text-align:center;box-shadow:0 2px 10px #0000000f}.tv-live-serving-head h2{margin:0;color:#0f172a;font-size:44px;letter-spacing:.5px;text-align:center;font-weight:800;text-transform:uppercase;border-bottom:none;padding-bottom:0}.tv-live-serving-head p{display:none}.tv-live-serving-list{margin-top:0;display:grid;gap:10px;overflow:auto;padding:0 2px 6px}.tv-live-serving-card{background:#fff;border:3px solid transparent;border-radius:18px;padding:10px 14px 8px;text-align:center;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000000d;transition:.3s ease}.tv-live-serving-card-active{border-color:#22c55e;transform:none;animation:none}.tv-live-serving-counter{display:block;color:#1f2937;font-weight:700;margin-bottom:2px;text-align:center;font-size:35px;text-transform:uppercase}.tv-live-serving-token{display:block;color:#0f172a;font-size:74px;font-weight:800;line-height:1;text-align:center}.tv-live-serving-empty{margin-top:0;background:#fff;border:1px dashed #cbd5e1;border-radius:22px;padding:18px 14px;color:#475569;text-align:center}.tv-live-serving-footer{margin-top:auto;background:#fff;border-radius:14px;padding:10px 12px;text-align:center;color:#475569;font-size:31px;font-weight:500;box-shadow:0 2px 10px #0000000d}.tv-live-error{margin:0 0 12px;padding:10px 12px;border-radius:10px;background:#fee2e2;color:#b91c1c;font-size:13px}@media (max-width: 1100px){.counter-queue-lists{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 768px){.dashboard-shell{padding-bottom:24px}.dashboard-topbar{padding-inline:12px}.dashboard-topbar-inner{gap:10px;padding:10px 0}.dashboard-brand-badge{width:34px;height:34px;border-radius:10px;font-size:11px}.dashboard-title{font-size:20px}.stats-grid,.module-grid{grid-template-columns:1fr;gap:10px}.module-card{flex-basis:calc((100% - 12px)/2);max-width:calc((100% - 12px)/2);padding:14px}.module-card-wide{flex-basis:calc((100% - 12px)/2);max-width:calc((100% - 12px)/2)}.module-card h3{font-size:18px}.token-page-wrap{gap:10px}.token-card-top{flex-direction:column;padding:14px;gap:10px}.token-card-top h3{font-size:21px}.token-meta{gap:8px 14px}.token-generate-btn{width:100%;min-width:0;padding:10px 14px;font-size:15px}.counter-queue-actions,.counter-queue-lists{grid-template-columns:1fr}.counter-queue-lists article h4{font-size:20px}.counter-queue-token-row strong{font-size:22px}.counter-queue-token-row span{font-size:14px}}@media (max-width: 640px){.dashboard-shell{padding-inline:0}.dashboard-topbar{padding-inline:12px}.dashboard-wrapper{padding:0}.dashboard-topbar-inner{flex-direction:column;align-items:flex-start}.dashboard-header-actions{width:100%;justify-content:space-between;gap:8px;flex-wrap:wrap}.dashboard-user{width:100%}.stats-grid,.module-grid{grid-template-columns:1fr}.module-card{flex-basis:100%;max-width:100%;min-width:0}.module-card-wide{flex-basis:100%;max-width:100%}.token-meta{flex-direction:row;gap:8px 12px}}@media (max-width: 420px){.dashboard-title{font-size:18px}.header-logout-btn{width:100%}.token-card-top h3{font-size:19px}.token-latest strong{font-size:18px}}.tv-live-page{position:relative;height:100vh;width:100%;min-width:1024px;overflow:hidden;background:#eef2f7}.tv-live-layout{display:grid;grid-template-columns:minmax(0,7fr) minmax(320px,3fr);height:100%}.tv-live-media-panel{position:relative;width:100%;height:100%;background:#d6dbe3;border-right:8px solid #e2e8f0}.tv-live-media-head{position:absolute;top:18px;left:18px;right:18px;z-index:5;display:flex;align-items:center;justify-content:space-between}.tv-live-brand,.tv-live-clock{border-radius:14px;background:#fffffff2;box-shadow:0 6px 18px #0f172a1f}.tv-live-brand{display:flex;align-items:center;gap:12px;padding:8px 16px;border-radius:14px}.tv-live-logo{height:auto;width:auto;max-width:none;object-fit:contain;border-radius:6px;flex-shrink:0}.tv-live-title{color:#0f172a;font-size:24px;font-weight:800;text-transform:uppercase}.tv-live-clock{padding:11px 14px;color:#111827;font-size:22px;font-weight:700}.tv-live-media-stage{position:absolute;top:0;right:0;bottom:0;left:0}.tv-live-media-image,.tv-live-media-video,.tv-live-media-youtube{width:100%;height:100%;display:block;border:0;object-fit:cover}.tv-live-media-youtube{position:absolute;top:0;right:0;bottom:0;left:0}.tv-live-slideshow,.tv-live-slide{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.tv-live-slide-img{width:100%;height:100%;object-fit:cover;display:block;will-change:transform}.tv-live-slide-in{z-index:2;animation:tvFadeIn 1.3s ease-out forwards}.tv-live-slide-out{z-index:1;animation:tvFadeOut 1.5s ease-in forwards}@keyframes tvFadeIn{0%{opacity:0;transform:scale(1.03)}to{opacity:1;transform:scale(1)}}@keyframes tvFadeOut{0%{opacity:1}to{opacity:0}}.tv-live-kb-0{animation:tvKb0 8s ease-in-out infinite alternate}.tv-live-kb-1{animation:tvKb1 8s ease-in-out infinite alternate}.tv-live-kb-2{animation:tvKb2 8s ease-in-out infinite alternate}.tv-live-kb-3{animation:tvKb3 8s ease-in-out infinite alternate}@keyframes tvKb0{0%{transform:scale(1)}to{transform:scale(1.14) translate(-1.8%,-1.2%)}}@keyframes tvKb1{0%{transform:scale(1.14) translate(-1.5%,-1%)}to{transform:scale(1) translate(0)}}@keyframes tvKb2{0%{transform:scale(1)}to{transform:scale(1.12) translate(2%,1.5%)}}@keyframes tvKb3{0%{transform:scale(1.1) translate(1.2%,-1.8%)}to{transform:scale(1) translate(0)}}.tv-live-media-empty{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#cfd5de,#b6bec9)}.tv-live-media-caption{left:12px;bottom:58px;background:#0f172ab8}.tv-live-ticker{position:absolute;bottom:0;width:100%;padding:10px 0;background:#111827;color:#fff;z-index:6;overflow:hidden;white-space:nowrap}.tv-live-ticker span{display:inline-block;padding-left:100%;min-width:max-content;animation:tv-live-marquee 20s linear infinite;font-size:22px;font-weight:500}@keyframes tv-live-marquee{0%{transform:translate(0)}to{transform:translate(-100%)}}.tv-live-serving-panel{width:100%;height:100%;min-height:0;padding:0;display:flex;flex-direction:column;background:linear-gradient(165deg,#d8e2ee,#e9eff7 45%,#d2dce8);box-shadow:inset 1px 0 #ffffff8c}.tv-live-serving-panel-inner{flex:1;min-height:0;display:flex;flex-direction:column;gap:16px;padding:24px 20px 20px}.tv-live-serving-head{margin:0;padding:22px 24px 20px;border-radius:20px;background:linear-gradient(180deg,#fff,#f8fafc);box-shadow:0 1px #ffffffd9 inset,0 10px 32px #0f172a1a;border:1px solid rgba(148,163,184,.38);position:relative;overflow:hidden}.tv-live-serving-head:before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(90deg,#059669,#10b981,#34d399)}.tv-live-serving-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#059669}.tv-live-serving-live-dot{width:9px;height:9px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 3px #22c55e4d;animation:tv-live-pulse-dot 1.8s ease-out infinite}@keyframes tv-live-pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(.88)}}.tv-live-serving-head h2{margin:8px 0 0;color:#0f172a;font-size:clamp(28px,3vw,42px);line-height:1.08;font-weight:800;letter-spacing:-.02em;text-transform:uppercase}.tv-live-serving-list{flex:1;min-height:0;margin:0;padding:4px 4px 4px 0;display:flex;flex-direction:column;gap:10px;overflow-y:auto;overflow-x:hidden}.tv-live-serving-list::-webkit-scrollbar{width:5px}.tv-live-serving-list::-webkit-scrollbar-thumb{background:#64748b66;border-radius:999px}.tv-live-serving-card{position:relative;border-radius:16px;border:2px solid rgba(59,130,246,.35);background:#fff;padding:18px 20px 16px;overflow:hidden;animation:tv-card-pulse 2.2s ease-in-out infinite}@keyframes tv-card-pulse{0%,to{border-color:#3b82f64d;box-shadow:0 0 0 2px #3b82f614,0 4px 16px #0f172a0f}50%{border-color:#3b82f68c;box-shadow:0 0 0 4px #3b82f61f,0 8px 32px #3b82f626,0 0 20px #3b82f614}}.tv-live-serving-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,#60a5fa,#3b82f6,#60a5fa);background-size:100% 200%;animation:tv-bar-scroll 1.8s linear infinite}@keyframes tv-bar-scroll{0%{background-position:0% 0%}to{background-position:0% 200%}}.tv-live-serving-card:after{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(59,130,246,.06) 40%,rgba(59,130,246,.1) 50%,rgba(59,130,246,.06) 60%,transparent 100%);animation:tv-shine-sweep 3s ease-in-out infinite}@keyframes tv-shine-sweep{0%{left:-100%}to{left:200%}}.tv-live-serving-card-active{border-color:#3b82f680;background:linear-gradient(135deg,#eff6ff,#fff 50%)}.tv-live-serving-card-inner{display:flex;align-items:center;justify-content:space-between;gap:12px 20px}.tv-live-serving-card-col{display:flex;flex-direction:column;gap:4px;min-width:0}.tv-live-serving-card-col-counter{flex:1}.tv-live-serving-card-col-token{flex:0 0 auto;align-items:flex-end;text-align:right}.tv-live-serving-card-label{font-size:10px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#94a3b8}.tv-live-serving-counter{margin:0;font-size:clamp(28px,3vw,38px);font-weight:800;color:#334155;line-height:1.2;text-transform:uppercase;word-break:break-word}.tv-live-serving-token{margin:0;font-size:clamp(42px,5vw,64px);font-weight:800;line-height:1;color:#0f172a;font-variant-numeric:tabular-nums}.tv-live-serving-card-active .tv-live-serving-token{color:#1d4ed8}.tv-live-serving-card-active .tv-live-serving-counter{color:#1e293b}.tv-live-serving-empty{flex:1;min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px 24px;border-radius:20px;background:#ffffffb3;border:1px dashed rgba(148,163,184,.6);gap:8px}.tv-live-serving-empty-icon{font-size:40px;font-weight:200;color:#cbd5e1;line-height:1;margin-bottom:4px}.tv-live-serving-empty-title{margin:0;font-size:22px;font-weight:800;color:#475569}.tv-live-serving-empty-copy{margin:0;max-width:28ch;font-size:14px;font-weight:600;line-height:1.5;color:#94a3b8}.tv-live-serving-footer{margin-top:auto;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;padding:16px 20px;border-radius:16px;background:linear-gradient(90deg,#0f172a,#1e293b);color:#e2e8f0;box-shadow:0 8px 24px #0f172a47;border:1px solid rgba(51,65,85,.55)}.tv-live-serving-footer-label{font-size:clamp(12px,1.15vw,15px);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8}.tv-live-serving-footer-value{font-size:clamp(28px,3.2vw,40px);font-weight:800;font-variant-numeric:tabular-nums;color:#fff;line-height:1}.tv-live-serving-footer-credit{margin:10px 0 0;font-size:clamp(12px,1.2vw,18px);font-weight:500;color:#475569;text-align:center;letter-spacing:.02em;line-height:1.4}.tv-live-serving-panel .tv-live-error{margin:0;padding:12px 16px;border-radius:12px;font-size:14px;font-weight:600;background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}
