:root{--bg-900: #0a0c10;--bg-800: #111418;--bg-700: #181c22;--bg-600: #1f252e;--bg-500: #272e3a;--border: #2a3040;--text-primary: #e2e8f0;--text-muted: #64748b;--accent: #38bdf8;--accent-dim: #0ea5e9;--danger: #f87171;--success: #34d399;--panel-w: 260px;--toolbar-h: 44px;--footer-h: 28px;--mobile-nav-h: 48px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Inter,system-ui,sans-serif;font-size:13px;background:var(--bg-900);color:var(--text-primary);overflow:hidden}.app{display:grid;grid-template-columns:var(--panel-w) var(--panel-w) 1fr;height:100vh;height:100dvh;overflow:hidden}.mobile-nav{display:none}.viewport-area{display:flex;flex-direction:column;height:100vh;background:var(--bg-900);overflow:hidden}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);gap:8px}.empty-state__icon{font-size:48px;opacity:.3}.study-list{display:flex;flex-direction:column;height:100vh;background:var(--bg-800);border-right:1px solid var(--border);overflow:hidden}.study-list__header{display:flex;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border);background:var(--bg-900)}.study-list__logo{font-size:15px;font-weight:700;letter-spacing:1px;color:var(--accent)}.study-list__search{display:flex;flex-direction:column;gap:6px;padding:10px 12px;border-bottom:1px solid var(--border)}.study-list__count{padding:6px 14px;font-size:11px;color:var(--text-muted);border-bottom:1px solid var(--border)}.study-list__items{flex:1;overflow-y:auto;list-style:none}.study-card{padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}.study-card:hover{background:var(--bg-700)}.study-card--active{background:var(--bg-600);border-left:2px solid var(--accent)}.study-card__name{font-weight:600;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.study-card__meta{display:flex;align-items:center;gap:8px;margin-bottom:3px}.study-card__desc{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.series-panel{display:flex;flex-direction:column;height:100vh;background:var(--bg-800);border-right:1px solid var(--border);overflow:hidden}.series-panel__header{padding:12px 14px;border-bottom:1px solid var(--border);background:var(--bg-900)}.series-panel__patient{font-weight:700;margin-bottom:2px}.series-panel__study{color:var(--text-muted);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.series-panel__date{color:var(--accent);font-size:11px;margin-top:2px}.panel-status{padding:12px 14px;color:var(--text-muted);font-size:12px}.series-list{flex:1;overflow-y:auto;list-style:none}.series-card{padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}.series-card:hover{background:var(--bg-700)}.series-card--active{background:var(--bg-600);border-left:2px solid var(--accent)}.series-card__top{display:flex;align-items:center;gap:8px;margin-bottom:4px}.series-card__number{color:var(--text-muted);font-size:11px;margin-left:auto}.series-card__desc{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.series-card__dims{font-size:10px;color:var(--text-muted);margin-top:2px}.toolbar{display:flex;align-items:center;gap:4px;height:var(--toolbar-h);padding:0 12px;background:var(--bg-800);border-bottom:1px solid var(--border);flex-shrink:0}.toolbar__tools{display:flex;gap:4px}.toolbar__actions{display:flex;gap:4px;margin-left:12px;padding-left:12px;border-left:1px solid var(--border)}.toolbar__info{margin-left:auto;font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums}.tool-btn{padding:4px 10px;border:1px solid var(--border);border-radius:4px;background:var(--bg-700);color:var(--text-primary);font-size:12px;cursor:pointer;transition:all .1s}.tool-btn:hover{background:var(--bg-600);border-color:var(--accent)}.tool-btn--active{background:var(--accent-dim);border-color:var(--accent);color:#fff}.toolbar__group{position:relative;display:flex}.tool-dropdown__menu{background:var(--bg-700);border:1px solid var(--border);border-radius:6px;padding:4px;min-width:150px;display:flex;flex-direction:column;gap:2px;box-shadow:0 8px 24px #0000008c;list-style:none}.tool-dropdown__item{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;padding:5px 10px;border-radius:4px;white-space:nowrap}.tool-dropdown__key{font-size:10px;color:var(--text-muted);margin-left:12px;font-variant-numeric:tabular-nums}.viewport-wrapper{display:flex;flex-direction:column;flex:1;overflow:hidden}.viewport-container{flex:1;position:relative;background:#000;overflow:hidden}.viewport-canvas{width:100%;height:100%;touch-action:none}.viewport-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);background:#000000b3;z-index:10}.viewport-overlay--error{color:var(--danger)}.dicom-overlay{position:absolute;inset:0;pointer-events:none;font-size:11px;font-family:Courier New,Courier,monospace;line-height:1.55;color:#e8e8e8;text-shadow:0 1px 3px rgba(0,0,0,.95),0 0 8px rgba(0,0,0,.8);z-index:10}.dicom-overlay__tl{position:absolute;top:8px;left:10px}.dicom-overlay__tr{position:absolute;top:8px;right:10px;text-align:right}.dicom-overlay__bl{position:absolute;bottom:8px;left:10px}.dicom-overlay__br{position:absolute;bottom:8px;right:10px;text-align:right}.dicom-overlay div{white-space:nowrap}.input{width:100%;padding:5px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg-700);color:var(--text-primary);font-size:12px;outline:none}.input:focus{border-color:var(--accent)}.input option{background:var(--bg-700)}.badge{display:inline-block;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:700;background:var(--bg-500);color:var(--accent);letter-spacing:.5px}.error-text{color:var(--danger)}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.upload-btn{margin-left:auto;padding:4px 10px;border:1px solid var(--accent-dim);border-radius:4px;background:transparent;color:var(--accent);font-size:11px;font-weight:600;cursor:pointer;letter-spacing:.3px;transition:all .15s}.upload-btn:hover{background:var(--accent-dim);color:#fff}.modal-backdrop{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-800);border:1px solid var(--border);border-radius:8px;width:520px;max-width:95vw;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);font-weight:600;font-size:14px}.modal__close{background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:2px 6px;border-radius:4px}.modal__close:hover{background:var(--bg-600);color:var(--text-primary)}.drop-zone{margin:24px;border:2px dashed var(--border);border-radius:8px;padding:48px 24px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:all .15s;color:var(--text-muted)}.drop-zone:hover,.drop-zone--active{border-color:var(--accent);background:#38bdf80d;color:var(--text-primary)}.drop-zone__icon{font-size:32px}.drop-zone__text{font-size:14px}.drop-zone__sub{font-size:12px;color:var(--text-muted)}.upload-progress{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 24px;color:var(--text-muted)}.progress-bar{width:100%;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.progress-bar__fill{height:100%;background:var(--accent);transition:width .3s ease;border-radius:2px}.upload-results{display:flex;flex-direction:column;gap:12px;padding:16px 18px;overflow-y:auto}.upload-results__section{display:flex;flex-direction:column;gap:6px}.upload-results__label{font-size:12px;font-weight:700;letter-spacing:.3px}.upload-results__label--ok{color:var(--success)}.upload-results__label--error{color:var(--danger)}.upload-results__list{list-style:none;display:flex;flex-direction:column;gap:4px}.upload-result{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:4px;font-size:12px}.upload-result--ok{background:#34d39912}.upload-result--error{background:#f8717112}.upload-result__name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-result__size{color:var(--text-muted);flex-shrink:0}.upload-result__msg{color:var(--danger);font-size:11px;flex-shrink:0}.upload-results__actions{display:flex;justify-content:flex-end;gap:8px;padding-top:8px;border-top:1px solid var(--border)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width: 1180px){:root{--panel-w: 228px}.study-list__header,.series-panel__header{padding-inline:10px}.study-card,.series-card{padding-inline:12px}.toolbar{gap:6px;overflow-x:auto;scrollbar-width:none}.toolbar::-webkit-scrollbar{display:none}.toolbar__tools,.toolbar__actions{flex-shrink:0}}@media (max-width: 820px){:root{--panel-w: 100vw;--toolbar-h: 48px;--footer-h: 24px}body{font-size:14px}.app{display:grid;grid-template-columns:1fr;grid-template-rows:var(--mobile-nav-h) minmax(0,1fr);height:100dvh}.mobile-nav{display:flex;align-items:stretch;height:var(--mobile-nav-h);background:var(--bg-900);border-bottom:1px solid var(--border);z-index:20}.mobile-nav__btn{flex:1;border:0;border-right:1px solid var(--border);background:var(--bg-900);color:var(--text-muted);font:inherit;font-size:12px;font-weight:700;cursor:pointer;transition:color .15s,background .15s}.mobile-nav__btn--active{color:var(--accent);background:var(--bg-800);box-shadow:inset 0 -2px 0 var(--accent)}.mobile-nav__btn:disabled{color:#3f4858;cursor:not-allowed}.mobile-nav__icon-btn{display:flex;align-items:center;justify-content:center;width:44px;flex-shrink:0;border:0;border-left:1px solid var(--border);background:var(--bg-900);color:var(--text-muted);cursor:pointer;transition:color .15s,background .15s}.mobile-nav__icon-btn:hover,.mobile-nav__icon-btn:active{background:var(--bg-800);color:var(--text-primary)}.mobile-nav__icon-btn--danger:hover,.mobile-nav__icon-btn--danger:active{background:#f871711a;color:var(--danger)}.study-list,.series-panel,.viewport-area{grid-column:1;grid-row:2;width:100vw;height:calc(100dvh - var(--mobile-nav-h));min-width:0;border-right:0}.app--studies .series-panel,.app--studies .viewport-area,.app--series .study-list,.app--series .viewport-area,.app--viewer .study-list,.app--viewer .series-panel{display:none}.study-list__header{min-height:56px;padding:10px 14px}.study-list__logo{font-size:17px}.study-list__search{padding:12px 14px}.input,.tool-btn,.upload-btn{min-height:40px;font-size:14px}.study-card,.series-card{padding:14px 16px}.study-card__desc,.series-card__dims,.series-panel__study,.series-panel__date{font-size:12px}.series-panel__header{padding:14px 16px}.toolbar{order:3;height:auto;min-height:54px;padding:6px 8px;border-top:1px solid var(--border);border-bottom:0;overflow-x:auto}.toolbar__tools,.toolbar__actions{gap:6px}.toolbar__actions{margin-left:8px;padding-left:8px}.tool-btn{padding-inline:12px;white-space:nowrap}.toolbar__info{position:sticky;right:0;padding:0 6px;background:var(--bg-800)}.tool-dropdown__item{min-height:44px;font-size:14px;padding:0 14px}.viewport-container{min-height:0}.dicom-overlay{font-size:10px}}@media (max-width: 520px){.toolbar__actions{margin-left:4px;padding-left:4px}.tool-btn{padding-inline:10px}.modal{width:calc(100vw - 20px);max-height:calc(100dvh - 24px)}.drop-zone{margin:16px;padding:34px 16px}}.login-page{position:relative;display:flex;align-items:center;justify-content:center;height:100vh;height:100dvh;background:var(--bg-900);padding:16px;overflow:hidden}.login-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 20% 40%,rgba(56,189,248,.07) 0%,transparent 70%),radial-gradient(ellipse 40% 60% at 80% 70%,rgba(14,165,233,.05) 0%,transparent 70%);pointer-events:none}.login-card{position:relative;background:#111418eb;border:1px solid rgba(56,189,248,.15);border-radius:16px;padding:40px 36px 32px;width:100%;max-width:400px;display:flex;flex-direction:column;gap:0;box-shadow:0 24px 64px #0009,0 0 0 1px #ffffff08 inset;backdrop-filter:blur(12px)}.login-card__header{display:flex;align-items:center;gap:14px;margin-bottom:28px}.login-card__logo-mark{font-size:36px;color:var(--accent);line-height:1;filter:drop-shadow(0 0 12px rgba(56,189,248,.5))}.login-card__title{font-size:22px;font-weight:800;letter-spacing:2px;color:var(--text-primary)}.login-card__subtitle{font-size:11px;color:var(--text-muted);letter-spacing:.3px;margin-top:2px}.login-tabs{display:flex;gap:0;background:var(--bg-700);border:1px solid var(--border);border-radius:8px;padding:3px;margin-bottom:24px}.login-tab{flex:1;border:0;background:transparent;color:var(--text-muted);font:inherit;font-size:13px;font-weight:600;padding:8px;border-radius:5px;cursor:pointer;transition:background .18s,color .18s}.login-tab--active{background:var(--bg-500);color:var(--text-primary);box-shadow:0 1px 4px #0000004d}.login-form{display:flex;flex-direction:column;gap:16px}.login-form__field{display:flex;flex-direction:column;gap:6px}.login-form__label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.input--auth{padding:10px 12px;font-size:13px;border-radius:7px;border:1px solid var(--border);background:var(--bg-700);color:var(--text-primary);transition:border-color .15s,box-shadow .15s}.input--auth:focus{border-color:var(--accent);box-shadow:0 0 0 3px #38bdf81f;outline:none}.input--auth::placeholder{color:var(--bg-500)}.login-form__error{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--danger);padding:9px 12px;background:#f8717114;border:1px solid rgba(248,113,113,.2);border-radius:7px}.login-form__success{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:24px 16px;color:var(--success)}.login-form__success-icon{width:44px;height:44px;border-radius:50%;background:#34d3991f;border:1px solid rgba(52,211,153,.3);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:4px}.login-form__success strong{font-size:15px;color:var(--text-primary)}.login-form__success p{font-size:12px;color:var(--text-muted);line-height:1.6}.login-form__submit{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:6px;padding:11px;border:0;border-radius:8px;background:linear-gradient(135deg,#38bdf8,#0ea5e9);color:#000;font:inherit;font-size:14px;font-weight:700;cursor:pointer;transition:opacity .15s,transform .1s;box-shadow:0 4px 14px #38bdf84d}.login-form__submit:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.login-form__submit:active:not(:disabled){transform:translateY(0)}.login-form__submit:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.login-form__spinner{width:14px;height:14px;border:2px solid rgba(0,0,0,.2);border-top-color:#000;border-radius:50%;animation:spin .7s linear infinite}.login-card__notice{margin-top:20px;font-size:10px;color:var(--bg-500);text-align:center;line-height:1.5;border-top:1px solid var(--border);padding-top:16px}.study-list__brand{display:flex;flex-direction:column;gap:3px;min-width:0}.study-list__user{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.study-list__role{padding:1px 5px;border-radius:3px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.study-list__role--admin{background:#38bdf826;color:var(--accent)}.study-list__role--viewer{background:var(--bg-500);color:var(--text-muted)}.study-list__header-actions{display:flex;align-items:center;gap:4px;margin-left:auto;flex-shrink:0}.study-list__footer{display:flex;flex-direction:column;gap:4px;padding:10px 12px;border-top:1px solid var(--border);background:var(--bg-900)}.footer-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:7px;background:var(--bg-700);color:var(--text-muted);font:inherit;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s;text-align:left}.footer-btn:hover{background:var(--bg-600);color:var(--text-primary);border-color:var(--accent)}.footer-btn--danger:hover{background:#f871711a;border-color:var(--danger);color:var(--danger)}.header-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 9px;border:1px solid var(--border);border-radius:6px;background:var(--bg-700);color:var(--text-muted);font:inherit;font-size:11px;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s;white-space:nowrap}.header-btn:hover{background:var(--bg-600);color:var(--text-primary);border-color:var(--accent)}.header-btn--icon{padding:5px 7px}.header-btn--danger:hover{background:#f871711a;border-color:var(--danger);color:var(--danger)}.admin-dashboard{min-height:100vh;background:var(--bg-900);color:var(--text-primary);overflow-y:auto}.admin-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:20px 28px;background:var(--bg-800);border-bottom:1px solid var(--border);flex-wrap:wrap;position:sticky;top:0;z-index:10}.admin-header__brand{display:flex;align-items:center;gap:10px}.admin-header__icon{font-size:20px;color:var(--accent)}.admin-header__title{font-size:16px;font-weight:800;color:var(--text-primary);letter-spacing:.3px}.admin-header__subtitle{font-size:11px;color:var(--text-muted);margin-top:1px}.admin-header__actions{display:flex;gap:8px}.admin-body{padding:28px}.admin-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border);border-radius:7px;background:var(--bg-700);color:var(--text-primary);font:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.admin-btn:hover{background:var(--bg-600);border-color:var(--text-muted)}.admin-btn--primary{background:linear-gradient(135deg,#38bdf8,#0ea5e9);border-color:transparent;color:#000;font-weight:700;box-shadow:0 2px 8px #38bdf840}.admin-btn--primary:hover{opacity:.88;background:linear-gradient(135deg,#38bdf8,#0ea5e9)}.admin-btn--approve{background:#34d3991a;border-color:#34d3994d;color:var(--success);font-size:12px;padding:5px 11px}.admin-btn--approve:hover{background:#34d3992e;border-color:var(--success)}.admin-btn--danger{background:#f8717114;border-color:#f8717140;color:var(--danger);font-size:12px;padding:5px 11px}.admin-btn--danger:hover{background:#f8717126;border-color:var(--danger)}.admin-section{margin-bottom:36px}.admin-section__title{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:14px}.admin-section__title:after{content:"";flex:1;height:1px;background:var(--border)}.admin-table-wrapper{overflow-x:auto;border:1px solid var(--border);border-radius:10px;background:var(--bg-800)}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th{background:var(--bg-700);padding:11px 16px;text-align:left;color:var(--text-muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}.admin-table th:first-child{border-radius:10px 0 0}.admin-table th:last-child{border-radius:0 10px 0 0}.admin-table td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table tr:last-child td{border-bottom:0}.admin-table tbody tr{transition:background .1s}.admin-table tbody tr:hover td{background:#38bdf808}.admin-table__name{font-weight:600}.admin-table__email{color:var(--text-muted);font-size:12px}.admin-table__actions{display:flex;gap:6px;white-space:nowrap}.admin-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.2px}.admin-badge--active{background:#34d3991f;color:var(--success);border:1px solid rgba(52,211,153,.25)}.admin-badge--active:before{content:"";width:5px;height:5px;border-radius:50%;background:var(--success)}.admin-badge--pending{background:#fbbf241a;color:#fbbf24;border:1px solid rgba(251,191,36,.2)}.admin-empty{color:var(--text-muted);padding:32px;text-align:center;font-size:13px}.admin-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:48px;color:var(--text-muted);font-size:13px}.admin-error{padding:16px 28px;font-size:13px;color:var(--danger);background:#f871710f;border-radius:8px;margin-bottom:16px}.input--sm{padding:5px 9px;min-height:unset;font-size:12px;border-radius:5px}.admin-modal-backdrop{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:16px}.admin-modal{background:var(--bg-800);border:1px solid rgba(56,189,248,.15);border-radius:14px;padding:32px;width:100%;max-width:400px;box-shadow:0 24px 64px #0009}.admin-modal__title{font-size:17px;font-weight:700;margin-bottom:24px;color:var(--text-primary)}.admin-modal__footer{display:flex;justify-content:flex-end;gap:10px;margin-top:12px;padding-top:16px;border-top:1px solid var(--border)}.mobile-nav__spacer{flex:1}@media (max-width: 820px){.study-list__footer{display:none}.admin-header{padding:16px;position:static}.admin-body{padding:16px}}
