:root {
  --bg:#0B1120; --bg2:#111827; --bg3:#1C2537;
  --card:rgba(255,255,255,0.05); --card-h:rgba(255,255,255,0.08);
  --border:rgba(255,255,255,0.08);
  --blue:#4F9EF8; --blue2:#2563EB; --blue-g:rgba(79,158,248,0.15);
  --teal:#14B8A6; --green:#10B981; --green-g:rgba(16,185,129,0.15);
  --amber:#F59E0B; --red:#EF4444; --red-g:rgba(239,68,68,0.15);
  --purple:#8B5CF6; --sky:#0EA5E9;
  --text:#F1F5F9; --text2:#94A3B8; --text3:#4A5568;
  --nav-h:72px; --top-h:60px; --r:16px; --r-sm:10px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
.hidden{display:none!important}
html{height:100%;overflow:hidden}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);height:100dvh;overflow:hidden;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}
#app{display:flex;flex-direction:column;height:100dvh}

/* ── TOPBAR ── */
.topbar{height:var(--top-h);min-height:var(--top-h);display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:rgba(11,17,32,0.95);border-bottom:1px solid var(--border);backdrop-filter:blur(20px);position:relative;z-index:100}
.topbar-brand{display:flex;align-items:center;gap:10px}
.brand-icon{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--blue),var(--blue2));display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(79,158,248,0.3)}
.brand-icon svg{width:17px;height:17px;color:#fff}
.brand-title{font-size:14px;font-weight:700;line-height:1.1}
.brand-sub{font-size:11px;color:var(--text2)}
.topbar-right{display:flex;align-items:center;gap:10px}
.saldo-chip{padding:5px 12px;border-radius:20px;font-size:13px;font-weight:700;background:var(--card);border:1px solid var(--border);transition:all 0.4s}
.saldo-chip.pos{background:var(--green-g);border-color:rgba(16,185,129,0.3);color:var(--green)}
.saldo-chip.neg{background:var(--red-g);border-color:rgba(239,68,68,0.3);color:var(--red)}
.avatar-btn{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--purple));display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;cursor:pointer;overflow:hidden;flex-shrink:0;border:2px solid rgba(255,255,255,0.1)}
.avatar-btn img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.avatar-btn span{font-size:13px;font-weight:800}

/* ── MAIN ── */
.main-content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;padding-bottom:var(--nav-h)}
.main-content::-webkit-scrollbar{display:none}
.view{animation:fadeIn 0.22s ease-out}
.view.hidden{display:none}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.glass-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);backdrop-filter:blur(20px)}

/* ── DASHBOARD HERO ── */
.dash-hero{position:relative;overflow:hidden;min-height:270px;padding:20px 16px 24px;background:linear-gradient(180deg,#0D1A30 0%,var(--bg2) 100%)}
.dash-hero-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:0.15;animation:orbFloat 8s ease-in-out infinite}
.orb1{width:280px;height:280px;background:var(--blue);top:-80px;right:-60px}
.orb2{width:200px;height:200px;background:var(--teal);bottom:-50px;left:-50px;animation-delay:4s}
@keyframes orbFloat{0%,100%{transform:translate(0,0)}50%{transform:translate(12px,-12px)}}
.grid-lines{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.02) 1px,transparent 1px);background-size:40px 40px}
.dash-hero-content{position:relative;z-index:2;margin-bottom:16px}
.hero-greeting{font-size:13px;color:var(--text2)}
.hero-name{font-size:22px;font-weight:800;letter-spacing:-0.5px;margin:2px 0}
.hero-date{font-size:12px;color:var(--text3)}

/* SALDO CARD */
.saldo-card{position:relative;z-index:2;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:var(--r);padding:16px;backdrop-filter:blur(20px);transition:all 0.4s}
.saldo-card.positive{border-color:rgba(16,185,129,0.3);box-shadow:0 0 40px rgba(16,185,129,0.08)}
.saldo-card.negative{border-color:rgba(239,68,68,0.3);box-shadow:0 0 40px rgba(239,68,68,0.08)}
.saldo-label{font-size:10px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:1px}
.saldo-value{margin:6px 0 3px}
.saldo-num{font-size:42px;font-weight:900;letter-spacing:-2px;line-height:1;transition:color 0.4s}
.saldo-num.pos{color:var(--green);text-shadow:0 0 24px rgba(16,185,129,0.35)}
.saldo-num.neg{color:var(--red);text-shadow:0 0 24px rgba(239,68,68,0.25)}
.saldo-sub{font-size:11px;color:var(--text2);margin-bottom:10px}
.saldo-progress-wrap{height:3px;background:rgba(255,255,255,0.08);border-radius:2px;overflow:hidden}
.saldo-progress{height:100%;border-radius:2px;transition:width 0.8s cubic-bezier(0.34,1.56,0.64,1)}

/* MINI STATS */
.dash-stats-row{display:flex;gap:10px;padding:10px 16px}
.mini-stat{flex:1;background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px;display:flex;align-items:center;gap:8px}
.mini-stat-icon{font-size:18px}
.mini-stat-info{display:flex;flex-direction:column;gap:1px}
.mini-stat-val{font-size:14px;font-weight:700;line-height:1.1}
.mini-stat-lbl{font-size:9px;color:var(--text2)}

/* SECTION */
.section{padding:0 16px 16px}
.section-hdr{display:flex;justify-content:space-between;align-items:center;padding:14px 0 10px}
.section-hdr h3{font-size:15px;font-weight:700}
.text-btn{background:none;border:none;color:var(--blue);font-size:13px;font-weight:600;cursor:pointer}

/* MONTH SUMMARY */
.month-summary{padding:14px}
.month-bar{margin-bottom:10px}
.month-bar-hdr{display:flex;justify-content:space-between;font-size:12px;margin-bottom:5px}
.month-bar-hdr span:last-child{font-weight:700}
.month-track{height:7px;background:rgba(255,255,255,0.06);border-radius:4px;overflow:hidden}
.month-fill{height:100%;border-radius:4px;transition:width 0.8s cubic-bezier(0.34,1.56,0.64,1)}
.month-fill.over{background:linear-gradient(90deg,var(--blue),var(--green))}
.month-fill.under{background:linear-gradient(90deg,var(--amber),var(--red))}
.month-totals{display:flex;gap:0;border-top:1px solid var(--border);padding-top:10px;margin-top:10px}
.month-total{flex:1;text-align:center;border-right:1px solid var(--border)}
.month-total:last-child{border-right:none}
.month-total-val{display:block;font-size:15px;font-weight:700}
.month-total-lbl{display:block;font-size:9px;color:var(--text2);margin-top:1px}

/* ── CALENDAR ── */
.page-hdr{display:flex;align-items:center;gap:12px;padding:14px 16px 8px;position:sticky;top:0;z-index:50;background:rgba(11,17,32,0.95);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.page-hdr h2{font-size:19px;font-weight:800}
.page-hdr-flex{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;position:sticky;top:0;z-index:50;background:rgba(11,17,32,0.95);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.page-hdr-flex h2{font-size:19px;font-weight:800}
.back-btn{width:34px;height:34px;border-radius:50%;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text)}
.back-btn svg{width:17px;height:17px}
.nav-arrow{width:32px;height:32px;border-radius:50%;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text2);flex-shrink:0;transition:all 0.15s}
.nav-arrow:hover{background:var(--card-h);color:var(--text)}
.nav-arrow svg{width:16px;height:16px}

.cal-wrap{padding:0 10px}
.cal-dow-row{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-size:11px;font-weight:600;color:var(--text3);padding:8px 0 4px}
.cal-dow-row .weekend{color:var(--text2)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;padding-bottom:8px}
.cal-day{border-radius:10px;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:all 0.15s;min-height:44px}
.cal-day.empty{cursor:default}
.cal-day:not(.empty):active{transform:scale(0.92)}
.cal-day-num{font-size:12px;font-weight:600;line-height:1;z-index:1}
.cal-day-code{font-size:9px;font-weight:800;line-height:1;margin-top:2px;z-index:1;letter-spacing:0.3px}
.cal-day-dot{width:5px;height:5px;border-radius:50%;background:#fff;opacity:0.9;margin-top:2px;z-index:1}
.cal-day.today .cal-today-ring{position:absolute;inset:2px;border:2px solid rgba(255,255,255,0.7);border-radius:8px;pointer-events:none}

/* Shift colors */
.cal-day.shift-F    {background:rgba(16,185,129,0.25)}
.cal-day.shift-S    {background:rgba(245,158,11,0.25)}
.cal-day.shift-N    {background:rgba(139,92,246,0.25)}
.cal-day.shift-TD,.cal-day.shift-TDK{background:rgba(59,130,246,0.25)}
.cal-day.shift-TF,.cal-day.shift-TFK{background:rgba(6,182,212,0.25)}
.cal-day.shift-Frei    {background:rgba(255,255,255,0.04);color:var(--text3)}
.cal-day.shift-Urlaub  {background:rgba(14,165,233,0.25)}
.cal-day.shift-Krank   {background:rgba(239,68,68,0.22)}
.cal-day.shift-note    {background:rgba(100,116,139,0.15)}
.cal-day.shift-Feiertag{background:rgba(234,179,8,0.22);border:1px solid rgba(234,179,8,0.35)}
.cal-day.past{opacity:0.65}
.cal-day.future-unplanned{background:rgba(255,255,255,0.02)}
.cal-day.future-unplanned .cal-day-num{color:var(--text3)}
.cal-day.today{box-shadow:0 0 0 2px var(--blue),0 0 12px rgba(79,158,248,0.3)}
.cal-day.weekend-day .cal-day-num{color:var(--text2)}

/* Shift code text colors */
.cal-day.shift-F .cal-day-code    {color:#10B981}
.cal-day.shift-S .cal-day-code    {color:#F59E0B}
.cal-day.shift-N .cal-day-code    {color:#A78BFA}
.cal-day.shift-TD .cal-day-code,
.cal-day.shift-TDK .cal-day-code  {color:#93C5FD}
.cal-day.shift-TF .cal-day-code,
.cal-day.shift-TFK .cal-day-code  {color:#67E8F9}
.cal-day.shift-Urlaub .cal-day-code  {color:#7DD3FC}
.cal-day.shift-Krank .cal-day-code   {color:#FCA5A5}
.cal-day.shift-Feiertag .cal-day-code{color:#EAB308}
.cal-day.shift-Feiertag .cal-day-num {color:#EAB308;font-weight:800}

/* Legend */
.cal-legend{display:flex;flex-wrap:wrap;gap:8px 14px;padding:4px 12px 12px;font-size:11px;color:var(--text2)}
.leg-item{display:flex;align-items:center;gap:4px}
.leg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.leg-check{font-size:9px;font-weight:800;color:rgba(255,255,255,0.5)}

/* RHYTHM */
.rhythm-wrap{padding:14px;overflow-x:auto}
.rhythm-months{display:flex;flex-direction:column;gap:10px;min-width:600px}
.rhythm-month-row{display:flex;align-items:center;gap:8px}
.rhythm-month-label{font-size:11px;font-weight:600;color:var(--text2);width:28px;flex-shrink:0}
.rhythm-days{display:flex;gap:2px;flex:1}
.rhythm-day{width:16px;height:28px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:7px;font-weight:800;flex-shrink:0;cursor:pointer;transition:transform 0.1s}
.rhythm-day:active{transform:scale(0.9)}
.rhythm-day.r-F    {background:rgba(16,185,129,0.5);color:#10B981}
.rhythm-day.r-S    {background:rgba(245,158,11,0.5);color:#F59E0B}
.rhythm-day.r-N    {background:rgba(139,92,246,0.5);color:#A78BFA}
.rhythm-day.r-TD,.rhythm-day.r-TDK{background:rgba(59,130,246,0.45);color:#93C5FD}
.rhythm-day.r-TF,.rhythm-day.r-TFK{background:rgba(6,182,212,0.45);color:#67E8F9}
.rhythm-day.r-Frei    {background:rgba(255,255,255,0.05);color:var(--text3)}
.rhythm-day.r-Urlaub  {background:rgba(14,165,233,0.45);color:#7DD3FC}
.rhythm-day.r-Krank   {background:rgba(239,68,68,0.4);color:#FCA5A5}
.rhythm-day.r-note    {background:rgba(100,116,139,0.3);color:var(--text3)}
.rhythm-day.r-Feiertag{background:rgba(234,179,8,0.45);color:#EAB308}
.rhythm-day.r-empty {background:rgba(255,255,255,0.02);color:transparent}
.rhythm-day.r-today {box-shadow:0 0 0 1.5px var(--blue)}

/* ── ENTRY CARDS ── */
.entry-list{display:flex;flex-direction:column;gap:8px}
.entry-list.padded{padding:12px 16px}
.entry-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm);padding:11px 13px;display:flex;align-items:center;gap:11px;position:relative;overflow:hidden;transition:all 0.15s}
.entry-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px}
.entry-card.positive::before{background:var(--green)}
.entry-card.negative::before{background:var(--red)}
.entry-card.neutral::before{background:var(--blue)}
.entry-shift-badge{min-width:38px;height:38px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;flex-shrink:0}
.shift-F{background:rgba(16,185,129,0.15);color:var(--green)}
.shift-S{background:rgba(245,158,11,0.15);color:var(--amber)}
.shift-N{background:rgba(139,92,246,0.15);color:var(--purple)}
.shift-TD,.shift-TDK,.shift-Tag{background:rgba(79,158,248,0.15);color:var(--blue)}
.shift-TF,.shift-TFK{background:rgba(20,184,166,0.15);color:var(--teal)}
.shift-default{background:rgba(255,255,255,0.06);color:var(--text2)}
.entry-info{flex:1;min-width:0}
.entry-date{font-size:11px;color:var(--text2)}
.entry-times{font-size:14px;font-weight:600}
.entry-note{font-size:10px;color:var(--text3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.entry-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px}
.entry-hours{font-size:14px;font-weight:700}
.entry-diff{font-size:10px;font-weight:600}
.entry-diff.pos{color:var(--green)}
.entry-diff.neg{color:var(--red)}
.del-btn{width:26px;height:26px;border-radius:50%;border:none;background:rgba(239,68,68,0.1);color:var(--red);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background 0.15s}
.del-btn:hover{background:rgba(239,68,68,0.25)}
.del-btn svg{width:13px;height:13px}
.empty-state{text-align:center;padding:40px 20px;display:flex;flex-direction:column;align-items:center;gap:10px}
.empty-icon{font-size:40px;opacity:0.4}
.empty-state p{color:var(--text2);font-size:13px}

/* ── FORM ── */
.form-body{padding:14px;display:flex;flex-direction:column;gap:10px}
.form-sec{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:14px}
.form-sec-lbl{display:flex;align-items:center;gap:9px;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:11px;text-transform:uppercase;letter-spacing:0.5px}
.sn{width:20px;height:20px;border-radius:50%;background:var(--blue);color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.form-input{background:rgba(255,255,255,0.06);border:1px solid var(--border);border-radius:var(--r-sm);padding:13px 14px;color:var(--text);font-size:16px;font-family:inherit;outline:none;width:100%;transition:border-color 0.2s,box-shadow 0.2s;-webkit-appearance:none}
.form-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(79,158,248,0.1)}
.form-group{margin-bottom:13px;display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:11px;font-weight:500;color:var(--text2)}
.form-group:last-child{margin-bottom:0}
.form-hint{font-size:10px;color:var(--text3)}
.time-row{display:flex;align-items:center;gap:8px}
.time-block{flex:1;display:flex;flex-direction:column;gap:5px}
.time-block label{font-size:10px;color:var(--text2)}
.time-inp{text-align:center;font-weight:700}
.time-arrow{width:22px;flex-shrink:0;color:var(--text3);display:flex;align-items:center;justify-content:center}
.time-arrow svg{width:15px;height:15px}
.duration-display{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;background:rgba(255,255,255,0.03);border-radius:var(--r-sm);border:1px solid var(--border);font-size:12px;font-weight:600;margin-top:8px}
.duration-diff{font-size:11px;font-weight:700}
.duration-diff.pos{color:var(--green)}
.duration-diff.neg{color:var(--red)}
.template-grid{display:flex;flex-wrap:wrap;gap:7px}
.tmpl-chip{display:flex;align-items:center;gap:5px;padding:7px 13px;border-radius:20px;border:1.5px solid var(--border);background:var(--card);cursor:pointer;transition:all 0.15s;font-size:12px;font-weight:600;color:var(--text2)}
.tmpl-chip.selected{border-color:var(--blue);background:rgba(79,158,248,0.15);color:var(--blue)}
.tmpl-chip .badge{font-size:9px;font-weight:800;opacity:0.7}
.pause-chips{display:flex;flex-wrap:wrap;gap:7px}
.pause-chip{padding:7px 14px;border-radius:20px;font-size:12px;font-weight:600;border:1.5px solid var(--border);background:var(--card);cursor:pointer;color:var(--text2);transition:all 0.15s}
.pause-chip.selected{border-color:var(--blue);background:rgba(79,158,248,0.15);color:var(--blue)}

/* BUTTONS */
.btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;font-weight:700;font-size:15px;border:none;border-radius:var(--r-sm);padding:13px 22px;cursor:pointer;transition:all 0.2s;font-family:inherit;box-shadow:0 4px 18px rgba(79,158,248,0.28)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 7px 24px rgba(79,158,248,0.38)}
.btn-primary:active{transform:translateY(0)}
.btn-primary.btn-full{width:100%}
.btn-primary.btn-lg{padding:15px;font-size:16px;border-radius:var(--r)}
.btn-secondary{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--card);color:var(--text);font-weight:600;font-size:13px;border:1px solid var(--border);border-radius:var(--r-sm);padding:11px 18px;cursor:pointer;transition:all 0.15s;font-family:inherit}
.btn-secondary:hover{background:var(--card-h)}
.btn-secondary.btn-full{width:100%}
.error-msg{background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.3);color:#FCA5A5;border-radius:var(--r-sm);padding:11px 14px;font-size:12px}
.icon-btn{width:34px;height:34px;border-radius:50%;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text2)}
.icon-btn svg{width:15px;height:15px}

/* LIST VIEW */
.compact-select{background:var(--card);border:1px solid var(--border);border-radius:var(--r-sm);padding:7px 9px;color:var(--text);font-size:12px;font-family:inherit;outline:none;-webkit-appearance:none;cursor:pointer}
.compact-select option{background:#1C2537}
.list-saldo-bar{margin:10px 16px 0;padding:12px 14px;display:flex;gap:0}
.lsb-item{flex:1;text-align:center;border-right:1px solid var(--border);padding:3px}
.lsb-item:last-child{border-right:none}
.lsb-val{display:block;font-size:14px;font-weight:700}
.lsb-lbl{display:block;font-size:9px;color:var(--text2);margin-top:1px}

/* ── PROFILE ── */
.profile-hero{margin:12px 16px 0;padding:20px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.profile-avatar-wrap{position:relative;display:inline-block}
.profile-avatar{width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--purple));display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:800;color:#fff;overflow:hidden;border:3px solid rgba(255,255,255,0.15)}
.profile-avatar img{width:100%;height:100%;object-fit:cover}
.avatar-upload-btn{position:absolute;bottom:0;right:0;width:28px;height:28px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid var(--bg2)}
.avatar-upload-btn svg{width:14px;height:14px;color:#fff}
.profile-info{width:100%}
.profile-name{font-size:20px;font-weight:800;margin-bottom:12px}
.profile-stats-row{display:flex;gap:0;border-top:1px solid var(--border);padding-top:12px}
.prof-stat{flex:1;text-align:center;border-right:1px solid var(--border)}
.prof-stat:last-child{border-right:none}
.prof-stat-val{display:block;font-size:16px;font-weight:700}
.prof-stat-lbl{display:block;font-size:9px;color:var(--text2);margin-top:2px}

.settings-body{padding:10px 16px;display:flex;flex-direction:column;gap:10px}
.settings-card{padding:16px}
.settings-card h3{font-size:13px;font-weight:700;margin-bottom:14px;color:var(--text2);text-transform:uppercase;letter-spacing:0.5px}
.tmpl-list{display:flex;flex-direction:column;gap:5px}
.tmpl-row{display:flex;align-items:center;gap:9px;padding:9px 11px;background:rgba(255,255,255,0.03);border-radius:var(--r-sm);border:1px solid var(--border)}
.tmpl-code{font-size:10px;font-weight:800;color:var(--blue);width:32px}
.tmpl-name{flex:1;font-size:12px}
.tmpl-time{font-size:10px;color:var(--text3)}
.tmpl-del{background:none;border:none;color:var(--text3);cursor:pointer;padding:2px}
.tmpl-del:hover{color:var(--red)}
.tmpl-del svg{width:13px;height:13px}

.year-stats-row{display:flex;flex-direction:column;gap:7px}
.ys-item{display:flex;align-items:center;gap:8px;font-size:12px}
.ys-lbl{color:var(--text2);width:100px;flex-shrink:0}
.ys-val{font-weight:700;margin-left:auto}

/* BOTTOM NAV */
.bottom-nav{height:var(--nav-h);min-height:var(--nav-h);display:flex;align-items:center;background:rgba(11,17,32,0.97);border-top:1px solid var(--border);position:relative;z-index:100;padding-bottom:env(safe-area-inset-bottom,0);backdrop-filter:blur(20px)}
.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:7px 3px;background:none;border:none;color:var(--text3);font-size:9px;font-weight:500;cursor:pointer;transition:all 0.2s;font-family:inherit}
.nav-btn svg{width:21px;height:21px}
.nav-btn.active{color:var(--blue)}
.nav-btn.active svg{filter:drop-shadow(0 0 6px rgba(79,158,248,0.5))}
.nav-add{flex:0 0 68px}
.add-fab{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue2));display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(79,158,248,0.38);transition:all 0.2s;margin-top:-12px}
.add-fab:hover{transform:scale(1.05)}
.add-fab svg{width:23px;height:23px;color:#fff}
.nav-profile-wrap{width:24px;height:24px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center}
.nav-profile-wrap img{width:100%;height:100%;object-fit:cover;border-radius:50%}

/* BOTTOM SHEET (day detail) */
.bottom-sheet{position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--bg2);border-radius:20px 20px 0 0;border-top:1px solid var(--border);padding:12px 20px 40px;transform:translateY(100%);transition:transform 0.3s cubic-bezier(0.34,1.1,0.64,1);max-height:70vh;overflow-y:auto}
.bottom-sheet.open{transform:translateY(0)}
.sheet-handle{width:36px;height:4px;border-radius:2px;background:rgba(255,255,255,0.15);margin:0 auto 16px}
.sheet-content{}
.sheet-overlay{position:fixed;inset:0;z-index:199;background:rgba(0,0,0,0.5);backdrop-filter:blur(4px)}

/* TOAST */
.toast{position:fixed;bottom:calc(var(--nav-h) + 10px);left:50%;transform:translateX(-50%);background:rgba(28,37,55,0.97);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 18px;font-size:13px;font-weight:500;z-index:999;backdrop-filter:blur(20px);white-space:nowrap;animation:slideUp 0.25s ease-out}
@keyframes slideUp{from{opacity:0;transform:translateX(-50%) translateY(14px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* SUCCESS */
.success-overlay{position:fixed;inset:0;z-index:1000;background:rgba(11,17,32,0.95);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(24px);animation:fadeIn 0.25s ease}
.success-box{text-align:center;padding:32px}
.success-check{width:76px;height:76px;margin:0 auto 18px;animation:popIn 0.5s cubic-bezier(0.34,1.56,0.64,1)}
.success-check svg{width:100%;height:100%}
@keyframes popIn{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.success-title{font-size:21px;font-weight:800;margin-bottom:6px}
.success-detail{font-size:13px;color:var(--text2)}
.success-saldo{margin-top:10px;font-size:17px;font-weight:700;color:var(--blue)}

/* AUTOFILL */
@media(prefers-color-scheme:dark){input:-webkit-autofill,input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0px 1000px #1C2537 inset;-webkit-text-fill-color:#F1F5F9}}

/* ── GEHALT / PAYSLIPS ── */
.gehalt-body{padding:12px 16px;display:flex;flex-direction:column;gap:12px}
.scan-card{padding:22px 18px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}
.scan-icon{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,rgba(79,158,248,0.18),rgba(139,92,246,0.18));display:flex;align-items:center;justify-content:center;margin-bottom:4px}
.scan-icon svg{width:30px;height:30px;color:var(--blue)}
.scan-title{font-size:17px;font-weight:800}
.scan-sub{font-size:12px;color:var(--text2);line-height:1.5;max-width:280px}
.scan-actions{margin-top:10px;width:100%}
.scan-actions .btn-primary{width:100%;cursor:pointer}
.ai-warning{margin-top:10px;font-size:12px;color:#FBBF24;background:rgba(251,191,36,0.1);border:1px solid rgba(251,191,36,0.25);border-radius:10px;padding:10px 12px;line-height:1.4}

.processing-card{padding:24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px}
.processing-text{font-size:14px;font-weight:600}
.processing-sub{font-size:12px;color:var(--text2)}
.loading-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,0.1);border-top-color:var(--blue);border-radius:50%;animation:spin 0.8s linear infinite;margin-bottom:6px}
@keyframes spin{to{transform:rotate(360deg)}}

/* Yearly summary */
.gehalt-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border-radius:14px;overflow:hidden;margin-top:4px}
.gs-cell{background:var(--bg2);padding:14px;text-align:center}
.gs-val{display:block;font-size:18px;font-weight:800}
.gs-lbl{display:block;font-size:10px;color:var(--text2);margin-top:3px}
.gehalt-summary-hdr{font-size:13px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:0.5px;padding:16px 16px 0}

/* Payslip cards */
.payslip-list{display:flex;flex-direction:column;gap:10px}
.payslip-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px;display:flex;align-items:center;gap:13px;cursor:pointer;transition:all 0.15s;position:relative;overflow:hidden}
.payslip-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px}
.payslip-card.ok::before{background:var(--green)}
.payslip-card.warn::before{background:var(--red)}
.payslip-card.neutral::before{background:var(--blue)}
.payslip-card:active{transform:scale(0.99)}
.payslip-thumb{width:46px;height:46px;border-radius:10px;object-fit:cover;background:var(--bg3);flex-shrink:0;border:1px solid var(--border)}
.payslip-info{flex:1;min-width:0}
.payslip-month{font-size:15px;font-weight:700}
.payslip-meta{font-size:12px;color:var(--text2);margin-top:2px}
.payslip-right{text-align:right;flex-shrink:0}
.payslip-netto{font-size:16px;font-weight:800;color:var(--blue)}
.payslip-netto-lbl{font-size:9px;color:var(--text3)}
.payslip-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;border-radius:20px;padding:2px 8px;margin-top:4px}
.payslip-badge.ok{background:rgba(16,185,129,0.12);color:var(--green)}
.payslip-badge.warn{background:rgba(239,68,68,0.12);color:var(--red)}

/* Detail sheet */
.pay-detail-img{width:100%;max-height:220px;object-fit:contain;border-radius:12px;background:var(--bg3);margin-bottom:14px;cursor:zoom-in}
.pay-detail-title{font-size:18px;font-weight:800;margin-bottom:2px}
.pay-detail-sub{font-size:12px;color:var(--text2);margin-bottom:14px}
.pay-field-grid{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:14px}
.pay-field{display:flex;justify-content:space-between;align-items:center;padding:11px 14px;border-bottom:1px solid var(--border);font-size:13px}
.pay-field:last-child{border-bottom:none}
.pay-field-lbl{color:var(--text2)}
.pay-field-val{font-weight:700}
.pay-field.highlight{background:rgba(79,158,248,0.06)}
.pay-field.highlight .pay-field-val{color:var(--blue);font-size:15px}

.reconcile-box{border-radius:12px;padding:14px;margin-bottom:14px}
.reconcile-box.ok{background:rgba(16,185,129,0.08);border:1px solid rgba(16,185,129,0.25)}
.reconcile-box.warn{background:rgba(239,68,68,0.08);border:1px solid rgba(239,68,68,0.25)}
.reconcile-box.neutral{background:var(--card);border:1px solid var(--border)}
.reconcile-hdr{font-size:13px;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:7px}
.reconcile-row{display:flex;justify-content:space-between;font-size:12px;padding:5px 0}
.reconcile-row .ok-icon{color:var(--green)}
.reconcile-row .warn-icon{color:var(--red)}
.reconcile-note{font-size:11px;color:var(--text2);margin-top:8px;line-height:1.4}

/* ── AUTH GATE ── */
.auth-gate{position:fixed;inset:0;z-index:2000;background:linear-gradient(180deg,#0D1A30 0%,#0B1120 100%);display:flex;align-items:center;justify-content:center;padding:24px}
.auth-gate.hidden{display:none}
.auth-card{width:100%;max-width:340px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px}
.auth-logo{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,var(--blue),var(--blue2));display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(79,158,248,0.4);margin-bottom:10px}
.auth-logo svg{width:32px;height:32px;color:#fff}
.auth-title{font-size:22px;font-weight:800}
.auth-sub{font-size:13px;color:var(--text2);margin-bottom:14px}
.auth-pin{width:100%;background:rgba(255,255,255,0.06);border:1px solid var(--border);border-radius:12px;padding:15px;color:var(--text);font-size:22px;text-align:center;letter-spacing:8px;outline:none;margin-bottom:10px;font-family:inherit}
.auth-pin:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(79,158,248,0.12)}
.auth-error{width:100%;background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.3);color:#FCA5A5;border-radius:10px;padding:10px;font-size:13px;margin-bottom:10px}
.auth-btn-full{width:100%}
.auth-hint{font-size:11px;color:var(--text3);margin-top:14px;line-height:1.4}

/* ── FULLSCREEN IMAGE VIEWER ── */
.img-viewer{position:fixed;inset:0;z-index:2100;background:rgba(0,0,0,0.94);display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn 0.2s ease}
.img-viewer.hidden{display:none}
.img-viewer img{max-width:100%;max-height:100%;object-fit:contain;border-radius:6px}
.img-viewer-close{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,0.12);border:none;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}

/* Encryption badge */
.enc-badge{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--green);background:rgba(16,185,129,0.08);border:1px solid rgba(16,185,129,0.2);border-radius:10px;padding:9px 12px;margin-bottom:4px}
.enc-badge svg{width:15px;height:15px;flex-shrink:0}

/* Explanation block */
.explain-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:rgba(139,92,246,0.12);border:1px solid rgba(139,92,246,0.3);color:#C4B5FD;font-weight:600;font-size:14px;border-radius:12px;padding:13px;cursor:pointer;margin-bottom:14px;font-family:inherit;transition:background 0.15s}
.explain-btn:hover{background:rgba(139,92,246,0.18)}
.explain-btn svg{width:17px;height:17px}
.explain-box{background:rgba(139,92,246,0.06);border:1px solid rgba(139,92,246,0.22);border-radius:12px;padding:14px;margin-bottom:14px;font-size:13px;line-height:1.6;color:var(--text)}
.explain-box .explain-hdr{font-size:12px;font-weight:700;color:#C4B5FD;margin-bottom:8px;display:flex;align-items:center;gap:6px}

/* PIN change row in profile */
.pin-change-card{padding:16px}

/* ═══════════ TC-Time Ergänzungen (V1) ═══════════ */
.brand-icon img{border-radius:9px;display:block}
.brand-icon{background:none!important;box-shadow:0 4px 14px rgba(0,0,0,.4)}

/* Auth-Gate Redesign */
.auth-gate{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(120% 100% at 50% 0%,#111a2e 0%,var(--bg) 60%);overflow:hidden}
.auth-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.auth-bg .hero-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5}
.auth-bg .orb1{width:300px;height:300px;background:#2563EB;top:-80px;left:-60px}
.auth-bg .orb2{width:260px;height:260px;background:#0EA5E9;bottom:-60px;right:-50px}
.auth-card{position:relative;z-index:1;width:100%;max-width:380px;background:rgba(17,24,39,.72);backdrop-filter:blur(24px);border:1px solid var(--border);border-radius:24px;padding:30px 24px 24px;box-shadow:0 30px 80px rgba(0,0,0,.55);animation:popIn .4s cubic-bezier(.2,.8,.2,1)}
.auth-logo{width:76px;height:76px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center}
.auth-logo img{border-radius:18px;box-shadow:0 10px 30px rgba(37,99,235,.4)}
.auth-brand{text-align:center;font-size:13px;font-weight:800;letter-spacing:3px;color:var(--text2);text-transform:uppercase;margin-bottom:14px}
.auth-title{text-align:center;font-size:23px;font-weight:800;margin-bottom:6px}
.auth-sub{text-align:center;font-size:13px;color:var(--text2);line-height:1.5;margin-bottom:18px}
.auth-inp{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:13px;padding:14px 15px;color:var(--text);font-size:15px;font-family:inherit;margin-bottom:10px;outline:none;transition:border-color .15s;-webkit-appearance:none}
.auth-inp:focus{border-color:var(--blue);background:rgba(79,158,248,.07)}
.auth-row{display:flex;gap:10px}.auth-row .auth-inp{flex:1}
select.auth-inp{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2394A3B8' d='M6 8 0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.auth-switch{text-align:center;font-size:13px;color:var(--text2);margin-top:14px}
.auth-switch a{color:var(--blue);font-weight:600;cursor:pointer}
.auth-error{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.3);color:#FCA5A5;border-radius:11px;padding:10px 13px;font-size:13px;margin-bottom:10px;text-align:center}
.auth-hint{text-align:center;font-size:11.5px;color:var(--text3);margin-top:14px;line-height:1.5}

/* Form rows */
.form-row{display:flex;gap:10px}.form-row .form-group{flex:1;min-width:0}

/* Profile role chip */
.profile-role-chip{display:inline-block;font-size:11px;font-weight:700;color:var(--text2);background:rgba(255,255,255,.06);border:1px solid var(--border);padding:3px 10px;border-radius:20px;margin:4px 0 10px}
.profile-role-chip.admin{color:#FCD34D;background:rgba(234,179,8,.12);border-color:rgba(234,179,8,.3)}
.admin-access{border-color:rgba(79,158,248,.3)!important;background:linear-gradient(180deg,rgba(79,158,248,.08),var(--card))!important}

/* Admin panel */
.hdr-count{font-size:12px;font-weight:600;color:var(--text3);margin-left:6px}
.admin-user-list{display:flex;flex-direction:column;gap:10px}
.admin-user{display:flex;gap:12px;align-items:center;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:14px;padding:12px}
.admin-user.pending{border-color:rgba(245,158,11,.35);background:rgba(245,158,11,.06)}
.admin-user.suspended{opacity:.6}
.au-avatar{width:42px;height:42px;flex-shrink:0;border-radius:12px;background:linear-gradient(135deg,#2563EB,#0EA5E9);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;color:#fff}
.au-info{flex:1;min-width:0}
.au-name{font-size:14px;font-weight:700;display:flex;align-items:center;gap:7px}
.au-meta{font-size:12px;color:var(--text2);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.au-meta2{font-size:11px;color:var(--text3);margin-top:1px}
.au-badge{font-size:9.5px;font-weight:800;padding:2px 7px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}
.au-badge.admin{background:rgba(234,179,8,.16);color:#FCD34D}
.au-badge.pending{background:rgba(245,158,11,.18);color:#FBBF24}
.au-badge.active{background:rgba(16,185,129,.16);color:#34D399}
.au-badge.susp{background:rgba(239,68,68,.16);color:#F87171}
.au-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}
.au-btn{font-size:12px;font-weight:600;padding:6px 11px;border-radius:9px;border:1px solid var(--border);background:rgba(255,255,255,.05);color:var(--text);cursor:pointer;white-space:nowrap}
.au-btn.ok{background:rgba(16,185,129,.15);border-color:rgba(16,185,129,.3);color:#34D399}
.au-btn.danger{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.25);color:#F87171}

/* Install banner */
.install-banner{position:fixed;left:12px;right:12px;bottom:84px;z-index:1500;display:flex;align-items:center;gap:12px;background:rgba(17,24,39,.92);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:16px;padding:12px 14px;box-shadow:0 16px 50px rgba(0,0,0,.5);animation:slideUp .35s}
.install-banner img{border-radius:9px}
.install-text{flex:1;display:flex;flex-direction:column;line-height:1.3}
.install-text b{font-size:13px}.install-text span{font-size:11px;color:var(--text2)}
.install-btn{padding:8px 14px!important;font-size:13px!important;width:auto!important}
.install-close{background:none;border:none;color:var(--text3);font-size:16px;cursor:pointer;padding:4px}

/* Payslip Confidence + Korrektur */
.conf-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;margin-left:6px;vertical-align:middle}
.conf-badge.ok{background:rgba(16,185,129,.15);color:#34D399}
.conf-badge.low{background:rgba(245,158,11,.16);color:#FBBF24}
.edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 0}
.edit-field{display:flex;flex-direction:column;gap:4px}
.edit-field span{font-size:11px;color:var(--text2);font-weight:600}
.edit-field input{background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:10px;padding:10px 11px;color:var(--text);font-size:14px;font-family:inherit;outline:none;-webkit-appearance:none}
.edit-field input:focus{border-color:var(--blue)}
