@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-color:#0b0f19;--panel-bg:#141b2db3;--panel-border:#ffffff0d;--text-main:#f1f5f9;--text-muted:#94a3b8;--accent-primary:#3b82f6;--accent-secondary:#0ea5e9;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--glass-shadow:0 8px 32px 0 #0000005e;--glass-blur:blur(12px)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);background-image:radial-gradient(circle at 15%,#3b82f614,#0000 25%),radial-gradient(circle at 85% 30%,#10b9810d,#0000 25%);min-height:100vh;font-family:Outfit,sans-serif;overflow-x:hidden}.glass-panel{background:var(--panel-bg);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--panel-border);box-shadow:var(--glass-shadow);border-radius:16px;transition:transform .3s,box-shadow .3s}.glass-panel:hover{transform:translateY(-2px);box-shadow:0 12px 40px #00000073}.layout{grid-template-columns:260px 1fr;min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--panel-border);background:#0b0f19f2;flex-direction:column;gap:20px;height:100vh;padding:24px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-logo{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:12px;font-size:24px;font-weight:700;display:flex}.role-badge{border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;font-weight:600;display:flex}.role-badge--petugas{color:var(--accent-primary);background:#3b82f61a;border:1px solid #3b82f633}.role-badge--dokter{color:var(--warning);background:#f59e0b1a;border:1px solid #f59e0b33}.nav-links{flex-direction:column;gap:8px;list-style:none;display:flex}.nav-item{color:var(--text-muted);cursor:pointer;border-radius:12px;align-items:center;gap:12px;padding:12px 16px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover,.nav-item.active{color:var(--accent-primary);background:#3b82f61a}.main-content{flex-direction:column;gap:32px;width:100%;max-width:1400px;margin:0 auto;padding:32px 40px;display:flex}.header{justify-content:space-between;align-items:center;display:flex}.header-title h1{margin-bottom:8px;font-size:28px;font-weight:600}.header-title p{color:var(--text-muted)}.top-cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;display:grid}.stat-card{flex-direction:column;gap:16px;padding:24px;display:flex}.stat-header{color:var(--text-muted);justify-content:space-between;align-items:center;font-size:14px;font-weight:500;display:flex}.stat-icon{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stat-icon.primary{color:var(--accent-primary);background:#3b82f61a}.stat-icon.success{color:var(--success);background:#10b9811a}.stat-icon.danger{color:var(--danger);background:#ef44441a}.stat-value{font-size:36px;font-weight:700}.charts-grid{grid-template-columns:2fr 1fr;gap:24px;display:grid}.chart-container{flex-direction:column;height:400px;padding:24px;display:flex}.chart-title{margin-bottom:24px;font-size:18px;font-weight:600}.chart-wrapper{flex:1;width:100%}.data-table-container{padding:24px;overflow-x:auto}.data-table{border-collapse:collapse;text-align:left;width:100%}.data-table th{color:var(--text-muted);border-bottom:1px solid var(--panel-border);padding:16px;font-weight:500}.data-table td{border-bottom:1px solid #ffffff05;padding:16px}.badge{border-radius:20px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-block}.badge.normal{color:var(--success);background:#10b9811a;border:1px solid #10b98133}.badge.abnormal{color:var(--danger);background:#ef44441a;border:1px solid #ef444433}.badge.pending{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b33}.badge.orthanc_refused,.badge.invalid_dicom{color:#8b5cf6;background:#8b5cf61a;border:1px solid #8b5cf633}.btn-view{border:1px solid var(--accent-primary);color:var(--accent-primary);cursor:pointer;background:0 0;border-radius:8px;padding:8px 16px;font-family:Outfit,sans-serif;font-weight:500;transition:all .2s}.btn-view:hover{background:var(--accent-primary);color:#fff}.login-layout{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{flex-direction:column;gap:24px;width:100%;max-width:480px;padding:40px;display:flex}.login-header{text-align:center;flex-direction:column;align-items:center;gap:16px;display:flex}.login-header h2{color:var(--text-main);font-size:28px}.login-header p{color:var(--text-muted);font-size:15px;line-height:1.5}.login-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-muted);font-size:14px;font-weight:500}.form-select,.input-with-icon input{border:1px solid var(--panel-border);width:100%;color:var(--text-main);background:#0f172a99;border-radius:12px;outline:none;padding:14px 16px;font-family:inherit;font-size:16px;transition:all .2s}.form-select:focus,.input-with-icon input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px #3b82f633}.input-with-icon{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);position:absolute;left:16px}.input-with-icon input{padding-left:48px}.btn-login{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;padding:16px;font-size:16px;font-weight:600;transition:opacity .2s,transform .2s}.btn-login:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-login:disabled{opacity:.7;cursor:not-allowed}.login-error{color:var(--danger);text-align:center;background:#ef44441a;border:1px solid #ef444433;border-radius:8px;padding:12px;font-size:14px}.password-hint{color:var(--text-muted);text-align:right;font-size:12px}.role-selector{border:1px solid var(--panel-border);background:#0f172a80;border-radius:12px;gap:12px;padding:6px;display:flex}.role-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px;font-family:Outfit,sans-serif;font-size:14px;font-weight:600;transition:all .2s;display:flex}.role-btn.active{color:var(--accent-primary);background:#3b82f626;border:1px solid #3b82f64d}.role-btn.active.doctor{color:var(--warning);background:#f59e0b26;border:1px solid #f59e0b4d}.role-notice{background:#f59e0b14;border:1px solid #f59e0b33;border-radius:8px;padding:10px 14px}.upload-section{flex-direction:column;gap:24px;display:flex}.pin-gate{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:40px 20px;display:flex}.pin-gate h4{color:var(--text-main);font-size:20px;font-weight:600}.pin-gate p{color:var(--text-muted);font-size:14px}.pin-input-row{align-items:center;gap:12px;display:flex}.pin-input{text-align:center;letter-spacing:.5em;border:1px solid var(--panel-border);width:120px;color:var(--text-main);background:#0f172ab3;border-radius:10px;outline:none;padding:12px 16px;font-family:Outfit,sans-serif;font-size:22px;transition:border-color .2s}.pin-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px #3b82f633}.btn-verify-pin{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;cursor:pointer;border:none;border-radius:10px;padding:12px 24px;font-family:Outfit,sans-serif;font-size:15px;font-weight:600;transition:opacity .2s}.btn-verify-pin:hover{opacity:.9}.upload-config{flex-wrap:wrap;align-items:flex-end;gap:24px;display:flex}.source-selector{gap:10px;display:flex}.source-btn{cursor:pointer;border:1px solid var(--panel-border);color:var(--text-muted);background:#0f172a80;border-radius:10px;padding:10px 18px;font-family:Outfit,sans-serif;font-size:14px;font-weight:500;transition:all .2s}.source-btn.active{color:var(--accent-primary);background:#3b82f626;border-color:#3b82f666}.drop-zone{border:2px dashed var(--panel-border);cursor:pointer;text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;transition:all .25s;display:flex}.drop-zone:hover{border-color:var(--accent-primary);background:#3b82f60a}.drop-zone.dragging{border-color:var(--accent-primary);background:#3b82f614;transform:scale(1.01)}.drop-zone p{color:var(--text-muted);font-size:15px}.drop-hint{color:#94a3b899;font-size:12px}.upload-list{flex-direction:column;gap:8px;margin-top:4px;display:flex}.upload-item{border:1px solid var(--panel-border);background:#0f172a66;border-radius:10px;align-items:center;gap:12px;padding:12px 16px;transition:background .2s;display:flex}.upload-item--success{border-color:#10b9814d}.upload-item--error{border-color:#ef44444d}.upload-item--uploading{border-color:#3b82f64d;animation:1.5s infinite pulse}.upload-item-info{flex-direction:column;flex:1;gap:2px;display:flex}.upload-item-name{color:var(--text-main);word-break:break-all;font-size:14px;font-weight:500}.upload-item-size{color:var(--text-muted);font-size:12px}.upload-item-status{min-width:200px;font-size:13px}.upload-item-actions{gap:6px;display:flex}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.preview-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.preview-modal{background:#0f172a;border:1px solid #ffffff1a;border-radius:16px;flex-direction:column;width:90vw;max-width:900px;max-height:90vh;display:flex;overflow:hidden}.preview-toolbar{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:14px 20px;font-size:14px;font-weight:500;display:flex}.preview-body{flex:1;padding:20px;overflow:auto}.preview-body img{max-width:100%;display:block}@media (max-width:1024px){.layout{grid-template-columns:220px 1fr}.main-content{padding:24px 20px}.charts-grid{grid-template-columns:1fr}}@media (max-width:768px){.layout{grid-template-columns:1fr}.sidebar{flex-flow:wrap;gap:8px;height:auto;padding:16px;position:static}.sidebar-logo{font-size:18px}.nav-links{flex-flow:wrap}.nav-item{padding:8px 12px;font-size:13px}.main-content{gap:20px;padding:16px}.header{flex-direction:column;align-items:flex-start;gap:16px}.top-cards{grid-template-columns:repeat(2,1fr);gap:12px}.stat-value{font-size:26px}.upload-config,.source-selector,.pin-input-row{flex-direction:column}}@media (max-width:480px){.top-cards{grid-template-columns:1fr}.login-card{padding:24px 20px}.data-table{font-size:13px}.data-table th,.data-table td{padding:10px 8px}}
