/* Apitzsch Planer – Stylesheet */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700;800&display=swap');
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0e0f14;--surf:#13141a;--surf2:#1a1b24;--surf3:#21222e;
  --brd:rgba(255,255,255,.09);--brd2:rgba(255,255,255,.15);
  --tx:#f0f0f5;--tx2:#9090b0;--mu:#55556a;--sh:rgba(0,0,0,.5);
  --acc:#f0a500;--acc2:#8b5cf6;--red:#ff6b6b;--grn:#6bcb77;
}
body.light{
  --bg:#eef0f8;--surf:#fff;--surf2:#e8ebf5;--surf3:#dde1ef;
  --brd:rgba(0,0,0,.08);--brd2:rgba(0,0,0,.16);
  --tx:#1a1a2e;--tx2:#5a5a7a;--mu:#9090b0;--sh:rgba(0,0,0,.12);
}
html,body{height:100%}
body{font-family:Arial,'Helvetica Neue',Helvetica,sans-serif;background:var(--bg);color:var(--tx);transition:background .25s,color .25s;font-size:14px;line-height:1.55;font-weight:500;letter-spacing:.01em}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-thumb{background:var(--surf3);border-radius:99px}

/* Icons */
.ff-icon{display:block;flex-shrink:0}
.icon-wrap{display:inline-flex;align-items:center;justify-content:center;line-height:0}

/* Seiten */
.page{display:none}
.page.active{display:flex}

/* ─── LOGIN ─────────────────────────────────── */
#pg-login,.login-body{min-height:100vh;align-items:center;justify-content:center;flex-direction:column;padding:20px;
  background:radial-gradient(ellipse 60% 50% at 75% 25%,rgba(240,165,0,.08),transparent),
             radial-gradient(ellipse 60% 50% at 20% 80%,rgba(139,92,246,.07),transparent),var(--bg)}
.login-body{display:flex}
.login-wrap{width:100%;display:flex;align-items:center;justify-content:center}
.theme-btn{position:fixed;top:16px;right:16px;width:36px;height:36px;border-radius:9px;
  background:var(--surf2);border:1px solid var(--brd2);color:var(--tx2);
  display:flex;align-items:center;justify-content:center;z-index:100;transition:background .18s}
.theme-btn:hover{background:var(--surf3)}
.login-card{width:100%;max-width:430px}
.login-logo{text-align:center;margin-bottom:28px}
.login-icon{width:62px;height:62px;background:linear-gradient(135deg,var(--acc),var(--acc2));border-radius:18px;
  display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 14px;
  box-shadow:0 8px 28px rgba(240,165,0,.25)}
.login-title{font-size:26px;font-weight:900;letter-spacing:-.5px}
.login-title span{color:var(--acc)}
.login-sub{font-size:13px;color:var(--mu);font-weight:600;margin-top:5px}
.login-box{background:var(--surf);border:1px solid var(--brd2);border-radius:20px;padding:28px;
  box-shadow:0 24px 64px var(--sh);transition:background .25s}
.login-tabs{display:flex;background:var(--surf2);border-radius:10px;padding:3px;border:1px solid var(--brd);margin-bottom:20px}
.login-tab{flex:1;padding:8px;border-radius:8px;font-size:13px;font-weight:800;cursor:pointer;border:none;
  background:none;color:var(--mu);transition:.18s}
.login-tab.active{background:var(--surf);color:var(--tx);box-shadow:0 2px 8px var(--sh)}

/* FEHLERMELDUNG – klar und groß */
.msg-box{display:none;align-items:flex-start;gap:10px;padding:13px 16px;border-radius:11px;
  font-size:13px;font-weight:700;margin-bottom:16px;line-height:1.5;
  border-width:1.5px;border-style:solid;animation:mSlide .2s ease}
.msg-box.show{display:flex}
.msg-box.err{background:rgba(255,60,60,.1);border-color:rgba(255,60,60,.35);color:#ff3333}
.msg-box.ok{background:rgba(50,200,100,.1);border-color:rgba(50,200,100,.35);color:#22cc66}
.msg-icon{font-size:18px;flex-shrink:0;line-height:1.5}
.ev-ext{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:99px;font-size:10px;font-weight:800;letter-spacing:.2px;background:rgba(116,185,255,.16);border:1px solid rgba(116,185,255,.38);color:#74b9ff;vertical-align:middle}
@keyframes mSlide{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* Formulare */
.fg{margin-bottom:14px}
.fg label{display:block;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--tx2);margin-bottom:6px}
.fg input,.fg select,.fg textarea{width:100%;background:var(--surf2);border:1.5px solid var(--brd2);
  border-radius:10px;padding:10px 13px;font-size:13px;color:var(--tx);font-weight:500;
  transition:border-color .2s,box-shadow .2s;outline:none;appearance:auto}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(240,165,0,.12)}
.fg textarea{resize:vertical;min-height:65px}
.fg select option{background:var(--surf);color:var(--tx)}
.frow2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pw-wrap{position:relative}
.pw-wrap input{padding-right:42px}
.pw-eye{position:absolute;right:11px;top:50%;transform:translateY(-50%);background:none;border:none;
  color:var(--mu);display:flex;align-items:center;transition:color .15s}
.pw-eye:hover{color:var(--tx2)}
.pw-bar{height:4px;background:var(--surf3);border-radius:99px;margin-top:7px;overflow:hidden}
.pw-bar>div{height:100%;border-radius:99px;width:0;transition:width .3s,background .3s}

/* Buttons */
.btn-primary{padding:10px 22px;background:linear-gradient(135deg,var(--acc),#c48800);color:#000;font-weight:900;
  font-size:13px;border:none;border-radius:10px;cursor:pointer;font-family:inherit;
  transition:transform .2s,box-shadow .2s;display:inline-flex;align-items:center;gap:6px}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 5px 16px rgba(240,165,0,.35)}
.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}
.btn-full{width:100%;justify-content:center}
.btn-sec{padding:10px 20px;background:var(--surf2);border:1px solid var(--brd2);color:var(--tx2);
  font-weight:700;font-size:13px;border-radius:10px;cursor:pointer;font-family:inherit;transition:.18s}
.btn-sec:hover{color:var(--tx);background:var(--surf3)}
.btn-danger{padding:10px 18px;background:rgba(255,107,107,.1);border:1px solid rgba(255,107,107,.28);
  color:#e05555;font-weight:700;font-size:13px;border-radius:10px;cursor:pointer;font-family:inherit;
  display:inline-flex;align-items:center;gap:6px;transition:background .18s}
.btn-danger:hover{background:rgba(255,107,107,.22)}

.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(0,0,0,.2);
  border-top-color:#000;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

.demo-hint{background:rgba(240,165,0,.07);border:1px solid rgba(240,165,0,.22);border-radius:10px;
  padding:12px 14px;font-size:11.5px;font-weight:600;color:var(--tx2);margin-top:14px;line-height:1.8}
.demo-hint strong{color:var(--acc);font-weight:900}
.demo-hint em{color:var(--acc);font-style:normal;font-weight:900}

/* ─── APP LAYOUT ────────────────────────────── */
#pg-app{flex-direction:row;height:100vh;overflow:hidden}

/* Sidebar */
.sidebar{width:245px;background:var(--surf);border-right:1px solid var(--brd);
  display:flex;flex-direction:column;height:100vh;overflow-y:auto;flex-shrink:0;
  transition:transform .3s,margin .3s,background .25s}
.sidebar.collapsed{transform:translateX(-245px);margin-right:-245px}
@media(max-width:900px){
  .sidebar{position:fixed;top:0;left:0;bottom:0;z-index:200;transform:translateX(-245px);margin:0}
  .sidebar.open{transform:translateX(0)}}
.sb-logo{padding:17px 18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--brd);flex-shrink:0}
.sb-logo-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--acc),var(--acc2));
  border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.sb-logo-name{font-size:16px;font-weight:900}
.sb-logo-name em{color:var(--acc);font-style:normal}
.sb-nav{padding:10px 8px}
.sb-sec{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:var(--mu);padding:8px 10px 5px}
.sb-sec.sb-collapsible{display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none}
.sb-nav-body{display:block}
.sb-nav-body.collapsed{display:none}
.nb{display:flex;align-items:center;gap:9px;width:100%;padding:8px 12px;border-radius:9px;
  cursor:pointer;font-size:13px;font-weight:700;color:var(--tx2);transition:.18s;
  margin-bottom:2px;background:none;border:none;text-align:left}
.nb:hover{background:var(--surf2);color:var(--tx)}
.nb.active{background:linear-gradient(135deg,rgba(240,165,0,.15),rgba(139,92,246,.08));color:var(--acc)}
.nb-ico{width:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sb-blk{border-top:1px solid var(--brd);padding:8px 8px 5px;flex-shrink:0}
.sb-blk-hd{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;color:var(--mu);
  padding:0 7px 8px;display:flex;align-items:center;justify-content:space-between}
.sb-blk-hd.sb-collapsible{cursor:pointer;user-select:none}
.sb-toggle{font-size:12px;line-height:1;color:var(--mu);padding:2px 4px;border-radius:5px}
.sb-blk-hd.sb-collapsible:hover .sb-toggle{background:var(--surf2);color:var(--tx2)}
.sb-blk-body{display:block}
.sb-blk.collapsed .sb-blk-body{display:none}
.sb-blk-hd button{background:none;border:none;color:var(--mu);display:flex;align-items:center;
  padding:2px;border-radius:5px;transition:.15s}
.sb-blk-hd button:hover{background:var(--surf2);color:var(--tx2)}
.sfi{display:flex;align-items:center;gap:7px;padding:6px 10px;border-radius:8px;cursor:pointer;
  font-size:12px;font-weight:700;color:var(--tx2);transition:.18s;margin-bottom:1px}
.sfi:hover,.sfi.active{background:var(--surf2);color:var(--tx)}
.sdot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.scnt{margin-left:auto;font-size:10px;font-weight:700;color:var(--mu);background:var(--surf3);
  padding:1px 6px;border-radius:99px}
.sb-cal-item{display:flex;align-items:center;gap:7px;padding:6px 10px;border-radius:8px;cursor:pointer;
  font-size:12px;font-weight:700;color:var(--tx2);transition:.18s;margin-bottom:1px}
.sb-cal-item:hover{background:var(--surf2);color:var(--tx)}
.sb-cal-item.active{background:linear-gradient(135deg,rgba(240,165,0,.16),rgba(139,92,246,.10));color:var(--tx);box-shadow:inset 0 0 0 1px rgba(240,165,0,.35)}
.sb-cal-item.active .sdot{box-shadow:0 0 0 2px rgba(240,165,0,.45)}
.sb-cal-edit{background:none;border:none;color:var(--mu);display:flex;align-items:center;
  opacity:0;transition:.15s;flex-shrink:0;margin-left:auto}
.sb-cal-item:hover .sb-cal-edit{opacity:1}
.sb-mem{display:flex;align-items:center;gap:7px;padding:6px 10px;border-radius:8px;cursor:pointer;
  font-size:12px;font-weight:700;color:var(--tx2);transition:.18s;margin-bottom:1px}
.sb-mem:hover{background:var(--surf2);color:var(--tx)}
.sb-mem.active{background:linear-gradient(135deg,rgba(240,165,0,.16),rgba(139,92,246,.10));color:var(--tx);box-shadow:inset 0 0 0 1px rgba(240,165,0,.35)}
.sb-mem.active .mav{box-shadow:0 0 0 2px rgba(240,165,0,.45)}
.mav{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:9px;font-weight:900;flex-shrink:0;color:#fff}
.mdot{width:7px;height:7px;border-radius:50%;margin-left:auto;flex-shrink:0}
.sb-foot{border-top:1px solid var(--brd);padding:10px;flex-shrink:0}
.sb-user{display:flex;align-items:center;gap:9px;padding:9px 11px;background:var(--surf2);
  border-radius:9px;cursor:pointer;transition:background .18s;margin-bottom:7px}
.sb-user:hover{background:var(--surf3)}
.sb-av{width:29px;height:29px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:900;flex-shrink:0;color:#fff}
.sb-uname{font-size:13px;font-weight:800}
.sb-urole{font-size:10px;color:var(--mu);font-weight:700}
.sb-arr{margin-left:auto;color:var(--mu);display:flex;align-items:center}
.sb-out{width:100%;padding:8px;border-radius:9px;border:1px solid rgba(255,107,107,.22);
  background:rgba(255,107,107,.07);color:#e05555;font-weight:800;font-size:12px;
  display:flex;align-items:center;justify-content:center;gap:6px;transition:background .18s}
.sb-out:hover{background:rgba(255,107,107,.17)}

/* Topbar */
.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:11px 20px;
  border-bottom:1px solid var(--brd);background:var(--surf);flex-shrink:0;gap:10px;flex-wrap:wrap;transition:background .25s}
.tb-l{display:flex;align-items:center;gap:8px}
.tb-r{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.ib{width:34px;height:34px;border-radius:9px;background:var(--surf2);border:1px solid var(--brd2);
  color:var(--tx2);display:flex;align-items:center;justify-content:center;transition:.18s;cursor:pointer;flex-shrink:0;padding:0}
#appZoomBtn{font-size:11px;font-weight:900;letter-spacing:.2px}
.ib:hover{background:var(--surf3);color:var(--tx)}
.mo-title{font-size:17px;font-weight:900;letter-spacing:-.3px;white-space:nowrap;min-width:155px}
.today-btn{padding:5px 12px;border-radius:8px;border:1px solid var(--brd2);background:var(--surf2);
  color:var(--tx2);font-size:12px;font-weight:800;white-space:nowrap;cursor:pointer;font-family:inherit;transition:.18s}
.today-btn:hover{color:var(--tx);background:var(--surf3)}
.srch-wrap{position:relative}
.srch-ico{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--mu);pointer-events:none;display:flex;align-items:center}
.srch-inp{background:var(--surf2);border:1px solid var(--brd2);border-radius:9px;padding:7px 11px 7px 30px;
  font-size:12px;color:var(--tx);width:148px;font-weight:600;transition:.2s;outline:none;font-family:inherit}
.srch-inp:focus{border-color:var(--acc);width:185px;box-shadow:0 0 0 3px rgba(240,165,0,.1)}
.srch-inp::placeholder{color:var(--mu)}
.vtog{display:flex;background:var(--surf2);border-radius:9px;padding:3px;border:1px solid var(--brd)}
.vb{padding:4px 10px;border-radius:7px;font-size:11px;font-weight:800;cursor:pointer;border:none;
  background:none;color:var(--mu);font-family:inherit;transition:.18s;white-space:nowrap}
.vb.active{background:var(--surf);color:var(--tx);box-shadow:0 2px 8px var(--sh)}
.add-btn{padding:7px 14px;background:linear-gradient(135deg,var(--acc),#c48800);color:#000;font-weight:900;
  font-size:12px;border:none;border-radius:9px;cursor:pointer;font-family:inherit;
  transition:transform .2s,box-shadow .2s;box-shadow:0 4px 14px rgba(240,165,0,.27);
  white-space:nowrap;display:flex;align-items:center;gap:6px}
.add-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(240,165,0,.38)}
.notif-btn{position:relative}
.notif-badge{position:absolute;top:-5px;right:-4px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:#ff6b6b;color:#fff;font-size:10px;font-weight:900;display:flex;align-items:center;justify-content:center;border:2px solid var(--surf)}
.notif-panel{position:absolute;right:18px;top:58px;width:360px;max-width:calc(100vw - 24px);background:var(--surf);border:1px solid var(--brd2);border-radius:12px;box-shadow:0 18px 45px var(--sh);z-index:260;overflow:hidden}
.notif-hd{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--brd);font-size:13px}
.notif-list{max-height:360px;overflow:auto}
.notif-item{padding:10px 12px;border-bottom:1px solid var(--brd);font-size:12px;line-height:1.4}
.notif-item:last-child{border-bottom:none}
.notif-item.unread{background:rgba(116,185,255,.07)}
.notif-item.notif-clickable{cursor:pointer;transition:background .15s ease, box-shadow .15s ease}
.notif-item.notif-clickable:hover{background:rgba(116,185,255,.14)}
.notif-item.notif-clickable:focus{outline:none;box-shadow:inset 0 0 0 2px rgba(116,185,255,.55)}
.notif-time{display:block;font-size:10px;color:var(--mu);margin-top:4px}
.notif-empty{padding:16px 12px;color:var(--mu);font-size:12px}

/* Views */
.content{flex:1;overflow:auto;padding:15px 18px}
.view{display:none}.view.active{display:block}

/* Monat */
.cal-wdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:5px}
.cal-wdays div{text-align:center;font-size:10px;font-weight:800;text-transform:uppercase;
  letter-spacing:.8px;color:var(--mu);padding-bottom:6px}
.cal-wdays .we{color:rgba(255,107,107,.45)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cell{background:var(--surf);border:1px solid var(--brd);border-radius:10px;min-height:98px;
  padding:6px;cursor:pointer;transition:border-color .18s,background .18s;overflow:hidden}
.cell:hover{border-color:rgba(240,165,0,.45);background:var(--surf2)}
.cell.other{opacity:.22;pointer-events:none}
.cell.tod{border-color:var(--acc);background:rgba(240,165,0,.05)}
.cell.wend{background:rgba(255,107,107,.022)}
.dnum{width:22px;height:22px;border-radius:7px;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;margin-bottom:4px;color:var(--tx2)}
.tod .dnum{background:var(--acc);color:#000}
.evchip{display:flex;align-items:center;gap:3px;padding:2px 5px;border-radius:4px;
  font-size:10px;font-weight:700;margin-bottom:2px;cursor:pointer;overflow:hidden;white-space:nowrap;transition:filter .15s}
.evchip:hover{filter:brightness(1.22)}
.evchip-t{overflow:hidden;text-overflow:ellipsis;flex:1}
.ev-more{font-size:10px;color:var(--mu);font-weight:800;margin-top:2px;cursor:pointer}
.ev-more:hover{color:var(--acc)}

/* Woche */
.w-scroll{overflow-x:auto}
.w-grid{display:grid;grid-template-columns:48px repeat(7,1fr);gap:4px;min-width:520px}
.whd{text-align:center;padding:8px 4px;border-radius:9px;background:var(--surf);border:1px solid var(--brd)}
.whd.tod{border-color:var(--acc);background:rgba(240,165,0,.06)}
.whd-d{font-size:9px;color:var(--mu);font-weight:800;text-transform:uppercase}
.whd-n{font-size:17px;font-weight:900;margin-top:1px}
.whd.tod .whd-n{color:var(--acc)}
.wtc{display:flex;flex-direction:column}
.wts{height:46px;display:flex;align-items:flex-start;padding-top:2px;justify-content:flex-end;padding-right:6px}
.wtl{font-size:9px;color:var(--mu);font-weight:700}
.wdc{position:relative;border:1px solid var(--brd);border-radius:9px;background:var(--surf);overflow:hidden;cursor:pointer}
.whl{height:46px;border-bottom:1px solid var(--brd)}
.wev{position:absolute;left:3px;right:3px;border-radius:5px;padding:2px 6px;font-size:10px;font-weight:700;
  cursor:pointer;overflow:hidden;border-left:3px solid;white-space:nowrap;transition:filter .15s;z-index:1}
.wev:hover{filter:brightness(1.15)}

/* Liste */
.l-wrap{max-width:none;width:100%}
.lg{margin-bottom:20px}
.lg-hd{font-size:11px;font-weight:900;color:var(--mu);text-transform:uppercase;letter-spacing:1px;
  padding-bottom:8px;border-bottom:1px solid var(--brd);margin-bottom:7px}
.li{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:10px;
  background:var(--surf);border:1px solid var(--brd);margin-bottom:4px;cursor:pointer;transition:.18s}
.li:hover{border-color:rgba(240,165,0,.3);background:var(--surf2)}
.li-bar{width:4px;height:36px;border-radius:4px;flex-shrink:0}
.li-info{flex:1;min-width:0}
.li-t{font-size:13px;font-weight:800;margin-bottom:2px}
.li-m{font-size:11px;color:var(--tx2);display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.li-m .ff-icon{opacity:.7}
.li-avs{display:flex;gap:3px;margin-left:auto}
.li-av{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:8px;font-weight:900;border:2px solid var(--surf);color:#fff}

/* Familie */
.f-scroll{overflow-x:auto}
.f-grid{display:grid;gap:4px;min-width:460px}
.fhd{background:var(--surf);border:1px solid var(--brd);border-radius:9px;padding:9px 5px;text-align:center;font-size:12px;font-weight:800}
.fav{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:900;margin:0 auto 4px;color:#fff}
.fdate{font-size:10px;color:var(--mu);font-weight:800;text-align:center;padding:3px;display:flex;align-items:center;justify-content:center;flex-direction:column}
.fdate.tod{color:var(--acc);font-weight:900}
.fcell{background:var(--surf);border:1px solid var(--brd);border-radius:7px;padding:4px;min-height:48px}
.fev{border-radius:4px;padding:2px 5px;font-size:9px;font-weight:700;margin-bottom:2px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:filter .15s}
.fev:hover{filter:brightness(1.15)}
.fnone{color:var(--mu);font-size:9px;padding:3px;display:block}

/* Empty state */
.empty{text-align:center;padding:60px 20px;color:var(--mu)}
.empty-ico{font-size:44px;margin-bottom:14px;line-height:1}
.empty-t{font-size:15px;font-weight:700;color:var(--tx2);margin-bottom:5px}

/* Detail Panel */
.dp{width:0;background:var(--surf);border-left:1px solid var(--brd);display:flex;flex-direction:column;
  transition:width .3s,background .25s;flex-shrink:0;overflow:hidden}
.dp.open{width:360px}
@media(max-width:900px){.dp{position:fixed;top:0;right:0;bottom:0;z-index:150;width:0}.dp.open{width:min(100vw,360px)}.dp-body{min-width:0}}
.dp-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 17px;
  border-bottom:1px solid var(--brd);flex-shrink:0}
.dp-hd h3{font-size:14px;font-weight:900;flex:1;margin-right:8px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.dp-body{padding:15px 17px;flex:1;overflow-y:auto;min-width:360px}
.dp-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:99px;font-size:12px;font-weight:800;margin-bottom:14px}
.dp-row{display:flex;align-items:flex-start;gap:9px;margin-bottom:11px}
.dp-ico{color:var(--mu);flex-shrink:0;margin-top:1px;display:flex;align-items:center}
.dp-lbl{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--mu);margin-bottom:2px}
.dp-val{font-size:13px;font-weight:700;word-break:break-word}
.dp-mems{display:flex;gap:7px;flex-wrap:wrap;margin-top:5px}
.dp-mem{text-align:center}
.dp-mav{width:27px;height:27px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:900;margin:0 auto;color:#fff}
.dp-mn{font-size:9px;color:var(--mu);margin-top:2px;font-weight:700}
.dp-acts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:15px}
.dpbtn{min-width:0;padding:8px 6px;border-radius:9px;border:1px solid var(--brd2);
  background:var(--surf2);color:var(--tx2);font-size:11px;font-weight:800;cursor:pointer;
  font-family:inherit;transition:.18s;display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap}
.dpbtn:hover{color:var(--tx);background:var(--surf3)}
.dpbtn.red:hover{background:rgba(255,107,107,.13);color:#e05555;border-color:rgba(255,107,107,.3)}

/* Modals */
.ov{position:fixed;inset:0;background:rgba(0,0,0,.65);display:none;align-items:center;
  justify-content:center;z-index:1000;backdrop-filter:blur(8px);padding:14px}
.ov.open{display:flex}
.modal{background:var(--surf);border:1px solid var(--brd2);border-radius:18px;width:100%;
  max-width:510px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 28px 70px var(--sh);
  animation:mIn .22s ease;transition:background .25s}
.modal-sm{max-width:400px}
.modal-lg{max-width:600px}
@keyframes mIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.mhd{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--brd);flex-shrink:0}
.mhd h2{font-size:16px;font-weight:900}
.mbody{padding:17px 20px;overflow-y:auto;flex:1}
.mfoot{padding:12px 20px;border-top:1px solid var(--brd);display:flex;gap:7px;justify-content:flex-end;flex-shrink:0}
.divider{border:none;border-top:1px solid var(--brd);margin:12px 0}
.section-lbl{font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:1px;color:var(--mu);margin-bottom:9px}
.sec-div{border-top:1px solid var(--brd);margin:16px 0 14px;padding-top:14px;font-size:13px;font-weight:900}

.chk-grp{display:flex;gap:6px;flex-wrap:wrap}
.chk-item{display:flex;align-items:center;gap:5px;background:var(--surf2);border:1.5px solid var(--brd2);
  border-radius:9px;padding:6px 10px;cursor:pointer;font-size:12px;font-weight:700;transition:border-color .18s}
.chk-item:hover{border-color:var(--acc)}
.chk-item input{accent-color:var(--acc)}
.tgl-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0;font-size:13px;font-weight:700;color:var(--tx2)}
.tgl{position:relative;display:inline-block;width:40px;height:22px;cursor:pointer;flex-shrink:0}
.tgl input{opacity:0;width:0;height:0}
.tgls{position:absolute;inset:0;background:var(--surf3);border-radius:99px;transition:.25s}
.tgls::before{content:'';position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.25s}
input:checked+.tgls{background:var(--acc)}
input:checked+.tgls::before{transform:translateX(18px)}
.cpick{display:flex;gap:7px;flex-wrap:wrap;margin-top:6px}
.cdot{width:27px;height:27px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;transition:.18s}
.cdot.sel{border-color:#fff;transform:scale(1.18)}
body.light .cdot.sel{border-color:#333}
.info-box{background:rgba(240,165,0,.07);border:1px solid rgba(240,165,0,.22);border-radius:10px;
  padding:11px 13px;font-size:12px;font-weight:600;color:var(--tx2);margin-bottom:14px;line-height:1.6}
.info-box strong{color:var(--acc);font-weight:800}

/* Sync Modal */
.sync-acts{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:5px}
.sync-act{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surf2);
  border:1.5px solid var(--brd2);border-radius:11px;cursor:pointer;transition:.18s}
.sync-act:hover{border-color:var(--acc);background:var(--surf3)}
.sync-act-ico{display:flex;flex-shrink:0}
.sync-act-name{font-size:13px;font-weight:800;margin-bottom:1px}
.sync-act-desc{font-size:11px;color:var(--tx2);font-weight:600}
.sprov{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surf2);
  border:1.5px solid var(--brd2);border-radius:11px;margin-bottom:8px;cursor:pointer;transition:.18s}
.sprov:hover{border-color:var(--acc)}
.sprov.conn{border-color:rgba(107,203,119,.4);background:rgba(107,203,119,.04)}
.sp-logo{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.sp-info{flex:1}
.sp-name{font-size:13px;font-weight:800;margin-bottom:1px}
.sp-desc{font-size:11px;color:var(--tx2);font-weight:600}
.sp-last{font-size:10px;color:var(--mu);margin-top:2px}
.sbadge{font-size:11px;font-weight:800;padding:3px 9px;border-radius:99px;white-space:nowrap}
.sbadge.on{background:rgba(107,203,119,.15);color:#3a9a45}
.sbadge.off{background:var(--surf3);color:var(--mu)}

/* Sync Schnittstellen (auf-/zuklappbar) */
.conn-acc{border:1px solid var(--brd);border-radius:10px;background:var(--surf);margin-bottom:8px;overflow:hidden}
.conn-acc-hd{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:var(--surf2);border:none;color:var(--tx);font-size:13px;font-weight:800;text-align:left}
.conn-acc-hd:hover{background:var(--surf3)}
.conn-acc-body{padding:12px}

/* Profil Modal */
.prof-av-wrap{text-align:center;margin-bottom:20px}
.prof-av{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;color:#fff;margin:0 auto 7px}

/* Cal Modal */
.cal-mi{display:flex;align-items:center;gap:9px;padding:9px 12px;background:var(--surf2);
  border:1px solid var(--brd2);border-radius:9px;margin-bottom:6px}
.cal-mi-info{flex:1}
.cal-mi-name{font-size:13px;font-weight:800}
.cal-mi-sub{font-size:10px;color:var(--mu);font-weight:700}
.cal-mi-btn{background:var(--surf3);border:none;border-radius:7px;padding:5px 10px;font-size:12px;
  font-weight:700;cursor:pointer;color:var(--tx2);font-family:inherit;transition:.18s;display:flex;align-items:center;gap:4px}
.cal-mi-btn:hover{background:var(--surf);color:var(--tx)}

/* Switch Modal */
.sw-item{display:flex;align-items:center;gap:9px;padding:10px 12px;background:var(--surf2);
  border:1px solid var(--brd2);border-radius:9px;cursor:pointer;transition:.18s;margin-bottom:6px}
.sw-item:hover,.sw-item.active{border-color:var(--acc)}
.sw-av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;flex-shrink:0}
.sw-name{font-size:13px;font-weight:800}
.sw-email{font-size:11px;color:var(--tx2);font-weight:600}
.sw-check{margin-left:auto;color:var(--acc);display:flex;align-items:center}

/* Toast */
.toast{position:fixed;bottom:20px;right:20px;padding:11px 16px;border-radius:12px;font-size:13px;
  font-weight:700;font-family:'Nunito',sans-serif;box-shadow:0 10px 28px var(--sh);border:1px solid;
  transform:translateY(80px);opacity:0;transition:.28s;z-index:9999;display:flex;align-items:center;
  gap:8px;max-width:320px;pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}
.toast.success{background:#0d2a0d;border-color:rgba(107,203,119,.35);color:#6bcb77}
.toast.error  {background:#2a0d0d;border-color:rgba(255,107,107,.35);color:#ff6b6b}
.toast.info   {background:var(--surf3);border-color:var(--brd2);color:var(--tx)}

/* Aufgaben (Chips + Seitenansicht) */
.task-chip,.holiday-chip{display:flex;align-items:center;gap:4px;padding:2px 5px;border-radius:4px;font-size:10px;font-weight:700;margin-bottom:2px;cursor:pointer;overflow:hidden;white-space:nowrap;transition:filter .15s;border:1px solid transparent}
.task-chip{background:rgba(107,203,119,.16);color:#6bcb77;border-color:rgba(107,203,119,.28)}
.holiday-chip{background:rgba(247,201,72,.16);color:#f7c948;border-color:rgba(247,201,72,.28)}
.holiday-chip.school{background:rgba(116,185,255,.18);color:#74b9ff;border-color:rgba(116,185,255,.3)}
.task-chip:hover,.holiday-chip:hover{filter:brightness(1.15)}
.task-chip.done{opacity:.6;text-decoration:line-through}
.task-more,.holiday-more{font-size:10px;color:var(--mu);font-weight:800;margin-top:2px;cursor:pointer}
.task-more:hover,.holiday-more:hover{color:var(--acc)}

.wev-task{border-left-color:#6bcb77!important;background:rgba(107,203,119,.22)!important;color:#d6ffd8;z-index:4;font-size:11px;line-height:16px}
.wev-holiday{border-left-color:#74b9ff!important;background:rgba(116,185,255,.22)!important;color:#d7ebff;z-index:4;font-size:11px;line-height:16px}
.li-task .li-bar{background:#6bcb77!important}
.li-holiday .li-bar{background:#74b9ff!important}

.tasks-page{display:flex;flex-direction:column;gap:12px}
.tasks-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;flex-wrap:wrap;background:var(--surf);border:1px solid var(--brd);border-radius:12px;padding:12px}
.tasks-head h3{font-size:18px;line-height:1.1}
.tasks-sub{font-size:12px;color:var(--mu);font-weight:700;margin-top:3px}
.tasks-actions{display:flex;gap:7px;flex-wrap:wrap}
.tasks-quick{display:grid;grid-template-columns:1fr 170px auto;gap:8px;background:var(--surf);border:1px solid var(--brd);border-radius:12px;padding:10px}
.tasks-quick input{background:var(--surf2);border:1.5px solid var(--brd2);border-radius:10px;padding:9px 11px;font-size:13px;color:var(--tx);font-weight:600;outline:none}
.tasks-quick input:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(240,165,0,.12)}
.tasks-table-wrap{background:var(--surf);border:1px solid var(--brd);border-radius:12px;overflow:auto}
.tasks-table{width:100%;border-collapse:collapse;min-width:620px}
.tasks-table th,.tasks-table td{padding:10px 12px;border-bottom:1px solid var(--brd);text-align:left;font-size:12px}
.tasks-table th{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--mu);font-weight:900;background:var(--surf2)}
.tasks-table tr:last-child td{border-bottom:none}
.tasks-table tr.is-focus{background:rgba(240,165,0,.08)}
.task-link{background:none;border:none;padding:0;color:var(--tx);font-weight:800;cursor:pointer;text-align:left}
.task-link:hover{color:var(--acc)}

@media(max-width:900px){
  .tasks-quick{grid-template-columns:1fr}
  .tasks-head{padding:10px}
}

/* Profilseite */
.profile-page{width:100%;max-width:none}
.profile-card{background:var(--surf);border:1px solid var(--brd);border-radius:14px;overflow:hidden;box-shadow:0 8px 26px var(--sh);width:100%}
