*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:#0f172a;color:#f1f5f9;min-height:100vh;-webkit-font-smoothing:antialiased}

/* Header */
#app-header{position:sticky;top:0;z-index:100;background:#0f172a;border-bottom:1px solid rgba(255,255,255,.08);padding:.7rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.logo{font-size:1rem;font-weight:700;color:#f1f5f9;display:flex;align-items:center;gap:.4rem}
.user-name{font-size:.78rem;color:#64748b}

/* Tabs */
#tab-bar{position:sticky;top:53px;z-index:99;background:#0f172a;border-bottom:1px solid rgba(255,255,255,.08);display:flex;overflow-x:auto;scrollbar-width:none;padding:0 .5rem}
#tab-bar::-webkit-scrollbar{display:none}
.tab-btn{flex:0 0 auto;padding:.65rem .9rem;background:none;border:none;border-bottom:2px solid transparent;color:#64748b;font-size:.82rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s}
.tab-btn.active{color:#0ea5e9;border-bottom-color:#0ea5e9}
.tab-btn:hover:not(.active){color:#94a3b8}

/* Tab panels */
.tab-panel{display:none;padding:1rem;max-width:640px;margin:0 auto}
.tab-panel.active{display:block}

/* Cards */
.card{background:#1e293b;border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:.9rem 1rem;margin-bottom:.6rem}
.card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;cursor:pointer;user-select:none}
.card-body{margin-top:.75rem}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.3rem;padding:.45rem .9rem;border-radius:8px;border:none;font-size:.82rem;font-weight:500;cursor:pointer;transition:opacity .15s}
.btn:hover{opacity:.85}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-primary{background:#0ea5e9;color:#fff}
.btn-ghost{background:rgba(255,255,255,.07);color:#94a3b8}
.btn-danger{background:rgba(239,68,68,.12);color:#ef4444}
.btn-sm{padding:.3rem .65rem;font-size:.77rem}
.btn-icon{padding:.35rem .45rem;border-radius:6px}

/* Forms */
.form-group{margin-bottom:.8rem}
.form-label{display:block;font-size:.77rem;color:#94a3b8;margin-bottom:.28rem;font-weight:500}
.form-input{width:100%;padding:.5rem .75rem;background:#0f172a;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#f1f5f9;font-size:.87rem;transition:border-color .15s}
.form-input:focus{outline:none;border-color:#0ea5e9}
.form-row{display:flex;gap:.5rem}
.form-row .form-group{flex:1}
.form-hint{font-size:.72rem;color:#475569;margin-top:.2rem}
.form-calc{font-size:.82rem;color:#38bdf8;font-weight:600;margin-top:.2rem}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:#1e293b;border-radius:16px;padding:1.25rem;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;transform:translateY(18px);opacity:0;transition:transform .22s ease,opacity .2s}
.modal-overlay.open .modal{transform:translateY(0);opacity:1}
.modal-title{font-size:1rem;font-weight:700;margin-bottom:1rem}
.modal-footer{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.07)}

/* Alarm classes (border + background) */
.alarm-zelena{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.3)!important}
.alarm-rumena{background:rgba(234,179,8,.1);border-color:rgba(234,179,8,.3)!important}
.alarm-oranzna{background:rgba(249,115,22,.12);border-color:rgba(249,115,22,.35)!important}
.alarm-rdeca{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.35)!important}
.alarm-crna{background:rgba(17,24,39,.9);border-color:rgba(255,255,255,.15)!important}
.alarm-ni{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.07)!important}

/* Alarm dots */
.alarm-dot{display:inline-block;width:9px;height:9px;border-radius:50%;flex-shrink:0}
.dot-zelena{background:#22c55e}
.dot-rumena{background:#eab308}
.dot-oranzna{background:#f97316}
.dot-rdeca{background:#ef4444}
.dot-crna{background:#6b7280}
.dot-ni{background:#334155}

/* Alarm text colors */
.txt-zelena{color:#4ade80}
.txt-rumena{color:#fbbf24}
.txt-oranzna{color:#fb923c}
.txt-rdeca{color:#f87171}
.txt-crna{color:#9ca3af}
.txt-ni{color:#475569}

/* Therapy card */
.therapy-card{border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.75rem;margin-bottom:.45rem}
.therapy-name{font-weight:600;font-size:.9rem}
.therapy-meta{font-size:.73rem;color:#64748b;margin-top:.12rem;line-height:1.4}
.therapy-footer{display:flex;align-items:flex-end;justify-content:space-between;margin-top:.65rem;flex-wrap:wrap;gap:.4rem}
.therapy-stat{min-width:0}
.stat-label{font-size:.68rem;color:#64748b;margin-bottom:.05rem}
.stat-val{font-size:.9rem;font-weight:700}
.therapy-actions{display:flex;gap:.25rem;flex-shrink:0}

/* Patient card */
.patient-name{font-size:.95rem;font-weight:600}
.patient-soba{font-size:.76rem;color:#64748b;margin-top:.05rem}
.alarm-summary{display:flex;gap:.25rem;align-items:center;flex-wrap:wrap}
.chevron{color:#334155;font-size:1rem;transition:transform .2s;line-height:1}
.chevron.open{transform:rotate(90deg)}

/* Zaloge filter toggle buttons */
.zf-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .65rem;border-radius:99px;border:1px solid rgba(255,255,255,.1);font-size:.76rem;font-weight:500;cursor:pointer;transition:opacity .15s,border-color .15s;opacity:.35;background:rgba(255,255,255,.05);color:#94a3b8}
.zf-btn.active{opacity:1}
.zs-btn{display:inline-flex;padding:.28rem .65rem;border-radius:99px;border:1px solid rgba(255,255,255,.1);font-size:.74rem;font-weight:500;cursor:pointer;background:rgba(255,255,255,.04);color:#64748b;transition:all .15s}
.zs-btn.active{background:rgba(14,165,233,.15);border-color:rgba(14,165,233,.4);color:#38bdf8}
.zf-crna.active{background:rgba(107,114,128,.2);border-color:rgba(107,114,128,.4);color:#d1d5db}
.zf-rdeca.active{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.4);color:#f87171}
.zf-oranzna.active{background:rgba(249,115,22,.15);border-color:rgba(249,115,22,.4);color:#fb923c}
.zf-rumena.active{background:rgba(234,179,8,.12);border-color:rgba(234,179,8,.35);color:#fbbf24}
.zf-zelena.active{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.35);color:#4ade80}
.zf-ni.active{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.15);color:#64748b}

/* Stanje zalog rows */
.zaloga-row{display:flex;align-items:center;gap:.65rem;padding:.6rem .75rem;border-radius:10px;border:1px solid rgba(255,255,255,.07);background:#1e293b;margin-bottom:.35rem}
.zaloga-dot{flex-shrink:0}
.zaloga-info{flex:1;min-width:0}
.zaloga-pac{font-size:.7rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.zaloga-med{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.zaloga-right{text-align:right;flex-shrink:0}
.zaloga-zmanjka{font-size:.78rem;font-weight:700}
.zaloga-dni{font-size:.68rem;color:#64748b}

/* User rows (Info tab) */
.user-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.06)}
.user-row:last-child{border:none}
.user-dname{font-size:.87rem;font-weight:500}
.user-uname{font-size:.73rem;color:#64748b}
.badge-admin{display:inline-block;font-size:.63rem;font-weight:700;background:rgba(14,165,233,.2);color:#38bdf8;padding:.1rem .4rem;border-radius:5px;margin-left:.35rem}

/* Section titles */
.section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#475569;margin:.85rem 0 .5rem}
.section-title:first-child{margin-top:0}

/* FAB */
.fab{position:fixed;right:1.25rem;bottom:1.5rem;width:52px;height:52px;border-radius:50%;background:#0ea5e9;border:none;color:#fff;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(14,165,233,.4);transition:transform .15s;z-index:90}
.fab:hover{transform:scale(1.08)}
.fab.hidden{display:none}

/* Toast */
.toast{position:fixed;bottom:5rem;left:50%;transform:translateX(-50%) translateY(10px);background:#334155;color:#f1f5f9;padding:.55rem 1.1rem;border-radius:99px;font-size:.8rem;opacity:0;transition:opacity .2s,transform .2s;z-index:300;white-space:nowrap;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Search */
.search-wrap{position:relative;margin-bottom:.75rem}
.search-wrap input{width:100%;padding:.5rem .75rem .5rem 2.1rem;background:#1e293b;border:1px solid rgba(255,255,255,.08);border-radius:10px;color:#f1f5f9;font-size:.85rem}
.search-wrap input:focus{outline:none;border-color:#0ea5e9}
.search-wrap svg{position:absolute;left:.65rem;top:50%;transform:translateY(-50%);color:#475569;width:15px;height:15px;pointer-events:none}

/* Empty state */
.empty{text-align:center;padding:2.5rem 1rem;color:#475569;font-size:.85rem}
.empty-icon{font-size:2.2rem;margin-bottom:.5rem}

/* Divider */
.divider{height:1px;background:rgba(255,255,255,.07);margin:.65rem 0}

/* Alert box */
.alert{padding:.65rem .85rem;border-radius:8px;font-size:.82rem;margin-bottom:.75rem}
.alert-err{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.3);color:#f87171}
.alert-ok{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.25);color:#4ade80}

/* Login page */
.login-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem}
.login-box{width:100%;max-width:360px}
.login-card{background:#1e293b;border-radius:14px;padding:1.5rem;border:1px solid rgba(255,255,255,.07)}

/* Nastavitve */
.set-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.06)}
.set-row:last-child{border:none}
.set-label{font-size:.85rem}
.set-desc{font-size:.72rem;color:#64748b;margin-top:.1rem}
.set-input{width:80px;text-align:right}

/* Dnevnik */
.dn-row{display:grid;grid-template-columns:7px auto 1fr 2fr;align-items:center;gap:.5rem .65rem;padding:.55rem .1rem;border-bottom:1px solid rgba(255,255,255,.05);font-size:.78rem}
.dn-row:last-child{border:none}
.dn-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dn-dot-dodal{background:#22c55e}
.dn-dot-uredil{background:#38bdf8}
.dn-dot-izbrisal{background:#ef4444}
.dn-dot-vnos{background:#0ea5e9}
.dn-dot-spremenil{background:#f97316}
.dn-dot-geslo{background:#eab308}
.dn-time{color:#475569;white-space:nowrap;font-size:.72rem}
.dn-user{color:#94a3b8;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dn-opis{color:#cbd5e1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Scrollbar */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}
