/* ================================================================
   Trainingsplan — Designsystem (eigenständig)
   Stimmung: luftig & warm, Teal-Primär + Koralle-Akzent, viel Weißraum.
   Mobil-first.
   ================================================================ */
:root{
  --bg:#f6f4ef;            /* warmes Off-White */
  --surface:#ffffff;
  --surface-2:#fbfaf6;
  --ink:#1c2422;          /* fast-schwarz, leicht grün */
  --ink-soft:#5c655f;
  --muted:#919a92;
  --line:#e7e3d8;
  --teal:#0f766e;         /* Primär */
  --teal-700:#0b5c55;
  --teal-50:#e6f3f1;
  --coral:#f4795b;        /* Akzent / Energie */
  --coral-50:#fdede8;
  --gold:#e0b341; --silver:#b8bcc4; --bronze:#c8895a;
  --ok:#2f9e6f; --warn:#e0902f; --bad:#d9534f;
  --r:16px; --r-sm:11px; --r-lg:24px;
  --sh:0 1px 2px rgba(28,36,34,.04), 0 8px 24px rgba(28,36,34,.06);
  --sh-lg:0 12px 40px rgba(15,118,110,.14);
  --fs:15px;
  --ff:'Inter','Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--ff);font-size:var(--fs);line-height:1.55;
  color:var(--ink);background:var(--bg);
  background-image:radial-gradient(1200px 400px at 100% -10%,var(--teal-50),transparent 60%);
  background-attachment:fixed;
}
a{color:var(--teal);text-decoration:none}
a:hover{color:var(--teal-700)}
h1,h2,h3{line-height:1.2;letter-spacing:-.01em;margin:.2em 0 .4em}
h1{font-size:1.7rem;font-weight:800}
h2{font-size:1.25rem;font-weight:700}
h3{font-size:1.02rem;font-weight:700}
small,.muted{color:var(--muted)}
.ink-soft{color:var(--ink-soft)}

/* ---------- Layout ---------- */
.shell{max-width:1080px;margin:0 auto;padding:0 16px 96px}
.shell-narrow{max-width:680px}
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.row.between{justify-content:space-between}
.grid{display:grid;gap:14px}
.grid-2{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-auto{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.spacer{flex:1}
.stack>*+*{margin-top:12px}

/* ---------- Topbar ---------- */
.topbar{
  position:sticky;top:0;z-index:40;backdrop-filter:saturate(1.4) blur(10px);
  background:rgba(246,244,239,.82);border-bottom:1px solid var(--line);
}
.topbar .inner{max-width:1080px;margin:0 auto;display:flex;align-items:center;gap:14px;padding:12px 16px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.brand .dot{width:26px;height:26px;border-radius:9px;background:linear-gradient(135deg,var(--teal),var(--coral));
  display:grid;place-items:center;color:#fff;font-size:14px;box-shadow:var(--sh)}
.nav{display:flex;gap:4px;margin-left:8px}
.nav a{padding:8px 12px;border-radius:10px;color:var(--ink-soft);font-weight:600;font-size:.92rem}
.nav a:hover{background:var(--surface)}
.nav a.active{background:var(--teal);color:#fff}
.burger{display:none;margin-left:auto;background:var(--surface);border:1px solid var(--line);
  border-radius:10px;width:42px;height:42px;cursor:pointer;font-size:18px}

/* ---------- Cards ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--sh);padding:18px}
.card.pad-lg{padding:24px}
.card.flat{box-shadow:none}
.card.tint{background:linear-gradient(135deg,var(--teal-50),var(--surface))}
.card-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.card:has(table){overflow-x:auto}

/* ---------- Hero ---------- */
.hero{background:linear-gradient(135deg,var(--teal),var(--teal-700));color:#fff;border-radius:var(--r-lg);
  padding:30px 26px;box-shadow:var(--sh-lg);position:relative;overflow:hidden}
.hero:after{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(244,121,91,.55),transparent 70%)}
.hero h1{color:#fff;margin:0}
.hero p{color:rgba(255,255,255,.85);margin:.3em 0 0}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;cursor:pointer;
  border:1px solid transparent;border-radius:12px;padding:11px 16px;font-weight:700;font-size:.94rem;
  font-family:inherit;background:var(--surface);color:var(--ink);box-shadow:var(--sh);transition:.12s;
  text-decoration:none}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-700);color:#fff}
.btn-accent{background:var(--coral);color:#fff}
.btn-ghost{background:transparent;box-shadow:none;border-color:var(--line);color:var(--ink-soft)}
.btn-ghost:hover{background:var(--surface)}
.btn-sm{padding:7px 11px;font-size:.85rem;border-radius:10px}
.btn-block{width:100%}
.btn-danger{background:#fff;color:var(--bad);border-color:#f0cfce}

/* ---------- Forms ---------- */
label{display:block;font-weight:600;font-size:.85rem;color:var(--ink-soft);margin:0 0 5px}
input,select,textarea{
  width:100%;font-family:inherit;font-size:1rem;color:var(--ink);background:var(--surface-2);
  border:1px solid var(--line);border-radius:11px;padding:11px 12px;transition:.12s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal);
  box-shadow:0 0 0 3px var(--teal-50);background:#fff}
textarea{min-height:90px;resize:vertical}
.field{margin-bottom:14px}
.inline-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}
.checkbox{display:flex;align-items:center;gap:8px}
.checkbox input{width:auto}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip-check{position:relative}
.chip-check input{position:absolute;opacity:0}
.chip-check span{display:inline-block;padding:7px 12px;border:1px solid var(--line);border-radius:999px;
  background:var(--surface-2);font-size:.85rem;cursor:pointer;color:var(--ink-soft)}
.chip-check input:checked + span{background:var(--teal);color:#fff;border-color:var(--teal)}

/* ---------- Badges / Pills ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;
  font-size:.74rem;font-weight:700;letter-spacing:.02em}
.badge-teal{background:var(--teal-50);color:var(--teal-700)}
.badge-coral{background:var(--coral-50);color:#c2492f}
.badge-muted{background:#eee9dd;color:var(--ink-soft)}
.badge-ok{background:#e3f4ec;color:var(--ok)}
.badge-warn{background:#fbf0db;color:var(--warn)}
.badge-bad{background:#fae3e2;color:var(--bad)}
.level-gold{background:linear-gradient(135deg,#f4d06a,#e0b341);color:#5b4607}
.level-silver{background:linear-gradient(135deg,#dfe2e7,#b8bcc4);color:#3c4047}
.level-bronze{background:linear-gradient(135deg,#e0a877,#c8895a);color:#5a3318}

/* ---------- Status dots ---------- */
.dot-s{width:10px;height:10px;border-radius:50%;display:inline-block;flex:none}
.s-done{background:var(--ok)} .s-skipped{background:var(--bad)}
.s-future{background:var(--silver)} .s-overdue{background:var(--coral)}
.s-today{background:var(--teal)} .s-moved{background:#8b6fd6}

/* ---------- Tables ---------- */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);
  padding:8px 10px;border-bottom:1px solid var(--line);font-weight:700}
td{padding:10px;border-bottom:1px solid var(--line);vertical-align:middle}
tr:last-child td{border-bottom:none}

/* ---------- Stat tiles ---------- */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}
.tile{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px;box-shadow:var(--sh)}
.tile .num{font-size:1.7rem;font-weight:800;letter-spacing:-.02em;color:var(--teal-700)}
.tile .lbl{font-size:.8rem;color:var(--ink-soft);font-weight:600}
.tile.accent .num{color:var(--coral)}

/* ---------- Calendar (client week) ---------- */
.weekgrid{display:grid;gap:10px}
.dayrow{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:12px 14px;box-shadow:var(--sh)}
.dayrow.is-today{border-color:var(--teal);box-shadow:0 0 0 2px var(--teal-50),var(--sh)}
.dayrow .dh{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.dayrow .dh .wd{font-weight:800}
.dayrow .dh .dd{color:var(--muted);font-size:.85rem}
.wkitem{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--line);
  border-radius:var(--r-sm);background:var(--surface-2);margin-top:8px;text-decoration:none;color:var(--ink)}
.wkitem:hover{border-color:var(--teal);background:#fff}
.wkitem .t{font-weight:700}
.empty-day{color:var(--muted);font-size:.85rem;padding:4px 2px}

/* ---------- Exercise / set logging ---------- */
.exq{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);box-shadow:var(--sh);
  margin-bottom:14px;overflow:hidden}
.exq .exhd{display:flex;gap:12px;padding:14px;align-items:flex-start}
.exq .exhd img{width:64px;height:64px;border-radius:12px;object-fit:cover;flex:none;background:var(--surface-2)}
.exq .exhd .nm{font-weight:800}
.exq .exbody{padding:0 14px 14px}
.setrow{display:grid;grid-template-columns:34px 1fr 1fr 1fr 36px;gap:8px;align-items:center;
  padding:7px 0;border-top:1px solid var(--line)}
.setrow .sn{font-weight:800;color:var(--muted);text-align:center}
.setrow input{padding:9px 8px;text-align:center}
.setrow .soll{font-size:.72rem;color:var(--muted);text-align:center}
.gl{display:inline-block;background:var(--coral-50);color:#c2492f;font-weight:800;border-radius:7px;
  padding:1px 7px;font-size:.72rem;margin-right:6px}

/* ---------- Mood / stars ---------- */
.stars{display:flex;gap:6px}
.stars input{display:none}
.stars label{font-size:28px;cursor:pointer;color:#dcd8cb;margin:0}
.stars label:hover,.stars label:hover ~ label{color:var(--coral)}
.stars input:checked ~ label{color:#dcd8cb}
.starwrap{direction:rtl;display:inline-flex}
.starwrap input:checked ~ label{color:var(--coral)}
.starwrap label:hover,.starwrap label:hover ~ label{color:var(--coral)}

/* ---------- Bottom nav (client mobile) ---------- */
.bottomnav{position:fixed;left:0;right:0;bottom:0;z-index:50;display:none;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-top:1px solid var(--line)}
.bottomnav .inner{max-width:680px;margin:0 auto;display:flex;justify-content:space-around;padding:8px 6px}
.bottomnav a{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--muted);
  font-size:.7rem;font-weight:700;padding:4px 14px;border-radius:10px}
.bottomnav a.active{color:var(--teal)}
.bottomnav a .ic{font-size:18px}

/* ---------- Misc ---------- */
.alert{border-radius:var(--r);padding:12px 14px;font-weight:600;margin-bottom:14px}
.alert-err{background:var(--coral-50);color:#c2492f}
.alert-ok{background:#e3f4ec;color:var(--ok)}
.linkbox{background:var(--teal-50);border:1px dashed var(--teal);border-radius:var(--r);padding:14px;
  word-break:break-all;font-family:ui-monospace,monospace;font-size:.85rem;color:var(--teal-700)}
.divider{height:1px;background:var(--line);margin:18px 0}
.pagehd{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin:18px 0 14px}
.muscle-bar{height:8px;border-radius:6px;background:var(--teal);}
.progress{height:10px;background:var(--surface-2);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.progress>span{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--coral))}

/* ---------- Responsive ---------- */
@media (max-width:780px){
  .grid-2,.grid-3{grid-template-columns:1fr}
  .nav{display:none;position:absolute;top:64px;right:12px;left:12px;flex-direction:column;
    background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:8px;box-shadow:var(--sh-lg)}
  .nav.open{display:flex}
  .nav a{padding:12px}
  .burger{display:block}
  .bottomnav{display:block}
  .shell{padding-bottom:84px}
  h1{font-size:1.45rem}
  .hero{padding:24px 20px}
  .setrow{grid-template-columns:28px 1fr 1fr 1fr 32px;gap:6px}
}
@media (min-width:781px){ .mobile-only{display:none} }
