/* ==========================================================================
   TOKENS
   ========================================================================== */
:root{
  --c-primary:#3f51b5; --c-primary-600:#273271;
  --c-success:#27ae60; --c-danger:#c0392b;
  --c-primary-soft: #e9edff; --c-primary-soft-border: #cfd7ff;

  --c-text:#202127; --c-muted:#6b7294;
  --c-bg:#f4f4f6; --c-card:#fff;

  --radius-6:6px; --radius-8:8px; --radius-12:12px; --radius-14:14px; --radius-18:18px;
  --shadow-1:0 2px 10px rgba(0,0,0,.04);
  --shadow-2:0 2px 8px 0 #ececf3;

  --sp-2:.5rem; --sp-3:.75rem; --sp-4:1rem; --sp-5:1.25rem; --sp-6:1.5rem;
  --font:'Inter', Arial, system-ui, sans-serif;

  --bottom-nav-h: 64px;

  --equip-actions-w: 56px;   /* vaste breedte voor de iconen rechts */
  
  /* Benchmarks: extra zachte kleurtinten */
  --c-success-soft: #e6f7ec;
  --c-success-soft-border: #c7eed6;
  --c-est-soft: #fff4e6;
  --c-est-soft-border: #ffd9a8;
  --c-info-soft: #e8ecff;
  --c-info-soft-border: #cfd7ff;
    /* Calendar/Weekbar: extra subtiele day fills */
  --c-primary-soft-2: #f3f5ff;
  --c-primary-soft-2-border: #e4e9ff;

  --c-success-soft-2: #f2fbf6;
  --c-success-soft-2-border: #d9f2e4;

  --bm-kpi-w: 64px;   /* vaste breedte voor 1/3/5RM tegels (pas aan naar smaak) */

  /* Desktop layout cap */
  --page-max-w: 800px;      /* probeer 920–1040 naar smaak */
  --page-side-pad: 16px;    /* mobiele zij-padding */

  /* iOS safe-area (notch / statusbar) */
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left: env(safe-area-inset-left, 0px);
}

/* ==========================================================================
   BASE
   ========================================================================== */
html,body{height:100%}
body{
  background:var(--c-bg);
  color:var(--c-text);
  font-family:var(--font);
  min-height:100vh;
  margin:0;
}

/* Logo + titel (algemene opmaak) */
.logo{ width:64px; display:block; }
h1{ font-size:2rem; font-weight:700; letter-spacing:1px; color:#202127; margin:0 0 1.5rem 0; }
/* Login/reset pagina: titel net wat compacter */
body.login-page h1{
  font-size: 1.55rem;      /* was 2rem */
  letter-spacing: 0.2px;   /* was 1px */
  margin-bottom: 1.1rem;   /* was 1.5rem */
}
/* Algemene content-marges voor pagina-main containers */
.dashboard-main,.workout-detail-main,.settings-main,.equipment-main,.profiledata-main,.account-main{
  /* mobile first: padding links/rechts, en op desktop centreren met max-width */
  width: min(var(--page-max-w), calc(100% - (var(--page-side-pad) * 2)));
  margin: 1.1rem auto 1.6rem auto;

  padding:0;
  padding-bottom: calc(var(--bottom-nav-h) + 16px + env(safe-area-inset-bottom));
}

/* ==========================================================================
   LAYOUT SHELLS (Topbar / Bottom nav / Titles)
   ========================================================================== */
.topbar{
  display:flex; align-items:center; justify-content:space-between;

  /* zelfde “desktop cap” als je main containers */
  width: min(var(--page-max-w), calc(100% - (var(--page-side-pad) * 2)));
  margin: 0 auto;
  box-sizing: border-box;

  background:#fff;
  padding: calc(.8rem + constant(safe-area-inset-top)) 1rem .4rem 1rem;
  padding: calc(.8rem + env(safe-area-inset-top)) 1rem .4rem 1rem;
  box-shadow: var(--shadow-2);
  position:sticky; top:0; z-index:20;
}
.topbar-title{ flex:1; text-align:center; font-size:1.16rem; font-weight:600; color:#38405a; }
.logo-center{
  height: 40px;
  width: auto;
  opacity: 0.98;
}

/* Dashboard brand (icon + wordmark) in topbar */
.brand-center{
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: center;
  text-decoration: none;
}

.brand-center__icon{
  height: 36px;
  width: auto;
  display: block;
}

.brand-center__wordmark{
  height: 16px;   /* subtiel, niet schreeuwerig */
  width: auto;
  display: block;
}

.brand-center__wordmark{ display: none; }
@media (min-width: 720px){
  .brand-center__wordmark{ display: block; }
}

.bottom-nav{
  position: fixed;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);

  /* zelfde “desktop cap” als je main containers */
  width: min(var(--page-max-w), calc(100% - (var(--page-side-pad) * 2)));
  box-sizing: border-box;

  display: flex; justify-content: space-between; align-items: center;
  background: #fff;
  border-top: 1.5px solid #ececf3;
  height: calc(var(--bottom-nav-h) + env(safe-area-inset-bottom));

  /* horizontale ruimte + veilige onderrand */
  padding: 0 clamp(10px, 3.5vw, 18px) max(.65rem, env(safe-area-inset-bottom));
  gap: 10px;
  z-index: 100;
}

.bottom-nav a{
  text-decoration:none; color:#8d94ad; font-weight:500; font-size:1.1rem;
  flex:1; text-align:center; padding:.5rem 0; border-radius:7px; transition:color .15s, background .15s;
}
.bottom-nav .nav-active{ color:var(--c-primary); background:#e3e7fa; }

.month-title{
  text-align:center; font-size:1.17rem; font-weight:500; color:#38405a;
  margin:.6rem 0 .2rem 0;
}

/* ==========================================================================
   COMPONENTS
   ========================================================================== */

/* Buttons */
.btn{
  display:inline-block; width:100%;
  padding:.9rem 1rem; border:0; border-radius:12px;
  font-weight:700; letter-spacing:.3px; cursor:pointer; transition:background .18s,opacity .18s, box-shadow .18s;
}
.btn[disabled]{opacity:.7; cursor:not-allowed;}
.btn-primary{ background:var(--c-primary); color:#fff; font-size:1.02rem; }
.btn-primary:hover{ background:var(--c-primary-600); }
.btn-secondary{ background:#e3e7fa; color:var(--c-primary); font-size:1.02rem; }
.btn-danger{ background:var(--c-danger); color:#fff; }
.btn-ghost{
  background: transparent;
  color: var(--c-primary);
  border: 1px solid #d7dbff;
}
.btn-ghost:hover{
  background: #f3f4ff;
}
/* verticale afstand tussen opeenvolgende knoppen */
.btn + .btn{ margin-top:12px; }
/* horizontale knoppenrij */
.btn-row{ display:flex; gap:8px; }
.btn-row .btn + .btn{ margin-top:0; }

/* Floating Action Button (herbruikbaar) */
.fab-btn{
  position: fixed;
  right: 16px;
  bottom: calc(var(--bottom-nav-h) + 12px); /* boven de bottom-nav */
  width: 52px; height: 52px; border-radius: 50%;
  border: none;
  font-size: 1.6rem; color: #fff;
  background: var(--c-primary);
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
  z-index: 120;
}
.fab-btn:active{ transform: translateY(1px); }

/* Voorkom double-tap zoom op knoppen (mobiel) */
.btn,
.icon-btn,
.player-overlay button{
  touch-action: manipulation;
}

/* Regen knop: zichtbaar maar "niet actief" */
#regen-btn.is-disabled {
  opacity: 0.35;
  cursor: not-allowed;
  filter: grayscale(1);
}

/* voorkomt hover effecten als je die hebt */
#regen-btn.is-disabled:hover {
  transform: none;
  box-shadow: none;
}

/* Form controls */
.input, .textarea, .select select{
  width:100%; box-sizing:border-box; font-size:1rem;
  background:#f6f7fa; border:1px solid #e3e7fa; border-radius:12px; padding:.8rem 1rem;
}
.input:focus, .textarea:focus{
  outline:none; border-color:var(--c-primary); background:#fff;
  box-shadow:0 0 0 3px rgba(63,81,181,.18);
}
/* Input error state (login/register) */
.input.is-error{
  border-color: #e57373;
  background: #fffafa;
}

/* Select: alleen ring tonen bij toetsenbordnavigatie, geen witte bg */
.select select:focus-visible{
  outline:none; border-color:var(--c-primary);
  box-shadow:0 0 0 3px rgba(63,81,181,.18);
}
.select select:focus:not(:focus-visible){
  outline:none; border-color:inherit; box-shadow:none; background:inherit;
}

/* ===== Form controls: consistent (ook op iOS) ===== */
input.input,
select,
textarea.input{
  -webkit-appearance:none;   /* iOS native look uit */
  appearance:none;
  font: inherit;
  color: var(--c-text);
}

/* <select> met eigen pijl en kleuren */
/* <select> met eigen pijl en kleuren (verbeterde zichtbaarheid) */
.select{
  position: relative;
  border-radius: 12px;                  /* optisch gelijk aan .input */
}
.select select{
  -webkit-appearance:none;
  appearance:none;
  width: 100%;
  padding-right: 44px;                  /* iets meer ruimte voor pijl */
  color: var(--c-text);
  background: #f6f7fa;
  border: 1px solid #e3e7fa;
  border-radius: 12px;
  height: 48px;                         /* consistent met inputs */
  line-height: 1.2;
  cursor: pointer;
}
.select::after{
  content:"";
  position:absolute;
  right:12px; top:50%;
  width: 12px; height: 8px;             /* groter dan voorheen */
  background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' fill='none' stroke='%2338405a' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-size:12px 8px;
  transform:translateY(-50%);
  transition: transform .18s ease;      /* ✅ nieuw: animatie voor rotatie */
  pointer-events:none;
  opacity:.9;                           /* net iets duidelijker */
}


/* Placeholder tot er gekozen is */
select:invalid{ color: var(--c-muted); }
option[disabled][value=""]{ display:none; }

/* Disabled: alles wat valer, inclusief pijl */
.select select:disabled{
  color:#a7adc4;
  background:#f0f1f6;
  cursor:not-allowed;
}
.select:has(select:disabled)::after{
  opacity:.35;
}

/* Date input: consistent (iOS/Android/Desktop) */
input[type="date"].input{
  position: relative;
  min-height: 48px;
  -webkit-appearance:none; appearance:none;
  width:100%;
  background:#f6f7fa;
  border:1px solid #e3e7fa;
  border-radius:12px;
  padding:.8rem 2.25rem .8rem .9rem;   /* ruimte voor icoon rechts */
  line-height:1.2;
  color:var(--c-text);
  font: inherit;

  /* eigen icoon rechts – één regel, percent-encoded */
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Crect x='3' y='5' width='18' height='16' rx='2' ry='2' fill='none' stroke='%2338405a' stroke-width='2'/%3E%3Cpath d='M16 3v4M8 3v4M3 11h18' fill='none' stroke='%2338405a' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 10px center;
  background-size:18px 18px;
}

/* iOS native indicator verbergen maar klikgebied behouden */
input[type="date"].input::-webkit-calendar-picker-indicator{
  opacity: 0;
  position: absolute;
  right: 10px;
  width: 24px;
  height: 24px;
  cursor: pointer;
}

/* iOS: waarde links uitlijnen */
input[type="date"].input::-webkit-date-and-time-value{ text-align:left; }

/* iOS/WebKit: “value box” consistent houden (ook als veld leeg is) */
input[type="date"].input::-webkit-datetime-edit{
  line-height: 1.2;
  padding: 0;
}



/* Cards */
.card{
  background:var(--c-card); border-radius:14px; box-shadow:var(--shadow-1); padding:var(--sp-4);
}

/* Info bubble (bijv. ideeënbus intro) */
.info-card{
  background: var(--c-card);               /* dus gewoon wit zoals andere bubbels */
  border: 1px solid #e3e7fa;              /* zelfde bordertoon als inputs */
  border-left: 4px solid #e6eafe;         /* subtiel accent (past bij jouw hover-blauw) */
}

.info-card__text{
  margin: 0;
  color: var(--c-text);
  line-height: 1.45;
  font-size: 0.95rem;
}

/* List item */
/* List item (link-rij) */
.list-item{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  background:var(--c-card);
  padding:14px var(--sp-4);
  border-radius:16px;
  box-shadow:var(--shadow-1);
  /* belangrijk: anchors netjes als ‘card’ */
  text-decoration:none;
  color:var(--c-text);
}
.list-item:visited{ color:var(--c-text); }            /* geen paars */
.list-item:hover{
  background:#fff;
  box-shadow:0 4px 14px rgba(0,0,0,.06);
  transform:translateY(-1px);
}
.list-item:active{ transform:translateY(0); }
.list-item:focus-visible{
  outline:3px solid var(--c-primary-soft);           /* subtiele focus */
  outline-offset:2px;
}

.list-item__title{
  font-weight:700;
  color:#202127;                                     /* stevige tekstkleur */
}
.arrow-icon{ display:flex; align-items:center; margin-left:12px; }


/* Icon buttons (base) + scoped variant in topbar */
.icon-btn{
  border:0; background:transparent; padding:6px; border-radius:8px; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; /* centreer svg/glyph */
}
.icon-btn:focus{ outline:2px solid rgba(63,81,181,.35) }

/* topbar variant */
.topbar .icon-btn{
  width:38px; height:38px; padding:.2rem; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:#757575; font-size:1.15em; transition:background .18s,color .16s;
}
.topbar .icon-btn:hover,
.topbar .icon-btn:focus{
  color:var(--c-primary);
  background:#e6eafe;
}

/* Add-knop in de topbar: blauw rondje met perfect gecentreerd wit plusje */
.topbar .btn-top-add{
  position:relative;                  /* voor ::before/::after */
  width:42px; height:42px;
  border-radius:50%;
  background:var(--c-primary);
  color:#fff;                         /* fallback als ::before/::after wegvallen */
  display:flex; align-items:center; justify-content:center;
  font-size:1.35rem; font-weight:700;
  box-shadow:0 3px 10px rgba(63,81,181,.22);
  margin-left:.6em;
}
.topbar .btn-top-add:hover,
.topbar .btn-top-add:focus-visible{
  background:var(--c-primary-600);
  color:#fff;
  outline:none;
}
/* Zelfde ruimte behouden, maar knop onzichtbaar maken */
.topbar .btn-top-add.is-invisible {
  visibility: hidden;
  pointer-events: none;
}

/* tekst-plusje verbergen (toegankelijkheid blijft via aria-label) */
.topbar .btn-top-add > span{
  opacity:0;
  pointer-events:none;
}

/* “getekend” plusje: exact gecentreerd */
.topbar .btn-top-add::before,
.topbar .btn-top-add::after{
  content:"";
  position:absolute;
  left:50%; top:50%;
  width:14px; height:2px;
  background:#fff;
  border-radius:1px;
  transform:translate(-50%,-50%);
}
.topbar .btn-top-add::after{
  transform:translate(-50%,-50%) rotate(90deg);
}


/* Chips */
.chip{
  display:inline-flex; align-items:center; justify-content:center; min-width:44px;
  padding:.25rem .6rem; border-radius:999px; background:#e9edff; color:#3f51b5; font-weight:700;
}
/* Chip modifiers (Benchmarks) */
.chip--measured{
  background: var(--c-success-soft);
  border: 1px solid var(--c-success-soft-border);
  color:#1e6a3a;
}
.chip--estimated{
  background: var(--c-est-soft);
  border: 1px solid var(--c-est-soft-border);
  color:#8a4b0d;
}
.chip--muted{ opacity:.7; }
.chip--active{
  background: var(--c-primary-soft);
  border: 1px solid var(--c-primary-soft-border);
  color: var(--c-primary);
}
.chip--toggle{ gap:.35rem; } /* voor “Alleen gemeten” switch-chip */


/* Modal */
.modal-backdrop{
  position:fixed; inset:0; background:rgba(0,0,0,.35);
  display:flex; align-items:center; justify-content:center;
  padding:clamp(12px, 2.5vh, 20px); z-index:1000; overscroll-behavior:contain;
}
.modal{
  background:#fff; border-radius:18px; width:min(560px, calc(100% - 32px));
  max-height:min(80vh, calc(100dvh - 64px)); overflow:auto; -webkit-overflow-scrolling:touch;
  box-shadow:0 18px 60px rgba(0,0,0,.25);
  padding:18px; padding-bottom:max(18px, env(safe-area-inset-bottom));
}

/* Regen modal: quota check row (spinner + tekst) */
.regen-check{
  display:flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid #e3e7fa;
  background: #f7f8fc;
  color: #38405a;
}

.regen-spinner{
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid currentColor;
  border-right-color: transparent;
  display: inline-block;
  animation: bggen-spin 0.9s linear infinite; /* hergebruik bestaande keyframes */
}

.modal__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding-bottom:8px;
  margin-bottom:12px;
}
/* Modal header: back + title gegroepeerd links */
.modal__header-left{ display:flex; align-items:center; gap:8px; }

/* Back-icoon klikbaar gebied net wat groter */
.modal__back{ padding:6px; border-radius:8px; }
.modal__back:hover,
.modal__back:focus-visible{ background:#eef1ff; outline:none; }

/* Als we op de eerste stap zitten, back verbergen */
.modal--first-step .modal__back{ visibility:hidden; }

/* Als je de oude 'Terug' knoppen in de stappen laat staan, verberg ze: */
#wizard-step-type .btn-ghost,
#wizard-step-aantal .btn-ghost{ display:none !important; }

.modal__title{ font-weight:800; font-size:1.2rem; margin:0 0 12px 0; }
.modal__subtitle{
  font-weight:700;
  font-size:0.95rem;     /* kleiner dan titel */
  line-height:1.3;
  margin:6px 0 10px;
  color:#202127;
}
.modal__header .modal__title{ margin:0; }
.modal__footer{
  padding-top:12px;
}
.modal .btn{ width:100%; }

/* Ad-hoc duurkeuze: actieve chip = zwarte rand; overige = lichtgrijs */
.modal .chip {
  border: 1px solid #c6c6c6;          /* lichtere rand voor niet-actief */
}
.modal .chip.chip--active {
  border-color: #000;                  /* duidelijke zwarte rand voor actief */
  background: rgba(0,0,0,0.04);        /* subtiele fill (optioneel) */
}

/* Toetsenbordnavigatie duidelijk houden */
.modal .chip:focus-visible {
  outline: 2px solid #000;
  outline-offset: 2px;
}

/* Table-like helper (geschiedenis-lijst) */
.table-like .row{
  display:grid;
  grid-template-columns:120px 120px 1fr auto;
  gap:8px;
  padding:.4rem 0;
  border-bottom:1px solid #f0f2fa;
  align-items:center; /* zorgt dat alles verticaal netjes in 1 lijn zit */
}

.table-like .row.head{
  font-weight:600;
  border-bottom:2px solid #e9ecf7;
}


/* 1) Terug-link: subtiele breadcrumb onder de titel, linkerkant */
.wizard-step .btn-ghost{
  background:transparent;
  color:var(--c-primary);
  padding:0;
  margin:0 0 8px 0;         /* klein beetje ruimte onder de titel */
  font-weight:600;
  box-shadow:none;
  border:0;
  width:auto;
}
.wizard-step .btn-ghost:hover{
  text-decoration:underline;
  background:transparent;
}
/* Geen blauwe tap-highlight op knoppen binnen de wizard (iOS/Android) */
.wizard-step button{
  -webkit-tap-highlight-color: transparent;
}



/* Wizard-lijsten: tekst links, controls rechts */
.wizard-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.wizard-row__label {
  flex: 1;
  text-align: left;
}

/* Rechterkant (slider / teller / pijltje) */
.wizard-row__control,
.wizard-row__arrow {
  margin-left: 12px;
  display: inline-flex;
  align-items: center;
}

/* Presence-toggle (aan/uit voor bijv. barbells) */
.equip-toggle {
  position: relative;
  display: inline-block;
  width: 42px;
  height: 24px;
}

.equip-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.equip-toggle__slider {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: #d0d5ff;
  transition: 0.2s;
}

.equip-toggle__slider::before {
  content: "";
  position: absolute;
  height: 18px;
  width: 18px;
  left: 3px;
  top: 3px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.25);
  transition: 0.2s;
}

.equip-toggle input:checked + .equip-toggle__slider {
  background: var(--c-primary);
}

.equip-toggle input:checked + .equip-toggle__slider::before {
  transform: translateX(18px);
}

/* Teller (− 0 +) voor aantallen zoals plates/dumbbells/etc. */
.equip-counter {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #fff;
  border-radius: 999px;
  padding: 3px 6px;
  border: 1px solid #e3e7fa;
}

.equip-counter__btn {
  border: none;
  border-radius: 50%;
  width: 26px;
  height: 26px;
  font-weight: 700;
  line-height: 1;
  background: #e6eafe;
  cursor: pointer;
}

.equip-counter__value {
  min-width: 18px;
  text-align: center;
  font-weight: 700;
  font-size: .95rem;
}

/* Aantal-selector: compact en nog steeds goed klikbaar */
.plusmin-container{
  display:grid;
  grid-template-columns: repeat(3, minmax(72px, 1fr));
  gap:10px;
  align-items:center;
  justify-items:center;
  margin:8px 0 14px;
}

.plusmin-container .btn{
  width:76px;
  height:44px;               /* >= 44px voor toegankelijkheid */
  border-radius:12px;
  font-size:1.2rem;         /* iets kleiner dan eerst */
  font-weight:700;
}

.plusmin-container .input{
  width:76px;
  height:44px;               /* matcht knoppen */
  text-align:center;
  background:#fff;
  border-radius:12px;
  padding:0;
}

/* Op touch-devices iets ruimer (beter tikdoel) */
@media (pointer: coarse){
  .plusmin-container .btn,
  .plusmin-container .input{
    width:88px;
    height:48px;
    font-size:1.3rem;
  }
}


/* Verberg browser-spinners op number input + forceer centrering */
#wizard-step-aantal input[type="number"]{
  text-align:center;
  -moz-appearance:textfield;
  appearance:textfield;
}
#wizard-step-aantal input[type="number"]::-webkit-outer-spin-button,
#wizard-step-aantal input[type="number"]::-webkit-inner-spin-button{
  -webkit-appearance:none;
  margin:0;
}


/* Calendar (month modal) */
.calendar-grid{
  display:grid; grid-template-columns:repeat(7, 1fr); gap:8px; margin-bottom:12px;
}
.calendar__weekday {
  text-align: center;
  font-weight: 600;
  color: var(--c-muted);
  font-size: 0.85rem;
}
.calendar__spacer{ height:0; }
.calendar__day{
  position:relative; aspect-ratio:1/1; background:var(--c-card);
  border:1px solid #e3e7fa; border-radius:12px; box-shadow:var(--shadow-1);
  font-weight:700; display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition: box-shadow .18s, border-color .18s, transform .04s;
}
.calendar__day:hover{ transform:translateY(-1px); }
/* Vandaag: underline onder het getal (geen outline) */
.calendar__day--today{ outline:none; }

.calendar__day--today .calendar__num{
  position: relative;
  display: inline-block;
}
.calendar__day--today .calendar__num::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-3px;                 /* iets dichter bij het getal */
  transform:translateX(-50%);
  width:12px;                  /* iets korter */
  height:2px;                  /* dunner */
  background:rgba(63,81,181,.55); /* subtieler dan full primary */
  border-radius:999px;
}
.calendar__day--selected{ border-color:var(--c-primary); box-shadow:0 0 0 3px rgba(63,81,181,.18); }

/* Workout status (data) */
.calendar__day--planned{
  background: var(--c-primary-soft-2);
  border-color: var(--c-primary-soft-2-border);
}

.calendar__day--done{
  background: var(--c-success-soft-2);
  border-color: var(--c-success-soft-2-border);
}

/* Selected moet altijd de blauwe rand houden, ook als er planned/done op zit */
.calendar__day--selected.calendar__day--planned,
.calendar__day--selected.calendar__day--done{
  border-color: var(--c-primary);
}
.calendar__day--other {
  background: #f9f9fb;
  color: #bbb;
  border-style: dashed;   /* subtiele scheiding */
}
.calendar__mark--other {
  color: #bbb;   /* status grijs */
  opacity: 0.7;
}
.calendar__num{ font-size:1rem; }
.calendar__mark {
  position: absolute;
  right: 6px;
  bottom: 2px;          /* lager, niet door nummer heen */
  font-size: 0.8rem;    /* subtieler */
  line-height: 1;
  opacity: .9;
}
.calendar__mark--done{ color:var(--c-success); }
.calendar__mark--planned{ color: var(--c-primary); opacity: .9; }

/* overschrijf kleuren voor andere-maand dagen */
.calendar__day--other .calendar__mark--done,
.calendar__day--other .calendar__mark--planned {
  color: #bbb !important;   /* lichtgrijs, wint van groen/rood */
  opacity: 0.7;
}

/* Weekbar (dashboard) */
.weekbar{
  display:grid;
  grid-template-columns:repeat(7, minmax(0,1fr));
  gap:8px;

  /* zelfde “desktop cap” als je main containers */
  width: min(var(--page-max-w), calc(100% - (var(--page-side-pad) * 2)));
  margin: 0 auto 1rem auto;
  box-sizing: border-box;

  background:#fff;
  border-radius:12px;
  padding:.4rem .3rem .2rem .3rem;
  box-shadow: var(--shadow-2);
}
.weekbar__day{
  position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:2px; height:72px; text-align:center; padding:6px 0 8px;
  background:transparent; border:1px solid #e3e7fa; border-radius:12px; cursor:pointer;
  transition: box-shadow .18s, border-color .18s, background .18s, transform .04s;
}
.weekbar__day:hover{ transform:translateY(-1px); }
/* Vandaag: underline onder het getal (geen outline) */
.weekbar__day--today{ outline:none; }

.weekbar__day--today .weekbar__num{
  position: relative;
  display: inline-block;
}
.weekbar__day--today .weekbar__num::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-2px;                  /* iets hoger, oogt rustiger in de weekbar */
  transform:translateX(-50%);
  width:14px;                   /* iets korter */
  height:2px;                   /* dunner */
  background:rgba(63,81,181,.55);/* subtieler dan full primary */
  border-radius:999px;
}
/* Selectie = ring (geen vulling), zodat status-vulling leidend blijft */
.weekbar__day--selected{
  background: transparent;
  border-color: var(--c-primary);
  box-shadow: 0 0 0 3px rgba(63,81,181,.18);
}
/* Workout status (data) */
.weekbar__day--planned{
  background: var(--c-primary-soft-2);
  border-color: var(--c-primary-soft-2-border);
}

.weekbar__day--done{
  background: var(--c-success-soft-2);
  border-color: var(--c-success-soft-2-border);
}
/* Selected moet altijd de blauwe rand houden, ook als er planned/done op zit */
.weekbar__day--selected.weekbar__day--planned,
.weekbar__day--selected.weekbar__day--done{
  border-color: var(--c-primary);
}
.weekbar__top{ font-size:.75rem; color:var(--c-muted); height:16px; line-height:16px; }
.weekbar__num{ font-weight:800; font-size:1.05rem; height:20px; line-height:20px; }
.weekbar__status{ font-size:.9rem; min-height:16px; line-height:16px; opacity:0; }
.weekbar__status--done{ color:var(--c-success); opacity:1; }
.weekbar__status--planned{ color:var(--c-primary); opacity:1; }

/* Weekbar swipe-animatie
   --------------------------------------------------
   We animeren de hele balk een klein stukje horizontaal
   zodat het voelt alsof je naar de volgende/vorige week schuift.
*/
.weekbar {
  position: relative;
  transition: transform .18s ease; /* moet overeenkomen met de JS timeout */
  will-change: transform;
  touch-action: pan-y; /* je mag horizontaal swipen zonder de pagina te 'locken' */
}

/* volgende week (user swipet naar links) -> schuif kort naar links */
.weekbar.weekbar--anim-next {
  transform: translateX(-20px);
}

/* vorige week (user swipet naar rechts) -> schuif kort naar rechts */
.weekbar.weekbar--anim-prev {
  transform: translateX(20px);
}

/* alleen op touch willen we dit gedrag 'actief' houden */
@media (pointer: coarse) {
  .weekbar {
    /* nog iets losser voor mobiel, minder 'snappy' randjes */
    scroll-snap-type: none;
  }
}


/* Auth (login/register) — zelfde desktop cap als de rest */
.auth-card{
  width: min(var(--page-max-w), calc(100% - (var(--page-side-pad) * 2)));
  max-width: var(--page-max-w);
}

.auth-form{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:12px;
}
@media (min-width: 720px){
  .auth-form{
    max-width: 420px;
    margin: 0 auto;
  }

  /* ✅ CTA iets meer presence op desktop */
  .auth-form .btn{
    padding: 1rem 1rem;
  }
    /* ✅ Helper-rows en switch-links ook in dezelfde gecentreerde kolom als het formulier */
  .auth-helper-row,
  .switch-auth{
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
  }
}


/* Inputs + buttons gewoon over de volle kaartbreedte */
.auth-form .input,
.auth-form .btn{
  width:100%;
  margin-left:0;
  margin-right:0;
}

.auth-helper-row,
.auth-legal{
  width:100%;
  margin:0;
  text-align:left;
}
/* Desktop: helper-row ook centreren met dezelfde kolombreedte als het form */
@media (min-width: 720px){
  .auth-helper-row{
    max-width: 420px;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* ✅ kleine extra lucht rond "Wachtwoord vergeten?" */
.auth-helper-row{
  margin-top: 2px;
  margin-bottom: 6px;
}

/* Login/Register: centreer de kaart op de pagina */
body.login-page{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:100vh;
  padding:24px var(--page-side-pad);
  background: var(--c-bg);
}

/* Extra ruimte tussen submit-knop en "switch-auth" (login/register) */
.switch-auth{
  margin-top: 12px;
}

/* Titel & logo netjes centreren binnen de kaart (werkt voor beide varianten) */
.auth-card,
.login-container,
.register-container{
  text-align:center;
}
.auth-card .logo,
.login-container .logo{
  margin-left:auto;
  margin-right:auto;
  display:block;
}

.logo-link {
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 18px;
}

.logo-link:hover {
  opacity: 0.9;
}

/* Brand lockup (icon + wordmark) */
.brand-icon{
  width: 56px;
  height: auto;
  display: block;
}

.brand-wordmark{
  height: 22px;
  width: auto;
  display: block;
  margin-top: 10px;
}

/* Juridische akkoordsectie onder het registratieformulier */
.auth-legal{
  width:min(100%, 320px);
  margin:4px auto 0;
  text-align:left;
  font-size:.9rem;
  color:var(--c-muted);
}
.checkbox-row{
  display:flex;
  align-items:flex-start;
  gap:8px;
}
.checkbox-row input[type="checkbox"]{
  margin-top:3px;
}
.checkbox-row span{
  flex:1;
}

/* Inline 'link-knop' voor voorwaarden/privacy in de tekst */
.link-btn{
  padding:0;
  margin:0;
  border:0;
  background:none;
  color:var(--c-primary);
  text-decoration:underline;
  font:inherit;
  cursor:pointer;
}
.link-btn:hover{
  text-decoration:none;
}

/* Body van modals met juridische tekst */
.modal__body{
  font-size:.95rem;
  line-height:1.5;
  color:var(--c-text);
}
.modal__body h3{
  margin:10px 0 4px;
  font-size:1rem;
}
.modal__body p{
  margin:4px 0;
}

/* Auth error / warning messages */
.error {
  display: none;               /* standaard verborgen */
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 10px;

  background: #fff3f3;         /* zacht rood */
  color: #8b1e1e;
  border: 1px solid #f1b0b0;

  font-size: 0.95rem;
  line-height: 1.4;

  animation: fadeSlideIn 0.25s ease-out;
}

.error.is-visible {
  display: block;
}

/* Auth success messages (zelfde als .error, maar groen) */
.success {
  display: none;               /* standaard verborgen */
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 10px;

  background: var(--c-success-soft);           /* zacht groen (token) */
  color: #1e6a3a;                               /* donker groen */
  border: 1px solid var(--c-success-soft-border); /* groene rand (token) */

  font-size: 0.95rem;
  line-height: 1.4;

  animation: fadeSlideIn 0.25s ease-out;       /* hergebruik bestaande animatie */
}

.success.is-visible {
  display: block;
}

@keyframes fadeSlideIn {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Link in de rode error box (resend bevestiging) */
.error .error__action{
  margin-top: 12px;
  text-align: center;
}

.error .error__action a{
  color: var(--c-primary);
  font-weight: 700;
  text-decoration: underline;
}

.error .error__action a:hover{
  text-decoration: none;
}

/* ==========================================================================
   UTILITIES
   ========================================================================== */
.mt-10{ margin-top:2.5rem; }
.mt-4{ margin-top:var(--sp-4); } .mb-4{ margin-bottom:var(--sp-4); }
.text-muted{ color:var(--c-muted); }
.stack-12{ display:flex; flex-direction:column; gap:12px; }
.stack-12 .btn + .btn{ margin-top:0; }

.hidden {
  display: none !important;
}

/* ===== Touch-friendly icon buttons (mobiel) ===== */

.modal__header > .icon-btn,
.modal__back,
.equipment-actions .icon-btn{
  width: 36px; height: 36px;           /* klikvlak desktop */
  padding: 0;
  border-radius: 10px;
  -webkit-tap-highlight-color: transparent;
  display:inline-flex; align-items:center; justify-content:center; /* NIEUW */
}


/* Zorg dat SVG's of het '✕' teken netjes schalen */
.modal__header > .icon-btn svg,
.modal__back svg,
.equipment-actions .icon-btn svg{
  width: 20px; height: 20px;
}
.modal__header > .icon-btn { font-size: 20px; }  /* voor '✕' glyph */

/* Op touch devices naar de 44×44 guideline */
@media (pointer: coarse){
  .modal__header > .icon-btn,
  .modal__back,
  .equipment-actions .icon-btn{
    width: 44px; height: 44px;
    border-radius: 12px;
  }
  .modal__header > .icon-btn svg,
  .modal__back svg,
  .equipment-actions .icon-btn svg{
    width: 22px; height: 22px;
  }
  .modal__header > .icon-btn { font-size: 24px; } /* '✕' duidelijker */
}


/* Kleine UX-polish: tikfeedback */
.modal__header > .icon-btn:hover,
.modal__header > .icon-btn:focus-visible,
.modal__back:hover,
.modal__back:focus-visible,
.equipment-actions .icon-btn:hover,
.equipment-actions .icon-btn:focus-visible{
  background: #eef1ff;
  outline: none;
}

/* Houd de materiaallijst visueel strak terwijl het klikvlak groeit */
.equipment-actions .icon-btn{
  margin: -6px 0;                     /* vergroot hit-area zonder rij hoger te maken */
}
@media (pointer: coarse){
  .equipment-actions .icon-btn{ margin: -8px 0; }
}


/* ==========================================================================
   PAGE-SPECIFIC (licht houden; alles liever via components)
   ========================================================================== */
/* Account & beveiliging */
.account-page{
  background:#f4f4f6;
  min-height:100vh;
}

.account-section-title{
  font-weight:700;
  font-size:1.05rem;
  margin:0 0 4px 0;
  color:#2a2a3b;
}

.account-section-muted{
  margin:0 0 10px 0;
  font-size:.92rem;
  color:var(--c-muted);
}

.account-email-pill{
  background:#f6f7fa;
  border-radius:12px;
  padding:.7rem .9rem;
  font-size:.98rem;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

.account-email-pill span{
  font-weight:500;
}

.account-sub-status{
  font-size:.9rem;
  margin:0 0 10px 0;
  color:#38405a;
}

.account-hint{
  margin-top:4px;
  font-size:.85rem;
  color:var(--c-muted);
}

/* Account: danger bubble (losse rode card) */
.danger-bubble{
  background:#fff5f5;
  border:1px solid #ffd0d0;
}

.danger-bubble__title{
  color: var(--c-danger);
}

.danger-bubble__text{
  color:#7a2a24;
}


/* Contactpagina */
.contact-page .contact-card {
  padding: 1.3rem 1.4rem;
}

.contact-page .contact-title {
  margin: 0 0 4px;
  font-size: 1.28rem;
  font-weight: 700;
  color: #202127;
}

.contact-page .contact-subtitle {
  margin: 0;
  font-size: 0.95rem;
  color: var(--c-muted);
}

/* Blok rond het mailadres */
.contact-page .contact-section {
  margin-top: 10px;
}

.contact-page .contact-section-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: #38405a;
  margin: 0 0 4px;
}

/* Maak van de pill een nette link zonder “hard” blauw */
.contact-page .contact-email-pill {
  margin-top: 4px;
  text-decoration: none;
  color: #38405a;
}

/* Icoon + tekst in de pill */
.contact-page .contact-email-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: #e3e7fa;
}

.contact-page .contact-email-icon svg {
  width: 14px;
  height: 14px;
}

.contact-page .contact-email-text {
  /* extra optisch beetje ruimte van het icoon af */
  margin-top: 1px;
}

/* Kleine toelichting + tip */
.contact-page .contact-meta {
  margin: 6px 0 0;
  font-size: 0.85rem;
  color: var(--c-muted);
}

.contact-page .contact-tip {
  margin: 8px 0 0;
  font-size: 0.9rem;
  color: #4b5677;
  line-height: 1.45;
}

/* =====================================
   FAQ - Nieuwe uniforme styling
   ===================================== */

.faq-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 16px;
}

/* FAQ card (container) */
.faq-item {
  background: #ffffff;
  border-radius: 22px;
  box-shadow:
    0 10px 25px rgba(15, 23, 42, 0.04),
    0 0 0 1px rgba(148, 163, 184, 0.08);
  overflow: hidden;
}

/* Vraag — typografie gelijk aan list-item__title */
.faq-question {
  width: 100%;
  background: #f9fafc;
  border: none;
  padding: 16px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;

  font-size: 1rem;             /* gelijk aan list-item__title */
  font-weight: 700;
  color: #22263a;
}

.faq-question-text {
  flex: 1;
  text-align: left;
}

.faq-caret {
  font-size: 0.9rem;
  color: #6b7280;
  transition: transform 0.18s ease;
}

/* Antwoord — typografie gelijk aan subtitel op help-card */
.faq-answer {
  display: none;
  padding: 12px 20px 18px;

  font-size: 0.95rem;          /* subtitel grootte */
  line-height: 1.45;
  color: #4b5677;

  border-top: 1px solid rgba(148, 163, 184, 0.20);
}

/* Open staat aan */
.faq-item--open .faq-answer {
  display: block;
}

.faq-item--open .faq-caret {
  transform: rotate(180deg);
}

.faq-item--open .faq-question {
  background: #eef0fb;
}

/* Begrippenlijst */
.terms-list{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:8px;
}
.terms-term{
  background:#f7f8fa;
  border-radius:12px;
  padding:.7rem .9rem;
}
.terms-term__title{
  margin:0 0 4px;
  font-weight:600;
  font-size:.95rem;
  color:#2a2a3b;
}
.terms-term__body{
  margin:0;
  font-size:.9rem;
  color:var(--c-muted);
  line-height:1.4;
}

   /* Settings/Profile header card */
.settings-page{ background:#f4f4f6; min-height:100vh; }
.profile-header{
  display:flex; align-items:center; margin-bottom:1.2rem;
  background:#fff; border-radius:12px; box-shadow:0 2px 10px #eee; padding:1.1rem 1.3rem;
}
.profile-pic{
  width:60px;
  height:60px;
  border-radius:50%;
  object-fit:cover;
  margin-right:0;           /* <- verplaatst naar wrapper */
  display:block;            /* <- voorkomt inline “baseline” gekke offsets */
}

/* Avatar wrapper + camera overlay */
.profile-avatar-wrap{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 60px;
  height: 60px;
  flex: 0 0 60px;           /* houdt ‘m stabiel in de row */
  margin-right: 1.1rem;     /* <- spacing hoort hier */
}

.avatar-edit-btn{
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translate(25%, 25%);

  width: 24px;
  height: 24px;
  border-radius: 999px;

  border: 2px solid #fff;          /* klein wit randje op de foto */
  background: var(--c-primary);     /* jouw primaire blauw */
  color: #fff;                      /* svg gebruikt currentColor */

  display: inline-flex;
  align-items: center;
  justify-content: center;

  padding: 0;
  cursor: pointer;
  box-shadow: 0 6px 16px rgba(0,0,0,.12);
  -webkit-tap-highlight-color: transparent;
}

.avatar-edit-btn svg{
  width: 14px;
  height: 14px;
  display: block;
}

.avatar-edit-btn:hover{
  background: var(--c-primary-600);
}

.avatar-edit-btn:focus-visible{
  outline: 3px solid rgba(63,81,181,.25);
  outline-offset: 2px;
}

/* Touch: tikdoel iets groter */
@media (pointer: coarse){
  .avatar-edit-btn{
    width: 30px;
    height: 30px;
  }
  .avatar-edit-btn svg{
    width: 16px;
    height: 16px;
  }
}


/* Onboarding: geen bottom-nav en geen extra bodem-padding */
.onboarding-page .bottom-nav { 
  display: none; 
}
/* Onboarding: klein beetje lucht onderaan zodat de card niet 'plakt' */
.onboarding-page #onboarding-form {
  margin-bottom: max(16px, env(safe-area-inset-bottom));
}
/* Globale regel geeft padding-bottom i.v.m. bottom-nav;
   voor onboarding willen we die ruimte niet. */
.onboarding-page .profiledata-main { 
  padding-bottom: 0 !important; 
}
/* Onboarding: compacter maken op scherm 1 en 2 */
.onboarding-page #ob-screen-1 .text-muted {
  margin-bottom: 6px;          /* minder ruimte onder de zin */
}

.onboarding-page #ob-screen-1 .trainingdays-card {
  margin-top: 4px;             /* kaart schuift dichter naar de zin */
}

.onboarding-page #ob-screen-2 .text-muted {
  margin-bottom: 6px;          /* minder ruimte boven materiaaltekst */
}

.onboarding-page #ob-screen-2 #equipment-mini {
  margin-top: 4px;             /* lijst dichter tegen de tekst */
}

/* Onboarding: minder ruimte tussen materiaal en knoppen */
.onboarding-page #equipment-mini {
  margin-bottom: 0rem;   /* klein beetje ruimte is genoeg */
  padding-bottom: 0;       /* geen extra “bodem-lucht” meer */
}

/* Onboarding: materiaal-kaart dichter tegen de tekst */
.onboarding-page #equipment-mini .equipment-empty {
  margin-top: 0.75em;  /* was 2.5em globaal */
}

/* Onboarding: benchmarks – zelfde compacte spacing als materiaal */
.onboarding-page #ob-screen-3 .text-muted {
  margin-bottom: 6px;          /* kleine afstand tussen intro + kleuruitleg */
}

.onboarding-page #ob-screen-3 #bm-mini {
  margin-top: 4px;             /* benchmarks-lijst dichter tegen de tekst */
}

/* Onboarding: lege staat benchmarks dichter tegen de tekst */
.onboarding-page #bm-mini .equipment-empty {
  margin-top: 0.75em;          /* zelfde als materiaal */
}

/* Initiaal-avatar (fallback wanneer geen profielfoto is gezet) */
.avatar-initial{
  width:60px;
  height:60px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#3f51b5;
  color:#fff;
  font-weight:600;
  font-size:1.4rem;
  user-select:none;
  margin-right:0;
}


.profile-info{ display:flex; flex-direction:column; justify-content:center; }
.profile-name{ font-size:1.17rem; font-weight:600; color:#2a2a3b; }
.profile-email{ font-size:.96rem; color:#7a7b9a; margin-top:3px; }

/* Settings list (als je <a class="list-item"> gebruikt, zijn onderstaande optioneel) */
.settings-list{ display:flex; flex-direction:column; gap:.8rem; }

/* Alleen zichtbaar voor admins; standaard verborgen om flikkeren te voorkomen */
.settings-link--admin {
  display: none;
}

.equipment-card{
  display:flex; align-items:center;
  background:#fff; border-radius:12px; padding:.7em 1em; margin-bottom:.7em;
  box-shadow:0 2px 6px rgba(40,42,70,.07);
  width:100%;                    /* ⚠️ forceer kaart op containerbreedte */
  box-sizing:border-box;         /* padding telt mee in die 100% */
  overflow:hidden;               /* geen horizontale ‘uitschieter’ */
}


.equipment-type{
  font-size:1.13em; font-weight:500; color:#222;
  /* laat de naam flexibel “vloeien” */
  flex:1 1 auto;
}

/* De badge: altijd vlak vóór de iconen, rechts uitgelijnd */
.equipment-info{
  margin-left:auto;                 /* duwt de badge naar rechts */
  display:inline-flex; align-items:center; justify-content:center;
  /* vaste visuele breedte → alle badges staan onder elkaar uitgelijnd */
  width:56px;                       /* pas aan naar smaak; 52–64px werkt goed */
  height:28px;
  border-radius:20px;
  background:#e6eafe; color:#3f51b5; font-weight:700;
  box-sizing:border-box;
}

/* Iconen rechts: vaste kolombreedte, zodat badge er altijd strak voor staat */
.equipment-actions{
  flex:0 0 var(--equip-actions-w);
  width:var(--equip-actions-w);
  display:flex; justify-content:flex-end; align-items:center; gap:.35em;
  margin-left:12px;
}

.equipment-empty{
  text-align:center; color:#7880a0; font-size:1.1em; margin-top:2.5em;
  background:#fff; padding:2em .8em; border-radius:16px; box-shadow:0 2px 10px #eee;
}


/* Trainingsdagen (voorkeuren-balk) */
.trainingdays-bar {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr)); /* standaard alles op 1 rij */
  gap: 8px;
  margin-top: 4px;
}

/* Alleen op héél smalle schermen in 2 rijen vallen */
@media (max-width: 360px) {
  .trainingdays-bar {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* Trainingsdagen-kaart in voorkeuren (bubbel-stijl) */
.trainingdays-card {
  margin-top: 12px;
  padding: 12px 14px 10px;
  border-radius: 16px;
  background: #f7f8fa;
}

.trainingdays-card .account-section-title {
  margin-bottom: 4px;
}

.trainingdays-card .account-section-muted {
  margin: 0 0 8px 0;
}

.trainingday-pill {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 6px 4px;
  border-radius: 12px;
  border: 1px solid #e3e7fa;
  background: #fff;
  font-size: 0.8rem;
  cursor: pointer;
  min-height: 56px;
  transition:
    background 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    transform 0.04s ease;
}

.trainingday-pill:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-1);
}

.trainingday-pill--active {
  background: #e9edff;
  border-color: #c5d0ff;
  box-shadow: inset 0 -3px 0 var(--c-primary);
}

.trainingday-pill__label {
  font-weight: 600;
  font-size: 0.8rem;
  color: var(--c-muted);
  margin-bottom: 2px;
}

.trainingday-pill__minutes {
  font-size: 0.85rem;
  font-weight: 500;
  color: #2c3e50;
}

.trainingday-pill--active .trainingday-pill__label,
.trainingday-pill--active .trainingday-pill__minutes {
  color: #1a237e;
}

.trainingday-help {
  font-size: 0.75rem;
  color: var(--c-muted);
  margin-top: 4px;
}

/* Workout UI */
.workout-card,.workout-detail-card{
  background:#fff; border-radius:14px; box-shadow:0 2px 10px #eee; padding:1.2rem; margin-bottom:1.3rem;
}
.workout-card h2,.workout-detail-card h2{ margin:0 0 .7rem 0; font-size:1.27rem; color:#202127; }
.workout-desc{ font-size:1.07rem; color:#38405a; margin-bottom:1.1rem; }
.workout-user-note {
  margin-top: 8px;
  padding: 8px 10px;
  background: #f9f9fb;
  border-radius: 10px;
  font-size: 0.95rem;
  color: var(--c-muted);
  line-height: 1.4;
  display: flex;                /* icoon + tekst naast elkaar */
  align-items: flex-start;
  gap: 8px;
}

.workout-user-note .note-icon {
  flex: 0 0 auto;
  line-height: 1;
  margin-top: 2px;              /* optisch centreren t.o.v. eerste tekstregel */
}

.workout-user-note .note-text {
  white-space: pre-line;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  line-clamp: 3;                /* standaard */
  -webkit-line-clamp: 3;        /* WebKit */
}


.restday-msg{
  background:#fff; border-radius:12px; padding:1.1rem; text-align:center; color:#7880a0; font-size:1.08rem; box-shadow:0 2px 10px #eee;
}
.workout-card-row{ display:flex; justify-content:space-between; align-items:center; }
.workout-link{ cursor:pointer; transition: box-shadow .15s, background .15s; outline:none; }
.workout-link:active,.workout-link:focus{ box-shadow:0 4px 18px #b3befa; background:#f0f4ff; }

/* Workout details: score/levels */
.workout-details{
  background:#f7f8fc; border-radius:7px; padding:13px 13px 8px 13px; margin-bottom:13px;
  box-shadow:0 1px 6px #e3e7fa70;
}
.workout-notes{ font-style:italic; color:var(--c-muted); margin-top:7px; margin-bottom:2px; font-size:.98em; }

.block-ui{
  margin-top:10px; padding:12px; border:1px dashed #e3e7fa; border-radius:10px; background:#fbfcff;
  box-shadow:0 1px 6px rgba(35,41,65,.04);
}
.emom-group{ display:flex; align-items:center; flex-wrap:wrap; gap:10px 14px; }
.emom-group label{ display:inline-flex; align-items:center; gap:6px; }

.level-choose,.level-picker{ display:flex; flex-wrap:wrap; align-items:center; gap:10px 14px; margin-bottom:8px; }
.level-title{ font-weight:600; color:#2a2a3b; margin-right:6px; }
.level-radio{ display:inline-flex; align-items:center; gap:6px; font-size:.98rem; }

.score-entry{ margin-top:6px; }
.score-title{ font-weight:600; color:#2a2a3b; margin-bottom:6px; }
.score-row{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin:6px 0; }

.score-type{
  min-width:150px; flex:0 0 150px;
  border:1px solid #e3e7fa; background:#f6f7fa; border-radius:7px; padding:8px 10px; font-size:1rem;
}
.score-value{
  flex:1 1 140px; min-width:120px;
  border:1px solid #d3d7ee;   /* was #e3e7fa */
  background:#ffffff;         /* was #f6f7fa */
  border-radius:7px; padding:8px 10px; font-size:1rem;
}
.workout-page .score-value:focus {
  background:#ffffff;
  border-color:var(--c-primary);
  box-shadow:0 0 0 3px rgba(63,81,181,.18);
}
.mini-status{ font-size:.9rem; color:var(--c-muted); margin-left:auto; }

.note-actions{
  display:flex;
  gap:10px;
  align-items:center;
}

/* =========================
   Workout Player Overlay
   ========================= */
   .player-overlay{
  position: fixed;
  inset: 0;
  z-index: 2200;
  display: none;
}

.player-overlay.is-open{ display: block; }

.player-overlay__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(30, 36, 52, 0.55);
  /* blur is optioneel; performance kan wisselen op mobiel */
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.player-overlay__sheet{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);

  width: min(var(--page-max-w), calc(100% - (var(--page-side-pad) * 2)));
  box-sizing: border-box;

  background: #fff;
  border-radius: 18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.25);

  padding: 14px 14px 14px;
  max-height: min(82vh, calc(100dvh - 64px));
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

.player-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom: 10px;
}

/* =========================
   Player header icon buttons (Audio + Close)
   ========================= */

.player-header .icon-btn{
  width: 38px;
  height: 38px;
  padding: 0;
  border-radius: 12px;
  color: var(--c-muted);              /* neutraal, zoals rest van UI */
  transition: background .18s, color .16s, opacity .16s;
  -webkit-tap-highlight-color: transparent;
}

.player-header .icon-btn{ font-size: 20px; line-height: 1; }  /* ook voor ✕ glyph */
.player-header #playerCloseBtn{ color: var(--c-text); }        /* close = zwart i.p.v. muted */

.player-header .icon-btn:hover,
.player-header .icon-btn:focus-visible{
  background: #eef1ff;               /* matcht je global icon hover */
  color: var(--c-primary);
  outline: none;
}

.player-header .icon-btn svg{
  width: 20px;
  height: 20px;
  display: block;
}

/* Muted state: iets zachter (maar nog steeds herkenbaar) */
.player-header #playerAudioBtn.is-muted{
  color: var(--c-muted);
  opacity: .75;
}

/* Op touch devices: 44x44 guideline (zelfde als elders in je CSS) */
@media (pointer: coarse){
  .player-header .icon-btn{
    width: 44px;
    height: 44px;
    border-radius: 12px;
  }
  .player-header .icon-btn svg{
    width: 22px;
    height: 22px;
  }
}

.player-title{
  margin:0;
  font-size: 1.05rem;
  font-weight: 800;
  color: #202127;
}

.player-sub{
  margin: 2px 0 0;
  font-size: .92rem;
  color: var(--c-muted);
}

.player-timer{
  background: var(--c-primary-soft);
  border: 1px solid var(--c-primary-soft-border);
  border-radius: 14px;
  padding: 12px;
  margin: 10px 0 12px;

  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Tijd altijd gecentreerd */
.player-timer__time{
  text-align: center;
  font-size: clamp(2.0rem, 6vw, 3.0rem);
  font-weight: 900;
  letter-spacing: .5px;
  color: #202127;
}

/* Alle controls bij elkaar, 1 rij */
.player-timer__controls{
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) 44px; /* <-- minmax(0,1fr) is de key */
  gap: 10px;
  align-items: center;
}

/* Vorige/Volgende even breed */
.player-timer__nav{
  width: 44px;
  min-width: 44px;
  height: 44px;
  padding: 0;
  border-radius: 12px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  font-weight: 900;
  font-size: 1.4rem;
  line-height: 1;
}

/* Middendeel: -15 / Start / +15 */
.player-timer__mid{
  display: flex;
  min-width: 0;
  flex-wrap: nowrap;
  gap: 8px;
  align-items: center;

  width: 100%;              /* neemt de hele middenkolom */
  justify-content: center;  /* centreert -15 / Start / +15 */
}

/* Kleine knoppen */
.player-timer__mini{
  height: 44px;
  width: 56px;
  padding: 0;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
}

/* Start/Pauze knop compacter (niet full width) */
.player-timer__play{
  height: 44px;
  width: clamp(96px, 34vw, 140px);  /* <-- schaalt op mobiel */
  padding: 0 14px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  min-width: 0;
}

@media (max-width: 420px){
  .player-timer__mini{ width: 52px; }
}
/* Heel smalle schermen: controls stapelen */
@media (max-width: 360px){
  .player-timer__controls{
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "mid mid"
      "prev next";
    gap: 8px;
  }

  /* Grid-areas koppelen aan bestaande knoppen */
  #playerPrevBtn{ grid-area: prev; width: 100%; }
  #playerNextBtn{ grid-area: next; width: 100%; }
  .player-timer__mid{ grid-area: mid; }

  /* Middenrij: Start knop krijgt de ruimte */
  .player-timer__mid{
    width: 100%;
  }
  .player-timer__play{
    width: auto;     /* was 140px */
    flex: 1 1 auto;
  }
  .player-timer__mini{
    width: 52px;     /* iets compacter */
  }
}

/* Huidige blok = “steviger” */
.player-block{
  background: #ffffff;
  border-radius: 14px;
  padding: 12px;

  /* iets steviger dan nu */
  border: 1px solid var(--c-primary-soft-border);
  box-shadow:
    0 6px 18px rgba(0,0,0,.06),
    inset 0 0 0 1px var(--c-primary-soft-border);
}

.player-block__label{
  font-weight: 800;
  color: var(--c-primary);
  margin-bottom: 6px;
}

.player-block__lines{
  color: #202127;
  line-height: 1.45;
  font-size: .98rem;
}

.player-next{
  margin-top: 16px;
  background: #f4f5f9;         /* iets grijzer */
  border: 1px dashed #d7daea;  /* iets neutraler */
  border-radius: 14px;
  padding: 10px 12px;
  opacity: .86;                /* net iets minder aanwezig */
}

.player-next__title{
  margin: 0 0 6px 0;
  font-weight: 900;
  color: #202127;
  display:flex;
  align-items:center;
  justify-content:space-between;
}

/* kleine “preview” hint rechts */
.player-next__title::after{
  content:"Preview";
  font-size:.78rem;
  font-weight:800;
  color: var(--c-muted);
  opacity:.9;
}

.player-next__label{
  font-weight: 800;
  color: #4b5677;   /* minder blauw */
  margin: 2px 0 6px 0;
}

.player-next__lines{
  color: #4b5677;
  font-size: .94rem;
  line-height: 1.4;
}

/* Start workout knop boven de blokken */
.btn-startworkout{
  margin: 10px 0 14px 0;
}


/* reset voor de teller (linkerkant) */
.note-actions .mini-status{
  opacity:.9;
  margin-left:0;            /* ← override van globale auto-margin */
}

/* alleen de status (rechts) naar de rand duwen */
.note-actions .mini-status + .mini-status{
  margin-left:auto;   /* werkt alleen vanaf het 2e .mini-status element */
}


@media (max-width:420px){
  .score-type{ flex-basis:130px; min-width:130px; }
  .score-value{ flex-basis:140px; }
}

/* Level pills + specs (compact) */
.level-option{ position:relative; cursor:pointer; user-select:none; }
.level-option input{ position:absolute; opacity:0; width:0; height:0; }
.level-option span{
  display:inline-block; padding:4px 10px; border-radius:9999px;
  transition: background-color .2s, box-shadow .2s;
}
.level-option input:checked + span{ background:rgba(52,152,219,.12); box-shadow:inset 0 0 0 1px #3498db; }

.workout-level-title{
  display:block;
  font-weight:800;
  color: var(--c-primary);   /* titels altijd blauw */
  margin: 0 0 6px 0;
}

.level-specs{
  border-radius:12px;
  padding:10px 12px;
  background:#fff;                  /* standaard wit */
  border:1px solid #e3e7fa;         /* subtiele rand */
  transition: background-color .2s, border-color .2s, box-shadow .2s;
}

/* Alleen het GEKOZEN level heeft lichte blauwe highlight */
.level-specs.active{
  background: var(--c-primary-soft);
  border-color: var(--c-primary-soft-border);
  box-shadow: inset 0 0 0 1px var(--c-primary-soft-border);
}

/* kleine hulpen */
.workout-level-list{ margin-top:2px; }
.level-specs + .level-specs{ margin-top:8px; }

/* --- Onboarding quick-pick: compacter voor mobiel --- */
.equip-quick { display: grid; gap: 12px; }

.equip-group {
  background: #fff;
  border: 1px solid #e3e7fa;
  border-radius: 12px;
  padding: 10px;
  box-shadow: 0 1px 6px #eef0ff;
}

.equip-group-title {
  font-weight: 600;
  color: #38405a;
  margin: 0 0 8px 2px;
  font-size: 1.02rem;
}

/* 2 kolommen op mobiel, valt terug naar 1 kolom op erg smal */
.equip-items {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
@media (max-width: 360px) {
  .equip-items { grid-template-columns: 1fr; }
}

.equip-item {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;                  /* compacter */
  border: 1px solid #e9edff;
  border-radius: 10px;
  background: #f9faff;
}

.equip-name {
  font-size: .95rem;                 /* iets kleiner */
  color: #2a2a3b;
  line-height: 1.2;
  word-break: break-word;
}

.qty {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #fff;
  border: 1px solid #e3e7fa;
  border-radius: 999px;
  padding: 3px 6px;                  /* compacter */
}
.qty button {
  border: none;
  background: #e6eafe;
  border-radius: 50%;
  width: 24px;                       /* kleiner */
  height: 24px;
  font-weight: 700;
  cursor: pointer;
  line-height: 1;
}
.qty span {
  min-width: 18px;
  text-align: center;
  font-weight: 700;
  font-size: .95rem;
}

.btn.is-loading{
  opacity: .85;
}

/* Klein draaiend bolletje in de knop */
.btn.is-loading::after{
  content:"";
  display:inline-block;
  width:14px;
  height:14px;
  margin-left:10px;
  border-radius:50%;
  border:2px solid currentColor;
  border-right-color: transparent;
  animation: bggen-spin 0.9s linear infinite; /* keyframes bestaan al */
  vertical-align: -2px;
}

/* Confirm-modal: zelfde look & feel als andere modals, maar compacter */
#app-confirm{
  position: fixed;
  inset: 0;
  z-index: 2100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  background: rgba(30,36,52,0.36);
}

.app-confirm-card{
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.25);
  width: min(420px, calc(100% - 32px));  /* niet meer full-width */
  padding: 16px 16px 14px;
}

.app-confirm-card__title{
  font-weight: 700;
  font-size: 1.05rem;
  margin: 0 0 6px 0;
  color: #2a2a3b;
}

.app-confirm-card__body{
  color: #2a2a3b;
  margin-bottom: 14px;
  font-size: .95rem;
  line-height: 1.4;
}

/* Alleen binnen de confirm-modal */
#app-confirm .btn-row{
  display:flex;
  gap:10px;
  align-items:stretch;      /* forceer gelijke hoogte in de rij */
}

#app-confirm .btn{
  flex:1 1 0;               /* beide knoppen even breed */
  margin:0;                 /* reset globale stack-margins */
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:44px;
  padding:0 16px;
  line-height:1;
  box-sizing:border-box;
  border-radius:12px;
}

/* gelijke border-thickness voor optische hoogte */
#app-confirm .btn-primary{ border:1px solid transparent; }
#app-confirm .btn-secondary{ border-width:1px; }

.link-muted {
  font-size: .95rem;
  color: var(--c-muted, #6b7280);
  text-decoration: underline;
}
.link-muted:hover { text-decoration: none; }

/* Benchmarks */
.bm-card{ display:flex; flex-direction:column; gap:10px; }
.bm-card__head{ display:flex; align-items:center; justify-content:space-between; gap:8px; }
.bm-title{ margin:0; font-size:1.05rem; }
.bm-chiprow{ display:flex; gap:8px; flex-wrap:wrap; }
.bm-footer{ font-size:.9rem; }
.bm-actions{ display:flex; gap:8px; margin-top:4px; }
.benchmark-row{ width:100%; text-align:left; cursor:pointer; }
.bm-inlinechips{ display:flex; gap:8px; flex-wrap:wrap; margin-top:6px; }
/* Benchmarks – layout op basis van equipment-card (zelfde breedte als Materiaal) */
.benchmark-row{
  display:flex;
  align-items:center;
  gap:12px;
  overflow:hidden;
  width:100%;                    /* net als .equipment-card */
  box-sizing:border-box;
  cursor:default;                /* kaart zelf is niet klikbaar */
}

.benchmark-row__left{
  flex:1 1 140px;                /* naam krijgt ruimte links */
  min-width:0;
}
/* KPI-rij: rechts uitlijnen, op één lijn houden */
.bm-kpis{
  margin-left:auto;
  display:flex;
  justify-content:flex-end;  /* ⇦ echt rechts uitlijnen */
  gap:6px;
  flex-wrap:nowrap;          /* niet afbreken */
  flex:0 1 64%;
  max-width:64%;
  min-width:180px;
}
@media (max-width: 320px){
  .bm-kpis{
    flex-wrap:wrap;          /* op héél smal scherm mag ‘ie breken */
    justify-content:flex-end;
    flex-basis:58%;
    max-width:58%;
  }
}

/* KPI-tiles: vaste, gelijke breedte */
.bm-kpi{
  appearance:none; -webkit-appearance:none;
  flex:0 0 var(--bm-kpi-w);  /* ⇦ allemaal even breed */
  width:var(--bm-kpi-w);
  min-width:var(--bm-kpi-w);
  padding:5px 7px;
  border-radius:10px;
  border:2px solid #e3e7fa;
  background:#fff;
  text-align:center;
  line-height:1.1;
  cursor:pointer;
}
.bm-kpi__label{ font-size:.68rem; font-weight:700; letter-spacing:.02em; }
.bm-kpi__val{   font-size:.85rem; font-weight:800; }


/* kleuren (tokens blijven hetzelfde) */
.bm-kpi--measured{
  border-color: var(--c-success-soft-border);
  background: var(--c-success-soft);
  color:#1e6a3a;
}
.bm-kpi--estimated{
  border-color: var(--c-est-soft-border);
  background: var(--c-est-soft);
  color:#8a4b0d;
}
.bm-kpi--muted{ opacity:.6; }

#bm-list.equipment-list{ overflow-x:hidden; }

.delete-btn {
  font-weight: 700;
  cursor: pointer;
  color: var(--c-danger);      /* rood */
  user-select: none;
  justify-self: end;           /* duwt 'm helemaal tegen de rechterrand */
  padding: 0 .5rem;            /* geeft iets tikruimte zonder de layout te breken */
  line-height: 1;
}
.delete-btn:hover {
  color: #e74c3c;
}

/* === HELP: onderwerpenlijst — zelfde stijl als Instellingen === */

.help-page .settings-main {
  background: transparent;
}

/* De card zelf mag optisch verdwijnen; alleen de list-items moeten 'drijven' */
.help-page .card {
  background: transparent;
  box-shadow: none;
  padding: 0;
}

/* Gebruik dezelfde spacing als de standaard settings-list */
.help-page .settings-list {
  display: flex;
  flex-direction: column;
  gap: .8rem; /* gelijk aan .settings-list elders */
}

/* Let op: géén .help-page .list-item-override meer:
   de knoppen gebruiken nu 1-op-1 de globale .list-item-styling
   (kleur + schaduw) zoals op de Instellingen-pagina. */

/* === Background generation banner === */
.bggen{
  position: sticky;
  top: 0;
  color: var(--c-text);

  /* ⬇️ ZELFDE DESKTOP CAP ALS PAGINA */
  width: min(var(--page-max-w), calc(100% - (var(--page-side-pad) * 2)));
  margin: 0 auto;

  box-sizing: border-box;

  z-index: 90; /* ⬅️ hier komen we zo op terug */

  background: var(--c-success-soft);
  border-bottom: 1px solid var(--c-success-soft-border);

  font: 500 14px/1.4 system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  padding: 10px 12px;
  box-shadow: 0 2px 6px rgba(0,0,0,.05);
}

button.bggen,
button.notice-banner{
  -webkit-appearance: none;
  appearance: none;
  color: var(--c-text);
}

.bggen--running {
  background: var(--c-success-soft);
  border-color: var(--c-success-soft-border);
}

.bggen.hidden { display: none; }
.bggen--success { background: #e8f5e9; border-color: #b6e0be; }
.bggen--error   { background: #ffebee; border-color: #ffcdd2; }

.bggen__content { display: flex; align-items: center; gap: 8px; }
.bggen__spinner {
  width: 14px; height: 14px; border-radius: 50%;
  border: 2px solid currentColor; border-right-color: transparent;
  display: inline-block; animation: bggen-spin 0.9s linear infinite;
}
@keyframes bggen-spin { to { transform: rotate(360deg); } }

.bggen--success .bggen__spinner,
.bggen--error .bggen__spinner { display: none; }

.bggen__text { flex: 1; }
.bggen__badge {
  font-size: 12px; background: #ddd; padding: 2px 6px; border-radius: 10px;
}
.bggen--running .bggen__badge { background: #ffe082; }
.bggen--success .bggen__badge { background: #a5d6a7; }
.bggen--error   .bggen__badge { background: #ef9a9a; }

.bggen__tray {
  margin-top: 8px; background: rgba(0,0,0,.02); border: 1px dashed rgba(0,0,0,.08);
  border-radius: 6px; padding: 8px;
}
.bggen__tray ul { margin: 0; padding-left: 18px; }

/* Als een banner direct na de topbar staat: geef wat lucht zoals op dashboard */
.topbar + .bggen,
.topbar + button.bggen{
  margin-top: 12px;
  border-radius: 12px;
}

/* Klikbare “notice” banner variant (alleen tekst + chevron) */
.notice-banner{
  display: flex;
  cursor: pointer;
  border: 0;
  text-align: left;
}
/* subtiele hover (desktop) */
@media (hover: hover){
  .notice-banner:hover{
    background: #eef6f0;
  }
}
.notice-banner .bggen__content{
  width: 100%;
}

.notice-banner__chev{
  font-size: 22px;
  line-height: 1;
  opacity: .75;
  margin-left: 6px;
}

.notice-banner:hover .notice-banner__chev{
  opacity: 1;
}

/* Player timer: geen verticale spacing in horizontale knop-rij */
.player-timer__mid .btn + .btn{
  margin-top: 0;
}

/* =========================
   Player Finish Sheet
   ========================= */
.player-finish{
  margin-top: 14px;
}

.player-finish.hidden{
  display: none;
}

.player-finish__card{
  background: #fff;
  border-radius: 16px;
  border: 1px solid #e3e7fa;
  box-shadow: 0 10px 28px rgba(0,0,0,.08);
  padding: 14px;
}

.player-finish__title{
  margin: 0 0 6px 0;
  font-size: 1.15rem;
  font-weight: 900;
  color: #202127;
}

.player-finish__msg{
  margin: 0 0 12px 0;
  color: var(--c-muted);
  line-height: 1.4;
  font-size: .98rem;
}

.player-finish__actions{
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 10px;
}