:root{
  --bgA:#fbfffe;
  --bgB:#f7f6ff;

  --text:#1a1f1d;
  --muted:#64706b;

  --card: rgba(255,255,255,.74);
  --stroke: rgba(120,120,140,.14);
  --shadow: 0 18px 44px rgba(0, 25, 25, .10);
  --r: 22px;

  --accentA:#22c7a8;
  --accentB:#8bf0df;
  --grad: linear-gradient(135deg, var(--accentA), var(--accentB));
}

/* ELKE = Mint */
body.theme-elke{
  --accentA:#22c7a8;
  --accentB:#8bf0df;
  --stroke: rgba(34,199,168,.18);
  --grad: linear-gradient(135deg, var(--accentA), var(--accentB));
}

/* BRITTA = Altrosa */
body.theme-britta{
  --accentA:#d98aa2; /* altrosa */
  --accentB:#f2c0cc; /* hellrosa */
  --stroke: rgba(217,138,162,.18);
  --grad: linear-gradient(135deg, var(--accentA), var(--accentB));
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text","SF Pro Display", Segoe UI, Roboto, Arial;
  color: var(--text);
  background:
    radial-gradient(1100px 800px at 18% -10%, color-mix(in srgb, var(--accentA) 22%, transparent), transparent 55%),
    radial-gradient(900px 700px at 90% 6%,  color-mix(in srgb, var(--accentB) 22%, transparent), transparent 55%),
    linear-gradient(180deg, var(--bgA), var(--bgB));
  min-height: 100svh;
  padding: 18px 16px 28px;
}

.app{ max-width: 520px; margin: 0 auto; display:flex; flex-direction:column; gap: 14px; }
.top{ display:flex; justify-content:space-between; align-items:flex-start; gap:12px; padding-top: 6px; }

.brand{ display:flex; gap:10px; align-items:center; }
.logoDot{
  width:12px;height:12px;border-radius:999px;
  background: var(--grad);
  box-shadow: 0 14px 30px color-mix(in srgb, var(--accentA) 22%, transparent);
}
.title{ font-weight: 780; letter-spacing: .2px; font-size: 22px; line-height: 1.1; }
.subtitle{ color: var(--muted); font-size: 12.5px; margin-top: 2px; }
.carryHint{
  font-size: 12px;
  color: var(--muted);
  margin-top: 2px;
  font-weight: 600;
}
.seg{
  display:inline-flex;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.55);
  border-radius: 999px;
  padding: 4px;
  gap: 4px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.seg.full{ width:100%; justify-content:space-between; }
.segBtn{
  text-decoration:none;
  color: var(--text);
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 13px;
  letter-spacing:.2px;
}
.segBtn.active{
  background: var(--grad);
  color: #fff;
  box-shadow: 0 18px 38px color-mix(in srgb, var(--accentB) 18%, transparent);
}

.toast{
  border: 1px solid var(--stroke);
  background: rgba(255,255,255,.70);
  border-radius: 16px;
  padding: 10px 12px;
  color: var(--text);
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  font-size: 13px;
}

.card{
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  overflow:hidden;
}

.cardHead{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 14px 16px 10px;
  border-bottom: 1px solid color-mix(in srgb, var(--stroke) 75%, transparent);
  gap: 10px;
}
.cardTitle{ font-weight: 780; font-size: 15px; }
.hint{ color: var(--muted); font-size: 12px; }

.monthNav{ display:flex; align-items:center; gap: 8px; }
.monthLabel{ font-weight: 750; font-size: 13px; min-width: 110px; text-align:center; }

.iconBtn{
  appearance:none;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.55);
  border-radius: 14px;
  padding: 8px 10px;
  cursor:pointer;
  color: var(--text);
  font-weight: 800;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.iconBtn:active{ transform: scale(.99); }

.calendar{
  padding: 12px 12px 6px;
  display:grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;
}
.dow{ color: var(--muted); font-size: 11px; text-align:center; padding-bottom: 2px; }

.day{
  appearance:none;
  border: 1px solid color-mix(in srgb, var(--stroke) 75%, transparent);
  background: rgba(255,255,255,.52);
  border-radius: 16px;
  padding: 10px 0;
  cursor:pointer;
  position:relative;
  transition: transform .08s ease;
}
.day:active{ transform: scale(.99); }
.day.dim{ opacity:.45; }
.day.today{ box-shadow: 0 0 0 3px color-mix(in srgb, var(--accentB) 14%, transparent); }
.dayNum{ font-weight: 760; font-variant-numeric: tabular-nums; font-size: 13px; }

.day.mark{
  border-color: color-mix(in srgb, var(--accentB) 22%, var(--stroke));
  background:
    radial-gradient(120px 60px at 20% 0%, color-mix(in srgb, var(--accentA) 20%, transparent), transparent 55%),
    radial-gradient(120px 60px at 90% 10%, color-mix(in srgb, var(--accentB) 18%, transparent), transparent 55%),
    rgba(255,255,255,.62);
}

/* Marker-Leiste pro Typ */
.day.mark-work::after,
.day.mark-vac::after,
.day.mark-sick::after,
.day.mark-hol::after,
.day.mark-comp::after{
  content:"";
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom: 7px;
  width: 26px;
  height: 4px;
  border-radius: 999px;
  background: var(--grad);
  opacity: .9;
}
.day.mark-vac::after{ background: linear-gradient(135deg, #ffb35c, #ffd59a); }
.day.mark-sick::after{ background: linear-gradient(135deg, #ff5a8f, #ff4f4f); }
.day.mark-hol::after{ background: linear-gradient(135deg, #ffc342, #ffe08a); }
.day.mark-comp::after{ background: linear-gradient(135deg, #7aa7ff, #b6caff); } /* neutral */

.cardFoot{ padding: 10px 16px 14px; display:flex; flex-direction:column; gap: 10px; }

.btn{
  appearance:none;
  border:none;
  border-radius: 16px;
  padding: 12px 14px;
  font-weight: 800;
  font-size: 14px;
  cursor:pointer;
  transition: transform .08s ease;
}
.btn:active{ transform: scale(.99); }
.btn.full{ width:100%; }
.btn.primary{
  background: var(--grad);
  color:#fff;
  box-shadow: 0 18px 40px color-mix(in srgb, var(--accentB) 18%, transparent);
}

.legend{ display:flex; flex-wrap:wrap; gap: 8px; }
.chip{
  font-size: 12px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--stroke) 85%, transparent);
  background: rgba(255,255,255,.55);
  color: var(--text);
}
.chip.vac{ border-color: rgba(255,179,92,.35); }
.chip.sick{ border-color: rgba(255,92,92,.35); }
.chip.hol{ border-color: rgba(255,195,66,.35); }
.chip.comp{ border-color: rgba(122,167,255,.35); }

.stats{
  padding: 12px 16px 16px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.stat{
  border: 1px solid color-mix(in srgb, var(--stroke) 75%, transparent);
  background: rgba(255,255,255,.55);
  border-radius: 18px;
  padding: 12px 12px;
}
.stat.small{ grid-column: span 1; }
.k{ color: var(--muted); font-size: 12px; }
.v{ font-weight: 900; font-size: 18px; margin-top: 6px; font-variant-numeric: tabular-nums; }
.s{ color: var(--muted); font-size: 11.5px; margin-top: 2px; }

/* Modal */
.modal{ position:fixed; inset:0; display:none; align-items:flex-end; justify-content:center; z-index: 50; }
.modal.open{ display:flex; }
.backdrop{
  position:absolute; inset:0;
  background: rgba(12,12,18,.35);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.sheet{
  position:relative;
  width: min(520px, 100%);
  background: rgba(255,255,255,.80);
  border: 1px solid color-mix(in srgb, var(--stroke) 85%, transparent);
  border-radius: 26px 26px 0 0;
  box-shadow: 0 -20px 60px rgba(0, 25, 25, .22);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  padding-bottom: 12px;
  z-index: 2;
}
.sheetHead{
  display:flex; justify-content:space-between; align-items:center;
  padding: 14px 16px 10px;
  border-bottom: 1px solid color-mix(in srgb, var(--stroke) 75%, transparent);
}
.sheetTitle{ font-weight: 900; font-size: 16px; }
.sheetSub{ color: var(--muted); font-size: 12px; margin-top: 2px; }

.form{ padding: 14px 16px 8px; display:flex; flex-direction:column; gap: 10px; }
.lbl{ font-size: 12px; color: var(--muted); font-weight: 750; }
.in{
  width:100%;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--stroke) 85%, transparent);
  background: rgba(255,255,255,.58);
  padding: 12px 12px;
  outline:none;
  font-size: 14px;
}
.in:focus{ box-shadow: 0 0 0 4px color-mix(in srgb, var(--accentB) 14%, transparent); }
.ta{ resize:none; }

.two{ display:grid; grid-template-columns: 1fr 1fr; gap: 10px; }

.segRadio{ display:flex; align-items:center; justify-content:center; width:50%; border-radius: 999px; overflow:hidden; }
.segRadio input{ display:none; }
.segRadio span{
  width:100%; text-align:center;
  padding: 10px 12px;
  font-weight: 800;
  font-size: 13px;
  color: var(--text);
  border-radius: 999px;
}
.segRadio input:checked + span{ background: var(--grad); color:#fff; }

.typeRow{ display:flex; flex-wrap:wrap; gap: 8px; }
.typePill{
  display:inline-flex;
  border: 1px solid color-mix(in srgb, var(--stroke) 85%, transparent);
  background: rgba(255,255,255,.55);
  border-radius: 999px;
  padding: 8px 10px;
  font-size: 12.5px;
  font-weight: 800;
  color: var(--text);
  cursor:pointer;
}
.typePill input{ display:none; }
.typePill input:checked + span{
  background: var(--grad);
  color:#fff;
  padding: 6px 10px;
  border-radius: 999px;
}

.sheetHint{ padding: 6px 16px 10px; color: var(--muted); font-size: 12px; text-align:center; }
.footer{ text-align:center; color: var(--muted); font-size: 12px; padding-top: 6px; }
