/* CRYOPOINT Kalender — Design-Tokens, orientiert am „Cryopoint BI"-System
   Navy #002343 · Türkis #00b2ea · Status Grün/Amber/Rot · Off-White · Inter · weiche Schatten */
:root{
  --bg:#F4F5F7;            /* kühles Off-White Canvas */
  --surface:#FFFFFF;       /* Karten */
  --ink:#16212E;           /* Body-Text (navy-ink) */
  --navy:#002343;          /* Brand / Struktur / Headings */
  --ink2:#566270;          /* sekundär */
  --ink3:#8A929C;          /* gedämpft */
  --hair:rgba(0,35,67,.10);
  --hair2:rgba(0,35,67,.055);
  /* Geräte-Akzente (gedämpft, harmonisiert mit Navy/Türkis) */
  --eisbox:#0095C8; --redlight:#C2564A; --becken:#7A6BB0; --boa:#2F97A2; --sauna:#5566B5; --arm:#7C848E;
  /* Status (BI-Semantik) */
  --green:#1EA672; --amber:#E0A800; --red:#E23D4B;
  --accent:#00B2EA;        /* Türkis-Brand-Akzent (Ghost, aktiv, Buchung) */
  --now:#002343;           /* Jetzt-Marker = Navy (strukturell, kein Warn-Rot) */
  --shadow:0 1px 2px rgba(0,35,67,.04),0 4px 12px rgba(0,35,67,.05);
  --radius:12px;
  --font:'Inter',-apple-system,system-ui,"Segoe UI","Helvetica Neue",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}

/* ——— Frosted App-Header ——— */
.appbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  padding:13px 22px;background:rgba(244,245,247,.75);backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--hair)}
.appbar .brand{font-weight:700;font-size:15px;letter-spacing:-.01em;color:var(--navy)}
.appbar .brand small{display:block;font-weight:500;font-size:11px;color:var(--ink2);letter-spacing:.01em}
.appbar .date{font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--navy)}
.appbar .date span{color:var(--ink2);font-weight:500}
.seg{display:inline-flex;background:var(--surface);border:1px solid var(--hair);border-radius:10px;padding:2px}
.seg button{border:0;background:transparent;font:inherit;font-size:12.5px;font-weight:500;color:var(--ink2);
  padding:5px 12px;border-radius:8px;cursor:pointer}
.seg button.on{background:var(--navy);color:#fff;font-weight:600}

/* ——— Schraffuren (Puffer / geblockt) ——— */
.hatch{background-image:repeating-linear-gradient(135deg,transparent 0,transparent 5px,rgba(0,35,67,.05) 5px,rgba(0,35,67,.05) 6.5px)}
.hatch-block{background-image:repeating-linear-gradient(135deg,transparent 0,transparent 4px,rgba(0,35,67,.08) 4px,rgba(0,35,67,.08) 6px)}

/* ——— Termin-Karte (Concept-Mockups) ——— */
.appt{position:absolute;left:7px;right:7px;border-radius:10px;background:var(--surface);
  box-shadow:var(--shadow);padding:7px 10px;border-left:3px solid var(--dev,#ccc);overflow:hidden}
.appt .nm{font-weight:600;font-size:12.5px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--navy)}
.appt .mt{font-size:10.5px;color:var(--ink2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appt.past{opacity:.5}
.appt.run{border-left-color:var(--green)}
.appt.due{border-left-color:var(--amber);box-shadow:0 2px 10px rgba(224,168,0,.22),var(--shadow);animation:pulse 2.8s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 1px 6px rgba(224,168,0,.16),var(--shadow)}50%{box-shadow:0 3px 14px rgba(224,168,0,.34),var(--shadow)}}
.pill{display:inline-block;font-size:9.5px;font-weight:700;padding:1px 7px;border-radius:999px;color:#fff;vertical-align:middle;margin-left:6px}
.pill.due{background:var(--amber)} .pill.run{background:var(--green)}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;vertical-align:middle}

/* ——— Jetzt-Linie ——— */
.now{position:absolute;left:0;right:0;height:0;border-top:2px solid var(--now);z-index:8}
.now::after{content:'';position:absolute;left:-3px;top:-4px;width:7px;height:7px;border-radius:50%;background:var(--now)}

/* ——— Legende ——— */
.legend{display:flex;flex-wrap:wrap;gap:16px;padding:14px 22px 26px;font-size:11.5px;color:var(--ink2)}
.legend b{color:var(--navy);font-weight:600}
.legend .it{display:flex;align-items:center;gap:6px}
.swatch{width:14px;height:14px;border-radius:4px;display:inline-block}
