
:root {
  --green: #1D9E75;
  --green-dark: #0F6E56;
  --green-light: #E1F5EE;
  --green-mid: #9FE1CB;
  --sidebar-bg: #0f1923;
  --sidebar-text: #a8b8c8;
  --sidebar-active: #1D9E75;
  --sidebar-hover: #1a2535;
  --bg: #f0f4f8;
  --card: #ffffff;
  --border: #e2e8f0;
  --border-light: #f1f5f9;
  --text: #0f1923;
  --text-2: #4a5568;
  --text-3: #94a3b8;
  --blue: #3b82f6;
  --amber: #f59e0b;
  --red: #ef4444;
  --purple: #8b5cf6;
  --pink: #ec4899;
  --radius: 10px;
  --radius-sm: 6px;
  --shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);
  --shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);
  --shadow-lg: 0 10px 25px rgba(0,0,0,.1), 0 4px 10px rgba(0,0,0,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Outfit',sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}
input,select,button,textarea{font-family:'Outfit',sans-serif}

/* ═══ SCROLLBAR ═══ */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}

/* ═══ LOGIN ═══ */
#login-screen{position:fixed;inset:0;background:var(--sidebar-bg);display:flex;align-items:center;justify-content:center;z-index:1000}
.login-bg-pattern{position:absolute;inset:0;opacity:.04;background-image:repeating-linear-gradient(45deg,#fff 0,#fff 1px,transparent 0,transparent 50%);background-size:20px 20px}
.login-box{position:relative;width:380px;background:#1a2535;border:1px solid #2a3a4d;border-radius:16px;padding:2.5rem;box-shadow:0 25px 50px rgba(0,0,0,.4)}
.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:2rem}
.login-logo-icon{width:40px;height:40px;background:var(--green);border-radius:10px;display:flex;align-items:center;justify-content:center}
.login-logo-icon svg{width:22px;height:22px;fill:#fff}
.login-logo-text{font-size:22px;font-weight:700;color:#fff;letter-spacing:-.5px}
.login-logo-text span{color:var(--green)}
.login-sub{font-size:12px;color:#64748b;margin-bottom:1.5rem;line-height:1.4}
.login-fr{margin-bottom:1rem}
.login-fr label{display:block;font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}
.login-fr input{width:100%;background:#0f1923;border:1px solid #2a3a4d;border-radius:8px;padding:10px 14px;color:#fff;font-size:14px;outline:none;transition:border-color .2s}
.login-fr input:focus{border-color:var(--green)}
.login-fr input::placeholder{color:#3a4a5d}
.login-err{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:9px 12px;font-size:12px;color:#fca5a5;margin-bottom:1rem;display:none}
.login-btn{width:100%;background:var(--green);color:#fff;border:none;border-radius:8px;padding:11px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}
.login-btn:hover{background:var(--green-dark)}
.login-btn:active{transform:scale(.99)}
.login-hint{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid #2a3a4d}
.login-hint-title{font-size:11px;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}
.login-hint-row{display:flex;justify-content:space-between;font-size:11px;color:#3a4a5d;margin-bottom:3px}

/* ═══ LAYOUT ═══ */
#app{display:none;height:100vh;overflow:hidden}
.layout{display:flex;height:100vh}

/* ═══ SIDEBAR ═══ */
.sidebar{width:220px;flex-shrink:0;background:var(--sidebar-bg);display:flex;flex-direction:column;overflow:hidden}
.sidebar-header{padding:1.25rem 1rem 1rem;border-bottom:1px solid #1a2535}
.sidebar-logo{display:flex;align-items:center;gap:8px}
.sidebar-logo-icon{width:30px;height:30px;background:var(--green);border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sidebar-logo-icon svg{width:16px;height:16px;fill:#fff}
.sidebar-logo-text{font-size:16px;font-weight:700;color:#fff;letter-spacing:-.3px}
.sidebar-logo-text span{color:var(--green)}
.sidebar-user{padding:.75rem 1rem;border-bottom:1px solid #1a2535}
.sidebar-user-name{font-size:12px;font-weight:600;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-role{font-size:10px;margin-top:2px}
.role-sa{color:var(--green)}
.role-a{color:#60a5fa}
.role-i{color:#fbbf24}
.sidebar-nav{flex:1;overflow-y:auto;padding:.5rem 0}
.nav-section{padding:.5rem 1rem .25rem;font-size:10px;font-weight:600;color:#2a3a4d;text-transform:uppercase;letter-spacing:.8px}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 1rem;cursor:pointer;color:var(--sidebar-text);font-size:13px;font-weight:400;transition:all .15s;border-left:2px solid transparent;margin:1px 0}
.nav-item:hover{background:var(--sidebar-hover);color:#e2e8f0}
.nav-item.active{background:rgba(29,158,117,.12);color:var(--green);border-left-color:var(--green);font-weight:500}
.nav-item svg{width:16px;height:16px;flex-shrink:0;opacity:.7}
.nav-item.active svg{opacity:1}
.sidebar-footer{padding:1rem;border-top:1px solid #1a2535}
.logout-btn{display:flex;align-items:center;gap:8px;width:100%;background:transparent;border:1px solid #2a3a4d;border-radius:7px;padding:7px 10px;color:#64748b;font-size:12px;cursor:pointer;transition:all .15s}
.logout-btn:hover{background:#1a2535;color:#94a3b8}
.logout-btn svg{width:14px;height:14px}

/* ═══ MAIN ═══ */
.main{flex:1;overflow:hidden;display:flex;flex-direction:column}
.topbar{background:var(--card);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;gap:12px;flex-shrink:0}
.topbar-title{font-size:16px;font-weight:600;color:var(--text);flex:1}
.topbar-date{font-size:12px;color:var(--text-3);font-weight:400}
.content{flex:1;overflow-y:auto;padding:1.5rem}

/* ═══ CARDS ═══ */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:14px;font-weight:600;color:var(--text)}
.card-body{padding:1.25rem}

/* ═══ BUTTONS ═══ */
.btn{display:inline-flex;align-items:center;gap:6px;border-radius:var(--radius-sm);padding:7px 14px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s}
.btn-primary{background:var(--green);color:#fff}.btn-primary:hover{background:var(--green-dark)}
.btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text-2)}.btn-secondary:hover{background:var(--bg)}
.btn-danger{background:transparent;border:1px solid #fca5a5;color:#ef4444}.btn-danger:hover{background:#fef2f2}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-blue{background:#3b82f6;color:#fff}.btn-blue:hover{background:#2563eb}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ═══ FORM ═══ */
.form-group{margin-bottom:.875rem}
.form-group label{display:block;font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.form-group input,.form-group select,.form-group textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 11px;font-size:13px;color:var(--text);background:#fff;outline:none;transition:border-color .2s,box-shadow .2s}
.form-group input:focus,.form-group select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(29,158,117,.1)}
.form-group input.err{border-color:var(--red);box-shadow:0 0 0 3px rgba(239,68,68,.1)}
.form-grid{display:grid;gap:.75rem}
.form-grid-2{grid-template-columns:1fr 1fr}
.form-grid-3{grid-template-columns:1fr 1fr 1fr}
.checkbox-row{display:flex;align-items:center;gap:8px;padding:8px 0}
.checkbox-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--green);cursor:pointer}
.checkbox-row label{font-size:13px;color:var(--text-2);cursor:pointer;margin:0;font-weight:400;text-transform:none;letter-spacing:0}

/* ═══ ALERTS ═══ */
.alert{border-radius:var(--radius-sm);padding:9px 12px;font-size:12px;margin-bottom:6px;display:flex;align-items:flex-start;gap:8px;line-height:1.5}
.alert-gap{background:#fffbeb;border:1px solid #fde68a;color:#92400e}
.alert-limit{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}
.alert-doc{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}
.alert svg{width:14px;height:14px;flex-shrink:0;margin-top:1px}
.alerts-header{font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:8px;display:flex;align-items:center;gap:6px}

/* ═══ BADGES ═══ */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}
.badge-green{background:var(--green-light);color:var(--green-dark)}
.badge-blue{background:#eff6ff;color:#1d4ed8}
.badge-amber{background:#fffbeb;color:#92400e}
.badge-red{background:#fef2f2;color:#991b1b}
.badge-purple{background:#f5f3ff;color:#5b21b6}
.badge-pink{background:#fdf2f8;color:#9d174d}
.badge-gray{background:#f8fafc;color:#475569;border:1px solid var(--border)}
.badge-suppl{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}

/* ═══ EXPIRY LABELS ═══ */
.exp-ok{color:var(--green);font-size:11px;font-weight:500}
.exp-warn{color:var(--amber);font-size:11px;font-weight:500}
.exp-err{color:var(--red);font-size:11px;font-weight:500}

/* ═══ CALENDAR NAV ═══ */
.cal-nav{display:flex;align-items:center;gap:8px;margin-bottom:1rem}
.cal-period{font-size:15px;font-weight:600;color:var(--text);min-width:200px}
.cal-nav-btn{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-2);transition:all .15s}
.cal-nav-btn:hover{background:var(--bg);border-color:#cbd5e1}
.cal-today-btn{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 12px;height:32px;font-size:12px;font-weight:500;cursor:pointer;color:var(--text-2);transition:all .15s}
.cal-today-btn:hover{background:var(--bg)}
.view-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.view-btn{padding:5px 14px;font-size:12px;font-weight:500;cursor:pointer;background:#fff;border:none;color:var(--text-3);transition:all .15s}
.view-btn.active{background:var(--sidebar-bg);color:#fff}
.legend{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:.75rem}
.leg{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-3)}
.leg-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}

/* ═══ DAY VIEW ═══ */
.day-outer{border:1px solid var(--border);border-radius:var(--radius);overflow:auto;background:#fff;max-height:calc(100vh - 280px)}
.day-head{display:flex;background:#f8fafc;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}
.day-corner{width:54px;flex-shrink:0;border-right:1px solid var(--border)}
.instr-hcol{flex:1;min-width:170px;border-right:1px solid var(--border);padding:8px 10px}
.instr-hcol:last-child{border-right:none}
.instr-hbar{height:3px;border-radius:2px;margin-bottom:5px}
.instr-hname{font-size:12px;font-weight:600;color:var(--text)}
.instr-hkat{font-size:10px;color:var(--text-3);margin-top:1px}
.day-body{display:flex}
.time-col{width:54px;flex-shrink:0;border-right:1px solid var(--border)}
.hlbl{height:64px;font-size:10px;color:var(--text-3);padding:4px 6px;text-align:right;border-bottom:1px solid var(--border-light);line-height:1;font-family:'DM Mono',monospace}
.instr-dcol{flex:1;min-width:170px;border-right:1px solid var(--border);position:relative}
.instr-dcol:last-child{border-right:none}
.dslot{height:64px;border-bottom:1px solid var(--border-light)}

/* ═══ EVENTS ═══ */
.ev{position:absolute;left:4px;right:4px;border-radius:7px;padding:5px 8px;z-index:2;overflow:hidden;cursor:pointer;line-height:1.4;transition:filter .1s,transform .1s}
.ev:hover{filter:brightness(.94);transform:scale(1.01)}
.ev-type{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;opacity:.75;margin-bottom:1px}
.ev-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ev-sub{font-size:10px;opacity:.75;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.ev-kat{display:inline-block;font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;margin-top:2px;opacity:.85}
.ev-time{font-size:9px;opacity:.6;margin-top:2px;font-family:'DM Mono',monospace}

/* ═══ WEEK VIEW ═══ */
.wk-outer{border:1px solid var(--border);border-radius:var(--radius);overflow:auto;background:#fff;max-height:calc(100vh - 280px)}
.wk-head{display:flex;background:#f8fafc;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}
.wk-corner{width:54px;flex-shrink:0;border-right:1px solid var(--border)}
.wk-dh{flex:1;min-width:80px;text-align:center;padding:8px 4px;border-right:1px solid var(--border);cursor:pointer}
.wk-dh:last-child{border-right:none}
.wk-dh:hover{background:#f1f5f9}
.wk-dname{font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.4px}
.wk-dnum{font-size:18px;font-weight:600;color:var(--text);line-height:1.3}
.wk-dnum.today{background:var(--green);color:#fff;border-radius:50%;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;font-size:14px}
.wk-body{display:flex}
.wk-tcol{width:54px;flex-shrink:0;border-right:1px solid var(--border)}
.wk-hlbl{height:56px;font-size:10px;color:var(--text-3);padding:3px 6px;text-align:right;border-bottom:1px solid var(--border-light);font-family:'DM Mono',monospace}
.wk-dcol{flex:1;min-width:80px;border-right:1px solid var(--border);position:relative}
.wk-dcol:last-child{border-right:none}
.wk-ts{height:56px;border-bottom:1px solid var(--border-light)}
.wk-ev{position:absolute;left:2px;right:2px;border-radius:5px;padding:2px 5px;font-size:10px;z-index:2;overflow:hidden;cursor:pointer;line-height:1.3;transition:filter .1s}
.wk-ev:hover{filter:brightness(.92)}
.we-t{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.we-s{font-size:9px;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ═══ TABLES ═══ */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;padding:9px 12px;border-bottom:2px solid var(--border);font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
td{padding:9px 12px;border-bottom:1px solid var(--border-light);color:var(--text);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#f8fafc}

/* ═══ KURSANT CARD ═══ */
.kurs-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:10px;transition:box-shadow .15s}
.kurs-card:hover{box-shadow:var(--shadow-md)}
.kurs-name{font-size:14px;font-weight:600;color:var(--text)}
.progress-wrap{display:flex;align-items:center;gap:10px;margin:.5rem 0}
.progress-bar{flex:1;height:7px;background:var(--bg);border-radius:10px;overflow:hidden}
.progress-fill{height:100%;border-radius:10px;transition:width .4s}
.progress-label{font-size:12px;font-weight:600;min-width:72px;text-align:right}
.kurs-meta{font-size:11px;color:var(--text-3);display:flex;gap:12px;flex-wrap:wrap}

/* ═══ PROGRESS COLORS ═══ */
.prog-ok{background:var(--green)}
.prog-warn{background:var(--amber)}
.prog-full{background:var(--red)}

/* ═══ INLINE ITEMS LIST ═══ */
.list-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:6px;background:#fff;transition:box-shadow .15s}
.list-item:hover{box-shadow:var(--shadow)}
.color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.list-main{flex:1;min-width:0}
.list-name{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-detail{font-size:11px;color:var(--text-3);margin-top:1px}
.list-actions{display:flex;gap:6px;flex-shrink:0}

/* ═══ SEARCH ═══ */
.search-wrap{position:relative;margin-bottom:1rem}
.search-wrap svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--text-3)}
.search-wrap input{width:100%;padding:8px 12px 8px 32px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;background:#fff}
.search-wrap input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(29,158,117,.1)}
.search-results{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:.75rem;display:none;background:#fff;box-shadow:var(--shadow-md)}
.sr-item{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--border-light);cursor:pointer}
.sr-item:last-child{border-bottom:none}
.sr-item:hover{background:#f8fafc}
.sr-name{font-weight:500;color:var(--text);flex:1;font-size:13px}
.sr-detail{font-size:11px;color:var(--text-3)}

/* ═══ MODAL ═══ */
.ov{position:fixed;inset:0;background:rgba(15,25,35,.6);display:flex;align-items:center;justify-content:center;z-index:500;backdrop-filter:blur(3px)}
.modal{background:#fff;border-radius:14px;padding:0;width:420px;max-width:95vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}
.modal-header{padding:1.25rem 1.5rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:15px;font-weight:600;color:var(--text)}
.modal-close{width:28px;height:28px;border:none;background:var(--bg);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:all .15s}
.modal-close:hover{background:var(--border);color:var(--text)}
.modal-body{padding:1.25rem 1.5rem;overflow-y:auto;flex:1}
.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:#fafafa}
.modal-footer-left{margin-right:auto}
.warn-box{border-radius:var(--radius-sm);padding:9px 12px;font-size:12px;margin-bottom:.875rem;line-height:1.6;display:none}
.warn-conflict{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}
.warn-urlop{background:#fffbeb;border:1px solid #fde68a;color:#92400e}
.ki-box{background:var(--bg);border-radius:var(--radius-sm);padding:8px 11px;font-size:11px;color:var(--text-2);margin-top:5px;display:none;line-height:1.7}
.ki-box.show{display:block}
.ki-hl{font-weight:600;color:var(--text)}
.ki-warn{color:var(--red);font-weight:600}
.ki-ok{color:var(--green);font-weight:600}
.time-row{display:grid;grid-template-columns:1fr 28px 1fr;gap:6px;align-items:end}
.time-sep{text-align:center;font-size:18px;color:var(--text-3);padding-bottom:7px}

/* ═══ PASS CELL ═══ */
.pass-cell{font-family:'DM Mono',monospace;font-size:12px;color:var(--text-2);background:var(--bg);padding:3px 8px;border-radius:4px;cursor:pointer;user-select:all;border:1px solid var(--border)}
.pass-cell:hover{border-color:var(--green)}

/* ═══ STAT TABLE ═══ */
.stat-total{font-size:13px;font-weight:600;color:var(--text);margin-top:1rem;padding-top:1rem;border-top:2px solid var(--border);display:flex;justify-content:flex-end}

/* ═══ EXPORT CARDS ═══ */
.export-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}
.exp-card{border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;background:#fff}
.exp-card h5{font-size:13px;font-weight:600;color:var(--text);margin-bottom:5px}
.exp-card p{font-size:12px;color:var(--text-3);margin-bottom:12px;line-height:1.5}
.exp-card select,.exp-card input{width:100%;margin-bottom:8px;border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 10px;font-size:12px;outline:none}
.exp-card select:focus,.exp-card input:focus{border-color:var(--green)}

/* ═══ DRIVES TABLE ═══ */
.drives-table{width:100%;border-collapse:collapse;font-size:11px;margin-top:10px}
.drives-table th{padding:5px 8px;border-bottom:1px solid var(--border);font-weight:600;color:var(--text-3);font-size:10px;text-transform:uppercase;letter-spacing:.4px;background:#f8fafc}
.drives-table td{padding:6px 8px;border-bottom:1px solid var(--border-light);color:var(--text)}
.drives-table tr:last-child td{border-bottom:none}
.drives-table tfoot td{font-weight:600;border-top:2px solid var(--border);padding-top:8px}

/* ═══ USERS TAB ═══ */
.user-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:6px;background:#fff}
.user-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;color:#fff}

/* ═══ ANIMATIONS ═══ */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.card,.kurs-card,.list-item{animation:fadeIn .2s ease}
.ov{animation:fadeIn .15s ease}

/* ═══ MONTH FILTER ═══ */
.filter-bar{display:flex;gap:8px;align-items:center;margin-bottom:1rem;flex-wrap:wrap}
.filter-bar label{font-size:12px;color:var(--text-2);font-weight:500}
.filter-bar select,.filter-bar input{border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px;font-size:12px;background:#fff;outline:none}
.filter-bar select:focus,.filter-bar input:focus{border-color:var(--green)}

/* ═══ MOBILE ═══ */
#bottom-nav{display:none}
@media(max-width:680px){
  .sidebar{display:none!important}
  .layout{flex-direction:column}
  .main{height:100vh}
  .topbar{padding:.6rem 1rem;gap:6px;flex-wrap:nowrap}
  .topbar-date{display:none}
  #btn-add-zajecia{margin-left:0}
  .content{padding:.875rem;padding-bottom:80px}
  #bottom-nav{
    display:flex!important;
    position:fixed;bottom:0;left:0;right:0;
    background:var(--sidebar-bg);
    border-top:1px solid #1a2535;
    z-index:50;height:64px;
    padding-bottom:env(safe-area-inset-bottom)
  }
  .bnav-item{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:3px;cursor:pointer;color:#4a6070;font-size:10px;font-weight:500;
    transition:color .15s;padding:6px 4px;border:none;background:transparent
  }
  .bnav-item svg{width:20px;height:20px}
  .bnav-item.active{color:var(--green)}
  .bnav-label{margin-top:1px}
  .bnav-add{
    width:44px;height:44px;border-radius:50%;
    background:var(--green);color:#fff;
    display:flex;align-items:center;justify-content:center;
    border:none;cursor:pointer;
    box-shadow:0 4px 12px rgba(29,158,117,.4);
    transition:background .15s,transform .1s;
    margin-bottom:4px
  }
  .bnav-add:active{transform:scale(.94)}
  .bnav-add svg{width:22px;height:22px}
  #topbar-title{font-size:15px;font-weight:600}
  .day-outer{max-height:calc(100vh - 160px)}
  .instr-hcol{min-width:130px;padding:6px 7px}
  .instr-dcol{min-width:130px}
  .hlbl{height:64px;font-size:9px;padding:3px 3px}
  .time-col{width:40px}
  .day-corner{width:40px}
  .ev{padding:4px 6px}
  .ev-name{font-size:11px}
  .ev-car,.ev-time{font-size:9px}
  .wk-outer{max-height:calc(100vh - 160px)}
  .wk-corner,.wk-tcol{width:40px}
  .wk-dh{min-width:44px;padding:6px 2px}
  .wk-dname{font-size:9px}
  .wk-dnum{font-size:13px}
  .wk-dcol{min-width:44px}
  .wk-ev{padding:2px 3px;font-size:9px}
  .cal-period{font-size:13px;min-width:0;flex:1;text-align:center}
  .legend{gap:8px}
  .leg{font-size:10px}
  .card-header{padding:.875rem 1rem;flex-wrap:wrap;gap:8px}
  .card-body{padding:1rem}
  .kurs-card{padding:.875rem 1rem}
  .kurs-name{font-size:13px}
  th{padding:6px 8px;font-size:10px}
  td{padding:6px 8px;font-size:12px}
  .list-item{flex-wrap:wrap;gap:6px;padding:8px 10px}
  .list-actions{width:100%;display:flex;justify-content:flex-end}
  /* Modal — slide up full screen */
  .ov{align-items:flex-end;padding:0}
  .modal{
    width:100%!important;max-width:100%!important;
    border-radius:16px 16px 0 0!important;
    max-height:92vh
  }
  .modal-header{padding:1rem 1.25rem .875rem}
  .modal-body{padding:1rem 1.25rem}
  .modal-footer{padding:.875rem 1.25rem}
  .form-grid-2{grid-template-columns:1fr}
  .form-grid-3{grid-template-columns:1fr 1fr}
  /* font-size 16px zapobiega zoom na iOS */
  .form-group input,.form-group select{font-size:16px!important;padding:11px 12px}
  .time-row input{font-size:18px!important;text-align:center;padding:11px}
  .btn{padding:9px 16px;font-size:13px}
  .btn-sm{padding:7px 12px;font-size:12px}
  .filter-bar{flex-wrap:wrap}
  .filter-bar select,.filter-bar input{font-size:14px!important}
  .export-grid{grid-template-columns:1fr}
  .drives-table{font-size:10px}
  .drives-table th,.drives-table td{padding:4px 5px}
  .user-row{flex-wrap:wrap;gap:6px}
  .pass-cell{font-size:10px;padding:2px 5px}
  .alert{font-size:11px;padding:7px 10px}
  .search-wrap input{font-size:16px!important}
}
