/* =====================================================================
   Portal Upliso.de – App-Styles (Design nach BAUPLAN 2)
   Palette: brand #1F3A5F · accent #2DB5C4 · ok #2E9E5B · warn #E0A030 · danger #C0392B
   ===================================================================== */
:root{
  --brand:#1F3A5F; --accent:#2DB5C4;
  --ok:#2E9E5B; --warn:#E0A030; --danger:#C0392B;
  --ink:#0F172A; --muted:#64748B; --faint:#94A3B8;
  --line:#E7EBF0; --line2:#E2E8F0; --bg:#F5F7FA; --card:#fff;
  --radius:12px; --shadow:0 1px 3px rgba(15,23,42,.06),0 8px 24px rgba(15,23,42,.05);
  --shadow-lg:0 18px 48px rgba(15,23,42,.18);
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{font-family:'Hanken Grotesk',system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-size:14px;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;padding:0;}
input,textarea,select{font-family:inherit;font-size:14px;}
input::placeholder,textarea::placeholder{color:var(--faint);}
::selection{background:rgba(45,181,196,.25);}
::-webkit-scrollbar{width:10px;height:10px;}
::-webkit-scrollbar-thumb{background:#CBD5E1;border-radius:8px;border:2px solid transparent;background-clip:padding-box;}
::-webkit-scrollbar-thumb:hover{background:#94A3B8;background-clip:padding-box;}
@keyframes spin{to{transform:rotate(360deg);}}
@keyframes fade{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
@keyframes slide{from{transform:translateX(100%);}to{transform:none;}}
@keyframes toast{from{opacity:0;transform:translateY(12px) scale(.98);}to{opacity:1;transform:none;}}
@keyframes pulse{0%{transform:scale(.85);opacity:.6;}70%{transform:scale(1.7);opacity:0;}100%{opacity:0;}}
@keyframes shimmer{0%{background-position:-320px 0;}100%{background-position:320px 0;}}

/* ---- App-Shell ---- */
.app{height:100vh;display:flex;flex-direction:column;overflow:hidden;}
.topbar{height:64px;flex-shrink:0;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 18px;position:relative;z-index:50;}
.body{flex:1;display:flex;min-height:0;}
.main{flex:1;overflow:auto;padding:26px 30px;}
.brandbox{width:38px;height:38px;border-radius:10px;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:800;font-size:14px;letter-spacing:.03em;box-shadow:0 2px 7px rgba(31,58,95,.28);flex-shrink:0;overflow:hidden;}
.brandbox img{width:100%;height:100%;object-fit:cover;}

/* ---- Sidebar ---- */
.sidebar{width:236px;flex-shrink:0;background:#fff;border-right:1px solid var(--line);display:flex;flex-direction:column;padding:14px 12px;transition:width .18s;overflow:hidden;}
.sidebar.collapsed{width:70px;}
.nav-item{display:flex;align-items:center;gap:12px;height:42px;padding:0 12px;border-radius:10px;color:var(--muted);font-weight:600;font-size:14px;position:relative;white-space:nowrap;margin-bottom:2px;transition:background .13s,color .13s;}
.nav-item:hover{background:#F1F5F9;color:var(--ink);}
.nav-item.active{background:rgba(45,181,196,.10);color:var(--brand);}
.nav-item.active::before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:3px;border-radius:3px;background:var(--accent);}
.nav-item .badge{margin-left:auto;background:var(--danger);color:#fff;font-size:10.5px;font-weight:800;min-width:18px;height:18px;padding:0 5px;border-radius:9px;display:grid;place-items:center;}
.sidebar.collapsed .nav-item span.label,.sidebar.collapsed .nav-sep-label,.sidebar.collapsed .badge{display:none;}
.nav-sep{margin:12px 6px 6px;border-top:1px solid var(--line);}
.nav-sep-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);padding:8px 12px 4px;}
.collapse-btn{margin-top:auto;display:flex;align-items:center;gap:12px;height:40px;padding:0 12px;border-radius:10px;color:var(--faint);font-weight:600;font-size:13px;}
.collapse-btn:hover{background:#F1F5F9;color:var(--muted);}

/* ---- Topbar bits ---- */
.searchwrap{flex:1;display:flex;justify-content:center;min-width:0;}
.searchbox{position:relative;width:100%;max-width:520px;}
.searchbox input{width:100%;height:40px;border:1px solid var(--line2);border-radius:10px;padding:0 40px 0 38px;background:#F8FAFC;color:var(--ink);outline:none;transition:border-color .15s,background .15s,box-shadow .15s;}
.searchbox input:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(45,181,196,.13);}
.searchbox .ic-left{position:absolute;left:12px;top:0;bottom:0;display:flex;align-items:center;color:var(--faint);pointer-events:none;}
.searchbox .ic-right{position:absolute;right:11px;top:0;bottom:0;display:flex;align-items:center;color:var(--faint);}
.search-drop{position:absolute;top:48px;left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:6px;z-index:80;max-height:60vh;overflow:auto;animation:fade .12s;}
.search-drop .row{width:100%;display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:8px;text-align:left;}
.search-drop .row:hover{background:#F1F5F9;}
.icon-btn{width:40px;height:40px;border-radius:9px;display:grid;place-items:center;color:#475569;position:relative;}
.icon-btn:hover{background:#F1F5F9;}
.dot{position:absolute;top:7px;right:7px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--danger);color:#fff;font-size:10px;font-weight:800;display:grid;place-items:center;border:2px solid #fff;}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;flex-shrink:0;}
.menu{position:absolute;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);z-index:80;overflow:hidden;padding:6px;animation:fade .12s;}
.menu button{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;text-align:left;font-size:13.5px;font-weight:600;color:#334155;}
.menu button:hover{background:#F1F5F9;}

/* ---- Headings ---- */
.page-head{display:flex;align-items:center;gap:14px;margin-bottom:22px;flex-wrap:wrap;}
.page-head h1{font-size:23px;font-weight:800;margin:0;letter-spacing:-.01em;}
.page-head .sub{color:var(--muted);font-size:13.5px;}
.spacer{flex:1;}

/* ---- Cards ---- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);}
.card-pad{padding:18px 20px;}
.grid{display:grid;gap:18px;}
.kpis{grid-template-columns:repeat(4,1fr);}
.two-col{grid-template-columns:1fr 1fr;}
@media(max-width:1100px){.kpis{grid-template-columns:repeat(2,1fr);}.two-col{grid-template-columns:1fr;}}

.kpi{padding:18px 20px;}
.kpi .label{font-size:12.5px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:8px;}
.kpi .num{font-size:34px;font-weight:800;letter-spacing:-.02em;margin-top:8px;line-height:1;}
.kpi .ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 16px;border-radius:10px;font-weight:700;font-size:13.5px;transition:filter .13s,background .13s,box-shadow .13s;white-space:nowrap;}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(45,181,196,.32);}
.btn-accent:hover{filter:brightness(.96);}
.btn-brand{background:var(--brand);color:#fff;}
.btn-brand:hover{filter:brightness(1.1);}
.btn-ghost{background:#F1F5F9;color:#334155;}
.btn-ghost:hover{background:#E2E8F0;}
.btn-danger{background:#FBEAE8;color:var(--danger);}
.btn-danger:hover{background:#F5D9D5;}
.btn-sm{height:34px;padding:0 12px;font-size:13px;}
.btn:disabled{opacity:.55;cursor:not-allowed;}

/* ---- Pills / markers ---- */
.pill{display:inline-flex;align-items:center;gap:5px;height:24px;padding:0 10px;border-radius:20px;font-size:12px;font-weight:700;}
.pill-gray{background:#F1F5F9;color:#475569;}
.pill-green{background:#E4F4EA;color:#1E7A44;}
.pill-blue{background:#E4EEF6;color:#1F3A5F;}
.pill-red{background:#FBEAE8;color:#B23227;}
.pill-amber{background:#FBF0DD;color:#9A6B12;}
.dot-prio{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.prio-hoch{background:var(--danger);}
.prio-mittel{background:var(--warn);}
.prio-niedrig{background:var(--ok);}
.lock{color:var(--faint);display:inline-flex;vertical-align:middle;}
.countdown{font-size:12px;font-weight:700;padding:2px 9px;border-radius:20px;background:#F1F5F9;color:#475569;}
.countdown.urgent{background:#FBEAE8;color:var(--danger);}

/* ---- Table ---- */
.table{width:100%;border-collapse:collapse;}
.table th{text-align:left;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--faint);padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap;}
.table td{padding:12px 14px;border-bottom:1px solid #F1F5F9;font-size:13.5px;vertical-align:middle;}
.table tbody tr{cursor:pointer;transition:background .1s;}
.table tbody tr:hover{background:#F8FAFC;}
.table .strong{font-weight:700;color:var(--ink);}
.toolbar{display:flex;align-items:center;gap:10px;padding:14px 16px;flex-wrap:wrap;border-bottom:1px solid var(--line);}
.select{height:38px;border:1px solid var(--line2);border-radius:9px;padding:0 30px 0 12px;background:#fff;color:var(--ink);font-weight:600;font-size:13px;outline:none;cursor:pointer;
  appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;}
.tsearch{position:relative;flex:1;min-width:180px;max-width:340px;}
.tsearch input{width:100%;height:38px;border:1px solid var(--line2);border-radius:9px;padding:0 12px 0 36px;background:#F8FAFC;outline:none;}
.tsearch input:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(45,181,196,.13);}
.tsearch .ic{position:absolute;left:11px;top:0;bottom:0;display:flex;align-items:center;color:var(--faint);}

/* ---- Slide-over panel + modal ---- */
.overlay{position:fixed;inset:0;background:rgba(15,23,42,.42);z-index:200;display:flex;justify-content:flex-end;animation:fade .15s;}
.overlay.center{align-items:center;justify-content:center;}
.panel{width:min(560px,100%);height:100%;background:#fff;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slide .22s ease;}
.panel .head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;}
.panel .head h2{margin:0;font-size:18px;font-weight:800;}
.panel .cnt{flex:1;overflow:auto;padding:22px;}
.panel .foot{padding:16px 22px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end;}
.modal{width:min(440px,100%);background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);padding:24px;animation:fade .15s;}

/* ---- Form ---- */
.field{margin-bottom:15px;}
.field label{display:block;font-size:12.5px;font-weight:700;color:#334155;margin-bottom:6px;display:flex;align-items:center;gap:6px;}
.field input,.field textarea,.field select{width:100%;height:42px;border:1px solid var(--line2);border-radius:10px;padding:0 13px;background:#fff;color:var(--ink);outline:none;transition:border-color .13s,box-shadow .13s;}
.field textarea{height:auto;min-height:88px;padding:11px 13px;resize:vertical;}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,181,196,.13);}
.field .err{color:var(--danger);font-size:12px;margin-top:5px;display:none;}
.field.has-error input,.field.has-error textarea{border-color:var(--danger);}
.field.has-error .err{display:block;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 16px;}
.form-grid .full{grid-column:1/-1;}
@media(max-width:520px){.form-grid{grid-template-columns:1fr;}}

/* ---- Empty / skeleton ---- */
.empty{text-align:center;padding:48px 20px;color:var(--muted);}
.empty .ic{width:56px;height:56px;border-radius:16px;background:#F1F5F9;color:var(--faint);display:grid;place-items:center;margin:0 auto 14px;}
.empty h3{margin:0 0 6px;font-size:16px;color:var(--ink);}
.skel{background:linear-gradient(90deg,#EEF2F6 25%,#F6F9FC 37%,#EEF2F6 63%);background-size:640px 100%;animation:shimmer 1.3s infinite linear;border-radius:8px;}

/* ---- Toasts ---- */
.toasts{position:fixed;right:20px;bottom:20px;z-index:300;display:flex;flex-direction:column;gap:10px;}
.toast{min-width:260px;max-width:380px;background:#fff;border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:12px;box-shadow:var(--shadow-lg);padding:13px 16px;display:flex;align-items:flex-start;gap:11px;animation:toast .2s;}
.toast.ok{border-left-color:var(--ok);}
.toast.err{border-left-color:var(--danger);}
.toast .t{font-weight:700;font-size:13.5px;}
.toast .m{font-size:13px;color:var(--muted);}

/* ---- Timeline ---- */
.tl{position:relative;padding-left:26px;}
.tl::before{content:"";position:absolute;left:9px;top:4px;bottom:4px;width:2px;background:var(--line);}
.tl-item{position:relative;padding:0 0 16px;}
.tl-item .node{position:absolute;left:-26px;top:1px;width:20px;height:20px;border-radius:50%;background:#fff;border:2px solid var(--line2);display:grid;place-items:center;color:var(--faint);}

.mobile-only{display:none;}
@media(max-width:900px){
  .sidebar{position:fixed;left:0;top:64px;bottom:0;z-index:120;transform:translateX(-100%);transition:transform .2s;box-shadow:var(--shadow-lg);}
  .sidebar.open{transform:none;}
  .mobile-only{display:grid;}
  .main{padding:18px 16px;}
}
