:root{--blue: #1d4f91;--gray: #7d8796;--black: #0f1115;--dark-green: #0f3d2e;--text-light: #eef3f7}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(160deg,var(--black),var(--dark-green));color:var(--text-light)}.app-shell{min-height:100vh}.sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:linear-gradient(180deg,#14233d,#121922 45%,#0f3d2e);border-right:1px solid rgba(238,243,247,.15);padding:24px 16px;display:flex;flex-direction:column;gap:18px}.logo{font-size:1.4rem;font-weight:700;letter-spacing:.08em}.nav-links{display:flex;flex-direction:column;gap:10px}.nav-link{padding:10px 12px;border-radius:8px;color:var(--text-light);text-decoration:none;background:#7d879629}.nav-link.router-link-active{background:var(--blue)}.content{min-height:100vh;padding:24px}.with-sidebar{margin-left:260px}.card{width:min(720px,100%);background:#0f1115c7;border:1px solid rgba(125,135,150,.25);border-radius:14px;padding:26px}.login-card{width:min(460px,100%)}.login-page{min-height:calc(100vh - 48px);display:grid;place-items:center}.login-form{display:grid;gap:14px;margin-top:16px}.upload-tabs{display:flex;gap:10px;margin:0;padding:6px;background:#0f1115b3;border:1px solid rgba(125,135,150,.35);border-radius:12px;width:fit-content}.upload-tab{background:transparent;border:1px solid transparent;color:#dbe2ea}.upload-tab.active{background:var(--blue);border-color:#eef3f740;color:var(--text-light)}.upload-page{position:relative;width:100%;min-height:calc(100vh - 48px);background:#0f1115c7;border:1px solid rgba(125,135,150,.25);border-radius:14px;padding:24px;display:grid;grid-template-rows:auto auto 1fr;gap:18px}.dashboard-page{width:100%;min-height:calc(100vh - 48px);background:#0f1115c7;border:1px solid rgba(125,135,150,.25);border-radius:14px;padding:24px;display:grid;grid-template-rows:auto auto 1fr;gap:16px;align-content:start}.requirements-page{width:100%;min-height:calc(100vh - 48px);background:radial-gradient(circle at top right,#1d4f9129,#0f1115e0);border:1px solid rgba(125,135,150,.25);border-radius:14px;padding:24px;display:grid;gap:18px}.requirements-hero{border:1px solid rgba(125,135,150,.28);border-radius:12px;background:linear-gradient(160deg,#0f3d2e47,#1d4f9133);padding:18px}.requirements-hero h1{margin:0 0 8px}.requirements-hero p{margin:0;color:#d2dbe7}.format-badges{margin-top:14px;display:flex;gap:10px}.format-badge{border:1px solid #8ab0e5;background:#1d4f9159;color:#e6f0ff;border-radius:999px;padding:6px 10px;font-weight:600;font-size:.9rem}.requirements-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:14px}.requirements-card{border:1px solid rgba(125,135,150,.28);background:#0f1115b8;border-radius:12px;padding:16px}.requirements-card h2{margin:0 0 12px;font-size:1.05rem}.requirements-card:nth-child(1){grid-column:span 8}.requirements-card:nth-child(2){grid-column:span 4}.requirements-card:nth-child(3){grid-column:span 12}.column-chip-list{display:flex;flex-wrap:wrap;gap:8px}.column-chip{padding:6px 10px;border-radius:999px;border:1px solid rgba(125,135,150,.5);background:#7d879626;color:#e5ebf3;font-size:.9rem}.value-pair-list{display:grid;gap:10px}.value-pair{display:flex;align-items:center;gap:8px}.value-label{padding:6px 10px;border-radius:8px;background:#0f3d2e80;border:1px solid rgba(83,195,143,.5);min-width:70px;text-align:center;font-weight:600}.value-or{color:#9fb0c7;font-size:.9rem}.requirements-list{margin:0;padding-left:18px;color:#d3dbe6}.requirements-list li+li{margin-top:8px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.dashboard-header h1{margin:0}.dashboard-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.export-message{margin:-6px 0 0;color:#cfd8e4}.dashboard-filters{display:grid;grid-template-columns:minmax(220px,2fr) repeat(4,minmax(120px,1fr)) minmax(190px,1.35fr) minmax(190px,1.35fr) auto;gap:10px;align-items:end;width:100%;border:1px solid rgba(125,135,150,.3);border-radius:10px;background:#0f111573;padding:10px}.dashboard-filters label{margin:0;min-width:0}.dashboard-filters .sample-search{min-width:0}.sample-search-input-wrap{position:relative}.sample-search-input-wrap input{padding-right:34px}.sample-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:18px;height:18px;border-radius:999px;border:1px solid rgba(220,226,235,.5);background:#e6ecf333;color:#e5ebf2;font-size:12px;line-height:1;padding:0}.dashboard-filters input,.dashboard-filters select{width:100%}.filter-clear-btn{white-space:nowrap;margin-left:auto}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.ws-status{padding:6px 10px;border-radius:999px;border:1px solid transparent;font-size:.85rem}.ws-connected{background:#0f3d2e99;border-color:#53c38f}.ws-connecting{background:#1d4f9173;border-color:#8ab0e5}.ws-disconnected{background:#5c1818b3;border-color:#f08f8f}.dashboard-table-wrap{overflow:auto;border:1px solid rgba(125,135,150,.3);border-radius:10px}.dashboard-pager{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;border:1px solid rgba(125,135,150,.3);border-radius:10px;background:#0f111573;padding:10px}.page-size-select{margin:0;min-width:180px;justify-self:start}.pager-controls{display:flex;align-items:center;gap:6px;justify-self:center}.pager-controls .page-token{min-width:34px;padding:8px 10px}.pager-controls .page-token.active{background:var(--dark-green);border:1px solid rgba(143,183,168,.7)}.pager-controls .page-token.dots{background:#7d87962e;cursor:default}.pager-status{justify-self:end;color:#c9d1db;font-size:.92rem}.dashboard-table{width:100%;min-width:960px;border-collapse:collapse;background:#0f111580}.dashboard-table th,.dashboard-table td{border-bottom:1px solid rgba(125,135,150,.25);border-right:1px solid rgba(125,135,150,.25);padding:10px;text-align:left;white-space:nowrap}.dashboard-table th:last-child,.dashboard-table td:last-child{border-right:none}.dashboard-table th{font-weight:600;color:#dce4ee;background:#1d4f9133}.sort-btn{width:100%;display:inline-flex;align-items:center;justify-content:space-between;gap:8px;padding:0;border:0;background:transparent;color:inherit;font:inherit;cursor:pointer}.toast-stack{position:fixed;top:18px;right:18px;z-index:1200;display:grid;gap:10px;width:min(420px,calc(100vw - 28px))}.toast{display:grid;grid-template-columns:1fr auto;align-items:start;gap:12px;padding:12px 12px 12px 14px;border-radius:10px;border:1px solid;box-shadow:0 10px 20px #0000004d}.toast p{margin:0;line-height:1.35}.toast-success{background:#0f3d2ef2;border-color:#53c38f;color:#dcfaeb}.toast-error{background:#5c1818f2;border-color:#f08f8f;color:#ffe4e4}.toast-close{background:transparent;border:1px solid rgba(255,255,255,.35);color:inherit;line-height:1;padding:4px 7px}.upload-header h1{margin:0 0 8px}.upload-header p{margin:0;color:#c9d1db}.upload-panel{border:1px solid rgba(125,135,150,.3);border-radius:12px;background:linear-gradient(180deg,#1d4f9114,#0f3d2e1f);padding:18px}.upload-panel h2{margin:0 0 8px}.upload-panel p{margin:0;color:#d0d8e2}.file-upload-form{margin-top:14px;display:grid;gap:12px}.file-toolbar{display:flex;justify-content:space-between;gap:12px;align-items:center}.file-picker-btn{display:inline-flex;align-items:center;border:1px solid var(--gray);border-radius:8px;padding:10px 14px;background:#0f3d2ebf;color:var(--text-light);cursor:pointer;font-weight:600}.file-input-hidden{display:none}.clear-files-btn{background:#7d879640;border:1px solid rgba(125,135,150,.6)}.file-list-wrap{overflow-x:auto;border:1px solid rgba(125,135,150,.3);border-radius:10px}.file-list-table{width:100%;min-width:680px;table-layout:fixed;border-collapse:collapse;background:#0f111580}.file-list-table th,.file-list-table td{border-bottom:1px solid rgba(125,135,150,.25);padding:10px;text-align:left;white-space:nowrap}.file-list-table th{font-weight:600;color:#dce4ee;background:#1d4f9133}.file-col-name{width:60%}.file-col-type{width:14%}.file-col-size{width:16%}.file-col-action{width:10%}.filename-text{display:block;overflow:hidden;text-overflow:ellipsis}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;padding:0;border-radius:8px}.icon-btn svg{width:16px;height:16px;fill:currentColor}.icon-btn.danger{background:#7d879640;border:1px solid rgba(125,135,150,.6)}.manual-upload-form{margin-top:14px;display:grid;gap:12px}.manual-toolbar{display:flex;justify-content:flex-end}.row-remove-btn{background:#7d879640;border:1px solid rgba(125,135,150,.6);padding:8px 10px}.manual-table-wrap{overflow-x:auto;border:1px solid rgba(125,135,150,.3);border-radius:10px}.manual-table{width:100%;min-width:1180px;border-collapse:collapse;background:#0f111580}.manual-table th,.manual-table td{border-bottom:1px solid rgba(125,135,150,.25);padding:10px;text-align:left;white-space:nowrap}.manual-table th{font-weight:600;color:#dce4ee;background:#1d4f9133}.manual-table td input,.manual-table td select{width:100%;min-width:95px}.manual-actions{display:flex;justify-content:flex-end}.submit-error,.submit-success{margin:0}.submit-error{color:#ffb4b4}.submit-success{color:#a8f0c9}label{display:grid;gap:8px;color:#d7dde5}input{border:1px solid var(--gray);border-radius:8px;padding:10px;background:#0f1115e0;color:var(--text-light)}input[type=datetime-local]{color-scheme:dark;background:#0a0d12f2;border-color:#7d8796bf;min-width:0;font-size:.92rem;padding-right:8px}select{border:1px solid var(--gray);border-radius:8px;padding:10px 36px 10px 10px;background-color:#0f1115eb;color:var(--text-light);appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:linear-gradient(45deg,transparent 50%,#9fb4d3 50%),linear-gradient(135deg,#9fb4d3 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 2px),calc(100% - 12px) calc(50% - 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat}select:hover{border-color:#9fb4d3}select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 2px #1d4f9159}button{border:none;border-radius:8px;padding:10px 14px;cursor:pointer;background:var(--blue);color:var(--text-light);font-weight:600}button:disabled{opacity:.7;cursor:not-allowed}.form-error{margin:0;color:#ffb4b4}.logout-btn{margin-top:auto;background:var(--dark-green);border:2px solid #8fb7a8;box-shadow:inset 0 0 0 1px #0f11158c,0 0 0 1px #8fb7a840}.sidebar-export-status{margin-top:auto;margin-bottom:10px;display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;border:1px solid rgba(143,183,168,.55);background:#0f3d2e47;color:#dcebe4;font-size:.9rem}.sidebar-export-status+.logout-btn{margin-top:0}.spinner{width:14px;height:14px;border:2px solid rgba(220,235,228,.35);border-top-color:#dcebe4;border-radius:999px;animation:spin .8s linear infinite;flex:0 0 auto}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:900px){.sidebar{position:static;width:100%;height:auto}.with-sidebar{margin-left:0}.requirements-card:nth-child(1),.requirements-card:nth-child(2),.requirements-card:nth-child(3){grid-column:span 12}.dashboard-filters{grid-template-columns:repeat(2,minmax(0,1fr))}.filter-clear-btn{margin-left:0}.dashboard-pager{grid-template-columns:1fr;justify-items:stretch}.pager-controls{justify-self:center;flex-wrap:wrap;justify-content:center}.pager-status,.page-size-select{justify-self:start}}@media(max-width:1400px){.dashboard-filters{grid-template-columns:minmax(220px,2fr) repeat(3,minmax(120px,1fr)) minmax(190px,1.3fr) minmax(190px,1.3fr)}.filter-clear-btn{margin-left:0}}
