:root{--pa-primary:#0f2744;--pa-on-primary:#f8fafc;--pa-primary-container:#1d4ed8;--pa-primary-glow:#1d4ed838;--pa-secondary:#0369a1;--pa-secondary-fixed:#bae6fd;--pa-on-secondary-fixed-variant:#0c4a6e;--pa-surface:#f1f5f9;--pa-surface-low:#e2e8f0;--pa-surface-container-lowest:#fff;--pa-on-surface:#0f172a;--pa-on-surface-variant:#475569;--pa-outline:#94a3b873;--pa-outline-variant:#cbd5e1;--pa-error:#dc2626;--pa-error-bg:#fef2f2;--pa-success-bg:#ecfdf5;--pa-shadow:#0f172a0f;--pa-shadow-md:#0f172a1a;--pa-nav-h:76px;--font-display:"Outfit", system-ui, sans-serif;--font-inter:"Inter", system-ui, sans-serif;--radius-sm:10px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--ease-out:cubic-bezier(.22, 1, .36, 1);--transition-fast:.18s var(--ease-out)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}*{box-sizing:border-box}html{scroll-behavior:smooth}html,body{min-height:100%;font-family:var(--font-inter);color:var(--pa-on-surface);background-color:var(--pa-surface);background-image:radial-gradient(ellipse 120% 80% at 50% -30%, var(--pa-primary-glow), transparent 55%), radial-gradient(ellipse 70% 50% at 100% 0%, #0ea5e912, transparent 45%);-webkit-font-smoothing:antialiased;margin:0;font-size:15px;line-height:1.5}#root{min-height:100vh;padding-bottom:calc(var(--pa-nav-h) + 28px)}a{color:var(--pa-secondary);text-underline-offset:3px}a:hover{color:var(--pa-primary-container)}.hidden{display:none!important}.login-wrap{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--pa-surface-container-lowest);border-radius:var(--radius-lg);border:1px solid var(--pa-outline);width:100%;max-width:420px;box-shadow:0 4px 6px -1px var(--pa-shadow), 0 24px 48px -12px var(--pa-shadow-md);overflow:hidden}.login-accent{background:linear-gradient(90deg, var(--pa-primary) 0%, var(--pa-primary-container) 48%, #0ea5e9 100%);height:5px}.login-body{padding:32px 28px 28px}.login-icon{border-radius:var(--radius-md);background:linear-gradient(145deg, var(--pa-surface-low), #f8fafc);border:1px solid var(--pa-outline);justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 16px;font-size:34px;display:flex;box-shadow:inset 0 1px #fffc}.login-title{font-family:var(--font-display);color:var(--pa-primary);text-align:center;letter-spacing:-.04em;margin:0 0 8px;font-size:1.5rem;font-weight:800}.login-sub{text-align:center;color:var(--pa-on-surface-variant);margin:0 0 24px;font-size:.875rem;line-height:1.55}.field{margin-bottom:16px}.field label{text-transform:uppercase;letter-spacing:.04em;color:var(--pa-on-surface-variant);margin-bottom:8px;font-size:.75rem;font-weight:600;display:block}.field-row{flex-direction:row;align-items:center;gap:10px;margin-bottom:16px;display:flex}.field-row label{text-transform:none;letter-spacing:0;color:var(--pa-on-surface);cursor:pointer;align-items:center;gap:10px;margin-bottom:0;font-size:.8125rem;font-weight:500;display:flex}.field-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--pa-primary-container);border-radius:4px}.field input,.field select,.field textarea{border-radius:var(--radius-sm);border:1px solid var(--pa-outline-variant);width:100%;font-family:var(--font-inter);background:var(--pa-surface-container-lowest);color:var(--pa-on-surface);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:12px 14px;font-size:.9375rem}.field textarea{resize:vertical;min-height:100px}.field input:hover,.field select:hover,.field textarea:hover{border-color:#94a3b8}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--pa-primary-container);box-shadow:0 0 0 3px var(--pa-primary-glow);outline:none}.btn-primary{border-radius:var(--radius-sm);width:100%;font-family:var(--font-inter);color:var(--pa-on-primary);background:linear-gradient(180deg, #2563eb 0%, var(--pa-primary-container) 100%);cursor:pointer;box-shadow:0 1px 2px var(--pa-shadow-md);transition:transform var(--transition-fast), box-shadow var(--transition-fast), filter var(--transition-fast);border:none;margin-top:10px;padding:14px 18px;font-size:.9375rem;font-weight:600}.btn-primary:hover:not(:disabled){filter:brightness(1.05);box-shadow:0 4px 14px -2px #1d4ed873}.btn-primary:active:not(:disabled){transform:translateY(1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;filter:none;box-shadow:none}.btn-ghost{background:var(--pa-surface-container-lowest);border:1px solid var(--pa-outline-variant);color:var(--pa-primary);border-radius:var(--radius-sm);font-family:var(--font-inter);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);padding:10px 16px;font-size:.875rem;font-weight:600}.btn-ghost:hover{background:var(--pa-surface-low);border-color:#94a3b8}.msg{border-radius:var(--radius-sm);border:1px solid #0000;margin-bottom:14px;padding:12px 14px;font-size:.875rem}.msg.err{background:var(--pa-error-bg);color:#991b1b;border-color:#dc262633}.msg.ok{background:var(--pa-success-bg);color:#047857;border-color:#10b98140}.glass-bar{z-index:30;-webkit-backdrop-filter:saturate(1.2)blur(16px);border-bottom:1px solid var(--pa-outline);background:#ffffffb8;margin:0;padding:14px 20px 12px;position:sticky;top:0;box-shadow:inset 0 1px #fff9}.glass-inner{justify-content:space-between;align-items:center;gap:16px;max-width:960px;margin:0 auto;display:flex}.brand{font-family:var(--font-display);color:var(--pa-primary);letter-spacing:-.03em;font-size:.9375rem;font-weight:800;line-height:1.25}.brand-sub{font-family:var(--font-inter);color:var(--pa-on-surface-variant);letter-spacing:.02em;margin-top:2px;font-size:.6875rem;font-weight:500;display:block}.user-mini{color:var(--pa-on-surface-variant);text-align:right;max-width:52%;font-size:.6875rem;line-height:1.45}.user-mini strong{color:var(--pa-on-surface);font-size:.8125rem;font-weight:600;display:block}.page-scroll{max-width:960px;margin:0 auto;padding:12px 20px 28px}.page-title{font-family:var(--font-display);letter-spacing:-.04em;color:var(--pa-on-surface);margin:6px 0 8px;font-size:clamp(1.5rem,4vw,1.75rem);font-weight:800}.sub-head .page-title{margin:0;font-size:1.25rem}.page-sub{color:var(--pa-on-surface-variant);max-width:42rem;margin:0 0 20px;font-size:.875rem;line-height:1.55}.hero{border-radius:var(--radius-lg);background:linear-gradient(135deg, var(--pa-primary) 0%, #1e3a5f 42%, var(--pa-primary-container) 100%);color:var(--pa-on-primary);box-shadow:0 4px 6px -1px var(--pa-shadow), 0 20px 40px -12px #0f274473;margin-bottom:20px;padding:22px 20px 20px;position:relative;overflow:hidden}.hero:after{content:"";pointer-events:none;background:radial-gradient(circle at 100% 0,#ffffff1f,#0000 50%);position:absolute;inset:0}.hero h2,.hero p,.hero-select,.hero .stat-grid{z-index:1;position:relative}.hero h2{font-family:var(--font-display);letter-spacing:-.02em;margin:0 0 6px;font-size:1.125rem;font-weight:800}.hero p{opacity:.92;margin:0 0 14px;font-size:.8125rem;line-height:1.5}.hero-select{border-radius:var(--radius-sm);width:100%;max-width:100%;color:var(--pa-on-primary);font-family:var(--font-inter);cursor:pointer;background:#ffffff24;border:1px solid #ffffff47;padding:10px 12px;font-size:.8125rem;font-weight:600}.hero-select:focus{outline:none;box-shadow:0 0 0 2px #ffffff59}.hero-select option{color:var(--pa-on-surface)}.stat-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-top:16px;display:grid}.stat-cell{border-radius:var(--radius-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff24;border:1px solid #ffffff1f;padding:14px}.stat-cell .lbl{opacity:.88;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:.6875rem}.stat-cell .val{font-family:var(--font-display);letter-spacing:-.02em;font-size:1.0625rem;font-weight:800}.card{background:var(--pa-surface-container-lowest);border-radius:var(--radius-md);border:1px solid var(--pa-outline);box-shadow:0 1px 3px var(--pa-shadow);transition:box-shadow var(--transition-fast);margin-bottom:14px;padding:18px}.card:hover{box-shadow:0 8px 24px -8px var(--pa-shadow-md)}.card h3{font-family:var(--font-display);letter-spacing:-.02em;margin:0 0 12px;font-size:1rem;font-weight:700}.row-list{flex-direction:column;gap:0;display:flex}.row-item{border-bottom:1px solid var(--pa-outline-variant);justify-content:space-between;align-items:flex-start;gap:12px;padding:14px 0;font-size:.875rem;display:flex}.row-item:last-child{border-bottom:none;padding-bottom:0}.muted{color:var(--pa-on-surface-variant);font-size:.8125rem}.badge{letter-spacing:.02em;border-radius:999px;padding:3px 10px;font-size:.6875rem;font-weight:600;display:inline-block}.badge-warn{color:var(--pa-error);background:#dc26261f}.badge-ok{background:var(--pa-secondary-fixed);color:var(--pa-on-secondary-fixed-variant)}.badge-role-admin{color:var(--pa-primary);background:#0f27441a}.badge-role-ql{background:var(--pa-secondary-fixed);color:var(--pa-on-secondary-fixed-variant)}.badge-role-nv{color:#92400e;background:#fbbf2440}.source-bar-wrap{margin-top:8px}.source-row{align-items:center;gap:10px;margin-bottom:10px;font-size:.8125rem;display:flex}.source-row span:first-child{text-overflow:ellipsis;white-space:nowrap;flex:0 0 38%;overflow:hidden}.source-track{background:var(--pa-surface-low);border-radius:999px;flex:1;height:8px;overflow:hidden}.source-fill{background:linear-gradient(90deg, var(--pa-secondary), #0ea5e9);height:100%;transition:width .4s var(--ease-out);border-radius:999px}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.toolbar input[type=search],.toolbar input[type=text]{border-radius:var(--radius-sm);border:1px solid var(--pa-outline-variant);min-width:160px;font-family:var(--font-inter);background:var(--pa-surface-container-lowest);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);flex:1;padding:11px 14px;font-size:.875rem}.toolbar input[type=search]:focus,.toolbar input[type=text]:focus{border-color:var(--pa-primary-container);box-shadow:0 0 0 3px var(--pa-primary-glow);outline:none}.toolbar label{color:var(--pa-on-surface-variant);align-items:center;gap:8px;font-size:.8125rem;display:flex}.chip{border:1px solid var(--pa-outline-variant);background:var(--pa-surface-container-lowest);cursor:pointer;font-size:.8125rem;font-weight:600;font-family:var(--font-inter);color:var(--pa-on-surface-variant);transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast);border-radius:999px;padding:8px 14px}a.chip{color:var(--pa-on-surface-variant);align-items:center;text-decoration:none;display:inline-flex}.chip:hover{color:var(--pa-on-surface);border-color:#94a3b8}.chip.on{background:linear-gradient(180deg, #e0f2fe 0%, var(--pa-secondary-fixed) 100%);border-color:var(--pa-secondary);color:var(--pa-on-secondary-fixed-variant);box-shadow:0 1px 2px #0369a11f}a.chip.on{color:var(--pa-on-secondary-fixed-variant)}.touch-list .touch{text-align:left;border:1px solid var(--pa-outline);border-radius:var(--radius-md);background:var(--pa-surface-container-lowest);width:100%;box-shadow:0 1px 3px var(--pa-shadow);cursor:pointer;font-family:var(--font-inter);color:inherit;transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);margin-bottom:12px;padding:16px 18px;display:block}.touch-list .touch:hover{box-shadow:0 12px 28px -8px var(--pa-shadow-md);border-color:#cbd5e1;transform:translateY(-1px)}.touch-list .touch:active{transform:translateY(0)}.touch .t1{margin-bottom:4px;font-size:.9375rem;font-weight:600}.touch .t2{color:var(--pa-on-surface-variant);font-size:.8125rem;line-height:1.45}.touch .amt{font-family:var(--font-display);color:var(--pa-primary-container);letter-spacing:-.02em;margin-top:8px;font-size:1.0625rem;font-weight:800}.load-more{border-radius:var(--radius-sm);border:1px dashed var(--pa-outline-variant);width:100%;font-family:var(--font-inter);color:var(--pa-secondary);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);background:#ffffff80;margin-top:10px;padding:14px;font-size:.875rem;font-weight:600;display:block}.load-more:hover:not(:disabled){background:var(--pa-surface-container-lowest);border-color:var(--pa-secondary)}.load-more:disabled{opacity:.5;cursor:not-allowed}.tile{border:1px solid var(--pa-outline);border-radius:var(--radius-md);background:var(--pa-surface-container-lowest);width:100%;box-shadow:0 1px 3px var(--pa-shadow);cursor:pointer;text-align:left;font-family:var(--font-inter);color:inherit;transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);align-items:flex-start;gap:16px;margin-bottom:12px;padding:18px;display:flex}a.tile{color:inherit;text-decoration:none}.tile:hover{box-shadow:0 12px 32px -10px var(--pa-shadow-md);border-color:#cbd5e1;transform:translateY(-2px)}.tile:active{transform:translateY(0)}.tile-icon{border-radius:var(--radius-sm);border:1px solid var(--pa-outline);background:linear-gradient(145deg,#e2e8f0,#f1f5f9);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex}.tile h4{font-family:var(--font-display);letter-spacing:-.02em;margin:0 0 4px;font-size:1rem;font-weight:700}.tile p{color:var(--pa-on-surface-variant);margin:0;font-size:.8125rem;line-height:1.45}.account-card .logout-row{margin-top:18px}.admin-link{border-top:1px solid var(--pa-outline-variant);color:var(--pa-on-surface-variant);margin-top:22px;padding-top:18px;font-size:.8125rem}.admin-link a{font-weight:600}.bottom-nav{z-index:40;padding:0 16px calc(12px + env(safe-area-inset-bottom,0));pointer-events:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav-inner{pointer-events:auto;border-radius:var(--radius-xl);-webkit-backdrop-filter:saturate(1.2)blur(20px);max-width:520px;box-shadow:0 4px 6px -1px var(--pa-shadow), 0 20px 40px -12px var(--pa-shadow-md);border:1px solid var(--pa-outline);background:#ffffffe0;justify-content:space-around;align-items:center;margin:0 auto;padding:10px 8px;display:flex}.nav-btn{cursor:pointer;font-family:var(--font-inter);color:var(--pa-on-surface-variant);max-width:76px;transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;border-radius:14px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:8px 6px;font-size:.625rem;font-weight:500;text-decoration:none;display:flex}.nav-btn .ic{transition:transform var(--transition-fast);font-size:22px;line-height:1}.nav-btn.on{color:var(--pa-primary-container);background:#2563eb1a;font-weight:700}.nav-btn.on .ic{transform:scale(1.06)}.sub-head{align-items:center;gap:12px;margin-bottom:16px;display:flex}.sub-head a:first-child,.sub-head button:first-child{flex-shrink:0}.sub-head button,.sub-head>a:first-of-type:not(.chip){border:1px solid var(--pa-outline-variant);background:var(--pa-surface-container-lowest);border-radius:var(--radius-sm);cursor:pointer;width:42px;height:42px;color:var(--pa-primary);transition:background var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);justify-content:center;align-items:center;font-size:1.125rem;text-decoration:none;display:inline-flex}.sub-head button:hover,.sub-head>a:first-of-type:not(.chip):hover{background:var(--pa-surface-low);box-shadow:0 2px 8px var(--pa-shadow);border-color:#94a3b8}.table-wrap{border-radius:var(--radius-sm);border:1px solid var(--pa-outline-variant);background:var(--pa-surface-container-lowest);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.8125rem}th,td{text-align:left;border-bottom:1px solid var(--pa-outline-variant);padding:10px 12px}th{text-transform:uppercase;letter-spacing:.05em;color:var(--pa-on-surface-variant);white-space:nowrap;background:linear-gradient(#f8fafc 0%,#f1f5f9 100%);font-size:.6875rem;font-weight:600}tbody tr:hover td{background:#f1f5f999}tr:last-child td{border-bottom:none}.overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0f172a7a;justify-content:center;align-items:flex-end;padding:16px;display:flex;position:fixed;inset:0}@media (width>=560px){.overlay{align-items:center}}.modal{background:var(--pa-surface-container-lowest);border-radius:var(--radius-lg) var(--radius-lg) 0 0;border:1px solid var(--pa-outline);width:100%;max-width:520px;max-height:88vh;box-shadow:0 -8px 40px var(--pa-shadow-md);padding:22px;overflow-y:auto}@media (width>=560px){.modal{border-radius:var(--radius-lg);box-shadow:0 24px 64px -12px var(--pa-shadow-md)}}.modal h2{font-family:var(--font-display);letter-spacing:-.02em;margin:0 0 14px;font-size:1.125rem;font-weight:800}.modal .close-x{float:right;border:1px solid var(--pa-outline-variant);background:var(--pa-surface-low);border-radius:var(--radius-sm);cursor:pointer;width:38px;height:38px;color:var(--pa-on-surface);transition:background var(--transition-fast);font-size:1.25rem;line-height:1}.modal .close-x:hover{background:#e2e8f0}.modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.empty{text-align:center;color:var(--pa-on-surface-variant);border-radius:var(--radius-sm);border:1px dashed var(--pa-outline-variant);background:#f1f5f980;padding:36px 20px;font-size:.875rem}.spin{text-align:center;color:var(--pa-on-surface-variant);padding:40px 24px;font-size:.875rem;font-weight:500}.spin:after{content:"";border:3px solid var(--pa-outline-variant);border-top-color:var(--pa-primary-container);border-radius:50%;width:28px;height:28px;margin:16px auto 0;animation:.7s linear infinite spin-rotate;display:block}@keyframes spin-rotate{to{transform:rotate(360deg)}}@media (prefers-reduced-motion:reduce){.spin:after{border-top-color:var(--pa-outline-variant);animation:none}}@media (width>=768px){.stat-grid{grid-template-columns:repeat(4,1fr)}.page-scroll{padding-left:28px;padding-right:28px}}
