/* =========================================================================
   ServiceHub — Dashboard-Redesign (Handoff-Paket "Servicehub.zip", Richtung A+B)
   Visuell 1:1 aus sh/theme.css (Tokens) + sh/app.css (.hero/.kpi/.cols/.agenda).
   ──────────────────────────────────────────────────────────────────────────
   WICHTIG — Scoping: ALLE Tokens und Komponentenklassen sind unter dem
   Wrapper `.sh-redesign` gekapselt. Die Tokens werden NICHT global auf :root
   gesetzt (das würde mit ui-components.css / internal-modern.css / sh-odoo-theme
   kollidieren und jede andere Ansicht umfärben). Der Wrapper lebt nur im
   gerenderten Dashboard-DOM → beim Verlassen der Ansicht verschwindet das
   komplette Styling automatisch (mainContent.innerHTML wird ersetzt).
   Light + Dark über [data-theme] (am <html>), exakt wie im Vorlagen-Paket.
   ========================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Figtree:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

/* ---------- Tokens (Light) — 1:1 aus theme.css :root, gescoped ---------- */
.sh-redesign{
  --accent:#E73D25; --accent-700:#C5331E; --accent-600:#D6371F;
  --accent-soft:#FCEDE7; --accent-line:rgba(231,61,37,.22);
  --honey:#D99A2B; --honey-soft:#FBF0DA;
  --ok:#16A34A; --ok-soft:#E9F8EF;
  --warn:#C7791A; --warn-soft:#FBF1E0; --warn-line:rgba(199,121,26,.32);
  --info:#2F6BD6; --info-soft:#EAF1FC;
  --violet:#7C5BD6; --violet-soft:#F0ECFB;

  --bg:#FAF6F2; --surface:#FFFFFF; --surf-2:#F6F1EB; --surf-3:#EFE8E0;
  --ink:#231C17; --text:#463D35; --text-2:#6B6157; --muted:#9A8F84;
  --border:#EEE5DC; --border-2:#E3D9CE; --field:#F6F1EB;

  --font-head:'Space Grotesk','Figtree',system-ui,sans-serif;
  --font-body:'Figtree',system-ui,sans-serif;
  --font-mono:'Space Mono',ui-monospace,monospace;

  --r-xs:7px; --r-sm:9px; --r-md:12px; --r-lg:16px; --r-xl:20px; --r-pill:999px;

  --sh-sm:0 1px 2px rgba(120,80,50,.06);
  --sh-md:0 6px 20px rgba(120,80,50,.07),0 1px 2px rgba(120,80,50,.05);
  --sh-lg:0 18px 44px rgba(120,80,50,.14);
  --sh-pop:0 12px 32px rgba(60,40,25,.18);
  --sh-accent:0 5px 14px rgba(231,61,37,.28);

  --ring:0 0 0 3px var(--accent-soft);
  --tr:.16s cubic-bezier(.2,.7,.3,1);

  font-family:var(--font-body);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
}

/* ---------- Tokens (Dark) — 1:1 aus theme.css [data-theme="dark"] ---------- */
[data-theme="dark"] .sh-redesign{
  --accent:#F2543B; --accent-700:#E0432B; --accent-600:#EC4A30;
  --accent-soft:rgba(242,84,59,.16); --accent-line:rgba(242,84,59,.30);
  --honey:#E6AE4A; --honey-soft:rgba(230,174,74,.16);
  --ok:#3Bc07a; --ok-soft:rgba(59,192,122,.15);
  --warn:#E5A33C; --warn-soft:rgba(229,163,60,.15); --warn-line:rgba(229,163,60,.36);
  --info:#5C8FE8; --info-soft:rgba(92,143,232,.16);
  --violet:#9D82E6; --violet-soft:rgba(157,130,230,.16);

  --bg:#15120F; --surface:#1E1A16; --surf-2:#241F1A; --surf-3:#2C2620;
  --ink:#F6F1EC; --text:#E2D8CE; --text-2:#B3A99E; --muted:#8C8175;
  --border:#2E2822; --border-2:#3A332B; --field:#241F1A;

  --sh-sm:0 1px 2px rgba(0,0,0,.4);
  --sh-md:0 6px 20px rgba(0,0,0,.35),0 1px 2px rgba(0,0,0,.4);
  --sh-lg:0 18px 44px rgba(0,0,0,.5);
  --sh-pop:0 12px 32px rgba(0,0,0,.55);
  --ring:0 0 0 3px var(--accent-soft);
}

/* ---------- base resets (nur innerhalb des Wrappers) ---------- */
.sh-redesign *{box-sizing:border-box}
.sh-redesign h1,.sh-redesign h2,.sh-redesign h3,.sh-redesign p{margin:0}
.sh-redesign svg{display:block}
.sh-redesign .heading{font-family:var(--font-head);color:var(--ink);letter-spacing:-.02em}
.sh-redesign .mono{font-family:var(--font-mono)}
.sh-redesign .muted{color:var(--muted)}

/* ---------- cards (theme.css) ---------- */
.sh-redesign .card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-md);overflow:hidden}
.sh-redesign .card-h{display:flex;align-items:center;gap:10px;padding:16px 18px 13px}
.sh-redesign .card-h h2{font-family:var(--font-head);font-size:15px;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:9px}
.sh-redesign .card-h .tick{width:9px;height:9px;border-radius:3px;background:var(--accent)}
.sh-redesign .card-h .lk{margin-left:auto;font-size:12.5px;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:4px;cursor:pointer}
.sh-redesign .card-h .lk svg{width:13px;height:13px}

/* ---------- badges (theme.css) ---------- */
.sh-redesign .badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--r-pill);font-size:11.5px;font-weight:600;white-space:nowrap}
.sh-redesign .badge i{width:6px;height:6px;border-radius:50%}
.sh-redesign .b-neutral{background:var(--surf-2);color:var(--text-2)} .sh-redesign .b-neutral i{background:var(--muted)}
.sh-redesign .b-info{background:var(--info-soft);color:var(--info)} .sh-redesign .b-info i{background:var(--info)}
.sh-redesign .b-ok{background:var(--ok-soft);color:var(--ok)} .sh-redesign .b-ok i{background:var(--ok)}
.sh-redesign .b-warn{background:var(--warn-soft);color:var(--warn)} .sh-redesign .b-warn i{background:var(--warn)}
.sh-redesign .b-violet{background:var(--violet-soft);color:var(--violet)} .sh-redesign .b-violet i{background:var(--violet)}
.sh-redesign .b-accent{background:var(--accent-soft);color:var(--accent)} .sh-redesign .b-accent i{background:var(--accent)}

/* ---------- chips (theme.css) ---------- */
.sh-redesign .chip{padding:7px 14px;border-radius:var(--r-pill);border:1px solid var(--border-2);background:var(--surface);font-size:12.5px;font-weight:600;color:var(--text-2);cursor:pointer;transition:var(--tr)}
.sh-redesign .chip:hover{border-color:var(--border-2);background:var(--surf-2);color:var(--ink)}
.sh-redesign .chip.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}

/* ---------- avatars (theme.css) ---------- */
.sh-redesign .avatar{border-radius:50%;background:linear-gradient(145deg,#7A6A5C,#4A4038);color:#fff;font-weight:600;display:inline-flex;align-items:center;justify-content:center;flex:none}
.sh-redesign .avatar.no{background:transparent;color:var(--muted);border:1px dashed var(--border-2)}
.sh-redesign .av-28{width:28px;height:28px;font-size:11px}
.sh-redesign .av-32{width:32px;height:32px;font-size:12px}

/* ---------- tables (theme.css) ---------- */
.sh-redesign .tbl{width:100%;border-collapse:collapse}
.sh-redesign .tbl thead th{font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);text-align:left;padding:11px 18px;border-bottom:1px solid var(--border)}
.sh-redesign .tbl tbody td{padding:0 18px;height:54px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle;color:var(--text)}
.sh-redesign .tbl tbody tr{transition:background .12s}
.sh-redesign .tbl tbody tr:hover{background:var(--surf-2)}
.sh-redesign .tbl tbody tr:last-child td{border-bottom:none}
.sh-redesign .tbl .strong{font-weight:600;color:var(--ink)}
.sh-redesign .prio{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:12.5px;color:var(--text)}
.sh-redesign .prio i{width:8px;height:8px;border-radius:50%}

/* ---------- crumb (app.css) ---------- */
.sh-redesign .crumb{font-size:12px;color:var(--muted);font-weight:500;margin-bottom:14px}
.sh-redesign .crumb b{color:var(--text-2)}

/* ---------- hero (app.css) ---------- */
.sh-redesign .hero{position:relative;overflow:hidden;border-radius:var(--r-lg);border:1px solid var(--border);padding:24px 26px;margin-bottom:18px;display:flex;align-items:center;gap:24px;background:linear-gradient(120deg,#FFF4EE,#FCE7DC 55%,#FBE9D8)}
[data-theme="dark"] .sh-redesign .hero{background:linear-gradient(120deg,#2A211B,#2E211C 55%,#2B2018)}
.sh-redesign .hero::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(199,80,50,.10) 1.1px,transparent 1.2px);background-size:15px 15px;opacity:.6;pointer-events:none}
.sh-redesign .hero-l{position:relative;z-index:1}
.sh-redesign .hero .ey{font-family:var(--font-head);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-700);margin-bottom:6px}
.sh-redesign .hero h1{font-family:var(--font-head);font-size:27px;font-weight:700;letter-spacing:-.025em;color:var(--ink)}
.sh-redesign .fchips{display:flex;gap:8px;flex-wrap:wrap;margin-top:15px}
.sh-redesign .fchip{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:var(--r-pill);font-size:12.5px;font-weight:600;background:color-mix(in srgb,var(--surface) 70%,transparent);color:var(--text);border:1px solid var(--accent-line)}
.sh-redesign .fchip svg{width:14px;height:14px}
.sh-redesign .fchip .pp{width:7px;height:7px;border-radius:50%}
.sh-redesign .hero-r{position:relative;z-index:1;margin-left:auto}
.sh-redesign .ring{position:relative;width:96px;height:96px}
.sh-redesign .ring svg{transform:rotate(-90deg)}
.sh-redesign .ring .rc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.sh-redesign .ring .rc b{font-family:var(--font-head);font-size:22px;color:var(--ink);line-height:1}
.sh-redesign .ring .rc small{font-size:10.5px;color:var(--muted);font-weight:600;margin-top:2px}

/* ---------- KPIs (app.css) ---------- */
.sh-redesign .kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.sh-redesign .kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 17px;box-shadow:var(--sh-md);position:relative;overflow:hidden;cursor:pointer;transition:var(--tr)}
.sh-redesign .kpi:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.sh-redesign .kpi .kt{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.sh-redesign .kpi .ki{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center}
.sh-redesign .kpi .ki svg{width:18px;height:18px}
.sh-redesign .kpi .num{font-family:var(--font-head);font-size:30px;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.03em}
.sh-redesign .kpi .lb{font-size:12.5px;color:var(--text);font-weight:600;margin-top:7px}
.sh-redesign .kpi .kfoot{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;margin-top:14px}
.sh-redesign .kpi .sub2{font-size:11.5px;color:var(--muted);font-weight:600;line-height:1.35;max-width:120px}
.sh-redesign .kpi .mini{width:76px;height:30px;flex:none}
.sh-redesign .kpi .mini svg{width:100%;height:100%}
.sh-redesign .kpi.amber .ki{background:var(--warn-soft);color:var(--warn)}
.sh-redesign .kpi.info .ki{background:var(--info-soft);color:var(--info)}
.sh-redesign .kpi.honey .ki{background:var(--honey-soft);color:var(--honey)}
.sh-redesign .kpi.hot{background:linear-gradient(140deg,#F1543C,#CE3620);border-color:transparent;color:#fff}
.sh-redesign .kpi.hot .ki{background:rgba(255,255,255,.18);color:#fff}
.sh-redesign .kpi.hot .num,.sh-redesign .kpi.hot .lb{color:#fff}
.sh-redesign .kpi.hot .sub2{color:rgba(255,255,255,.88)}
.sh-redesign .kpi.hot .tag{position:absolute;top:16px;left:78px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:rgba(255,255,255,.2);padding:3px 8px;border-radius:var(--r-pill)}

/* ---------- columns: agenda + team (app.css) ---------- */
.sh-redesign .cols{display:grid;grid-template-columns:1.15fr 1fr;gap:18px;margin-bottom:18px}
.sh-redesign .agenda{padding:4px 18px 16px}
.sh-redesign .ag{display:flex;gap:14px;padding:13px 0;border-top:1px solid var(--border)}
.sh-redesign .ag:first-child{border-top:none}
.sh-redesign .ag-t{font-family:var(--font-mono);font-size:12.5px;font-weight:700;color:var(--ink);width:50px;flex:none}
.sh-redesign .ag-bar{width:3px;border-radius:3px;flex:none}
.sh-redesign .ag-b{min-width:0}
.sh-redesign .ag-b b{font-size:13.5px;font-weight:600;color:var(--ink);display:block}
.sh-redesign .ag-b span{font-size:12px;color:var(--muted)}
.sh-redesign .ag-st{margin-left:auto;align-self:center}
.sh-redesign .work{padding:8px 20px 20px}
.sh-redesign .wbars{display:flex;align-items:flex-end;gap:14px;height:120px;padding-top:10px}
.sh-redesign .wb{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}
.sh-redesign .wb .bar{width:100%;max-width:34px;border-radius:8px 8px 4px 4px;background:linear-gradient(180deg,#F4654E,var(--accent));min-height:6px}
.sh-redesign .wb .bar.soft{background:linear-gradient(180deg,var(--surf-3),var(--border-2))}
.sh-redesign .wb .vb{font-family:var(--font-mono);font-size:11px;color:var(--muted);font-weight:700}
.sh-redesign .wb .db{font-size:11.5px;color:var(--muted);font-weight:600}

/* ---------- empty + loading ---------- */
.sh-redesign .sh-dash-empty{padding:22px 18px;text-align:center;color:var(--muted);font-size:13px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px}
.sh-redesign .sh-dash-empty .lk{font-size:12.5px;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:4px;cursor:pointer;text-decoration:none}
.sh-redesign .sh-dash-empty .lk svg{width:13px;height:13px}
.sh-redesign .sh-dash-loading{padding:40px 18px;text-align:center;color:var(--muted);font-size:13px}

/* ---------- responsive (app.css) ---------- */
@media(max-width:1180px){
  .sh-redesign .kpis{grid-template-columns:repeat(2,1fr)}
  .sh-redesign .cols{grid-template-columns:1fr}
}
@media(max-width:640px){
  .sh-redesign .kpis{grid-template-columns:1fr}
  .sh-redesign .hero{flex-direction:column;align-items:flex-start}
  .sh-redesign .hero-r{margin-left:0}
}
