:root{--navy: #0f172a;--navy-mid: #1e293b;--slate: #334155;--muted: #64748b;--border: #e2e8f0;--bg: #f8fafc;--white: #ffffff;--indigo: #6366f1;--indigo-dk: #4f46e5;--indigo-lt: #eef2ff;--emerald: #10b981;--emerald-lt: #d1fae5;--rose: #f43f5e;--rose-lt: #fff1f2;--amber: #f59e0b;--indigo-darker: #3730a3;--emerald-mid: #059669;--emerald-dark: #065f46;--emerald-darker: #047857;--emerald-border: #a7f3d0;--rose-100: #ffe4e6;--rose-dark: #be123c;--rose-border: #fecdd3;--slate-lt: #94a3b8;--bg-alt: #f1f5f9;--radius-sm: .5rem;--radius: .875rem;--radius-lg: 1.25rem;--shadow-sm: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow: 0 4px 16px rgba(15, 23, 42, .08), 0 1px 4px rgba(15, 23, 42, .06);--shadow-lg: 0 20px 60px rgba(15, 23, 42, .12), 0 4px 16px rgba(15, 23, 42, .06);font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--navy)}@supports (font-variation-settings: normal){:root{font-family:Inter var,Inter,system-ui,sans-serif}}*,*:before,*:after{box-sizing:border-box}body{margin:0;-webkit-font-smoothing:antialiased}.auth-shell{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:1.5rem;background:var(--bg)}.auth-card{width:100%;max-width:440px;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:2.5rem;margin:auto 0}.dash-shell{display:flex;flex-direction:column;height:100dvh;overflow:hidden;background:radial-gradient(ellipse 60% 40% at 70% 0%,rgba(99,102,241,.1) 0%,transparent 60%),var(--bg)}.dash-header{background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.dash-body{flex:1;overflow-y:auto;width:100%;max-width:1024px;margin:0 auto;padding:2.5rem 1.5rem;animation:cardIn .35s ease both;scrollbar-width:none;-ms-overflow-style:none}.dash-body::-webkit-scrollbar{display:none}@keyframes cardIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-logo{display:flex;align-items:center;gap:.5rem;margin-bottom:2rem}.auth-logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--indigo),var(--indigo-dk));border-radius:var(--radius-sm);display:grid;place-items:center;color:var(--white);font-size:1.1rem}.auth-logo-name{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;color:var(--navy)}.auth-card h1{margin:0 0 .25rem;font-size:1.6rem;font-weight:700;letter-spacing:-.03em;color:var(--navy)}.auth-subtitle{font-size:.875rem;color:var(--muted);margin:0 0 1.75rem}.field{display:flex;flex-direction:column;gap:.375rem}.field label{font-size:.8125rem;font-weight:600;color:var(--slate);letter-spacing:.01em}.field input{width:100%;padding:.75rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.9375rem;color:var(--navy);background:var(--white);transition:border-color .15s,box-shadow .15s;outline:none}.field input:focus{border-color:var(--indigo);box-shadow:0 0 0 3px #6366f126}.field input::placeholder{color:var(--slate-lt)}form.auth-form{display:grid;gap:1.1rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;border:none;border-radius:var(--radius-sm);font-size:.9375rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;position:relative;overflow:hidden;width:100%}.btn:active{transform:scale(.98)}.btn-primary{background:linear-gradient(135deg,var(--indigo) 0%,var(--indigo-dk) 100%);color:var(--white);box-shadow:0 2px 8px #6366f159}.btn-primary:hover{background:linear-gradient(135deg,var(--indigo-dk) 0%,var(--indigo-darker) 100%);box-shadow:0 4px 14px #6366f173}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-ghost{background:var(--bg);color:var(--slate);border:1.5px solid var(--border);width:auto}.btn-ghost:hover{background:var(--bg-alt)}.btn-danger{background:var(--rose-lt);color:var(--rose);border:1.5px solid var(--rose-border);width:auto;font-size:.875rem}.btn-danger:hover{background:var(--rose-100)}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:var(--white);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.alert{display:flex;align-items:flex-start;gap:.625rem;padding:.875rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;animation:alertIn .25s ease both}@keyframes alertIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.alert-error{background:var(--rose-lt);color:var(--rose-dark);border:1px solid var(--rose-border)}.alert-success{background:var(--emerald-lt);color:var(--emerald-dark);border:1px solid var(--emerald-border)}.alert-icon{font-size:1rem;flex-shrink:0}.auth-footer{margin-top:1.5rem;text-align:center;font-size:.8125rem;color:var(--muted)}.auth-footer a{color:var(--indigo);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.dash-header{background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.dash-header-brand{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1rem;letter-spacing:-.02em;color:var(--navy)}.dash-header-brand .logo-icon{width:30px;height:30px;background:linear-gradient(135deg,var(--indigo),var(--indigo-dk));border-radius:6px;display:grid;place-items:center;color:var(--white);font-size:.875rem}.dash-body{max-width:1024px;margin:0 auto;padding:2.5rem 1.5rem;animation:cardIn .35s ease both}.dash-body h2{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;letter-spacing:-.03em}.dash-body .page-sub{color:var(--muted);font-size:.875rem;margin:0 0 2rem}.upload-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.75rem;display:grid;gap:1.25rem}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:2.25rem 1.5rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:var(--bg);position:relative}.drop-zone:hover,.drop-zone.over{border-color:var(--indigo);background:var(--indigo-lt)}.drop-zone input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.drop-icon{font-size:2rem;margin-bottom:.5rem;display:block;transition:transform .2s}.drop-zone:hover .drop-icon{transform:translateY(-3px)}.drop-label{font-size:.9375rem;font-weight:600;color:var(--slate)}.drop-hint{font-size:.8125rem;color:var(--muted);margin-top:.25rem}.file-list{display:grid;gap:.5rem}.file-list-header{font-size:.8125rem;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}.file-item{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);animation:fileIn .2s ease both}@keyframes fileIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.file-icon{font-size:1.1rem;flex-shrink:0}.file-name{font-size:.875rem;font-weight:500;color:var(--navy);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-size:.75rem;color:var(--muted);flex-shrink:0}.stepper{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin:.5rem 0;position:relative}.stepper:before{content:"";position:absolute;top:14px;left:calc(12.5% + 14px);right:calc(12.5% + 14px);height:2px;background:var(--border);z-index:0}.stepper-fill{position:absolute;top:14px;left:calc(12.5% + 14px);right:calc(12.5% + 14px);height:2px;background:linear-gradient(90deg,var(--indigo),var(--emerald));z-index:1;transform-origin:left center;transition:transform .5s cubic-bezier(.4,0,.2,1)}.step{display:flex;flex-direction:column;align-items:center;gap:.375rem;position:relative;z-index:2}.step-dot{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:.8125rem;font-weight:700;transition:background .3s,border-color .3s,transform .3s;background:var(--white);border:2px solid var(--border);color:var(--muted)}.step.active .step-dot{background:var(--indigo-lt);border-color:var(--indigo);color:var(--indigo);transform:scale(1.1)}.step.done .step-dot{background:var(--indigo);border-color:var(--indigo);color:var(--white)}.step.complete .step-dot{background:var(--emerald);border-color:var(--emerald);color:var(--white);animation:popIn .35s cubic-bezier(.22,.68,0,1.4) both}@keyframes popIn{0%{transform:scale(.6)}to{transform:scale(1)}}.step-label{font-size:.6875rem;font-weight:600;letter-spacing:.03em;color:var(--muted);text-transform:uppercase;text-align:center;transition:color .3s}.step.active .step-label,.step.done .step-label{color:var(--indigo)}.step.complete .step-label{color:var(--emerald)}.step.active .step-dot:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:2px solid rgba(99,102,241,.3);animation:pulse 1.2s ease-out infinite}@keyframes pulse{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.7)}}.download-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:var(--emerald-lt);border:1.5px solid var(--emerald-border);border-radius:var(--radius);animation:bannerIn .4s cubic-bezier(.22,.68,0,1.2) both}@keyframes bannerIn{0%{opacity:0;transform:scale(.95) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.download-info{flex:1}.download-title{font-size:.9375rem;font-weight:700;color:var(--emerald-dark)}.download-sub{font-size:.8125rem;color:var(--emerald-darker);margin-top:.125rem}.btn-download{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--emerald);color:var(--white);border-radius:var(--radius-sm);font-size:.875rem;font-weight:700;text-decoration:none;transition:background .15s,transform .1s;white-space:nowrap;flex-shrink:0}.btn-download:hover{background:var(--emerald-mid);transform:translateY(-1px)}@media (max-width: 520px){.auth-card{padding:2rem 1.25rem}.dash-header{padding:0 1rem}.dash-body{padding:1.5rem 1rem}.stepper-fill{display:none}.stepper:before{display:none}.stepper{grid-template-columns:repeat(2,1fr);gap:.75rem}.download-banner{flex-direction:column;align-items:flex-start}.btn-download{width:100%;justify-content:center}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.app-footer{width:100%;padding:1rem 1.5rem;font-size:.8125rem;color:var(--muted);text-align:center;flex-shrink:0}.auth-shell .app-footer{border-top:1px solid rgba(226,232,240,.4);background:#fff6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);max-width:440px;margin-top:auto;border-radius:var(--radius-sm)}.dash-shell .app-footer{border-top:1px solid var(--border);background:var(--white)}.footer-content{max-width:1024px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:1rem;width:100%}.profile-section{display:flex;align-items:center;gap:1rem}.profile-info{display:flex;align-items:center;gap:.5rem;background:var(--bg);padding:.375rem .75rem .375rem .375rem;border-radius:20px;border:1px solid var(--border)}.avatar{width:24px;height:24px;background:var(--indigo-lt);color:var(--indigo);border-radius:50%;display:grid;place-items:center}.profile-email{font-size:.8125rem;font-weight:600;color:var(--slate)}.badge-admin{background:var(--amber);color:var(--white);font-size:.6875rem;font-weight:700;padding:.2rem .5rem;border-radius:12px;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 2px 4px #f59e0b4d}.badge-admin-sm{background:var(--amber);color:var(--white);font-size:.6rem;font-weight:700;padding:.15rem .4rem;border-radius:8px;text-transform:uppercase;margin-left:.5rem}.btn-logout{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:.5rem;border-radius:50%;display:grid;place-items:center;transition:background .2s,color .2s}.btn-logout:hover{background:var(--rose-lt);color:var(--rose)}.tabs{display:flex;gap:.5rem;background:var(--bg);padding:.375rem;border-radius:var(--radius);border:1px solid var(--border);width:fit-content}.tab-btn{background:transparent;border:none;padding:.5rem 1.25rem;font-size:.875rem;font-weight:600;color:var(--muted);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.tab-btn:hover{color:var(--navy)}.tab-btn.active{background:var(--white);color:var(--indigo);box-shadow:var(--shadow-sm)}.admin-body{max-width:1280px}.admin-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:2rem;animation:cardIn .35s ease both}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.card-header .btn{width:auto;padding:.5rem 1rem;font-size:.8125rem}.table-responsive{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem;text-align:left}.admin-table th{background:var(--bg);padding:.875rem 1rem;font-weight:600;color:var(--slate);border-bottom:1px solid var(--border)}.admin-table td{padding:1rem;border-bottom:1px solid var(--border);color:var(--navy);vertical-align:middle}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr{transition:background .15s}.admin-table tbody tr:hover{background:#f8fafc}.inactive-row{opacity:.6}.status-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:12px;font-size:.75rem;font-weight:600}.status-badge.active{background:var(--emerald-lt);color:var(--emerald-dark)}.status-badge.inactive{background:var(--rose-lt);color:var(--rose-dark)}.btn-toggle{background:transparent;border:1px solid transparent;padding:.375rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-toggle.btn-danger{color:var(--rose);border-color:var(--rose-border)}.btn-toggle.btn-danger:hover{background:var(--rose-lt)}.btn-toggle.btn-success{color:var(--emerald);border-color:var(--emerald-border)}.btn-toggle.btn-success:hover{background:var(--emerald-lt)}.text-center{text-align:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:50;padding:1rem;animation:fadeIn .2s ease}.modal-content{background:var(--white);border-radius:var(--radius-lg);padding:2rem;width:100%;max-width:400px;box-shadow:var(--shadow-lg);animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.modal-content h3{margin:0 0 .5rem;font-size:1.25rem;color:var(--navy)}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.modal-actions .btn{width:auto}.password-box{background:var(--bg);border:1px dashed var(--border);padding:1rem;border-radius:var(--radius-sm);text-align:center;margin-top:1rem;font-size:1.125rem;color:var(--indigo-dk);letter-spacing:.05em;font-weight:600}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
