:root{
  --copper:#b5794a;
  --copper-light:#e8c9a0;
  --copper-dark:#8a5a34;
  --bg:#faf9f8;
  --bg-warm:#f7f5f3;
  --card:#ffffff;
  --dark:#2a2a2a;
  --dark-2:#343434;
  --text:#1a1a1a;
  --muted:#54595f;
  --muted-2:#8a8d91;
  --border:rgba(0,0,0,0.07);
  --border-strong:rgba(0,0,0,0.12);
  --green:#3f9b5c;
  --green-bg:#e9f4ed;
  --amber:#c98a1e;
  --amber-bg:#fbf1de;
  --blue:#3a6ea5;
  --blue-bg:#e8eff6;
  --red:#c0492f;
  --red-bg:#fae9e5;
  --radius:14px;
  --tabh:62px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  font-family:'Poppins',system-ui,-apple-system,sans-serif;
  background:#e7e4e1;
  color:var(--text);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
/* hidden muss die display-Regeln von .app/.login schlagen */
.app[hidden],.login[hidden]{display:none}

/* phone shell (only for desktop preview; on a real phone it fills the screen) */
.app{
  max-width:440px;margin:0 auto;min-height:100vh;
  background:var(--bg);position:relative;
  display:flex;flex-direction:column;
  box-shadow:0 0 60px rgba(0,0,0,0.12);
}

/* ---------- top bar ---------- */
.appbar{
  position:sticky;top:0;z-index:20;
  background:var(--dark);color:#fff;
  padding:calc(env(safe-area-inset-top) + 14px) 18px 14px;
}
.appbar__row{display:flex;align-items:center;gap:12px}
.brand{display:flex;align-items:center;gap:9px;font-weight:700;font-size:15px;letter-spacing:-0.01em}
.brand__mark{
  width:28px;height:28px;border:1.5px solid rgba(255,255,255,0.55);border-radius:6px;
  display:flex;align-items:center;justify-content:center;
}
.brand__mark svg{width:15px;height:15px}
.brand__logo{height:26px;width:auto;display:block}
.appbar__spacer{flex:1}
.refresh{
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,0.10);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.refresh:active{background:rgba(255,255,255,0.22)}
.refresh svg{width:19px;height:19px;stroke:#fff;fill:none;stroke-width:2}
.refresh.spin svg{animation:spin .7s ease}
@keyframes spin{to{transform:rotate(360deg)}}
.synced{
  margin-top:10px;font-size:11px;color:rgba(255,255,255,0.55);
  display:flex;align-items:center;gap:6px;letter-spacing:0.01em;
}
.synced .dot{width:6px;height:6px;border-radius:50%;background:var(--green)}

/* ---------- views ---------- */
.scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--tabh) + env(safe-area-inset-bottom) + 16px)}
.view{display:none;padding:18px 16px 0}
.view.active{display:block}
.view__title{font-size:13px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:14px}

/* ---------- period chips ---------- */
.chip:disabled{opacity:0.34;cursor:default}

/* ---------- hero year-over-year row ---------- */
.hero__vy{display:flex;align-items:center;gap:9px;margin-top:9px;font-size:12.5px;color:var(--muted);font-weight:500}
.hero__vy .yoy{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:600;color:var(--green);background:var(--green-bg);padding:3px 9px;border-radius:20px}
.hero__vy .yoy.down{color:var(--red);background:var(--red-bg)}
.hero__vy .yoy.flat{color:var(--muted);background:var(--bg-warm)}
.hero__vy .yoy svg{width:12px;height:12px}

/* ---------- agilist batch card ---------- */
.batch{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:14px}
.batch__head{display:flex;justify-content:space-between;align-items:baseline}
.batch__head .t{font-size:13.5px;font-weight:600}
.batch__head .d{font-size:11.5px;color:var(--muted-2);font-weight:500}
.batch__main{display:flex;align-items:baseline;gap:8px;margin-top:9px}
.batch__n{font-size:34px;font-weight:700;color:var(--copper-dark);letter-spacing:-0.02em;line-height:1}
.batch__of{font-size:14px;color:var(--muted);font-weight:500}
.batch__bar{position:relative;height:9px;border-radius:6px;background:var(--bg-warm);margin-top:13px;overflow:hidden}
.batch__seg{position:absolute;top:0;left:0;height:100%;border-radius:6px;width:0;transition:width .9s cubic-bezier(.32,.72,0,1)}
.batch__seg.pending{background:var(--copper-light);z-index:1}
.batch__seg.paid{background:linear-gradient(90deg,var(--copper),var(--copper-dark));z-index:2}
.batch__foot{font-size:12px;color:var(--muted);margin-top:10px}
.batch__foot .num{color:var(--text);font-weight:600}

/* ---------- hero revenue ---------- */
.hero{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 18px 6px;margin-bottom:14px;overflow:hidden;
}
.hero__label{font-size:12px;color:var(--muted);font-weight:500;letter-spacing:0.02em}
.hero__val{font-size:40px;font-weight:700;letter-spacing:-0.02em;line-height:1.05;margin-top:4px}
.hero__val small{font-size:22px;font-weight:600;color:var(--muted);margin-left:2px}
.hero__delta{
  display:inline-flex;align-items:center;gap:4px;margin-top:8px;
  font-size:12.5px;font-weight:600;color:var(--green);
  background:var(--green-bg);padding:3px 9px;border-radius:20px;
}
.hero__delta.down{color:var(--red);background:var(--red-bg)}
.hero__delta svg{width:13px;height:13px}
.chart{margin:14px -18px 0;height:96px}
.chart svg{width:100%;height:100%;display:block}
.ridge-line{fill:none;stroke:var(--copper);stroke-width:2.2;stroke-linejoin:round;stroke-linecap:round}
.ridge-fill{fill:url(#ridgeGrad)}
.ridge-vy{fill:none;stroke:var(--muted-2);stroke-width:1.6;stroke-dasharray:3 3;stroke-linejoin:round;stroke-linecap:round;opacity:0.75}
.hero__legend{display:flex;gap:16px;margin-top:11px;font-size:11px;color:var(--muted);font-weight:500}
.hero__legend span{display:inline-flex;align-items:center;gap:6px}
.hero__legend i{width:16px;height:0;display:inline-block;border-top:2.4px solid var(--copper)}
.hero__legend i.vy{border-top:1.6px dashed var(--muted-2)}
.chart__draw .ridge-line{stroke-dasharray:1200;stroke-dashoffset:1200;animation:draw 1.1s ease forwards}
@keyframes draw{to{stroke-dashoffset:0}}

/* ---------- kpi grid ---------- */
.kpis{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.kpi{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.kpi__label{font-size:11.5px;color:var(--muted);font-weight:500}
.kpi__val{font-size:23px;font-weight:700;letter-spacing:-0.01em;margin-top:5px}
.kpi__delta{font-size:11.5px;font-weight:600;color:var(--green);margin-top:3px}
.kpi__delta.down{color:var(--red)}

/* ---------- section block ---------- */
.block{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:6px 16px;margin-bottom:14px}
.block__head{font-size:13.5px;font-weight:600;padding:12px 0 4px}
.prow{display:flex;align-items:center;gap:12px;padding:11px 0;border-top:1px solid var(--border)}
.prow:first-of-type{border-top:none}
.prow__name{flex:1;font-size:14px;font-weight:500}
.prow__sub{font-size:11.5px;color:var(--muted);margin-top:1px;font-weight:400}
.prow__val{font-size:14px;font-weight:600;text-align:right}
.bar{height:5px;border-radius:4px;background:var(--bg-warm);margin-top:7px;overflow:hidden}
.bar__fill{height:100%;background:var(--copper);border-radius:4px}

/* status mini row */
.statline{display:flex;gap:8px;padding:14px 0 4px}
.stat-pill{flex:1;text-align:center;background:var(--bg-warm);border-radius:11px;padding:11px 4px}
.stat-pill__n{font-size:21px;font-weight:700}
.stat-pill__l{font-size:10.5px;color:var(--muted);font-weight:500;margin-top:2px;letter-spacing:0.01em}

/* ---------- orders ---------- */
.chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:14px;-webkit-overflow-scrolling:touch}
.chips::-webkit-scrollbar{display:none}
.chip{
  white-space:nowrap;padding:7px 14px;border-radius:20px;font-size:13px;font-weight:500;
  background:var(--bg-warm);border:1px solid var(--border);color:var(--muted);transition:all .15s;
}
.chip.on{background:var(--dark);color:#fff;border-color:var(--dark)}
.chip .c{font-weight:600;opacity:.7}
.chip.on .c{opacity:.85}

.order{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:14px;margin-bottom:10px;display:flex;gap:13px;align-items:flex-start;
  transition:transform .12s;width:100%;text-align:left;
}
.order:active{transform:scale(0.985)}
.order__avatar{
  width:42px;height:42px;border-radius:11px;background:var(--bg-warm);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-weight:600;font-size:15px;color:var(--copper-dark);
}
.order__body{flex:1;min-width:0}
.order__top{display:flex;align-items:baseline;gap:8px}
.order__name{font-size:14.5px;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.order__total{font-size:14.5px;font-weight:700}
.order__items{font-size:12.5px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.order__meta{display:flex;align-items:center;gap:8px;margin-top:8px}
.order__no{font-size:11.5px;color:var(--muted-2);font-weight:500}
.order__time{font-size:11.5px;color:var(--muted-2);margin-left:auto}
.badge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;letter-spacing:0.01em}
.badge.processing{color:var(--blue);background:var(--blue-bg)}
.badge.completed{color:var(--green);background:var(--green-bg)}
.badge.onhold{color:var(--amber);background:var(--amber-bg)}
.badge.failed{color:var(--red);background:var(--red-bg)}
.flag{font-size:11px;margin-left:1px}

/* ---------- detail sheet ---------- */
.sheet-bg{
  position:fixed;inset:0;background:rgba(20,18,16,0.45);z-index:40;
  opacity:0;pointer-events:none;transition:opacity .25s;
}
.sheet-bg.open{opacity:1;pointer-events:auto}
.sheet{
  position:fixed;left:50%;transform:translateX(-50%) translateY(100%);
  bottom:0;width:100%;max-width:440px;z-index:50;
  background:var(--bg);border-radius:20px 20px 0 0;
  max-height:88vh;display:flex;flex-direction:column;
  transition:transform .28s cubic-bezier(.32,.72,0,1);
}
.sheet.open{transform:translateX(-50%) translateY(0)}
.sheet__grab{width:38px;height:4px;border-radius:3px;background:var(--border-strong);margin:9px auto 4px}
.sheet__head{padding:8px 18px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}
.sheet__title{flex:1}
.sheet__title h3{font-size:17px;font-weight:700}
.sheet__title p{font-size:12.5px;color:var(--muted);margin-top:2px}
.sheet__close{width:32px;height:32px;border-radius:50%;background:var(--bg-warm);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--muted)}
.sheet__scroll{overflow-y:auto;padding:16px 18px calc(env(safe-area-inset-bottom) + 24px)}
.dl-label{font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted-2);margin:18px 0 8px}
.dl-label:first-child{margin-top:0}
.kv{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:4px 14px}
.kv__row{display:flex;justify-content:space-between;gap:14px;padding:10px 0;border-top:1px solid var(--border);font-size:13.5px}
.kv__row:first-child{border-top:none}
.kv__row .k{color:var(--muted)}
.kv__row .v{font-weight:500;text-align:right}
.addr{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;font-size:13.5px;line-height:1.55}
.li{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:4px 14px}
.li__row{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-top:1px solid var(--border)}
.li__row:first-child{border-top:none}
.li__name{font-size:13.5px;font-weight:500}
.li__qty{font-size:11.5px;color:var(--muted);margin-top:1px}
.li__price{font-size:13.5px;font-weight:600}
.li__sum{display:flex;justify-content:space-between;padding:13px 0 4px;border-top:1.5px solid var(--border-strong);font-size:15px;font-weight:700}

/* ---------- service cases ---------- */
.badge.open{color:var(--amber);background:var(--amber-bg)}
.badge.progress{color:var(--blue);background:var(--blue-bg)}
.badge.done{color:var(--green);background:var(--green-bg)}

.svc-row{width:100%;display:flex;align-items:center;gap:13px;padding:13px 0;border-top:1px solid var(--border);text-align:left}
.svc-row:first-of-type{border-top:none}
.svc-ic{width:40px;height:40px;border-radius:11px;background:var(--bg-warm);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--copper-dark)}
.svc-ic svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.9}
.svc-body{flex:1;min-width:0}
.svc-name{font-size:14.5px;font-weight:600}
.svc-sub{font-size:11.5px;color:var(--muted);margin-top:2px}
.svc-sub b{color:var(--text);font-weight:600}
.svc-count{display:flex;flex-direction:column;align-items:flex-end;line-height:1.05}
.svc-count b{font-size:22px;font-weight:700;color:var(--copper-dark)}
.svc-count span{font-size:9.5px;color:var(--muted);font-weight:500;margin-top:2px;text-transform:uppercase;letter-spacing:0.04em}
.svc-chev{font-size:24px;color:var(--muted-2);margin-left:2px;font-weight:300}

/* segmented control (case category) */
.seg2{display:flex;background:var(--bg-warm);border:1px solid var(--border);border-radius:11px;padding:3px;margin-bottom:14px}
.seg2 button{flex:1;padding:9px 0;font-size:13px;font-weight:500;color:var(--muted);border-radius:8px;transition:all .18s}
.seg2 button.on{background:#fff;color:var(--text);font-weight:600;box-shadow:0 1px 4px rgba(0,0,0,0.07)}

/* case cards */
.case{width:100%;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:10px;display:flex;gap:13px;align-items:flex-start;text-align:left;transition:transform .12s}
.case:active{transform:scale(0.985)}
.case__badge{width:40px;height:40px;border-radius:11px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.case__badge.repair{background:#f3ece4;color:var(--copper-dark)}
.case__badge.return{background:#e8eff6;color:var(--blue)}
.case__badge svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.9}
.case__body{flex:1;min-width:0}
.case__top{display:flex;align-items:center;gap:8px}
.case__name{font-size:14px;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.case__summary{font-size:12.5px;color:var(--muted);margin-top:3px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.case__meta{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:11.5px;color:var(--muted-2)}
.case__meta .time{margin-left:auto}
.ai-tag{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:var(--copper-dark);background:#f3ece4;padding:2px 7px;border-radius:20px;letter-spacing:0.02em}

/* status controls in sheet */
.statusctl{display:flex;gap:8px}
.statusctl button{flex:1;padding:10px 0;border-radius:10px;font-size:12.5px;font-weight:600;background:var(--bg-warm);border:1px solid var(--border);color:var(--muted);transition:all .15s}
.statusctl button.on{background:var(--dark);color:#fff;border-color:var(--dark)}
.draft-hint{display:flex;align-items:center;gap:9px;margin-top:18px;padding:12px 14px;background:#f3ece4;border-radius:12px;font-size:12.5px;color:var(--copper-dark);font-weight:500;line-height:1.4}
.draft-hint svg{width:17px;height:17px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.9}

/* ---------- tab bar ---------- */
.tabbar{
  position:fixed;left:50%;transform:translateX(-50%);bottom:0;
  width:100%;max-width:440px;z-index:30;
  background:rgba(255,255,255,0.92);backdrop-filter:saturate(180%) blur(14px);
  border-top:1px solid var(--border);
  display:flex;padding-bottom:env(safe-area-inset-bottom);
}
.tab{
  flex:1;padding:9px 0 8px;display:flex;flex-direction:column;align-items:center;gap:3px;
  color:var(--muted-2);font-size:10.5px;font-weight:500;position:relative;
}
.tab svg{width:23px;height:23px;stroke:currentColor;fill:none;stroke-width:1.8}
.tab.on{color:var(--copper-dark)}
.tab.soon{opacity:0.4}
.tab.soon .soon-tag{position:absolute;transform:translate(18px,-9px);font-size:8px;background:var(--copper);color:#fff;padding:1px 5px;border-radius:8px;font-weight:600}

/* ========== additions for the live app (not in prototype) ========== */

/* skeleton / loading */
.skeleton{position:relative;overflow:hidden;background:var(--bg-warm);border-radius:8px;color:transparent!important}
.skeleton::after{
  content:"";position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.6),transparent);
  animation:shimmer 1.3s infinite;
}
@keyframes shimmer{100%{transform:translateX(100%)}}
.sk-line{height:14px;border-radius:7px;background:var(--bg-warm);margin:8px 0}
.sk-block{height:120px;border-radius:var(--radius);background:var(--bg-warm)}

/* inline error (quiet, in the design's voice) */
.inline-error{
  background:var(--red-bg);color:var(--red);border:1px solid rgba(192,73,47,0.18);
  border-radius:var(--radius);padding:13px 15px;font-size:13px;line-height:1.45;
  margin-bottom:14px;display:flex;gap:10px;align-items:flex-start;
}
.inline-error button{
  margin-left:auto;flex-shrink:0;font-size:12px;font-weight:600;color:var(--red);
  background:#fff;border:1px solid rgba(192,73,47,0.25);border-radius:9px;padding:6px 11px;
}
.empty-note{text-align:center;color:var(--muted);padding:40px 0;font-size:14px}

/* ---------- login screen ---------- */
.login{
  position:fixed;inset:0;z-index:100;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:24px;text-align:center;
}
.login__mark{
  width:64px;height:64px;border:2px solid var(--copper);border-radius:16px;
  display:flex;align-items:center;justify-content:center;margin-bottom:22px;
}
.login__mark svg{width:34px;height:34px}
.login__logo{width:72%;max-width:260px;height:auto;margin-bottom:22px}
.login h1{font-size:20px;font-weight:700;letter-spacing:-0.01em}
.login p{font-size:13px;color:var(--muted);margin-top:6px;margin-bottom:24px}
.login form{width:100%;max-width:320px;display:flex;flex-direction:column;gap:12px}
.login input{
  font-family:inherit;font-size:16px;padding:14px 16px;border-radius:12px;
  border:1px solid var(--border-strong);background:var(--card);color:var(--text);width:100%;
}
.login input:focus{outline:none;border-color:var(--copper)}
.login button{
  font-size:15px;font-weight:600;padding:14px;border-radius:12px;
  background:var(--dark);color:#fff;transition:opacity .2s;
}
.login button:disabled{opacity:0.5}
.login__err{font-size:12.5px;color:var(--red);min-height:16px}
