@import"https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;600&family=Inter:wght@400;500;600;700;800&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f4f6fb;--surface: #ffffff;--surface-raised: #f8fafc;--surface-hover: #f1f5f9;--border: #e2e8f0;--border-strong: #c8d3df;--brand: #2563eb;--brand-hover: #1d4ed8;--brand-light: #3b82f6;--brand-dim: #eff6ff;--brand-text: #1e40af;--sidebar-bg: #0f172a;--sidebar-border: #1e293b;--sidebar-text: #94a3b8;--sidebar-text-active: #f8fafc;--sidebar-item-hover: #1e293b;--sidebar-accent: #60a5fa;--success: #059669;--success-bg: #ecfdf5;--success-text: #065f46;--warning: #d97706;--warning-bg: #fffbeb;--warning-text: #92400e;--danger: #dc2626;--danger-bg: #fef2f2;--danger-text: #991b1b;--info: #0284c7;--info-bg: #f0f9ff;--info-text: #0c4a6e;--font: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-ui: "Inter", "Noto Sans JP", -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Menlo", "Monaco", monospace;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(15,23,42,.06);--shadow-sm: 0 1px 3px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.04);--shadow: 0 4px 8px rgba(15,23,42,.06), 0 2px 4px rgba(15,23,42,.04);--shadow-md: 0 8px 20px rgba(15,23,42,.08), 0 3px 8px rgba(15,23,42,.04);--shadow-lg: 0 20px 40px rgba(15,23,42,.12), 0 8px 16px rgba(15,23,42,.06);--transition: .18s ease;--transition-slow: .32s cubic-bezier(.4, 0, .2, 1)}html,body{font-family:var(--font);font-size:15px;line-height:1.6;color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}.layout-admin{display:flex;min-height:100vh}.sidebar{width:248px;flex-shrink:0;background:var(--sidebar-bg);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid rgba(255,255,255,.04);scrollbar-width:none}.sidebar::-webkit-scrollbar{display:none}.sidebar-logo{padding:1.5rem 1.25rem 1.125rem;border-bottom:1px solid var(--sidebar-border)}.sidebar-logo-eyebrow{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--sidebar-accent);margin-bottom:.35rem;font-family:var(--font-ui)}.sidebar-logo-title{font-size:.875rem;font-weight:600;color:#f1f5f9;line-height:1.4}.sidebar-nav{padding:.875rem .75rem;flex:1;display:flex;flex-direction:column;gap:.125rem}.sidebar-section-label{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:#334155;padding:.875rem .875rem .375rem;font-family:var(--font-ui)}.sidebar-btn{display:flex;align-items:center;gap:.625rem;padding:.525rem .875rem;border:none;background:none;border-radius:8px;cursor:pointer;color:var(--sidebar-text);font-family:var(--font);font-size:.845rem;font-weight:500;width:100%;text-align:left;transition:all var(--transition);position:relative}.sidebar-btn:hover{background:#ffffff0f;color:#e2e8f0}.sidebar-btn.active{background:#60a5fa24;color:#f0f9ff;font-weight:600}.sidebar-btn.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:50%;background:linear-gradient(180deg,#60a5fa,#3b82f6);border-radius:0 3px 3px 0}.sidebar-btn svg{flex-shrink:0;opacity:.5;transition:opacity var(--transition)}.sidebar-btn.active svg,.sidebar-btn:hover svg{opacity:1}.sidebar-btn.danger{color:#f87171}.sidebar-btn.danger:hover{background:#f871711a;color:#fca5a5}.sidebar-divider{height:1px;background:var(--sidebar-border);margin:.5rem .75rem}.sidebar-footer{padding:.75rem;border-top:1px solid var(--sidebar-border)}.admin-main{flex:1;min-width:0;display:flex;flex-direction:column}.page-header{background:var(--surface);border-bottom:1px solid var(--border);padding:.875rem 1.75rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;gap:1rem}.page-title{font-size:1.05rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.page-subtitle{font-size:.775rem;color:var(--text-muted);margin-top:.15rem}.page-content{padding:1.75rem;flex:1}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:1rem}.card-title{font-size:.95rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.375rem 1.25rem;box-shadow:var(--shadow-xs);position:relative;overflow:hidden;transition:box-shadow var(--transition)}.stat-card:hover{box-shadow:var(--shadow)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--stat-accent, var(--brand));border-radius:var(--radius-lg) var(--radius-lg) 0 0;opacity:.85}.stat-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.5rem;font-family:var(--font-ui)}.stat-value{font-size:1.875rem;font-weight:800;color:var(--text-primary);line-height:1;font-family:var(--font-mono);letter-spacing:-.03em}.stat-sublabel{font-size:.775rem;color:var(--text-secondary);margin-top:.35rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem 1rem;border-radius:var(--radius);border:1.5px solid transparent;font-family:var(--font);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition);text-decoration:none;line-height:1.4;white-space:nowrap;-webkit-user-select:none;user-select:none;letter-spacing:.005em}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}.btn-primary:hover{background:var(--brand-hover);border-color:var(--brand-hover);box-shadow:0 4px 14px #2563eb59;transform:translateY(-1px)}.btn-secondary{background:var(--surface);color:var(--text-secondary);border-color:var(--border-strong)}.btn-secondary:hover{background:var(--surface-hover);color:var(--text-primary);border-color:#94a3b8;box-shadow:var(--shadow-xs)}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover{background:#047857;box-shadow:0 4px 14px #0596694d;transform:translateY(-1px)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:#fecaca}.btn-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover{background:var(--surface-raised);color:var(--text-primary)}.btn-sm{padding:.3rem .7rem;font-size:.8rem;border-radius:var(--radius-sm);gap:.3rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem;border-radius:var(--radius-lg)}.btn-icon{width:34px;height:34px;padding:0;border-radius:var(--radius)}.form-group{margin-bottom:1.1rem}.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--text-secondary);margin-bottom:.375rem;letter-spacing:.01em}.form-input{width:100%;padding:.575rem .875rem;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-size:.9rem;color:var(--text-primary);background:var(--surface);transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);outline:none;appearance:none;-webkit-appearance:none}.form-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #2563eb1a;background:#fefeff}.form-input::placeholder{color:var(--text-muted)}select.form-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem;cursor:pointer}textarea.form-input{resize:vertical;min-height:80px}.badge{display:inline-flex;align-items:center;gap:.2rem;padding:.2rem .55rem;border-radius:var(--radius-full);font-size:.72rem;font-weight:700;line-height:1.4;font-family:var(--font-ui);letter-spacing:.01em}.badge-success{background:var(--success-bg);color:var(--success-text)}.badge-warning{background:var(--warning-bg);color:var(--warning-text)}.badge-danger{background:var(--danger-bg);color:var(--danger-text)}.badge-info{background:var(--info-bg);color:var(--info-text)}.badge-gray{background:#f1f5f9;color:#475569}.badge-blue{background:#eff6ff;color:#1d4ed8}.table-container{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}.table{width:100%;border-collapse:collapse;font-size:.875rem}.table th{background:var(--surface-raised);color:var(--text-secondary);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;font-family:var(--font-ui)}.table td{padding:.875rem 1rem;border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:var(--surface-raised)}.tabs{display:flex;border-bottom:2px solid var(--border);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;gap:.125rem}.tabs::-webkit-scrollbar{display:none}.tab-btn{padding:.75rem 1.125rem;border:none;background:none;cursor:pointer;font-family:var(--font);font-size:.875rem;font-weight:500;color:var(--text-muted);border-bottom:2.5px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all var(--transition);display:flex;align-items:center;gap:.4rem;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tab-btn:hover{color:var(--text-secondary);background:var(--surface-raised)}.tab-btn.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:700;background:#2563eb0a}.toggle-label{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer}.toggle-input{position:absolute;opacity:0;width:0;height:0}.toggle-track{width:38px;height:21px;background:var(--border-strong);border-radius:var(--radius-full);transition:background var(--transition);position:relative;flex-shrink:0}.toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:15px;height:15px;background:#fff;border-radius:50%;transition:transform var(--transition);box-shadow:0 1px 3px #0003}.toggle-input:checked+.toggle-track{background:var(--success)}.toggle-input:checked+.toggle-track:after{transform:translate(17px)}.progress{width:100%;height:5px;background:var(--border);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--success),#34d399);border-radius:var(--radius-full);transition:width .6s ease}.alert{display:flex;gap:.75rem;padding:.875rem 1rem;border-radius:var(--radius);border:1px solid transparent;font-size:.875rem;align-items:flex-start}.alert-success{background:var(--success-bg);border-color:#a7f3d0;color:var(--success-text)}.alert-warning{background:var(--warning-bg);border-color:#fde68a;color:var(--warning-text)}.alert-danger{background:var(--danger-bg);border-color:#fecaca;color:var(--danger-text)}.alert-info{background:var(--info-bg);border-color:#bae6fd;color:var(--info-text)}.modal-overlay{position:fixed;inset:0;background:#0a0f1eb3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeOverlay .2s ease}@keyframes fadeOverlay{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-xl);padding:2rem;width:100%;max-width:500px;box-shadow:var(--shadow-lg),0 0 0 1px #ffffff80 inset;animation:slideInModal .28s cubic-bezier(.34,1.56,.64,1)}@keyframes slideInModal{0%{opacity:0;transform:scale(.93) translateY(-14px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-sm{max-width:380px}.modal-lg{max-width:680px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;gap:1rem}.modal-title{font-size:1.05rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.modal-close{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:none;background:var(--surface-raised);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:all var(--transition);flex-shrink:0}.modal-close:hover{background:var(--border);color:var(--text-primary)}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border)}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:.75rem;color:var(--text-muted)}.empty-state{text-align:center;padding:3rem 2rem;color:var(--text-muted)}.material-item{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition)}.material-item:hover{border-color:var(--border-strong);box-shadow:var(--shadow-xs);transform:translate(1px)}.material-icon{width:38px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.material-icon.pdf{background:#fef2f2;color:#dc2626}.material-icon.url{background:#eff6ff;color:#2563eb}.material-icon.text{background:#fafaf9;color:#57534e}.material-icon.csv{background:#f0fdf4;color:#16a34a}.material-icon.img{background:#fdf4ff;color:#9333ea}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeIn .22s ease forwards}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:2000;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.toast{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;background:#0f172a;color:#f1f5f9;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);font-size:.875rem;font-weight:500;max-width:360px;pointer-events:auto;animation:toastIn .3s cubic-bezier(.34,1.56,.64,1);border:1px solid rgba(255,255,255,.08)}.toast.removing{animation:toastOut .25s ease forwards}.toast-success{border-left:3px solid #10b981}.toast-error{border-left:3px solid #f87171}.toast-info{border-left:3px solid var(--sidebar-accent)}@keyframes toastIn{0%{opacity:0;transform:translate(24px) scale(.94)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(24px)}}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.flex-1{flex:1}.min-w-0{min-width:0}.w-full{width:100%}.text-sm{font-size:.875rem}.text-xs{font-size:.72rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.hidden{display:none!important}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.login-page{display:flex;min-height:100vh;background:#060c1a;position:relative;overflow:hidden;font-family:var(--font)}.login-bg{position:absolute;inset:0;background:radial-gradient(ellipse 120% 80% at 15% 60%,rgba(37,99,235,.18) 0%,transparent 55%),radial-gradient(ellipse 80% 100% at 85% 30%,rgba(16,185,129,.1) 0%,transparent 55%),radial-gradient(ellipse 60% 60% at 60% 80%,rgba(139,92,246,.08) 0%,transparent 50%)}.login-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:56px 56px;-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black,transparent);mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black,transparent)}.login-bg:before{content:"";position:absolute;top:-20%;left:-10%;width:50%;height:60%;background:radial-gradient(circle,rgba(37,99,235,.12) 0%,transparent 70%);border-radius:50%;filter:blur(60px);animation:orb-drift 12s ease-in-out infinite alternate}.login-bg:after{content:"";position:absolute;bottom:-20%;right:-10%;width:45%;height:55%;background:radial-gradient(circle,rgba(16,185,129,.09) 0%,transparent 70%);border-radius:50%;filter:blur(80px);animation:orb-drift 16s ease-in-out infinite alternate-reverse}@keyframes orb-drift{0%{transform:translate(0) scale(1)}to{transform:translate(4%,3%) scale(1.08)}}.login-panel-left{display:none;flex-direction:column;justify-content:center;padding:4rem 4rem 4rem 5rem;position:relative;z-index:1}@media(min-width:1024px){.login-panel-left{display:flex;flex:1}}.login-brand-tag{display:inline-flex;align-items:center;gap:.5rem;padding:.325rem .875rem;background:#60a5fa1f;border:1px solid rgba(96,165,250,.22);border-radius:9999px;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#93c5fd;margin-bottom:2.25rem;width:fit-content;font-family:Inter,sans-serif}.login-brand-title{font-size:3rem;font-weight:800;color:#fff;line-height:1.15;letter-spacing:-.03em;margin-bottom:1.375rem}.login-brand-title span{background:linear-gradient(135deg,#60a5fa,#34d399 60%,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-brand-desc{font-size:.975rem;color:#475569;line-height:1.75;max-width:400px;margin-bottom:2.75rem}.login-features{display:flex;flex-direction:column;gap:.75rem}.login-feature-item{display:flex;align-items:center;gap:.875rem;color:#94a3b8;font-size:.9rem;padding:.625rem .875rem;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:10px;transition:all .25s}.login-feature-item:hover{background:#ffffff0d;color:#cbd5e1}.login-feature-dot{width:8px;height:8px;border-radius:50%;background:#60a5fa;flex-shrink:0;box-shadow:0 0 8px currentColor}.login-panel-right{display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;z-index:1;width:100%}@media(min-width:1024px){.login-panel-right{width:500px;flex-shrink:0;border-left:1px solid rgba(255,255,255,.05);background:#060c1a80;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}}.login-card{width:100%;max-width:420px;animation:loginCardIn .55s cubic-bezier(.22,1,.36,1)}@keyframes loginCardIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.login-card-inner{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:2.5rem;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);box-shadow:0 32px 64px #00000080,0 1px #ffffff1a inset,0 -1px #0000004d inset}.login-logo{display:flex;align-items:center;gap:.875rem;margin-bottom:2rem}.login-logo-icon{width:44px;height:44px;background:linear-gradient(135deg,#2563eb,#1d4ed8,#1e40af);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px #2563eb80,0 0 0 1px #ffffff1a inset;flex-shrink:0}.login-logo-text-main{font-size:.9rem;font-weight:700;color:#f1f5f9;line-height:1.3;letter-spacing:-.01em}.login-logo-text-sub{font-size:.68rem;color:#475569;font-family:Inter,sans-serif;letter-spacing:.02em;margin-top:.1rem}.login-heading{font-size:1.5rem;font-weight:800;color:#f8fafc;margin-bottom:.375rem;letter-spacing:-.02em}.login-subheading{font-size:.85rem;color:#475569;margin-bottom:2rem;line-height:1.5}.role-selector-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#475569;margin-bottom:.625rem;font-family:Inter,sans-serif}.role-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1.75rem}.role-btn{display:flex;flex-direction:column;align-items:center;gap:.45rem;padding:.875rem .5rem;border:1.5px solid rgba(255,255,255,.08);background:#ffffff0a;color:#64748b;border-radius:12px;cursor:pointer;transition:all .2s ease;font-family:var(--font);outline:none}.role-btn:hover{border-color:#ffffff2e;background:#ffffff14;color:#cbd5e1;transform:translateY(-2px);box-shadow:0 8px 16px #0000004d}.role-btn.active{border-color:#2563eb;background:#2563eb2e;color:#93c5fd;transform:translateY(-2px);box-shadow:0 8px 20px #2563eb40}.role-btn.active.hq{border-color:#f59e0b;background:#f59e0b26;color:#fcd34d;box-shadow:0 8px 20px #f59e0b33}.role-btn.active.region{border-color:#2563eb;background:#2563eb26;color:#93c5fd;box-shadow:0 8px 20px #2563eb33}.role-btn.active.participant{border-color:#10b981;background:#10b98126;color:#6ee7b7;box-shadow:0 8px 20px #10b98133}.role-btn-icon{width:34px;height:34px;border-radius:9px;background:#ffffff12;display:flex;align-items:center;justify-content:center;transition:all .2s}.role-btn.active .role-btn-icon{background:#ffffff24}.role-btn-label{font-size:.72rem;font-weight:600;line-height:1.3;text-align:center}.login-form{display:flex;flex-direction:column;gap:0}.login-field{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1.125rem;transition:all .25s ease}.login-field.hidden-field{display:none}.login-field-label{font-size:.78rem;font-weight:600;color:#64748b;letter-spacing:.02em;font-family:Inter,sans-serif}.login-input{width:100%;padding:.7rem .9rem;background:#ffffff0f;border:1.5px solid rgba(255,255,255,.1);border-radius:10px;color:#f1f5f9;font-family:var(--font);font-size:.9rem;outline:none;transition:all .2s;appearance:none;-webkit-appearance:none}.login-input:focus{border-color:#3b82f6;background:#3b82f614;box-shadow:0 0 0 3px #3b82f626}.login-input::placeholder{color:#334155}.login-input option{background:#1e293b;color:#f1f5f9}.login-btn{width:100%;padding:.8rem;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:11px;font-family:var(--font);font-size:.95rem;font-weight:700;cursor:pointer;transition:all .22s;margin-top:.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem;letter-spacing:.01em;box-shadow:0 4px 16px #2563eb59,0 1px #ffffff26 inset;position:relative;overflow:hidden}.login-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.1) 0%,transparent 100%);border-radius:11px;pointer-events:none}.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #2563eb80,0 1px #ffffff26 inset}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.login-btn.role-hq{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 16px #d9770659,0 1px #ffffff26 inset}.login-btn.role-hq:hover:not(:disabled){box-shadow:0 8px 24px #d9770680,0 1px #ffffff26 inset}.login-btn.role-participant{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 16px #05966959,0 1px #ffffff26 inset}.login-btn.role-participant:hover:not(:disabled){box-shadow:0 8px 24px #05966980,0 1px #ffffff26 inset}.login-message{padding:.75rem .9rem;border-radius:10px;font-size:.83rem;font-weight:500;margin-bottom:1.125rem;display:none;animation:msgFadeIn .25s ease}.login-message.show{display:block}.login-message.error{background:#dc262624;border:1px solid rgba(220,38,38,.28);color:#fca5a5}.login-message.success{background:#05966924;border:1px solid rgba(5,150,105,.28);color:#6ee7b7}@keyframes msgFadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}
