:root{--paper:#f6f2ea;--ink:#1b1b1d;--accent:var(--app-blue);--success:#2e7d5a;--warning:#c9871b;--error:#e04e39;--app-paper:#fbf7ee;--app-paper-deep:#f4eadb;--app-ink:#151412;--app-muted:#6f665a;--app-blue:#143f73;--app-blue-soft:#e8eef7;--app-sage:#315c3a;--app-sage-soft:#edf4e7;--app-amber:#91620c;--app-amber-soft:#fff5dd;--app-rose:#8f3f32;--app-rose-soft:#fae8e2;--app-line:#2a241a21;--app-panel:#fffdf8bd;--app-radius-lg:28px;--app-radius-md:22px;--app-radius-sm:12px;--app-shadow:0 18px 48px #2a241a14;--app-shadow-soft:0 14px 30px #2a241a0d;--app-serif:var(--font-display);--student-area-paper:var(--app-paper);--student-area-paper-deep:var(--app-paper-deep);--student-area-ink:var(--app-ink);--student-area-muted:var(--app-muted);--student-area-blue:var(--app-blue);--student-area-blue-soft:var(--app-blue-soft);--student-area-sage:var(--app-sage);--student-area-sage-soft:var(--app-sage-soft);--student-area-amber:var(--app-amber);--student-area-amber-soft:var(--app-amber-soft);--student-area-rose:var(--app-rose);--student-area-rose-soft:var(--app-rose-soft);--student-area-line:var(--app-line);--student-area-panel:var(--app-panel);--student-area-radius-lg:var(--app-radius-lg);--student-area-radius-md:var(--app-radius-md);--student-area-radius-sm:var(--app-radius-sm);--student-area-shadow:var(--app-shadow);--student-area-shadow-soft:var(--app-shadow-soft);--student-area-serif:var(--app-serif);--color-primary-50:#f3f6fb;--color-primary-100:var(--app-blue-soft);--color-primary-200:#cddced;--color-primary-300:#9fb8d5;--color-primary-400:#4775a8;--color-primary-500:var(--accent);--color-primary-600:var(--app-blue);--color-primary-700:#10345f;--color-primary-800:#0e2a4c;--color-primary-900:#0b213a;--color-accent-400:#4775a8;--color-accent-500:var(--accent);--color-accent-600:var(--app-blue);--color-success-400:#49a37a;--color-success-500:var(--success);--color-success-600:#236848;--color-warning-400:#e0a64b;--color-warning-500:var(--warning);--color-warning-600:#9d6b10;--color-error-400:#ef7461;--color-error-500:var(--error);--color-error-600:#b63a2a;--color-info-400:#4f95ff;--color-info-500:#2f76f4;--color-info-600:#205fd1;--color-gray-50:#fcfbf7;--color-gray-100:#f4efe6;--color-gray-200:#e8e1d5;--color-gray-300:#d8cfc0;--color-gray-400:#b7ae9e;--color-gray-500:#8f8679;--color-gray-600:#6c645a;--color-gray-700:#4d4740;--color-gray-800:#2f2b26;--color-gray-900:#1b1b1d;--bg-page:var(--paper);--bg-surface:#fbf8f1;--bg-raised:#fff;--bg-muted:#efe8dd;--bg-primary:var(--bg-raised);--bg-secondary:var(--bg-surface);--bg-tertiary:var(--bg-muted);--text-primary:var(--ink);--text-secondary:#3d3d42;--text-tertiary:#5c5c62;--text-muted:#7b7b82;--text-inverse:#f6f2ea;--border-subtle:#e2dbcf;--border-light:var(--border-subtle);--border-medium:#cfc4b5;--border-strong:#b7aa98;--border-focus:#143f738c;--action-primary:var(--accent);--action-primary-hover:#10345f;--action-secondary:#f0e9dd;--action-secondary-hover:#e5ddcf;--focus-ring:0 0 0 3px #143f7333;--gradient-primary:linear-gradient(120deg, var(--app-blue) 0%, #245a97 100%);--gradient-accent:linear-gradient(120deg, var(--app-blue) 0%, #315c3a 100%);--gradient-success:linear-gradient(120deg, #2e7d5a 0%, #236848 100%);--gradient-warning:linear-gradient(120deg, #c9871b 0%, #9d6b10 100%);--gradient-error:linear-gradient(120deg, #e04e39 0%, #b63a2a 100%);--gradient-glass:linear-gradient(180deg, #fffffff2 0%, #ffffffe6 100%);--shadow-sm:0 1px 2px #1b1b1d0f;--shadow-md:0 6px 14px #1b1b1d14;--shadow-lg:0 14px 30px #1b1b1d1f;--shadow-xl:0 22px 40px #1b1b1d24;--shadow-2xl:0 30px 60px #1b1b1d2e;--shadow-glow:0 0 24px #143f7329;--shadow-glow-lg:0 0 40px #143f7333;--shadow-card:0 12px 30px #1b1b1d14;--shadow-card-hover:0 18px 40px #1b1b1d1f;--font-sans:"Sarabun", "Helvetica Neue", Helvetica, Arial, sans-serif;--font-display:"Newsreader", "Times New Roman", serif;--font-mono:"IBM Plex Mono", "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.625;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.25rem;--radius-3xl:1.5rem;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.2s cubic-bezier(.4, 0, .2, 1);--transition-slow:.3s cubic-bezier(.4, 0, .2, 1);--z-dropdown:100;--z-sticky:200;--z-modal-backdrop:300;--z-modal:400;--z-toast:500;--glass-bg:var(--bg-surface);--glass-border:var(--border-subtle);--glass-blur:blur(0px);--glass-shadow:var(--shadow-sm)}@media (prefers-contrast:more){:root{--bg-surface:#fff;--bg-raised:#fff;--bg-muted:#f0e9dd;--text-primary:#0c0c0c;--text-secondary:#1f1f23;--text-tertiary:#34343a;--border-subtle:#8f897e;--border-light:var(--border-subtle);--border-medium:#6c645a;--border-strong:#4d4740;--border-focus:#143f73}}[data-contrast=high]{--bg-surface:#fff;--bg-raised:#fff;--bg-muted:#f0e9dd;--text-primary:#0c0c0c;--text-secondary:#1f1f23;--text-tertiary:#34343a;--border-subtle:#8f897e;--border-light:var(--border-subtle);--border-medium:#6c645a;--border-strong:#4d4740;--border-focus:#143f73}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-page);background-image:radial-gradient(circle at 8% 6%,#143f7314,#0000 42%),radial-gradient(circle at 90% 12%,#e04e390f,#0000 45%),linear-gradient(#ffffff73,#fff0);min-height:100vh}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:var(--leading-tight);color:var(--text-primary);font-family:var(--font-display)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}p{color:var(--text-secondary);line-height:var(--leading-relaxed)}a{color:var(--action-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--action-primary-hover)}code{font-family:var(--font-mono);background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--color-primary-600);padding:.125em .375em;font-size:.9em}input,select,textarea{font-family:inherit;font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);outline:none;width:100%}input:hover,select:hover,textarea:hover{border-color:var(--border-medium)}input:focus,select:focus,textarea:focus{border-color:var(--border-focus);box-shadow:var(--focus-ring)}input:focus-visible,select:focus-visible,textarea:focus-visible,button:focus-visible,a:focus-visible{outline:2px solid var(--border-focus);outline-offset:3px}input::placeholder{color:var(--text-muted)}select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-10)}button{font-family:inherit;font-size:var(--text-sm);cursor:pointer;border-radius:var(--radius-full);padding:var(--space-3) var(--space-5);touch-action:manipulation;transition:background-color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), color var(--transition-fast), opacity var(--transition-fast), transform var(--transition-fast);justify-content:center;align-items:center;gap:var(--space-2);border:none;font-weight:600;display:inline-flex}button:disabled{opacity:.5;cursor:not-allowed}.btn-icon{color:var(--text-secondary);padding:var(--space-2);border-radius:var(--radius-md);background:0 0;width:36px;height:36px}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon:active:not(:disabled){transform:scale(.98)}.btn-primary{background:var(--action-primary);color:var(--text-inverse);border:1px solid var(--action-primary);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--action-primary-hover);border-color:var(--action-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)scale(.98)}.btn-secondary{background:var(--action-secondary);color:var(--text-primary);border:1px solid var(--border-light)}.btn-secondary:hover:not(:disabled){background:var(--action-secondary-hover);border-color:var(--border-medium)}.btn-secondary:active:not(:disabled){transform:scale(.98)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-ghost:active:not(:disabled){transform:scale(.98)}.btn-danger{background:var(--color-error-500);color:var(--text-inverse)}.btn-danger:active:not(:disabled){transform:scale(.98)}.btn-success{background:var(--color-success-500);color:var(--text-inverse)}.btn-success:active:not(:disabled){transform:scale(.98)}.workshop-shell{gap:var(--space-6);padding:var(--space-6);grid-template-columns:240px minmax(0,1fr) 320px;min-height:100vh;display:grid}.left-rail,.right-rail{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-2xl);padding:var(--space-4);gap:var(--space-4);flex-direction:column;display:flex}.left-rail{top:var(--space-6);height:calc(100vh - (var(--space-6) * 2));position:sticky;overflow:auto}.right-rail{top:var(--space-6);height:calc(100vh - (var(--space-6) * 2));position:sticky;overflow:hidden}.center-workspace{gap:var(--space-6);flex-direction:column;min-width:0;display:flex}.rail-brand{align-items:center;gap:var(--space-3);display:flex}.rail-mark{border-radius:var(--radius-lg);background:var(--action-primary);width:38px;height:38px;color:var(--text-inverse);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;display:flex}.rail-mark span{font-weight:700;font-size:var(--text-sm);letter-spacing:.08em}.rail-titles{gap:var(--space-1);flex-direction:column;display:flex}.rail-eyebrow{font-size:var(--text-xs);letter-spacing:.18em;text-transform:uppercase;color:var(--text-tertiary);font-weight:600}.rail-title{font-size:var(--text-lg);font-family:var(--font-display);color:var(--text-primary);margin:0}.rail-search input{background:var(--bg-primary);border-radius:var(--radius-lg);font-size:var(--text-sm)}.rail-nav{gap:var(--space-2);flex-direction:column;display:flex}.rail-link{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);color:var(--text-secondary);transition:background-color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), color var(--transition-fast);border:1px solid #0000;font-weight:600;text-decoration:none;display:flex}.rail-link svg{width:18px;height:18px}.rail-link:hover{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-light)}.rail-link[aria-current=page]{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-medium);box-shadow:var(--shadow-sm)}.rail-actions{gap:var(--space-2);flex-direction:column;display:flex}.rail-footer{gap:var(--space-3);border-top:1px solid var(--border-light);padding-top:var(--space-3);flex-direction:column;margin-top:auto;display:flex}.rail-user{gap:var(--space-1);font-size:var(--text-sm);color:var(--text-secondary);flex-direction:column;display:flex}.rail-user span{color:var(--text-primary);font-weight:600}.rail-controls{align-items:center;gap:var(--space-2);display:flex}.rail-icon-button{border-radius:var(--radius-lg);border:1px solid var(--border-light);background:var(--bg-primary);width:38px;height:38px;color:var(--text-secondary);transition:background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);justify-content:center;align-items:center;display:inline-flex}.rail-icon-button:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-medium)}.right-rail-header{justify-content:space-between;align-items:center;gap:var(--space-2);display:flex;position:relative}.right-rail-title{gap:var(--space-1);flex-direction:column;display:flex}.right-rail-title h2{font-size:var(--text-lg);margin:0}.right-rail-toggle{border:1px solid var(--border-light);background:var(--bg-primary);color:var(--text-secondary);font-size:var(--text-xs);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full)}.right-rail-toggle:hover{border-color:var(--border-medium);color:var(--text-primary)}.rail-content{gap:var(--space-4);flex-direction:column;display:flex;overflow:auto}.rail-panel{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);padding:var(--space-4);gap:var(--space-2);flex-direction:column;display:flex}.rail-panel h3{font-size:var(--text-base);margin:0}.rail-panel p{font-size:var(--text-sm);color:var(--text-tertiary);margin:0}.context-panel{gap:var(--space-3)}.context-header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);display:flex}.context-list{gap:var(--space-2);flex-direction:column;display:flex}.context-row{gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-lg);border:1px solid var(--border-light);background:var(--bg-secondary);color:inherit;transition:border-color var(--transition-fast), transform var(--transition-fast);flex-direction:column;text-decoration:none;display:flex}.context-row:hover{border-color:var(--border-medium);transform:translateY(-1px)}.context-row-title{justify-content:space-between;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:600;display:flex}.context-row-body{gap:var(--space-1);font-size:var(--text-sm);color:var(--text-secondary);flex-direction:column;display:flex}.context-row-meta{font-size:var(--text-xs);color:var(--text-tertiary)}.context-status{font-size:var(--text-xs);border-radius:var(--radius-full);border:1px solid #0000;padding:2px 8px;font-weight:600}.context-status-ready{color:var(--color-success-600);background:#2e7d5a24;border-color:#2e7d5a33}.context-status-pending{color:var(--color-primary-600);background:#143f731f;border-color:#143f7333}.context-status-missing{color:var(--text-tertiary);background:#8f86791f;border-color:#8f867933}.context-status-failed{color:var(--color-error-600);background:#e04e391f;border-color:#e04e3933}.ledger-panel{gap:var(--space-3)}.ledger-header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);display:flex}.ledger-subtitle{font-size:var(--text-xs);color:var(--text-tertiary);margin:0}.ledger-status{font-size:var(--text-xs);border-radius:var(--radius-full);border:1px solid var(--border-light);padding:4px 10px;font-weight:600}.ledger-filters{gap:var(--space-2);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.ledger-filter{border-radius:var(--radius-full);border:1px solid var(--border-light);background:var(--bg-secondary);color:var(--text-secondary);font-size:var(--text-xs);padding:var(--space-2) var(--space-3);justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.ledger-filter.is-active{border-color:var(--border-medium);background:var(--bg-primary);color:var(--text-primary)}.ledger-count{font-weight:600}.ledger-feed{gap:var(--space-2);flex-direction:column;max-height:280px;display:flex;overflow:auto}.ledger-row{gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-lg);border:1px solid var(--border-light);background:var(--bg-secondary);display:flex}.ledger-dot{background:currentColor;border:1px solid;border-radius:999px;width:8px;height:8px;margin-top:6px}.ledger-row-body{gap:var(--space-1);font-size:var(--text-sm);flex-direction:column;display:flex}.ledger-row-title{color:var(--text-primary);font-weight:600}.ledger-row-meta{gap:var(--space-1);font-size:var(--text-xs);color:var(--text-tertiary);flex-wrap:wrap;display:flex}.ledger-empty{padding:var(--space-3);border:1px dashed var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--text-tertiary)}.ledger-severity-success{color:var(--color-success-600);border-color:#2e7d5a4d}.ledger-severity-warning{color:var(--color-warning-600);border-color:#c9871b4d}.ledger-severity-error{color:var(--color-error-600);border-color:#e04e394d}.ledger-severity-info{color:var(--color-primary-600);border-color:#143f734d}.pipeline-strip{grid-template-columns:repeat(6,minmax(0,1fr));align-items:center;gap:4px;display:grid}.pipeline-stage{text-transform:uppercase;letter-spacing:.08em;background:var(--bg-secondary);height:22px;color:var(--text-tertiary);border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;font-size:.65rem;font-weight:600;display:flex}.pipeline-neutral .pipeline-stage{border-style:dashed;border-color:var(--border-light);color:var(--text-muted);background:0 0}.pipeline-pending{background:var(--bg-secondary);color:var(--text-tertiary);border-color:var(--border-light)}.pipeline-running{color:var(--color-info-600);background:#2f76f42e;border-color:#2f76f459;animation:2s ease-in-out infinite pulse-status}.pipeline-succeeded{color:var(--color-success-600);background:#2e7d5a2e;border-color:#2e7d5a59}.pipeline-failed{color:var(--color-error-600);background:#e04e392e;border-color:#e04e3959}.rail-peek{gap:var(--space-3);text-align:center;color:var(--text-tertiary);font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;border-top:1px solid var(--border-light);padding-top:var(--space-3);flex-direction:column;justify-content:center;align-items:center;display:none}.rail-fab{right:var(--space-4);bottom:var(--space-4);z-index:450;background:var(--action-primary);color:var(--text-inverse);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);padding:var(--space-3) var(--space-5);position:fixed}.rail-backdrop{z-index:420;background:#0f0e0c66;border:none;border-radius:0;width:100%;height:100%;margin:0;padding:0;display:block;position:fixed;inset:0}.workshop-shell[data-viewport=tablet]{grid-template-columns:220px minmax(0,1fr)}.workshop-shell[data-viewport=tablet] .right-rail{right:var(--space-5);top:var(--space-5);bottom:var(--space-5);width:320px;transition:transform var(--transition-base);z-index:410;position:fixed;transform:translate(0)}.workshop-shell[data-viewport=tablet][data-rail=peek] .right-rail{transform:translate(calc(100% - 64px))}.workshop-shell[data-viewport=tablet][data-rail=peek] .rail-content{display:none}.workshop-shell[data-viewport=tablet][data-rail=peek] .rail-peek{display:flex}.workshop-shell[data-viewport=tablet][data-rail=peek] .right-rail-title{display:none}.workshop-shell[data-viewport=tablet][data-rail=peek] .right-rail-toggle{box-shadow:var(--shadow-sm);position:absolute;top:0;left:-72px}.workshop-shell[data-viewport=mobile]{padding:var(--space-4);grid-template-columns:1fr}.workshop-shell[data-viewport=mobile] .left-rail{height:auto;position:static}.workshop-shell[data-viewport=mobile] .right-rail{left:var(--space-4);right:var(--space-4);bottom:var(--space-4);height:min(70vh,520px);transition:transform var(--transition-base);z-index:430;position:fixed;top:auto;transform:translateY(120%)}.workshop-shell[data-viewport=mobile][data-rail-open=true] .right-rail{transform:translateY(0)}.workshop-shell[data-viewport=mobile] .rail-peek{display:none}.auth-shell{min-height:100vh;padding:var(--space-6);justify-content:center;align-items:center;display:flex}.page-grid{gap:var(--space-5);grid-template-columns:minmax(0,2fr) minmax(260px,1fr);display:grid}.page-main,.page-side,.page-single{gap:var(--space-5);flex-direction:column;display:flex}.page-hero{gap:var(--space-3);flex-direction:column;display:flex}.page-eyebrow{font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--text-tertiary);margin:0;font-weight:600}.page-hero h2{font-size:var(--text-2xl);font-family:var(--font-display);margin:0}.page-hero p{color:var(--text-tertiary);margin:0}.global-notification-container{top:var(--space-6);right:var(--space-6);z-index:1000;pointer-events:none;position:fixed}.global-notification-container>*{pointer-events:auto}@media (width<=768px){.global-notification-container{top:var(--space-4);right:var(--space-4)}}@media (width<=1024px){.page-grid{grid-template-columns:1fr}.page-side{order:-1}}.status-pill{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);text-transform:capitalize;font-weight:600;display:inline-flex}.status-queued{background:var(--color-gray-100);color:var(--color-gray-600)}.status-running{color:var(--color-info-600);background:#0ea5e926;animation:2s ease-in-out infinite pulse-status}.status-succeeded{color:var(--color-success-600);background:#10b98126}.status-failed{color:var(--color-error-600);background:#f43f5e26}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse-status{0%,to{opacity:1}50%{opacity:.7}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) ease-out}.animate-slide-in{animation:slideIn var(--transition-slow) ease-out}.animate-scale-in{animation:scaleIn var(--transition-base) ease-out}.animate-spin{animation:1s linear infinite spin}.animate-pulse{animation:2s ease-in-out infinite pulse-status}.animate-in{animation:fadeIn var(--transition-base) ease-out, slideInUp .4s cubic-bezier(.16, 1, .3, 1)}@keyframes slideInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:50ms}.stagger-children>:nth-child(3){animation-delay:.1s}.stagger-children>:nth-child(4){animation-delay:.15s}.stagger-children>:nth-child(5){animation-delay:.2s}.stagger-children>:nth-child(6){animation-delay:.25s}.stagger-children>:nth-child(7){animation-delay:.3s}.stagger-children>:nth-child(8){animation-delay:.35s}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}::selection{color:var(--text-primary);background:#6366f14d}.skeleton{background:linear-gradient(90deg, var(--bg-tertiary) 25%, var(--bg-secondary) 50%, var(--bg-tertiary) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.spinner{border:2px solid var(--border-light);border-top-color:var(--color-primary-500);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}table{border-collapse:separate;border-spacing:0;width:100%}th{text-align:left;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-light);font-weight:600}td{padding:var(--space-4);border-bottom:1px solid var(--border-light);font-size:var(--text-sm);vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr{transition:background var(--transition-fast)}tbody tr:hover{background:var(--bg-secondary)}:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}@media (width<=768px){:root{--text-3xl:1.5rem;--text-2xl:1.25rem;--text-xl:1.125rem}}@media print{body{background:var(--bg-primary)}}.app-shell{--minimal-shell-paper:color-mix(in srgb, var(--app-paper) 64%, transparent);--minimal-shell-paper-soft:color-mix(in srgb, var(--app-paper-deep) 34%, transparent);--minimal-shell-panel:color-mix(in srgb, var(--app-paper) 72%, transparent);--minimal-shell-blue-tint:color-mix(in srgb, var(--app-blue) 8%, transparent);--minimal-shell-sage-tint:color-mix(in srgb, var(--app-sage) 8%, transparent);--minimal-shell-blue-line:color-mix(in srgb, var(--app-blue) 15%, transparent);--minimal-shell-highlight:color-mix(in srgb, var(--bg-primary) 92%, transparent);--minimal-shell-shadow:color-mix(in srgb, var(--app-ink) 6%, transparent);isolation:isolate;min-height:100vh;color:var(--app-ink);background:var(--app-paper);position:relative;overflow-x:clip}.app-shell:before{content:"";z-index:0;pointer-events:none;background:radial-gradient(circle at 8% 0%, var(--minimal-shell-blue-tint), transparent 36%), radial-gradient(circle at 92% 6%, var(--minimal-shell-sage-tint), transparent 32%), linear-gradient(180deg, var(--minimal-shell-paper), var(--minimal-shell-paper-soft));position:fixed;inset:0}.app-skip-link{top:calc(env(safe-area-inset-top) + .75rem);left:calc(env(safe-area-inset-left) + .75rem);z-index:var(--z-toast);border-radius:var(--app-radius-sm);background:var(--app-blue);color:var(--text-inverse);transition:transform var(--transition-fast);padding:.7rem .95rem;font-weight:800;position:fixed;transform:translateY(-160%)}.app-skip-link:focus-visible{transform:translateY(0)}.app-header{z-index:var(--z-sticky);padding:calc(env(safe-area-inset-top) + .85rem) calc(env(safe-area-inset-right) + clamp(1rem, 3vw, 2rem)) .85rem calc(env(safe-area-inset-left) + clamp(1rem, 3vw, 2rem));border-bottom:1px solid var(--app-line);background:var(--app-paper);box-shadow:0 12px 34px var(--minimal-shell-shadow);grid-template-columns:minmax(13rem,auto) minmax(0,1fr) auto;align-items:center;gap:clamp(.8rem,2vw,1.4rem);display:grid;position:sticky;top:0}.app-brand{align-items:center;gap:.75rem;min-width:0;display:flex}.app-mark{border:1px solid var(--minimal-shell-blue-line);background:radial-gradient(circle at 34% 26%, var(--minimal-shell-highlight), transparent 32%), linear-gradient(145deg, var(--app-paper-deep), var(--app-blue-soft));width:2.75rem;height:2.75rem;color:var(--app-blue);letter-spacing:.04em;border-radius:34% 66% 58% 42%/42% 45% 55% 58%;flex:none;place-items:center;font-weight:900;display:grid}.app-brand-copy{gap:.05rem;min-width:0;display:grid}.app-brand-copy strong{color:var(--app-ink);letter-spacing:0;text-wrap:balance;font-size:1.35rem;font-weight:600;line-height:1}.app-kicker{color:var(--app-blue);letter-spacing:.16em;text-transform:uppercase;font-size:.68rem;font-weight:850}.app-nav{flex-wrap:wrap;justify-content:center;align-items:center;gap:.55rem;display:flex}.app-nav-link,.app-logout{border:1px solid var(--app-line);background:var(--minimal-shell-panel);min-height:2.75rem;color:var(--app-ink);touch-action:manipulation;transition:background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);border-radius:999px;justify-content:center;align-items:center;padding:.62rem .95rem;font-weight:800;text-decoration:none;display:flex}.app-nav-link:hover,.app-logout:hover{transform:translateY(-1px)}.app-nav-link.active{background:var(--app-blue);color:var(--text-inverse);border-color:#0000}.app-actions{min-width:0;font-size:var(--text-sm);justify-content:flex-end;align-items:center;gap:.75rem;display:flex}.app-user{min-width:0;max-width:min(24vw,20rem);color:var(--app-muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.app-logout{background:var(--minimal-shell-panel);color:var(--app-ink);cursor:pointer}.app-main{z-index:1;width:min(100%,1440px);padding:clamp(1.25rem, 3vw, 2.2rem) calc(env(safe-area-inset-right) + clamp(1rem, 3vw, 2rem)) clamp(2rem, 5vw, 4rem) calc(env(safe-area-inset-left) + clamp(1rem, 3vw, 2rem));margin:0 auto;position:relative}@media (prefers-reduced-motion:reduce){.app-skip-link,.app-nav-link,.app-logout{transition:none}.app-nav-link:hover,.app-logout:hover{transform:none}}@media (width<=820px){.app-header{grid-template-columns:1fr;align-items:stretch;position:relative}.app-nav{justify-content:flex-start}.app-actions{justify-content:space-between}.app-user{max-width:58vw}}.route-loading-panel{border:1px solid var(--app-line);border-radius:var(--app-radius-lg);background:var(--app-panel);width:min(100%,42rem);box-shadow:var(--app-shadow-soft);color:var(--app-ink);margin:0 auto;padding:clamp(2rem,5vw,3.5rem)}.route-loading-panel h2{color:var(--app-ink);margin:.35rem 0 0}.route-loading-panel p{color:var(--app-muted);margin:.5rem 0 0}.loading-panel{padding:var(--space-12) var(--space-8);text-align:center}.app-state-panel{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-2xl);box-shadow:var(--shadow-card);transition:box-shadow var(--transition-base)}.app-state-panel:hover{box-shadow:var(--shadow-card-hover)}.loading-content{align-items:center;gap:var(--space-6);flex-direction:column;display:flex}.loading-spinner{width:64px;height:64px;position:relative}.spinner-ring{border:3px solid var(--border-light);border-top-color:var(--color-primary-500);border-radius:50%;width:100%;height:100%;animation:1s linear infinite spin}.loading-text{gap:var(--space-2);flex-direction:column;display:flex}.loading-eyebrow{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);font-weight:600}.loading-text h2{font-size:var(--text-xl);margin:0}.loading-text p{font-size:var(--text-sm);margin:0}.unauth-panel{gap:var(--space-6);max-width:640px;padding:var(--space-8);grid-template-columns:minmax(0,1fr);display:grid}.unauth-graphic{padding:var(--space-6);background:var(--bg-secondary);border-radius:var(--radius-2xl);border:1px solid var(--border-light);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.graphic-circles{position:absolute;inset:0}.circle{background:color-mix(in srgb, var(--color-primary-500) 8%, transparent);border-radius:999px;position:absolute}.circle-1{width:120px;height:120px;top:-20px;left:-10px}.circle-2{width:180px;height:180px;bottom:-60px;right:-40px}.circle-3{width:90px;height:90px;bottom:20px;left:40px}.graphic-icon{background:var(--bg-primary);border:1px solid var(--border-light);width:72px;height:72px;color:var(--color-primary-500);box-shadow:var(--shadow-sm);border-radius:24px;justify-content:center;align-items:center;display:flex;position:relative}.unauth-content{gap:var(--space-3);flex-direction:column;display:flex}.unauth-eyebrow{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.12em;color:var(--text-tertiary);font-weight:600}.unauth-content h2{font-size:var(--text-2xl);margin:0}.unauth-content p{color:var(--text-secondary);margin:0}.unauth-buttons{gap:var(--space-3);flex-wrap:wrap;display:flex}.btn-large{padding:var(--space-3) var(--space-6);font-size:var(--text-sm)}@media (width<=720px){.unauth-panel{padding:var(--space-6)}}
