:root{
  --bg:#f6eee3; --bg2:#efe4d4; --card:#fffdf9; --ink:#2b2620; --ink2:#7a6f60; --line:#e9dcc8;
  --accent:#e07a5f; --accent-d:#c75f45; --sage:#5b8a72; --gold:#e0a458; --blue:#3b82f6;
  --shadow:0 6px 24px rgba(80,55,30,.08); --shadow-sm:0 2px 8px rgba(80,55,30,.06);
  --r:20px; --r-sm:14px;
}
*{box-sizing:border-box} html,body{margin:0;height:100%}
[hidden]{display:none!important}
body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
b,strong{font-weight:600}
h1,h2,h3{font-family:Fraunces,Georgia,serif;font-weight:600;margin:0;letter-spacing:-.01em}
small{color:var(--ink2)}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#d9c8ad;border-radius:9px}

#app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
#sidebar{background:linear-gradient(180deg,#fffdf9,#f3e8d6);border-right:1px solid var(--line);padding:18px 14px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:6px}
.brand{display:flex;gap:10px;align-items:center;padding:6px 8px 14px}
.brand-emoji{font-size:30px} .brand b{font-family:Fraunces,serif;font-size:18px} .brand small{display:block;font-size:12px}
#nav{display:flex;flex-direction:column;gap:3px;flex:1;overflow:auto}
.navi{display:flex;gap:11px;align-items:center;padding:11px 13px;border-radius:13px;color:var(--ink2);font-weight:500;font-size:14.5px;transition:.15s}
.navi .ic{font-size:18px;width:22px;text-align:center}
.navi:hover{background:#f0e6d5;color:var(--ink)}
.navi.on{background:var(--ink);color:#fff;box-shadow:var(--shadow-sm)}
.navi .badge{margin-left:auto;background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:1px 7px;border-radius:20px}
.navi.on .badge{background:#fff;color:var(--ink)}
.who{display:flex;gap:6px;padding:10px 6px 2px;border-top:1px solid var(--line);flex-wrap:wrap}
.av{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:16px;box-shadow:var(--shadow-sm)}

#main{display:flex;flex-direction:column;min-width:0}
#topbar{display:flex;align-items:center;gap:12px;padding:16px 22px;position:sticky;top:0;background:rgba(246,238,227,.86);backdrop-filter:blur(10px);z-index:5;border-bottom:1px solid var(--line)}
#menuBtn{display:none;font-size:22px}
#topTitle{font-family:Fraunces,serif;font-size:21px;font-weight:600}
#topDate{margin-left:auto;color:var(--ink2);font-size:13.5px;font-weight:500;text-transform:capitalize}
#view{padding:20px 22px 110px;max-width:1080px;width:100%}
#tabbar{display:none}

/* cards & grid */
.grid{display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:17px;box-shadow:var(--shadow-sm)}
.card.pad0{padding:0;overflow:hidden}
.card h3{font-size:16px;margin-bottom:3px}
.card .ch{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.card .ch .ic{font-size:19px}
.card .ch .badge{margin-left:auto;font-size:12px;color:var(--ink2);font-weight:600}
.hero{grid-column:1/-1;background:linear-gradient(120deg,#fffdf9,#f4e7d4);border:1px solid var(--line);border-radius:24px;padding:22px 24px;box-shadow:var(--shadow);display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.hero h1{font-size:27px} .hero p{margin:4px 0 0;color:var(--ink2)}
.hero .spark{margin-left:auto}

.section-h{display:flex;align-items:center;gap:12px;margin:4px 2px 16px}
.section-h h2{font-size:23px}
.section-h .sub{color:var(--ink2);font-size:14px}
.btn{background:var(--ink);color:#fff;padding:9px 15px;border-radius:11px;font-weight:600;font-size:14px;display:inline-flex;gap:7px;align-items:center;box-shadow:var(--shadow-sm);transition:.15s}
.btn:hover{transform:translateY(-1px)} .btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.accent{background:var(--accent)} .btn.sm{padding:6px 11px;font-size:13px;border-radius:9px}
.right{margin-left:auto}

/* list rows */
.row{display:flex;align-items:center;gap:12px;padding:12px 4px;border-bottom:1px solid var(--line)}
.row:last-child{border-bottom:none}
.row .t{font-weight:500} .row .s{font-size:12.5px;color:var(--ink2)}
.row .grow{flex:1;min-width:0} .row .grow .t{overflow:hidden;text-overflow:ellipsis}
.pill{font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:20px;background:#f0e6d5;color:var(--ink2);white-space:nowrap}
.dot{width:10px;height:10px;border-radius:50%;flex:none}
.check{width:24px;height:24px;border-radius:7px;border:2px solid var(--line);display:grid;place-items:center;flex:none;cursor:pointer;transition:.15s}
.check.on{background:var(--sage);border-color:var(--sage);color:#fff}
.chip-av{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:13px;flex:none}
.done .t{text-decoration:line-through;color:var(--ink2)}
.muted{color:var(--ink2)} .center{text-align:center}
.empty{text-align:center;color:var(--ink2);padding:26px 10px}
.tag{display:inline-block;font-size:11px;background:#f0e6d5;color:var(--ink2);padding:2px 8px;border-radius:8px;margin:2px 3px 0 0}

/* mini progress / chart */
.bar{height:8px;background:#efe2cd;border-radius:8px;overflow:hidden}.bar>i{display:block;height:100%;background:var(--sage)}
.kpi{font-family:Fraunces,serif;font-size:30px;font-weight:600;line-height:1}
.kpi small{font-family:Inter;font-size:13px;font-weight:500}
.seg{display:flex;gap:6px;background:#f0e6d5;padding:4px;border-radius:12px;flex-wrap:wrap}
.seg button{padding:7px 12px;border-radius:9px;font-weight:600;font-size:13px;color:var(--ink2)}
.seg button.on{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}

/* forms / modal */
.modal-wrap{position:fixed;inset:0;background:rgba(43,38,32,.42);display:grid;place-items:end center;z-index:50;backdrop-filter:blur(2px)}
.modal{background:var(--card);width:100%;max-width:480px;border-radius:24px 24px 0 0;padding:20px 20px calc(20px + env(safe-area-inset-bottom));box-shadow:0 -10px 40px rgba(0,0,0,.2);animation:up .22s ease}
@keyframes up{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}
@media(min-width:760px){.modal-wrap{place-items:center}.modal{border-radius:24px}}
.modal h3{font-size:19px;margin-bottom:14px}
.f{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.f label{font-size:13px;font-weight:600;color:var(--ink2)}
.f input,.f select,.f textarea{font-family:inherit;font-size:15px;padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:#fffdf9;color:var(--ink)}
.f textarea{min-height:74px;resize:vertical}
.modal-actions{display:flex;gap:10px;margin-top:6px}.modal-actions .btn{flex:1;justify-content:center}

.toast{position:fixed;bottom:84px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:11px 18px;border-radius:13px;font-weight:600;font-size:14px;z-index:60;box-shadow:var(--shadow)}

/* mobile */
@media(max-width:860px){
  #app{grid-template-columns:1fr}
  #sidebar{position:fixed;left:-300px;top:0;width:260px;z-index:40;transition:.25s;box-shadow:var(--shadow)}
  #sidebar.open{left:0}
  #menuBtn{display:block}
  #view{padding:16px 14px 100px}
  #tabbar{display:flex;position:fixed;bottom:0;left:0;right:0;background:rgba(255,253,249,.94);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:8px 6px calc(8px + env(safe-area-inset-bottom));z-index:30;justify-content:space-around}
  .tb{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:10.5px;color:var(--ink2);font-weight:600;padding:3px 8px;border-radius:10px}
  .tb .ic{font-size:21px}
  .tb.on{color:var(--accent)}
  .hero h1{font-size:23px}
}
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:35;display:none}.scrim.on{display:block}
@media(min-width:861px){.scrim{display:none!important}}

/* login */
body.login-mode #sidebar,body.login-mode #topbar,body.login-mode #tabbar{display:none!important}
body.login-mode #app{grid-template-columns:1fr}
body.login-mode #view{padding:0;max-width:none}
.login{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 30% 15%,#fbf3e7,#ecdcc4);padding:20px}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:36px 28px;width:100%;max-width:380px;text-align:center}
.login-emoji{font-size:46px}
.login-card h1{font-size:27px;margin-top:6px}
.login-who{display:flex;gap:18px;justify-content:center;margin:24px 0 16px}
.login-av{display:flex;flex-direction:column;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--ink2);cursor:pointer}
.login-av span{width:66px;height:66px;border-radius:50%;display:grid;place-items:center;font-size:32px;background:var(--c);color:#fff;border:3px solid transparent;transition:.18s;box-shadow:var(--shadow-sm)}
.login-av.sel span{border-color:var(--ink);transform:scale(1.06)}
.login-av.sel{color:var(--ink)}
.login-pin{width:100%;font-size:22px;text-align:center;letter-spacing:8px;padding:13px;border:1px solid var(--line);border-radius:14px;background:#fffdf9;margin-bottom:14px;font-family:inherit}
.login-err{color:var(--accent-d);font-size:13.5px;font-weight:600;margin-bottom:10px}
.login-go{width:100%;justify-content:center;padding:13px;font-size:15px}
.logout{margin-left:auto;font-size:12px;color:var(--ink2);font-weight:600;padding:4px 8px;border-radius:8px}
.logout:hover{background:#f0e6d5;color:var(--ink)}

/* ---- Vision / News / Hints (Ausbau 30.06.) ---- */
.vision-wait{text-align:center;padding:18px 6px}
.vision-wait h3{margin:14px 0 4px}
.spinner{width:42px;height:42px;margin:0 auto;border:4px solid #e7ddcf;border-top-color:var(--accent,#c98a5e);border-radius:50%;animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.hint{background:#fbf6ee;border:1px solid #ece0cf;border-radius:14px;padding:11px 14px;font-size:13.5px;line-height:1.5;color:#5c5247;margin-bottom:14px}
.row.news{display:flex;text-decoration:none;color:inherit;border-radius:12px}
.row.news:hover{background:#faf5ec}
.news-card{display:block;text-decoration:none;color:inherit;margin-bottom:12px;transition:transform .12s ease,box-shadow .12s ease}
.news-card:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(80,60,30,.10)}

/* ---- Politur 30.06. ---- */
#view{animation:viewIn .26s ease both}
@keyframes viewIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.card{transition:transform .14s ease, box-shadow .14s ease}
@media(hover:hover){.card:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(90,66,30,.10)}}
.grid .card{animation:viewIn .3s ease both}
.note{background:#fffdf9;border-color:#efe4d2}
.note.pinned{border-color:#e3b778;background:linear-gradient(180deg,#fff8ec,#fdf1de);box-shadow:0 6px 18px rgba(200,150,70,.12)}
.btn.accent[href^="tel:"]{text-decoration:none}
.seg{flex-wrap:wrap}
.kpi{letter-spacing:-.5px}
.section-h h2{letter-spacing:-.3px}
.navi .ic,.tb .ic{transition:transform .12s ease}
.navi:hover .ic{transform:scale(1.12)}
/* ============================================================
   PREMIUM-POLITUR (additiv, 30.06.) — Sand/Terracotta, warm
   Haengt an styles.css an. Bricht keine bestehenden Klassen.
   ============================================================ */

/* --- Zusatz-Tokens (warm, weich) --- */
:root{
  --r-pill:999px;
  --ease-soft:cubic-bezier(.2,.8,.2,1);
  --shadow-soft:0 4px 16px rgba(92,62,28,.07), 0 1px 3px rgba(92,62,28,.05);
  --shadow-lift:0 14px 34px rgba(92,62,28,.12), 0 4px 10px rgba(92,62,28,.07);
  --ring-accent:0 0 0 3px rgba(224,122,95,.18);
}

/* --- Ruhigerer Typo-Rhythmus --- */
body{line-height:1.5}
h1,h2,h3{line-height:1.18}
.card h3{letter-spacing:-.01em}
.row .s,.card .ch .badge,small{letter-spacing:.005em}
.hint{line-height:1.55}

/* --- Tiefe dezenter & edler --- */
.card{
  box-shadow:var(--shadow-soft);
  border-color:rgba(233,220,200,.85);
  transition:transform .18s var(--ease-soft), box-shadow .18s var(--ease-soft), border-color .18s var(--ease-soft);
}
@media(hover:hover){
  .card:hover{
    transform:translateY(-2px);
    box-shadow:var(--shadow-lift);
    border-color:rgba(224,164,88,.32);
  }
}
.hero{
  box-shadow:var(--shadow-lift);
  position:relative;overflow:hidden;
}
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 140% at 92% -20%, rgba(224,122,95,.10), transparent 55%);
}

/* --- Buttons: feiner Press/Hover, weiche Tiefe --- */
.btn{
  border-radius:12px;
  box-shadow:var(--shadow-soft);
  transition:transform .16s var(--ease-soft), box-shadow .16s var(--ease-soft), background .16s var(--ease-soft), filter .16s var(--ease-soft);
  -webkit-tap-highlight-color:transparent;
  position:relative;
}
.btn:hover{box-shadow:var(--shadow-lift)}
.btn:active{transform:translateY(0) scale(.975);box-shadow:var(--shadow-soft);filter:saturate(1.05)}
.btn:focus-visible{outline:none;box-shadow:var(--ring-accent),var(--shadow-soft)}
.btn.accent{background:linear-gradient(180deg,var(--accent),var(--accent-d))}
.btn.accent:hover{filter:brightness(1.03)}
.btn.ghost{box-shadow:none;border-color:rgba(233,220,200,.9);transition:transform .16s var(--ease-soft), background .16s var(--ease-soft), border-color .16s var(--ease-soft)}
.btn.ghost:hover{background:#fbf5ec;border-color:rgba(224,164,88,.4);transform:translateY(-1px)}
.btn.ghost:active{transform:scale(.975)}
.btn.sm{border-radius:10px}

/* --- Inputs/Selects/Textarea: schoener gerundet, sanfter Fokus --- */
.f input,.f select,.f textarea,.login-pin{
  border-radius:13px;
  border-color:rgba(233,220,200,.95);
  transition:border-color .16s var(--ease-soft), box-shadow .16s var(--ease-soft), background .16s var(--ease-soft);
  -webkit-appearance:none;appearance:none;
}
.f input:hover,.f select:hover,.f textarea:hover{border-color:rgba(224,164,88,.45)}
.f input:focus,.f select:focus,.f textarea:focus,.login-pin:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:var(--ring-accent);
  background:#fff;
}
.f input::placeholder,.f textarea::placeholder{color:#b6a895}
/* Select-Pfeil warm */
.f select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23c75f45' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 13px center;
  padding-right:36px;
}
.f label{letter-spacing:.01em}

/* --- .seg: echtes Segmented-Control mit gleitendem Aktiv-Zustand --- */
.seg{
  position:relative;
  gap:0;
  padding:4px;
  border-radius:14px;
  background:linear-gradient(180deg,#efe3d1,#ead9c2);
  box-shadow:inset 0 1px 3px rgba(92,62,28,.08);
  -webkit-tap-highlight-color:transparent;
}
.seg button{
  position:relative;
  z-index:1;
  background:transparent!important;
  box-shadow:none!important;
  border-radius:10px;
  flex:1 1 auto;
  min-height:38px;
  transition:color .2s var(--ease-soft), transform .12s var(--ease-soft);
}
.seg button:active{transform:scale(.97)}
.seg button.on{
  color:var(--ink);
  background:linear-gradient(180deg,#fffefb,#fff7ec)!important;
  box-shadow:0 2px 6px rgba(92,62,28,.12), 0 0 0 1px rgba(224,164,88,.18)!important;
  border-radius:10px;
}
/* sanfte Skalierung beim Aktivieren imitiert "gleiten" */
@keyframes segPop{from{transform:scale(.94);opacity:.7}to{transform:scale(1);opacity:1}}
.seg button.on{animation:segPop .22s var(--ease-soft)}

/* --- Pills & Badges edler --- */
.pill,.tag{
  border-radius:var(--r-pill);
  background:linear-gradient(180deg,#f4ead8,#eddfca);
  box-shadow:inset 0 0 0 1px rgba(224,164,88,.14);
}
.navi .badge,.card .ch .badge{border-radius:var(--r-pill)}
.navi.on .badge{box-shadow:0 1px 3px rgba(0,0,0,.18)}

/* --- Checkbox: weicher, befriedigender Toggle --- */
.check{
  border-radius:8px;
  transition:transform .16s var(--ease-soft), background .16s var(--ease-soft), border-color .16s var(--ease-soft), box-shadow .16s var(--ease-soft);
}
.check:hover{border-color:var(--sage)}
.check:active{transform:scale(.9)}
.check.on{box-shadow:0 2px 8px rgba(91,138,114,.28);animation:segPop .2s var(--ease-soft)}

/* --- Listen-Rows: zarter Hover, kein Bruch der Trennlinien --- */
.row{
  border-radius:12px;
  transition:background .14s var(--ease-soft);
}
@media(hover:hover){
  .card .row:hover{background:rgba(247,240,228,.7)}
}

/* --- KPI-Veredelung --- */
.kpi{background:linear-gradient(180deg,var(--ink),#4a4138);-webkit-background-clip:text;background-clip:text}
.kpi small{-webkit-text-fill-color:var(--ink2)}

/* --- Mini-Bar mit warmem Verlauf --- */
.bar>i{background:linear-gradient(90deg,var(--sage),#76a98e);transition:width .5s var(--ease-soft)}

/* --- Section-Header Rhythmus --- */
.section-h{margin:6px 2px 18px}
.section-h .sub{letter-spacing:.005em}

/* --- Schoenere Leerzustaende --- */
.empty{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:34px 16px;
  background:radial-gradient(80% 100% at 50% 0%, rgba(224,164,88,.06), transparent 70%);
  border-radius:16px;
  line-height:1.5;
}
.empty::before{
  content:"\1F343";
  font-size:34px;line-height:1;
  opacity:.85;
  filter:saturate(.85);
  animation:emptyFloat 3.6s ease-in-out infinite;
}
@keyframes emptyFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
/* falls eigenes Icon/Emoji im Markup steckt, kein Doppel-Symbol erzwingen */
.empty:has(.ic)::before,.empty:has(img)::before{content:none}

/* --- Hint: waermerer Akzentstreifen links --- */
.hint{
  position:relative;
  border-radius:14px;
  padding-left:16px;
}
.hint::before{
  content:"";position:absolute;left:0;top:10px;bottom:10px;width:3px;
  border-radius:var(--r-pill);
  background:linear-gradient(180deg,var(--accent),var(--gold));
}

/* --- Avatare leicht plastischer --- */
.av,.chip-av,.login-av span{box-shadow:0 2px 6px rgba(92,62,28,.18), inset 0 1px 0 rgba(255,255,255,.22)}

/* --- Navi-Politur --- */
.navi{transition:background .15s var(--ease-soft), color .15s var(--ease-soft), transform .12s var(--ease-soft)}
.navi:active{transform:scale(.985)}
.navi.on{box-shadow:0 4px 14px rgba(43,38,32,.2)}

/* --- Modal: weicher Auftritt, edler Schatten --- */
.modal{box-shadow:0 -12px 44px rgba(43,38,32,.22)}
@media(min-width:760px){.modal{box-shadow:var(--shadow-lift)}}
.modal-wrap{animation:fadeIn .18s ease both}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* --- Toast: sanftes Einschweben --- */
.toast{
  border-radius:14px;
  box-shadow:0 10px 30px rgba(43,38,32,.25);
  animation:toastIn .26s var(--ease-soft) both;
}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* --- Bottom-Tab: aktiver Punkt + Touch-Feedback --- */
.tb{transition:color .15s var(--ease-soft), transform .12s var(--ease-soft);position:relative}
.tb:active{transform:scale(.92)}
.tb.on .ic{transform:translateY(-1px) scale(1.06)}
.tb.on::after{
  content:"";position:absolute;bottom:-3px;left:50%;transform:translateX(-50%);
  width:5px;height:5px;border-radius:50%;background:var(--accent);
}

/* --- Login waermer --- */
.login-card{box-shadow:var(--shadow-lift)}
.login-av span{transition:transform .18s var(--ease-soft), border-color .18s var(--ease-soft), box-shadow .18s var(--ease-soft)}
.login-av:active span{transform:scale(.95)}
.login-go{border-radius:14px}

/* --- Mobile: Touch-Targets >=44px, ohne Optik zu verbiegen --- */
@media(max-width:860px){
  .btn{min-height:44px;padding:11px 16px}
  .btn.sm{min-height:40px}
  .seg button{min-height:44px}
  .navi{padding:13px 14px;min-height:46px}
  .check{width:26px;height:26px}
  .f input,.f select,.f textarea{font-size:16px;padding:13px 14px} /* >=16px = kein iOS-Zoom */
  .tb{min-width:48px;min-height:44px;justify-content:center}
  .row{padding:14px 6px}
}

/* --- Sanfte globale Uebergaenge fuer interaktive Elemente --- */
a,button,.navi,.tb,.check,.pill{-webkit-tap-highlight-color:transparent}

/* --- Reduced Motion respektieren --- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}

/* ---- Einkauf: Schnell-Erfassung + Chips ---- */
.shop-quick{padding:14px}
.quick-row{display:flex;gap:8px;align-items:center}
.quick-in{flex:1;min-width:0;padding:12px 14px;border:1.5px solid #e7dccb;border-radius:14px;font:inherit;font-size:15px;background:#fffdf9;outline:none;transition:border-color .15s ease, box-shadow .15s ease}
.quick-in:focus{border-color:var(--accent,#c2703f);box-shadow:0 0 0 3px rgba(194,112,63,.12)}
.btn.icon{width:44px;height:44px;min-width:44px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:19px;border-radius:14px}
.quick-hint{font-size:12.5px;color:#8a7e6f;margin-top:9px;padding-left:2px}
.chip-pool{display:flex;flex-direction:column;gap:12px}
.chip-grp-t{font-size:13px;font-weight:600;color:#7a6f5f;margin:2px 2px 7px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{border:1.5px solid #ece1d0;background:#fffdf9;border-radius:999px;padding:8px 13px;font:inherit;font-size:13.5px;color:#4a4039;cursor:pointer;transition:transform .1s ease, background .12s ease, border-color .12s ease;min-height:38px}
.chip:hover{background:#fbf2e6;border-color:#e3c9a8}
.chip:active{transform:scale(.95)}

/* ============================================================
   SIEGER-THEME: Warm Atelier — Cozy Premium (Design-Panel 30.06.)
   + Grafts: Akzent-Disziplin, Print-Typo, Gradient-Hairlines, semantische Chart-Palette
   ============================================================ */
:root{
  /* ---- Flaechen & Papier ---- */
  --bg:#f4ebdd;
  --bg-tint:#efe4d2;
  --card:#fffdf8;
  --card-raised:#fffefb;
  --card-sunken:#f8f0e3;

  /* ---- Tinten ---- */
  --ink:#241f19;
  --ink2:#766a59;
  --ink3:#9c8f7c;
  --line:#ece0cc;
  --line-soft:#f1e8d8;
  --hair:rgba(36,31,25,.06);

  /* ---- Akzente (ruhig, kuratiert) ---- */
  --accent:#d96f54;
  --accent-deep:#c25c43;
  --accent-soft:#fbeae3;
  --accent-glow:rgba(217,111,84,.30);
  --sage:#5b8a72;
  --sage-soft:#e7f0e9;
  --gold:#d99c4e;
  --gold-soft:#f8ecd6;
  --berry:#9a5b7e;
  --sky:#5b7fa6;

  /* ---- Radien ---- */
  --r-xl:24px;
  --r-lg:20px;
  --r-md:14px;
  --r-sm:10px;
  --r-pill:999px;

  /* ---- Tiefe: gestapelte weiche Schatten + Innenkante ---- */
  --sh-1:0 1px 2px rgba(58,44,28,.05), 0 2px 8px rgba(58,44,28,.05);
  --sh-2:0 2px 4px rgba(58,44,28,.05), 0 8px 20px rgba(58,44,28,.07), 0 18px 40px rgba(58,44,28,.05);
  --sh-3:0 4px 10px rgba(58,44,28,.08), 0 16px 36px rgba(58,44,28,.10), 0 32px 64px rgba(58,44,28,.08);
  --sh-press:inset 0 2px 6px rgba(58,44,28,.10);
  --edge:inset 0 1px 0 rgba(255,255,255,.9), inset 0 0 0 1px rgba(255,255,255,.5);
  --edge-line:inset 0 0 0 1px var(--hair);
  --ring:0 0 0 4px var(--accent-glow);

  /* ---- Bewegung ---- */
  --ease:cubic-bezier(.2,.8,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
  --t-fast:.16s;
  --t:.26s;
  --t-slow:.44s;

  /* ---- Spacing-Scale (4er-Basis) ---- */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px;
  --s-6:24px; --s-8:32px; --s-10:40px; --s-12:48px;

  /* ---- Typo-Scale ---- */
  --fs-hero:clamp(28px,5vw,42px);
  --fs-h1:clamp(22px,3.4vw,30px);
  --fs-h2:20px;
  --fs-body:15px;
  --fs-sm:13px;
  --fs-xs:11.5px;
  --lh:1.55;
  --tracking-cap:.08em;
}
/* ============ GRUNDLAGE ============ */
body{
  background:
    radial-gradient(1200px 600px at 12% -8%, #fbf4e8 0%, rgba(251,244,232,0) 60%),
    radial-gradient(900px 500px at 105% 0%, #f6ecdb 0%, rgba(246,236,219,0) 55%),
    var(--bg);
  color:var(--ink);
  font-family:Inter,system-ui,sans-serif;
  font-size:var(--fs-body);
  line-height:var(--lh);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  letter-spacing:-.005em;
}
h1,h2,h3,.hero h1,.section-h{
  font-family:Fraunces,Georgia,serif;
  font-optical-sizing:auto;
  font-weight:600;
  letter-spacing:-.012em;
  color:var(--ink);
}
::selection{background:var(--accent-soft);color:var(--accent-deep);}

/* ============ KARTEN: taktil, mehrschichtige Tiefe ============ */
.card{
  position:relative;
  background:
    linear-gradient(180deg, var(--card-raised), var(--card));
  border:none;
  border-radius:var(--r-lg);
  box-shadow:var(--sh-2), var(--edge);
  padding:var(--s-5);
  transition:transform var(--t) var(--ease-out),
             box-shadow var(--t) var(--ease-out);
}
/* haarfeiner Lichtsaum oben + leichte Top-Highlight-Linie */
.card::before{
  content:"";
  position:absolute; inset:0;
  border-radius:inherit;
  background:linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,0) 38%);
  opacity:.7; pointer-events:none;
}
.card:hover{
  transform:translateY(-3px);
  box-shadow:var(--sh-3), var(--edge);
}
/* Klickbare Kacheln bekommen Akzent-Tab beim Hover */
.card.tile,.card[role="button"],a.card{cursor:pointer;}
.card.tile::after,a.card::after{
  content:"";
  position:absolute; left:var(--s-5); right:var(--s-5); bottom:0; height:3px;
  border-radius:3px;
  background:linear-gradient(90deg,var(--accent),var(--gold));
  transform:scaleX(0); transform-origin:left;
  opacity:0;
  transition:transform var(--t) var(--ease-out), opacity var(--t) var(--ease-out);
}
.card.tile:hover::after,a.card:hover::after{transform:scaleX(1);opacity:.9;}

.section-h{
  font-size:var(--fs-h2);
  display:flex; align-items:center; gap:var(--s-3);
  margin:var(--s-2) 0 var(--s-4);
}
.section-h::after{
  content:""; flex:1; height:1px;
  background:linear-gradient(90deg,var(--line),transparent);
}

/* ============ BUTTONS: weich, federnd ============ */
.btn{
  --bh:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:var(--s-2);
  min-height:44px; padding:0 var(--s-5);
  font:600 var(--fs-body)/1 Inter,sans-serif;
  letter-spacing:-.01em;
  color:var(--ink);
  background:linear-gradient(180deg,#fffefb,#f7efe2);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  box-shadow:var(--sh-1), inset 0 1px 0 rgba(255,255,255,.85);
  cursor:pointer;
  transition:transform var(--t-fast) var(--spring),
             box-shadow var(--t-fast) var(--ease),
             background var(--t-fast) var(--ease),
             filter var(--t-fast) var(--ease);
}
.btn:hover{transform:translateY(-1px);box-shadow:var(--sh-2), inset 0 1px 0 rgba(255,255,255,.9);}
.btn:active{transform:translateY(1px) scale(.98);box-shadow:var(--sh-press);}
.btn:focus-visible{outline:none;box-shadow:var(--ring), var(--sh-1);}

.btn.accent{
  color:#fff;
  background:linear-gradient(180deg,#e07a5f,var(--accent-deep));
  border:1px solid var(--accent-deep);
  box-shadow:0 1px 2px rgba(194,92,67,.3), 0 6px 16px rgba(194,92,67,.28),
             inset 0 1px 0 rgba(255,255,255,.35);
  text-shadow:0 1px 0 rgba(120,40,25,.25);
}
.btn.accent:hover{filter:brightness(1.04) saturate(1.05);transform:translateY(-1px);
  box-shadow:0 2px 4px rgba(194,92,67,.3), 0 12px 28px rgba(194,92,67,.34), inset 0 1px 0 rgba(255,255,255,.4);}
.btn.ghost{
  background:transparent; border:1px solid var(--line);
  box-shadow:none; color:var(--ink2);
}
.btn.ghost:hover{background:rgba(255,255,255,.6);color:var(--ink);border-color:var(--accent);}
.btn.sm{min-height:36px;padding:0 var(--s-3);font-size:var(--fs-sm);border-radius:var(--r-sm);}
.btn.icon{min-height:44px;width:44px;padding:0;border-radius:var(--r-md);}

/* ============ PILL / BADGE / CHIP ============ */
.pill,.badge,.chip{
  display:inline-flex;align-items:center;gap:6px;
  border-radius:var(--r-pill);
  font:600 var(--fs-xs)/1 Inter,sans-serif;
  letter-spacing:.01em;
  padding:6px 11px;
}
.pill{background:var(--card-sunken);color:var(--ink2);box-shadow:var(--edge-line);}
.badge{
  background:var(--accent-soft);color:var(--accent-deep);
  box-shadow:inset 0 0 0 1px rgba(217,111,84,.18);
  text-transform:uppercase;letter-spacing:var(--tracking-cap);font-size:10.5px;
}
.badge.sage{background:var(--sage-soft);color:var(--sage);box-shadow:inset 0 0 0 1px rgba(91,138,114,.2);}
.badge.gold{background:var(--gold-soft);color:#b07e34;box-shadow:inset 0 0 0 1px rgba(217,156,78,.25);}
.chip{
  background:#fff;color:var(--ink2);
  border:1px solid var(--line);min-height:34px;padding:0 13px;cursor:pointer;
  transition:all var(--t-fast) var(--ease);
}
.chip:hover{border-color:var(--accent);color:var(--ink);transform:translateY(-1px);box-shadow:var(--sh-1);}
.chip[aria-pressed="true"],.chip.active{
  background:var(--accent-soft);color:var(--accent-deep);border-color:transparent;
  box-shadow:inset 0 0 0 1px rgba(217,111,84,.25);
}

/* ============ SEGMENTED CONTROL ============ */
.seg{
  display:inline-flex;gap:3px;padding:4px;
  background:var(--card-sunken);
  border-radius:var(--r-md);
  box-shadow:var(--sh-press), inset 0 0 0 1px var(--hair);
}
.seg>*{
  min-height:38px;padding:0 var(--s-4);
  display:inline-flex;align-items:center;justify-content:center;
  font:600 var(--fs-sm)/1 Inter,sans-serif;color:var(--ink2);
  border-radius:var(--r-sm);cursor:pointer;border:none;background:transparent;
  transition:color var(--t-fast) var(--ease);
}
.seg>.active,.seg>[aria-selected="true"]{
  color:var(--ink);
  background:linear-gradient(180deg,#fff,#fbf5ec);
  box-shadow:var(--sh-1), inset 0 1px 0 rgba(255,255,255,.9);
}

/* ============ KPI / Kennzahlen ============ */
.kpi{
  display:flex;flex-direction:column;gap:var(--s-1);
  padding:var(--s-4);
  background:linear-gradient(180deg,var(--card-raised),var(--card));
  border-radius:var(--r-md);
  box-shadow:var(--sh-1), var(--edge);
}
.kpi .num,.kpi b,.kpi strong{
  font-family:Fraunces,serif;font-weight:600;font-size:clamp(24px,4vw,32px);
  line-height:1;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:-.02em;
}
.kpi .label,.kpi small{
  font-size:var(--fs-xs);color:var(--ink3);
  text-transform:uppercase;letter-spacing:var(--tracking-cap);font-weight:600;
}
.kpi .delta-up{color:var(--sage);} .kpi .delta-down{color:var(--accent-deep);}

/* ============ ROW / CHECK / HINT / EMPTY ============ */
.row{
  display:flex;align-items:center;gap:var(--s-3);
  padding:var(--s-3) var(--s-2);
  border-radius:var(--r-sm);
  transition:background var(--t-fast) var(--ease);
}
.row:hover{background:var(--card-sunken);}
.row+.row{border-top:1px solid var(--line-soft);}

.check{
  appearance:none;-webkit-appearance:none;
  width:24px;height:24px;flex:0 0 24px;border-radius:8px;cursor:pointer;
  background:#fff;border:1.5px solid var(--line);
  box-shadow:inset 0 1px 2px rgba(58,44,28,.05);
  display:inline-grid;place-content:center;
  transition:background var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease),transform var(--t-fast) var(--spring);
}
.check:hover{border-color:var(--accent);}
.check:checked{
  background:linear-gradient(180deg,#e07a5f,var(--accent-deep));border-color:var(--accent-deep);
  box-shadow:0 2px 8px var(--accent-glow);
}
.check:checked::after{content:"";width:6px;height:11px;margin-top:-2px;border:solid #fff;border-width:0 2.5px 2.5px 0;transform:rotate(45deg);}
.check:active{transform:scale(.9);}

.hint{font-size:var(--fs-sm);color:var(--ink3);line-height:1.5;}
.empty{
  text-align:center;padding:var(--s-10) var(--s-6);color:var(--ink3);
  background:
    radial-gradient(420px 160px at 50% 0%, rgba(217,111,84,.06), transparent 70%),
    var(--card-sunken);
  border-radius:var(--r-lg);
  box-shadow:var(--edge-line);
}
.empty .section-h,.empty h3{justify-content:center;color:var(--ink2);}

/* ============ FORMS ============ */
input,select,textarea{
  width:100%;min-height:44px;padding:0 var(--s-4);
  font:500 var(--fs-body)/1.4 Inter,sans-serif;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:var(--r-md);
  box-shadow:inset 0 1px 2px rgba(58,44,28,.04);
  transition:border-color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease);
}
textarea{padding-top:12px;min-height:96px;resize:vertical;line-height:1.55;}
input::placeholder,textarea::placeholder{color:var(--ink3);}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--accent);
  box-shadow:var(--ring), inset 0 1px 2px rgba(58,44,28,.04);
}
select{appearance:none;background-image:
  linear-gradient(45deg,transparent 50%,var(--ink2) 50%),
  linear-gradient(135deg,var(--ink2) 50%,transparent 50%);
  background-position:calc(100% - 18px) 19px,calc(100% - 13px) 19px;
  background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:36px;}

/* ============ TOPBAR ============ */
#topbar{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;gap:var(--s-4);
  padding:var(--s-3) var(--s-5);
  background:rgba(248,241,231,.78);
  backdrop-filter:saturate(1.4) blur(16px);-webkit-backdrop-filter:saturate(1.4) blur(16px);
  border-bottom:1px solid var(--hair);
  box-shadow:0 1px 0 rgba(255,255,255,.6);
}

/* ============ SIDEBAR ============ */
#sidebar{
  background:linear-gradient(180deg,#fbf4e8,#f3e8d6);
  border-right:1px solid var(--line);
  padding:var(--s-5) var(--s-3);
}
.navi{
  display:flex;align-items:center;gap:var(--s-3);
  min-height:44px;padding:0 var(--s-3);margin:2px 0;
  border-radius:var(--r-md);
  font:600 var(--fs-body)/1 Inter,sans-serif;color:var(--ink2);
  text-decoration:none;cursor:pointer;position:relative;
  transition:color var(--t-fast) var(--ease),background var(--t-fast) var(--ease);
}
.navi svg,.navi .ico{opacity:.7;transition:opacity var(--t-fast) var(--ease),transform var(--t-fast) var(--spring);}
.navi:hover{background:rgba(255,255,255,.55);color:var(--ink);}
.navi:hover svg,.navi:hover .ico{opacity:1;transform:scale(1.08);}
.navi.active{
  color:var(--accent-deep);
  background:linear-gradient(180deg,#fffdf8,#fdf3ea);
  box-shadow:var(--sh-1), inset 0 0 0 1px rgba(217,111,84,.12);
}
.navi.active::before{
  content:"";position:absolute;left:-var(--s-3);left:-2px;top:50%;transform:translateY(-50%);
  width:4px;height:20px;border-radius:4px;
  background:linear-gradient(180deg,var(--accent),var(--gold));
}
.navi.active svg,.navi.active .ico{opacity:1;color:var(--accent);}

/* ============ BOTTOM TABS (mobile) ============ */
.tb{
  position:fixed;bottom:0;left:0;right:0;z-index:50;
  display:flex;justify-content:space-around;align-items:stretch;
  padding:6px max(8px,env(safe-area-inset-left)) calc(6px + env(safe-area-inset-bottom));
  background:rgba(249,243,233,.88);
  backdrop-filter:saturate(1.5) blur(20px);-webkit-backdrop-filter:saturate(1.5) blur(20px);
  border-top:1px solid var(--hair);
  box-shadow:0 -8px 24px rgba(58,44,28,.06);
}
.tb a,.tb button{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  min-height:52px;border:none;background:transparent;cursor:pointer;
  font:600 10.5px/1 Inter,sans-serif;letter-spacing:.01em;color:var(--ink3);
  border-radius:var(--r-md);
  transition:color var(--t-fast) var(--ease);
}
.tb a svg,.tb button svg,.tb .ico{transition:transform var(--t) var(--spring);}
.tb a.active,.tb button.active{color:var(--accent-deep);}
.tb a.active .ico,.tb a.active svg{
  transform:translateY(-2px) scale(1.12);
  filter:drop-shadow(0 4px 8px var(--accent-glow));
}

/* ============ HERO ============ */
.hero{
  position:relative;overflow:hidden;
  padding:var(--s-8) var(--s-6);
  border-radius:var(--r-xl);
  background:
    radial-gradient(620px 300px at 88% -20%, rgba(217,156,78,.18), transparent 60%),
    radial-gradient(520px 320px at -5% 120%, rgba(91,138,114,.16), transparent 62%),
    linear-gradient(180deg,#fffdf8,#fbf3e7);
  box-shadow:var(--sh-2), var(--edge);
}
.hero h1{font-size:var(--fs-hero);margin:0 0 var(--s-2);}
.hero p{color:var(--ink2);max-width:54ch;}
.hero::after{ /* zarte Papier-Koernung */
  content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:multiply;opacity:.5;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.025'/></svg>");
}

/* ============ Reduced motion ============ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:.01ms!important;animation-duration:.01ms!important;}
}
/* ============ DIAGRAMME: edel statt generisch ============ */
/* Sparkline-Container */
.chart{
  position:relative;width:100%;
  border-radius:var(--r-md);
  padding:var(--s-4);
  background:linear-gradient(180deg,var(--card-raised),var(--card));
  box-shadow:var(--sh-1), var(--edge);
}
.chart svg{display:block;width:100%;height:auto;overflow:visible;}

/* Flaechen-Sparkline (SVG nutzt diese Klassen) */
.spark-fill{fill:url(#sparkGrad);}
.spark-line{
  fill:none;stroke:var(--accent);stroke-width:2.5;
  stroke-linecap:round;stroke-linejoin:round;
  filter:drop-shadow(0 4px 6px var(--accent-glow));
}
.spark-dot{fill:#fff;stroke:var(--accent);stroke-width:3;
  filter:drop-shadow(0 2px 4px var(--accent-glow));}
.spark-grid{stroke:var(--line-soft);stroke-width:1;stroke-dasharray:2 5;}
.spark-axis{fill:var(--ink3);font:600 10px Inter,sans-serif;letter-spacing:.02em;}

/* Animiertes Einzeichnen */
.spark-line.draw{stroke-dasharray:1000;stroke-dashoffset:1000;animation:draw 1.1s var(--ease-out) forwards;}
.spark-fill.rise{transform-origin:bottom;animation:riseFill .9s var(--ease-out) both;}
@keyframes draw{to{stroke-dashoffset:0;}}
@keyframes riseFill{from{opacity:0;transform:scaleY(.6);}to{opacity:1;transform:scaleY(1);}}

/* ---- Fortschrittsbalken (Haushalt/Training/Finanzen) ---- */
.bar{
  --val:60%;
  position:relative;height:12px;border-radius:var(--r-pill);
  background:var(--card-sunken);
  box-shadow:var(--sh-press), inset 0 0 0 1px var(--hair);
  overflow:hidden;
}
.bar::before{
  content:"";position:absolute;inset:0;width:var(--val);
  border-radius:inherit;
  background:linear-gradient(90deg,var(--accent),var(--gold));
  box-shadow:0 1px 4px var(--accent-glow);
  transition:width var(--t-slow) var(--ease-out);
}
.bar::after{ /* Glanzstreifen */
  content:"";position:absolute;inset:0;width:var(--val);border-radius:inherit;
  background:linear-gradient(180deg,rgba(255,255,255,.45),rgba(255,255,255,0) 55%);
}
.bar.sage::before{background:linear-gradient(90deg,var(--sage),#7fb295);}
.bar.gold::before{background:linear-gradient(90deg,var(--gold),#f0c074);}

/* ---- Ringe / Donut (Gesundheit/Baby) ---- */
.ring{
  --val:72; --size:108px; --stroke:11px;
  position:relative;width:var(--size);height:var(--size);
  border-radius:50%;
  display:grid;place-content:center;
  background:
    radial-gradient(closest-side,var(--card) calc(100% - var(--stroke) - 1px),transparent calc(100% - var(--stroke))),
    conic-gradient(var(--accent) calc(var(--val)*1%),var(--card-sunken) 0);
  box-shadow:var(--sh-1), inset 0 0 0 1px var(--hair);
}
.ring::before{ /* feiner Akzent-Endpunkt-Glow */
  content:"";position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(from 0deg, transparent calc(var(--val)*1% - 2%), var(--accent-glow) calc(var(--val)*1%), transparent calc(var(--val)*1% + 1%));
  filter:blur(3px);
}
.ring .ring-val{font-family:Fraunces,serif;font-weight:600;font-size:24px;color:var(--ink);font-variant-numeric:tabular-nums;}
.ring .ring-lbl{font-size:10px;color:var(--ink3);text-transform:uppercase;letter-spacing:var(--tracking-cap);font-weight:600;text-align:center;}
.ring.sage{--accent:var(--sage);} .ring.gold{--accent:var(--gold);} .ring.berry{--accent:var(--berry);}

/* ---- Mini-Balken-Reihe (Kalender-Woche/Ausgaben) ---- */
.bars{display:flex;align-items:flex-end;gap:6px;height:64px;padding-top:4px;}
.bars .b{
  flex:1;border-radius:6px 6px 3px 3px;
  background:linear-gradient(180deg,var(--accent),var(--accent-deep));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.3);
  transition:transform var(--t) var(--spring),filter var(--t) var(--ease);
  transform-origin:bottom;
}
.bars .b:hover{filter:brightness(1.06) saturate(1.05);transform:scaleY(1.04);}
.bars .b.muted{background:var(--card-sunken);box-shadow:inset 0 0 0 1px var(--hair);}
.bars .b.sage{background:linear-gradient(180deg,#7fb295,var(--sage));}

/* Legende */
.legend{display:flex;gap:var(--s-4);flex-wrap:wrap;font-size:var(--fs-xs);color:var(--ink2);}
.legend i{width:9px;height:9px;border-radius:3px;display:inline-block;margin-right:5px;vertical-align:middle;}
/* ============ MIKRO-INTERAKTIONEN ============ */
/* Karten beim Erscheinen sanft hochfedern (gestaffelt via inline --i) */
@keyframes cardIn{
  from{opacity:0;transform:translateY(14px) scale(.985);}
  to{opacity:1;transform:translateY(0) scale(1);}
}
.card.enter,.kpi.enter,.chart.enter{
  animation:cardIn .5s var(--ease-out) both;
  animation-delay:calc(var(--i,0)*60ms);
}

/* Druck-Feedback fuer alles Klickbare auf Touch */
.btn,.chip,.navi,.tb a,.card.tile,.check{ -webkit-tap-highlight-color:transparent; }
.card.tile:active{transform:translateY(-1px) scale(.992);transition:transform .1s var(--ease);}

/* Aktiver Tab-Wechsel: Icon "pop" */
@keyframes tabPop{0%{transform:translateY(0) scale(1);}45%{transform:translateY(-4px) scale(1.18);}100%{transform:translateY(-2px) scale(1.12);}}
.tb a.active .ico,.tb a.active svg{animation:tabPop .42s var(--spring);}

/* Badge/Notification "atmen" (z.B. Notfall, neue Pinnwand) */
@keyframes pulseGlow{0%,100%{box-shadow:0 0 0 0 var(--accent-glow);}50%{box-shadow:0 0 0 6px rgba(217,111,84,0);}}
.badge.live,.pill.live,.dot-live{animation:pulseGlow 2.2s var(--ease) infinite;}

/* Toggle/Check Haken zeichnet sich */
@keyframes pop{0%{transform:scale(.6);}60%{transform:scale(1.12);}100%{transform:scale(1);}}
.check:checked{animation:pop .28s var(--spring);}

/* Skeleton-Shimmer fuer ladende Kacheln */
@keyframes shimmer{from{background-position:-200% 0;}to{background-position:200% 0;}}
.skeleton{
  background:linear-gradient(100deg,var(--card-sunken) 30%,#fff 50%,var(--card-sunken) 70%);
  background-size:200% 100%;animation:shimmer 1.4s linear infinite;
  border-radius:var(--r-sm);color:transparent!important;
}

/* Fortschritt/Ring beim Sichtbarwerden hochzaehlen (Klasse animate setzt --val per JS) */
.bar.animate::before{transition:width .9s var(--ease-out);}
.ring.animate{transition:background .9s var(--ease-out);}

/* Sanftes Floaten des Hero-Lichts */
@keyframes heroDrift{0%,100%{transform:translate(0,0);}50%{transform:translate(14px,-10px);}}
.hero::before{will-change:transform;}

/* Hover-Lift respektiert Touch (kein sticky hover) */
@media (hover:hover){
  .card:hover{transform:translateY(-3px);}
}
@media (hover:none){
  .card:hover{transform:none;box-shadow:var(--sh-2), var(--edge);}
}