@import"https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f0f4f8;--surface: #ffffff;--surface-raised: #f8fafc;--border: #e2e8f0;--border-strong: #cbd5e1;--brand: #2563eb;--brand-hover: #1d4ed8;--brand-dim: #eff6ff;--brand-text: #1e40af;--sidebar-bg: #111827;--sidebar-border: #1f2937;--sidebar-text: #9ca3af;--sidebar-text-active: #f9fafb;--sidebar-item-hover: #1f2937;--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-mono: "JetBrains Mono", "Menlo", "Monaco", monospace;--text-primary: #111827;--text-secondary: #4b5563;--text-muted: #9ca3af;--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow: 0 4px 6px rgba(0,0,0,.06), 0 2px 4px rgba(0,0,0,.04);--shadow-md: 0 8px 16px rgba(0,0,0,.08), 0 3px 6px rgba(0,0,0,.04);--shadow-lg: 0 20px 30px rgba(0,0,0,.1), 0 8px 12px rgba(0,0,0,.05);--transition: .2s ease;--transition-slow: .35s 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:240px;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 var(--sidebar-border)}.sidebar-logo{padding:1.5rem 1.25rem 1.25rem;border-bottom:1px solid var(--sidebar-border)}.sidebar-logo-eyebrow{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--sidebar-accent);margin-bottom:.3rem}.sidebar-logo-title{font-size:.9rem;font-weight:600;color:#fff;line-height:1.35}.sidebar-nav{padding:.75rem;flex:1;display:flex;flex-direction:column;gap:.1rem}.sidebar-section-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#4b5563;padding:.75rem .75rem .3rem}.sidebar-btn{display:flex;align-items:center;gap:.625rem;padding:.55rem .75rem;border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--sidebar-text);font-family:var(--font);font-size:.85rem;font-weight:500;width:100%;text-align:left;transition:all var(--transition);position:relative}.sidebar-btn:hover{background:var(--sidebar-item-hover);color:#e5e7eb}.sidebar-btn.active{background:#60a5fa1f;color:#fff;font-weight:600}.sidebar-btn.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:55%;background:var(--sidebar-accent);border-radius:0 2px 2px 0}.sidebar-btn svg{flex-shrink:0;opacity:.55;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:1rem 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.1rem;font-weight:700;color:var(--text-primary)}.page-subtitle{font-size:.78rem;color:var(--text-muted);margin-top:.1rem}.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)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-xs)}.stat-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.4rem}.stat-value{font-size:1.75rem;font-weight:800;color:var(--text-primary);line-height:1;font-family:var(--font-mono);letter-spacing:-.02em}.stat-sublabel{font-size:.77rem;color:var(--text-secondary);margin-top:.3rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;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}.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 12px #2563eb4d;transform:translateY(-1px)}.btn-secondary{background:var(--surface);color:var(--text-primary);border-color:var(--border-strong)}.btn-secondary:hover{background:var(--surface-raised);border-color:#94a3b8}.btn-success{background:var(--success);color:#fff;border-color:var(--success)}.btn-success:hover{background:#047857;box-shadow:0 4px 12px #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);border-color:var(--border)}.btn-sm{padding:.3rem .7rem;font-size:.8rem;border-radius:var(--radius-sm)}.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:.35rem}.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);outline:none;appearance:none;-webkit-appearance:none}.form-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #2563eb1a}.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='%236b7280' 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}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}.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:#f3f4f6;color:#6b7280}.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:.73rem;text-transform:uppercase;letter-spacing:.06em;padding:.7rem 1rem;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.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}.tabs::-webkit-scrollbar{display:none}.tab-btn{padding:.75rem 1.1rem;border:none;background:none;cursor:pointer;font-family:var(--font);font-size:.875rem;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all var(--transition);display:flex;align-items:center;gap:.4rem}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:700}.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:var(--shadow-xs)}.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:var(--success);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:#0f172aa6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);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);animation:slideInModal .25s cubic-bezier(.34,1.56,.64,1)}@keyframes slideInModal{0%{opacity:0;transform:scale(.94) translateY(-12px)}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.1rem;font-weight:700}.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);font-size:1.1rem;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)}@keyframes spin{to{transform:rotate(360deg)}}.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-raised);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)}.material-icon{width:36px;height:36px;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(6px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeIn .2s 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:var(--sidebar-bg);color:#f9fafb;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)}.toast.removing{animation:toastOut .25s ease forwards}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}.toast-info{border-left:3px solid var(--sidebar-accent)}@keyframes toastIn{0%{opacity:0;transform:translate(20px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(20px)}}.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:#0a0f1e;position:relative;overflow:hidden}.login-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 20% 50%,rgba(37,99,235,.12) 0%,transparent 60%),radial-gradient(ellipse 60% 80% at 80% 50%,rgba(5,150,105,.08) 0%,transparent 60%)}.login-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:48px 48px}.login-panel-left{display:none;flex-direction:column;justify-content:center;padding:4rem;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:.3rem .875rem;background:#60a5fa26;border:1px solid rgba(96,165,250,.25);border-radius:9999px;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#93c5fd;margin-bottom:2rem;width:fit-content}.login-brand-title{font-size:2.75rem;font-weight:800;color:#fff;line-height:1.2;letter-spacing:-.02em;margin-bottom:1.25rem}.login-brand-title span{background:linear-gradient(135deg,#60a5fa,#34d399);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-brand-desc{font-size:1rem;color:#64748b;line-height:1.7;max-width:420px}.login-features{display:flex;flex-direction:column;gap:1rem;margin-top:2.5rem}.login-feature-item{display:flex;align-items:center;gap:.875rem;color:#94a3b8;font-size:.9rem}.login-feature-dot{width:8px;height:8px;border-radius:50%;background:#60a5fa;flex-shrink:0}.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:480px;flex-shrink:0;border-left:1px solid rgba(255,255,255,.05)}}.login-card{width:100%;max-width:400px;animation:loginCardIn .5s cubic-bezier(.34,1.56,.64,1)}@keyframes loginCardIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-card-inner{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:2.25rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.login-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:1.75rem}.login-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #2563eb66}.login-logo-text-main{font-size:.9rem;font-weight:700;color:#fff;line-height:1.3}.login-logo-text-sub{font-size:.7rem;color:#64748b}.login-heading{font-size:1.35rem;font-weight:700;color:#f1f5f9;margin-bottom:.35rem;letter-spacing:-.01em}.login-subheading{font-size:.85rem;color:#64748b;margin-bottom:1.75rem}.role-selector-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#64748b;margin-bottom:.625rem}.role-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1.5rem}.role-btn{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.875rem .5rem;border:1.5px solid rgba(255,255,255,.1);background:#ffffff0a;color:#94a3b8;border-radius:10px;cursor:pointer;transition:all .2s ease;font-family:var(--font)}.role-btn:hover{border-color:#fff3;background:#ffffff12;color:#e2e8f0;transform:translateY(-1px)}.role-btn.active{border-color:#2563eb;background:#2563eb33;color:#93c5fd}.role-btn.active.hq{border-color:#f59e0b;background:#f59e0b26;color:#fcd34d}.role-btn.active.region{border-color:#2563eb;background:#2563eb26;color:#93c5fd}.role-btn.active.participant{border-color:#10b981;background:#10b98126;color:#6ee7b7}.role-btn-icon{width:32px;height:32px;border-radius:8px;background:#ffffff12;display:flex;align-items:center;justify-content:center;transition:all .2s}.role-btn.active .role-btn-icon{background:#ffffff1f}.role-btn-label{font-size:.72rem;font-weight:600;line-height:1.3;text-align:center;white-space:nowrap}.login-form{display:flex;flex-direction:column;gap:0}.login-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem;transition:all .25s ease}.login-field.hidden-field{display:none}.login-field-label{font-size:.78rem;font-weight:600;color:#94a3b8;letter-spacing:.02em}.login-input{width:100%;padding:.625rem .875rem;background:#ffffff0f;border:1.5px solid rgba(255,255,255,.1);border-radius:9px;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:#475569}.login-input option{background:#1e293b;color:#f1f5f9}.login-btn{width:100%;padding:.75rem;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:10px;font-family:var(--font);font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s;margin-top:.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem;letter-spacing:.01em}.login-btn:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-1px);box-shadow:0 6px 20px #2563eb66}.login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.login-btn.role-hq{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 6px 20px #d9770600}.login-btn.role-hq:hover{box-shadow:0 6px 20px #d9770666}.login-btn.role-participant{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 6px 20px #05966900}.login-btn.role-participant:hover{box-shadow:0 6px 20px #05966966}.login-message{padding:.7rem .875rem;border-radius:8px;font-size:.82rem;font-weight:500;margin-bottom:1rem;display:none;animation:fadeIn .2s ease}.login-message.show{display:block}.login-message.error{background:#dc262626;border:1px solid rgba(220,38,38,.3);color:#fca5a5}.login-message.success{background:#05966926;border:1px solid rgba(5,150,105,.3);color:#6ee7b7}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
