/* ==========================================================================
   Study Plan — Gamified Premium UI (iOS MedExPrep–inspired)
   Animated orbs, XP rewards, step accents, celebration screen.
   Brand: navy #162C55, teal #179D99, tealDeep #117673, tealSoft #3BC6C2
   ========================================================================== */

/* --------------------------------------------------------------------------
   0.  Page shell + background
   -------------------------------------------------------------------------- */
.medexp-plan{ max-width:1280px; margin:0 auto; width:100%; }

.medexp-planPage{
  background:linear-gradient(180deg, #F0FDFA 0%, #F1F5F9 35%, #F8FAFC 100%) !important;
  position:relative;
}
.medexp-planPage::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 500px at 10% 0%, rgba(23,157,153,.06), transparent 55%),
    radial-gradient(700px 400px at 90% 5%, rgba(59,198,194,.05), transparent 50%),
    radial-gradient(600px 350px at 50% 100%, rgba(22,44,85,.03), transparent 55%);
  pointer-events:none;
}


/* --------------------------------------------------------------------------
   0b.  Hero header banner
   -------------------------------------------------------------------------- */
.medexp-planHero{
  position:relative;
  background:linear-gradient(135deg, #162C55 0%, #1A3A6B 40%, #1E4D6E 70%, #117673 100%);
  padding:1.75rem 1.5rem 1.5rem;
  overflow:hidden;
}
.medexp-planHero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(500px 300px at 5% 0%, rgba(59,198,194,.22), transparent 55%),
    radial-gradient(400px 250px at 95% 100%, rgba(23,157,153,.18), transparent 50%);
  pointer-events:none;
}
.medexp-planHero::after{
  content:"";
  position:absolute;
  bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent 5%, rgba(59,198,194,.35) 50%, transparent 95%);
  pointer-events:none;
}
.medexp-planHero__deco{
  position:absolute; right:1.5rem; top:50%; transform:translateY(-50%);
  opacity:.55; pointer-events:none;
}
@media (max-width:680px){ .medexp-planHero__deco{ display:none; } }

.medexp-planHero__inner{
  position:relative; z-index:1;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
}
.medexp-planHero__text{ flex:1; min-width:0; }
.medexp-planHero__title{
  display:flex; align-items:center; gap:.65rem;
  font-size:1.4rem; font-weight:900; color:#fff;
  letter-spacing:-.02em; line-height:1.2;
}
.medexp-planHero__icon{ width:28px; height:28px; flex-shrink:0; stroke:#3BC6C2; opacity:.9; }
.medexp-planHero__sub{
  margin-top:.4rem; font-size:.92rem; font-weight:600;
  color:rgba(255,255,255,.75); line-height:1.45;
}
.medexp-planHero__actions{ display:flex; align-items:center; gap:.5rem; flex-shrink:0; }

/* Bell override inside hero */
.medexp-planHero .medexp-notifyBell{
  background:rgba(255,255,255,.12) !important;
  border-color:rgba(255,255,255,.18) !important;
  color:rgba(255,255,255,.85) !important;
  box-shadow:none !important;
}
.medexp-planHero .medexp-notifyBell:hover{
  background:rgba(255,255,255,.20) !important;
  color:#fff !important;
}
.medexp-planHero .medexp-notifyBadge{
  border-color:rgba(22,44,85,.5) !important;
}


/* --------------------------------------------------------------------------
   0c.  Wizard shell — step-reactive gradient background
   -------------------------------------------------------------------------- */
.tw-studyPlanShell{
  --wiz-c1: #179D99;
  --wiz-c2: #3BC6C2;
  margin-top:.5rem;
  position:relative;
  border-radius:24px;
  padding:0;
  background:#fff;
  overflow:hidden;
  box-shadow:
    0 1px 0 rgba(17,24,39,.02),
    0 8px 24px rgba(2,6,23,.06),
    0 20px 48px rgba(2,6,23,.03);
  border:1.5px solid rgba(148,163,184,.12);
}
.tw-studyPlanShell::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:
    radial-gradient(600px 400px at 8% 0%, color-mix(in srgb, var(--wiz-c1) 7%, transparent), transparent 60%),
    radial-gradient(500px 350px at 92% 0%, color-mix(in srgb, var(--wiz-c2) 5%, transparent), transparent 55%),
    radial-gradient(550px 400px at 50% 100%, rgba(22,44,85,.04), transparent 60%);
  pointer-events:none;
  transition:background .6s ease;
}
.tw-studyPlanShell .tw-btn{ cursor:pointer; }
.tw-studyPlanShell .tw-btn[disabled],
.tw-studyPlanShell .tw-btn:disabled{ cursor:not-allowed; }


/* ==========================================================================
   WIZARD — Gamified (iOS-inspired)
   ========================================================================== */

/* --------------------------------------------------------------------------
   W1.  Wizard hero card — animated orb + step info + XP
   -------------------------------------------------------------------------- */
.medexp-wizHero{
  position:relative;
  padding:1.5rem 1.5rem 1.25rem;
  background:linear-gradient(180deg, rgba(255,255,255,.95) 0%, rgba(255,255,255,.82) 100%);
  border-bottom:1px solid rgba(148,163,184,.10);
  overflow:hidden;
}
.medexp-wizHero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(350px 200px at 85% 20%, color-mix(in srgb, var(--wiz-c1) 8%, transparent), transparent 60%),
    radial-gradient(300px 200px at 15% 80%, color-mix(in srgb, var(--wiz-c2) 5%, transparent), transparent 55%);
  pointer-events:none;
  transition:background .5s ease;
}
.medexp-wizHero__inner{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  gap:1.25rem;
}

/* Animated orb */
.medexp-wizOrb{
  position:relative;
  width:72px;
  height:72px;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:linear-gradient(135deg, var(--wiz-c1), var(--wiz-c2));
  box-shadow:
    0 0 0 6px color-mix(in srgb, var(--wiz-c1) 12%, transparent),
    0 8px 24px color-mix(in srgb, var(--wiz-c1) 25%, transparent);
  animation:wizOrbPulse 2.5s ease-in-out infinite;
  transition:background .5s ease, box-shadow .5s ease;
}
.medexp-wizOrb::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:radial-gradient(circle at 35% 30%, rgba(255,255,255,.35), transparent 65%);
  pointer-events:none;
}
.medexp-wizOrb::after{
  content:"";
  position:absolute;
  inset:-8px;
  border-radius:inherit;
  background:radial-gradient(circle, color-mix(in srgb, var(--wiz-c1) 15%, transparent), transparent 70%);
  pointer-events:none;
  animation:wizOrbGlow 2.5s ease-in-out infinite;
}
.medexp-wizOrb__icon{
  width:28px; height:28px;
  fill:#fff;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.15));
  position:relative; z-index:1;
}
.medexp-wizOrb__emoji{
  font-size:32px;
  line-height:1;
  position:relative; z-index:1;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.12));
}

@keyframes wizOrbPulse{
  0%, 100%{ transform:scale(1); }
  50%{ transform:scale(1.06); }
}
@keyframes wizOrbGlow{
  0%, 100%{ opacity:.5; transform:scale(1); }
  50%{ opacity:1; transform:scale(1.12); }
}

/* Hero text area */
.medexp-wizHero__text{
  flex:1; min-width:0;
}
.medexp-wizHero__step{
  font-size:.7rem;
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--wiz-c1);
  margin-bottom:.25rem;
}
.medexp-wizHero__title{
  font-size:1.35rem;
  font-weight:900;
  color:rgba(22,44,85,.92);
  letter-spacing:-.02em;
  line-height:1.2;
}
.medexp-wizHero__motiv{
  margin-top:.35rem;
  font-size:.88rem;
  font-weight:600;
  color:rgba(15,23,42,.48);
  line-height:1.4;
}

/* XP badge in hero */
.medexp-wizXP{
  display:inline-flex;
  align-items:center;
  gap:.3rem;
  padding:.2rem .6rem;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(234,179,8,.10), rgba(245,158,11,.08));
  border:1px solid rgba(234,179,8,.22);
  margin-top:.45rem;
}
.medexp-wizXP__star{
  width:13px; height:13px;
  fill:#EAB308;
}
.medexp-wizXP__text{
  font-size:.72rem;
  font-weight:900;
  color:rgba(161,98,7,.85);
}


/* --------------------------------------------------------------------------
   W2.  Wizard stepper — gradient track + animated dots
   -------------------------------------------------------------------------- */
.medexp-wizStepper{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  position:relative;
  padding:1rem 1.5rem;
}

/* Background track */
.medexp-wizStepper::before{
  content:"";
  position:absolute;
  top:calc(1rem + 20px);
  left:calc(1.5rem + 22px);
  right:calc(1.5rem + 22px);
  height:5px;
  background:rgba(148,163,184,.12);
  border-radius:999px;
  z-index:0;
}

/* Filled progress track */
.medexp-wizTrack{
  position:absolute;
  top:calc(1rem + 20px);
  left:calc(1.5rem + 22px);
  right:calc(1.5rem + 22px);
  height:5px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--wiz-c1), var(--wiz-c2));
  z-index:0;
  transform-origin:left center;
  transition:transform .45s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 1px 6px color-mix(in srgb, var(--wiz-c1) 30%, transparent);
}

.medexp-wizStep{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.45rem;
  padding:0; border:none; background:transparent;
  cursor:pointer;
  text-align:center;
  position:relative; z-index:1;
  min-width:0; flex:0 0 auto;
}
.medexp-wizStep:hover .medexp-wizStepIcon{
  border-color:color-mix(in srgb, var(--wiz-c1) 40%, transparent);
}

/* Step dot circle */
.medexp-wizStepIcon{
  width:44px; height:44px;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:999px;
  background:rgba(255,255,255,.98);
  border:2.5px solid rgba(148,163,184,0.20);
  box-shadow:0 1px 4px rgba(2,6,23,.05);
  transition:all .3s cubic-bezier(.34,1.56,.64,1);
  position:relative;
}
.medexp-wizStepIcon svg{
  width:18px; height:18px;
  fill:rgba(15,23,42,.35);
  transition:fill .2s ease;
}

/* Active step — accent gradient with glow ring */
.medexp-wizStep.is-active .medexp-wizStepIcon{
  background:linear-gradient(135deg, var(--wiz-c1), var(--wiz-c2));
  border-color:transparent;
  transform:scale(1.12);
  box-shadow:
    0 0 0 5px color-mix(in srgb, var(--wiz-c1) 12%, transparent),
    0 4px 14px color-mix(in srgb, var(--wiz-c1) 30%, transparent);
  animation:spStepPulse 2.5s ease-in-out infinite;
}
.medexp-wizStep.is-active .medexp-wizStepIcon svg{ fill:#fff; }

@keyframes spStepPulse{
  0%, 100%{ box-shadow:0 0 0 5px color-mix(in srgb, var(--wiz-c1) 12%, transparent), 0 4px 14px color-mix(in srgb, var(--wiz-c1) 30%, transparent); }
  50%{ box-shadow:0 0 0 8px color-mix(in srgb, var(--wiz-c1) 8%, transparent), 0 4px 18px color-mix(in srgb, var(--wiz-c1) 35%, transparent); }
}

/* Completed step — faded accent with checkmark */
.medexp-wizStep.is-done .medexp-wizStepIcon{
  background:color-mix(in srgb, var(--wiz-c1) 10%, #fff);
  border-color:color-mix(in srgb, var(--wiz-c1) 35%, transparent);
}
.medexp-wizStep.is-done .medexp-wizStepIcon svg{
  fill:var(--wiz-c1);
  opacity:.85;
}

/* Step label */
.medexp-wizStepLabel{
  font-size:.7rem; font-weight:800;
  color:rgba(15,23,42,0.42);
  letter-spacing:.01em;
  max-width:72px; text-align:center; line-height:1.2;
}
.medexp-wizStep.is-active .medexp-wizStepLabel{
  color:var(--wiz-c1);
  font-weight:900;
}
.medexp-wizStep.is-done .medexp-wizStepLabel{
  color:color-mix(in srgb, var(--wiz-c1) 60%, #475569);
}


/* --------------------------------------------------------------------------
   W3.  Wizard form pane
   -------------------------------------------------------------------------- */
.medexp-wiz{ display:flex; flex-direction:column; gap:0; }
.medexp-wizHead{ }
.medexp-wizBody{ padding:1.25rem 1.5rem; }

.medexp-wizPane{
  display:flex; flex-direction:column; gap:1rem;
  padding-top:.25rem;
}
.medexp-wizPane .tw-h3,
.medexp-wizPane > h3{
  font-size:1.15rem !important; font-weight:900 !important;
  color:rgba(22,44,85,0.92) !important;
  letter-spacing:-0.02em !important; line-height:1.2 !important;
  margin:0 !important;
}
.medexp-wizPane > .tw-muted{
  color:rgba(15,23,42,0.50) !important;
  font-size:.88rem !important;
  line-height:1.5 !important;
  margin-top:-.35rem;
}

.medexp-wizRow{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:0.75rem; align-items:center;
}
.medexp-wizLabel{ font-weight:800; color:rgba(22,44,85,0.72); font-size:0.9rem; }
.medexp-wizHint{ color:rgba(15,23,42,0.50); font-size:0.86rem; line-height:1.45; }
.medexp-wizInline{ display:flex; gap:.5rem; align-items:center; flex-wrap:wrap; }
.medexp-wizQuick{ display:flex; gap:.55rem; flex-wrap:wrap; margin-top:-.15rem; }


/* --------------------------------------------------------------------------
   W4.  Tip card — lightbulb icon with soft gold wash
   -------------------------------------------------------------------------- */
.medexp-wizTip{
  display:flex;
  align-items:flex-start;
  gap:.65rem;
  padding:.75rem 1rem;
  margin-top:1rem;
  border-radius:16px;
  border:1px solid rgba(234,179,8,.18);
  background:linear-gradient(135deg, rgba(234,179,8,.05), rgba(245,158,11,.03));
}
.medexp-wizTip__icon{
  width:20px; height:20px; flex-shrink:0;
  fill:#EAB308;
  margin-top:1px;
  animation:wizTipPulse 3s ease-in-out infinite;
}
@keyframes wizTipPulse{
  0%, 100%{ opacity:.8; }
  50%{ opacity:1; }
}
.medexp-wizTip__text{
  font-size:.84rem; font-weight:600;
  color:rgba(22,44,85,.62);
  line-height:1.45;
}


/* --------------------------------------------------------------------------
   W5.  Quick preset buttons — per-step accent colors
   -------------------------------------------------------------------------- */
.medexp-wizQuick .tw-btn{
  border-radius:999px !important;
  font-weight:900 !important;
  padding:0.4rem 0.9rem !important;
  transition:all .18s cubic-bezier(.34,1.56,.64,1) !important;
}
.medexp-wizQuick .tw-btn:nth-child(1){
  background:linear-gradient(135deg, var(--wiz-c1), var(--wiz-c2)) !important;
  border-color:transparent !important;
  color:#fff !important;
  box-shadow:0 2px 8px color-mix(in srgb, var(--wiz-c1) 25%, transparent) !important;
}
.medexp-wizQuick .tw-btn:nth-child(2){
  background:linear-gradient(135deg, #117673, #162C55) !important;
  border-color:transparent !important;
  color:#fff !important;
  box-shadow:0 2px 8px rgba(22,44,85,0.25) !important;
}
.medexp-wizQuick .tw-btn:nth-child(3){
  background:linear-gradient(135deg, #FB7185, #F43F5E) !important;
  border-color:transparent !important;
  color:#fff !important;
  box-shadow:0 2px 8px rgba(244,63,94,0.25) !important;
}
.medexp-wizQuick .tw-btn:hover{ transform:translateY(-2px) scale(1.03) !important; }
.medexp-wizQuick .tw-btn:active{ transform:translateY(0) scale(0.98) !important; }


/* --------------------------------------------------------------------------
   W6.  Computed value box
   -------------------------------------------------------------------------- */
.medexp-wizComputed{
  padding:0.7rem 0.85rem;
  border:1.5px solid color-mix(in srgb, var(--wiz-c1) 18%, transparent);
  border-radius:14px;
  background:linear-gradient(135deg, color-mix(in srgb, var(--wiz-c1) 4%, #fff), color-mix(in srgb, var(--wiz-c2) 3%, #fff));
  font-weight:800;
  color:rgba(22,44,85,0.78);
}


/* --------------------------------------------------------------------------
   W7.  Chips — accent-responsive
   -------------------------------------------------------------------------- */
.medexp-wizChips{ display:flex; flex-wrap:wrap; gap:0.5rem; }

.medexp-chip{
  border:1.5px solid rgba(148,163,184,0.22);
  background:rgba(255,255,255,.80) !important;
  backdrop-filter:blur(6px);
  border-radius:999px;
  width:46px; height:46px;
  display:inline-flex; align-items:center; justify-content:center;
  padding:0;
  font-weight:900;
  font-size:0.88rem;
  color:rgba(22,44,85,0.85) !important;
  -webkit-text-fill-color:rgba(22,44,85,0.85) !important;
  cursor:pointer;
  transition:all .18s cubic-bezier(.34,1.56,.64,1);
}
.medexp-chip:hover{
  border-color:color-mix(in srgb, var(--wiz-c1) 40%, transparent);
  background:color-mix(in srgb, var(--wiz-c1) 4%, #fff);
  transform:translateY(-1px);
}
.medexp-chip.is-on{
  background:linear-gradient(135deg, var(--wiz-c1), var(--wiz-c2)) !important;
  border-color:transparent !important;
  color:#fff !important;
  -webkit-text-fill-color:#fff !important;
  box-shadow:0 2px 10px color-mix(in srgb, var(--wiz-c1) 30%, transparent), 0 6px 20px color-mix(in srgb, var(--wiz-c1) 18%, transparent);
  transform:scale(1.08);
  font-weight:900;
}
.medexp-chip.is-on:hover{
  box-shadow:0 2px 12px color-mix(in srgb, var(--wiz-c1) 36%, transparent), 0 8px 24px color-mix(in srgb, var(--wiz-c1) 22%, transparent);
}
.medexp-chip:disabled{ opacity:.35; cursor:not-allowed; }
.medexp-chip:disabled:hover{ border-color:rgba(148,163,184,0.22); background:rgba(255,255,255,.80); transform:none; }


/* --------------------------------------------------------------------------
   W8.  Toggle
   -------------------------------------------------------------------------- */
.medexp-wizToggle{
  display:flex; align-items:center; gap:0.7rem;
  padding:0.6rem 0.8rem;
  border:1.5px solid color-mix(in srgb, var(--wiz-c1) 18%, transparent);
  border-radius:14px;
  background:linear-gradient(135deg, color-mix(in srgb, var(--wiz-c1) 4%, #fff), rgba(255,255,255,.92));
  width:fit-content;
  transition:border-color .15s ease, background .15s ease;
}
.medexp-wizToggle:hover{
  border-color:color-mix(in srgb, var(--wiz-c1) 30%, transparent);
}
.medexp-wizToggle input{
  -webkit-appearance:none; appearance:none;
  width:1.25rem; height:1.25rem;
  border:2px solid rgba(148,163,184,.30);
  border-radius:5px;
  background:#fff;
  cursor:pointer;
  position:relative;
  transition:all .15s ease;
  flex-shrink:0;
}
.medexp-wizToggle input:checked{
  background:var(--wiz-c1) !important;
  border-color:var(--wiz-c1) !important;
}
.medexp-wizToggle input:checked::after{
  content:'';
  position:absolute;
  left:3.5px; top:1px;
  width:5px; height:9px;
  border:solid #fff; border-width:0 2px 2px 0;
  transform:rotate(45deg);
}
.medexp-wizToggleText{ font-weight:800; color:rgba(22,44,85,0.72); font-size:0.9rem; }


/* --------------------------------------------------------------------------
   W9.  Inputs focus
   -------------------------------------------------------------------------- */
.medexp-wiz .tw-input{
  border-radius:12px;
  border:1.5px solid rgba(148,163,184,0.22);
  transition:border-color .15s ease, box-shadow .15s ease;
}
.medexp-wiz .tw-input:focus{
  border-color:color-mix(in srgb, var(--wiz-c1) 55%, transparent) !important;
  box-shadow:0 0 0 3px color-mix(in srgb, var(--wiz-c1) 12%, transparent) !important;
}


/* --------------------------------------------------------------------------
   W10.  Slider + minutes
   -------------------------------------------------------------------------- */
.medexp-wizSlider{ width:100%; accent-color:var(--wiz-c1); }
.medexp-wizMins{ display:flex; align-items:center; gap:0.75rem; }
.medexp-wizMins input[type="number"]{ width:110px; }


/* --------------------------------------------------------------------------
   W11.  Choice row
   -------------------------------------------------------------------------- */
.medexp-wizChoiceRow{ display:flex; gap:0.55rem; flex-wrap:wrap; }


/* --------------------------------------------------------------------------
   W12.  Link button
   -------------------------------------------------------------------------- */
.medexp-wizLinkBtn{
  background:transparent; border:0; padding:0;
  color:var(--wiz-c1);
  font-weight:800; text-decoration:underline;
  text-underline-offset:2px;
  cursor:pointer; width:fit-content;
  transition:color .12s ease;
}
.medexp-wizLinkBtn:hover{ color:color-mix(in srgb, var(--wiz-c1) 70%, #000); }


/* --------------------------------------------------------------------------
   W13.  Sections (Personalize step cards)
   -------------------------------------------------------------------------- */
.medexp-wizSection{
  padding:0.9rem 1rem;
  border:1.5px solid color-mix(in srgb, var(--wiz-c1) 12%, transparent);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.96) 0%, color-mix(in srgb, var(--wiz-c1) 3%, #fff) 100%);
  box-shadow:0 1px 3px rgba(2,6,23,.02);
}
.medexp-wizSectionTitle{
  font-weight:900; font-size:1rem;
  color:rgba(22,44,85,0.82);
  letter-spacing:-0.01em;
}

.medexp-wizFocusList{ margin-top:0.6rem; }
.medexp-wizCheckboxGrid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:0.45rem 0.8rem;
  max-height:240px; overflow:auto; padding-right:0.25rem;
}
.medexp-wizCheck{
  display:flex; align-items:flex-start; gap:0.55rem;
  padding:0.4rem 0.5rem;
  border-radius:10px;
  transition:background .12s ease;
}
.medexp-wizCheck:hover{ background:color-mix(in srgb, var(--wiz-c1) 5%, #fff); }
.medexp-wizCheck input{ margin-top:0.15rem; accent-color:var(--wiz-c1); }
.medexp-wizCheckText{
  font-weight:750; color:rgba(22,44,85,0.72);
  font-size:0.9rem; line-height:1.3;
}


/* --------------------------------------------------------------------------
   W14.  Pills (blackout dates)
   -------------------------------------------------------------------------- */
.medexp-wizPills{ display:flex; flex-wrap:wrap; gap:0.45rem; margin-top:0.65rem; }
.medexp-pill{
  display:inline-flex; align-items:center; gap:0.5rem;
  border:1px solid color-mix(in srgb, var(--wiz-c1) 18%, transparent);
  border-radius:999px;
  padding:0.3rem 0.65rem;
  background:color-mix(in srgb, var(--wiz-c1) 4%, #fff);
  backdrop-filter:blur(4px);
  font-size:0.82rem; font-weight:700;
  color:rgba(22,44,85,0.68);
}
.medexp-pillX{
  border:0; background:transparent; cursor:pointer;
  font-weight:900; line-height:1;
  color:rgba(15,23,42,0.40);
  transition:color .12s ease;
}
.medexp-pillX:hover{ color:rgba(244,63,94,0.80); }


/* --------------------------------------------------------------------------
   W15.  Review summary (Step 5)
   -------------------------------------------------------------------------- */
.medexp-wizSummary{
  border:1.5px solid rgba(148,163,184,.12);
  border-radius:16px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);
  padding:0;
  overflow:hidden;
}
.medexp-wizSummaryRow{
  display:flex; justify-content:space-between; align-items:center;
  gap:1rem; padding:0.75rem 1rem;
  border-bottom:1px solid rgba(148,163,184,.08);
  transition:background .12s ease;
}
.medexp-wizSummaryRow:last-child{ border-bottom:none; }
.medexp-wizSummaryRow:hover{ background:rgba(148,163,184,.04); }

.medexp-wizSummaryK{
  display:flex; align-items:center; gap:0.5rem;
  color:rgba(15,23,42,0.60) !important;
  -webkit-text-fill-color:rgba(15,23,42,0.60) !important;
  font-weight:600; font-size:0.88rem;
}
.medexp-wizSummaryK::before{
  content:''; width:7px; height:7px;
  border-radius:999px; flex-shrink:0;
}
.medexp-wizSummaryRow:nth-child(1) .medexp-wizSummaryK::before{ background:color-mix(in srgb, var(--wiz-c1) 75%, transparent); }
.medexp-wizSummaryRow:nth-child(2) .medexp-wizSummaryK::before{ background:color-mix(in srgb, var(--wiz-c2) 70%, transparent); }
.medexp-wizSummaryRow:nth-child(3) .medexp-wizSummaryK::before{ background:rgba(236,72,153,.60); }
.medexp-wizSummaryRow:nth-child(4) .medexp-wizSummaryK::before{ background:rgba(139,92,246,.60); }
.medexp-wizSummaryRow:nth-child(5) .medexp-wizSummaryK::before{ background:rgba(234,179,8,.65); }
.medexp-wizSummaryRow:nth-child(6) .medexp-wizSummaryK::before{ background:rgba(163,230,53,.65); }

.medexp-wizSummaryV{
  color:rgba(22,44,85,0.90) !important;
  -webkit-text-fill-color:rgba(22,44,85,0.90) !important;
  font-weight:700; font-size:0.88rem; text-align:right;
}


/* --------------------------------------------------------------------------
   W16.  Footer bar — progress + XP
   -------------------------------------------------------------------------- */
.medexp-wizFoot{
  display:flex; align-items:center; justify-content:space-between;
  gap:1rem;
  padding:.85rem 1.5rem;
  border-top:1px solid rgba(148,163,184,.10);
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
}
/* Thin progress bar at top of footer */
.medexp-wizFoot::before{
  content:"";
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:rgba(148,163,184,.08);
}
.medexp-wizFootLeft, .medexp-wizFootRight{
  display:flex; gap:0.55rem; align-items:center;
}

/* XP preview in footer */
.medexp-wizFootXP{
  display:inline-flex;
  align-items:center;
  gap:.25rem;
  padding:.15rem .55rem;
  border-radius:999px;
  background:rgba(234,179,8,.08);
  border:1px solid rgba(234,179,8,.15);
  font-size:.68rem;
  font-weight:900;
  color:rgba(161,98,7,.75);
}
.medexp-wizFootXP svg{
  width:11px; height:11px; fill:#EAB308;
}

/* Animated arrow bounce on Next button */
.medexp-wizNextArrow{
  display:inline-block;
  animation:wizArrowBounce 1.5s ease-in-out infinite;
  margin-left:.2rem;
}
@keyframes wizArrowBounce{
  0%, 100%{ transform:translateX(0); }
  50%{ transform:translateX(3px); }
}


/* --------------------------------------------------------------------------
   W17.  Error + inline note messages
   -------------------------------------------------------------------------- */
.medexp-wizError{
  padding:0.65rem 0.8rem;
  border-radius:14px;
  border:1.5px solid rgba(244,63,94,0.22);
  background:linear-gradient(135deg, rgba(244,63,94,0.05), rgba(255,255,255,.95));
  color:rgba(190,18,60,0.88);
  font-weight:850; font-size:0.9rem;
}
.medexp-wizInlineNote{
  padding:0.65rem 0.8rem;
  border-radius:14px;
  border:1.5px solid color-mix(in srgb, var(--wiz-c1) 22%, transparent);
  background:linear-gradient(135deg, color-mix(in srgb, var(--wiz-c1) 5%, #fff), color-mix(in srgb, var(--wiz-c2) 3%, #fff));
  color:color-mix(in srgb, var(--wiz-c1) 85%, #000);
  font-weight:850; font-size:0.9rem;
}
.medexp-wizAvail{
  font-size:0.88rem; color:rgba(15,23,42,0.52);
  margin-top:-0.3rem; font-weight:600;
}


/* ==========================================================================
   CELEBRATION SCREEN — shown after plan creation
   ========================================================================== */
.medexp-celebrate{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:3rem 2rem;
  min-height:420px;
  background:linear-gradient(150deg, #162C55 0%, #1A3A6B 25%, #7C3AED 50%, #EC4899 75%, #F97316 100%);
  border-radius:24px;
  overflow:hidden;
  animation:celebFadeIn .6s ease;
}
@keyframes celebFadeIn{
  from{ opacity:0; transform:scale(.95); }
  to{ opacity:1; transform:scale(1); }
}

/* Sparkles */
.medexp-celebrate__sparks{
  position:absolute; inset:0;
  pointer-events:none; overflow:hidden;
}
.medexp-celebrate__spark{
  position:absolute;
  font-size:24px;
  animation:celebSparkle 2.5s ease-in-out infinite;
  filter:drop-shadow(0 0 6px rgba(255,255,255,.3));
}
.medexp-celebrate__spark:nth-child(1){ top:12%; left:8%; animation-delay:0s; }
.medexp-celebrate__spark:nth-child(2){ top:18%; right:12%; animation-delay:.4s; }
.medexp-celebrate__spark:nth-child(3){ top:65%; left:5%; animation-delay:.8s; }
.medexp-celebrate__spark:nth-child(4){ top:70%; right:8%; animation-delay:1.2s; }
.medexp-celebrate__spark:nth-child(5){ top:35%; right:5%; animation-delay:1.6s; }
.medexp-celebrate__spark:nth-child(6){ bottom:15%; left:15%; animation-delay:.2s; }
.medexp-celebrate__spark:nth-child(7){ bottom:20%; right:18%; animation-delay:.6s; }
@keyframes celebSparkle{
  0%, 100%{ opacity:.3; transform:scale(.7) rotate(0deg); }
  50%{ opacity:1; transform:scale(1.2) rotate(20deg); }
}

/* Central glow */
.medexp-celebrate__glow{
  position:absolute;
  top:38%; left:50%;
  transform:translate(-50%, -50%);
  width:340px; height:340px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(255,255,255,.22), transparent 60%);
  pointer-events:none;
  animation:celebGlow 3s ease-in-out infinite;
}
@keyframes celebGlow{
  0%, 100%{ transform:translate(-50%, -50%) scale(1); opacity:.6; }
  50%{ transform:translate(-50%, -50%) scale(1.18); opacity:1; }
}

/* Content */
.medexp-celebrate__icon{
  width:76px; height:76px;
  margin-bottom:1.25rem;
  position:relative; z-index:1;
  filter:drop-shadow(0 4px 20px rgba(234,179,8,.45));
}
.medexp-celebrate__icon svg{ width:100%; height:100%; }
.medexp-celebrate__label{
  font-size:.76rem; font-weight:900;
  letter-spacing:.10em; text-transform:uppercase;
  color:rgba(255,255,255,.90) !important;
  -webkit-text-fill-color:rgba(255,255,255,.90) !important;
  margin-bottom:.4rem;
  position:relative; z-index:1;
  text-shadow:0 1px 8px rgba(0,0,0,.25);
}
.medexp-celebrate__title{
  font-size:2rem; font-weight:900;
  color:#fff !important;
  -webkit-text-fill-color:#fff !important;
  line-height:1.15;
  position:relative; z-index:1;
  text-shadow:0 2px 16px rgba(0,0,0,.20);
}
.medexp-celebrate__desc{
  margin-top:.65rem;
  font-size:.95rem; font-weight:600;
  color:rgba(255,255,255,.88) !important;
  -webkit-text-fill-color:rgba(255,255,255,.88) !important;
  max-width:420px;
  line-height:1.5;
  position:relative; z-index:1;
  text-shadow:0 1px 8px rgba(0,0,0,.15);
}

/* XP + badge row */
.medexp-celebrate__rewards{
  display:flex; align-items:center; gap:.75rem;
  margin-top:1.5rem;
  position:relative; z-index:1;
}
.medexp-celebrate__xp{
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.45rem 1rem;
  border-radius:999px;
  background:linear-gradient(135deg, #EAB308, #F97316);
  color:#fff !important; -webkit-text-fill-color:#fff !important;
  font-weight:900; font-size:.88rem;
  box-shadow:0 4px 14px rgba(234,179,8,.45), 0 0 0 2px rgba(255,255,255,.15);
  text-shadow:0 1px 3px rgba(0,0,0,.15);
}
.medexp-celebrate__xp svg{ width:15px; height:15px; fill:#fff; }

.medexp-celebrate__badge{
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.45rem 1rem;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,.08));
  backdrop-filter:blur(12px);
  border:1.5px solid rgba(255,255,255,.25);
  color:#fff !important; -webkit-text-fill-color:#fff !important;
  font-weight:900; font-size:.88rem;
  box-shadow:0 4px 14px rgba(0,0,0,.12);
  text-shadow:0 1px 3px rgba(0,0,0,.15);
}

/* CTA button */
.medexp-celebrate__cta{
  margin-top:2rem;
  position:relative; z-index:1;
  display:inline-flex; align-items:center; gap:.5rem;
  padding:1rem 2.5rem;
  border-radius:999px;
  border:1.5px solid rgba(255,255,255,.30);
  background:linear-gradient(135deg, rgba(255,255,255,.18), rgba(255,255,255,.08)) !important;
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  color:#fff !important;
  -webkit-text-fill-color:#fff !important;
  font-weight:900; font-size:1.05rem;
  cursor:pointer;
  box-shadow:0 4px 24px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.25);
  transition:all .2s cubic-bezier(.34,1.56,.64,1);
  letter-spacing:-.01em;
}
.medexp-celebrate__cta:hover{
  transform:translateY(-3px) scale(1.04);
  box-shadow:0 8px 28px rgba(0,0,0,.22), 0 0 0 2px rgba(255,255,255,.30);
}
.medexp-celebrate__cta:active{
  transform:translateY(0) scale(.98);
}


/* ==========================================================================
   PLAN VIEW — Summary, Calendar, Checklist
   ========================================================================== */

/* --------------------------------------------------------------------------
   1.  Summary cards strip
   -------------------------------------------------------------------------- */
.medexp-summary{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:1rem; margin:0 0 1.25rem;
}
@media (max-width:980px){ .medexp-summary{ grid-template-columns:1fr; } }

.medexp-summaryCard{
  --_a:#3BC6C2; --_b:#179D99;
  position:relative;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
  border:1.5px solid color-mix(in srgb, var(--_a) 14%, transparent);
  border-radius:20px;
  padding:1.15rem 1.25rem;
  display:flex; flex-direction:column; gap:0.35rem;
  box-shadow:0 1px 0 rgba(17,24,39,.02), 0 4px 14px rgba(2,6,23,.05), 0 12px 32px rgba(2,6,23,.03);
  transition:transform .22s cubic-bezier(.34,1.56,.64,1), box-shadow .22s ease;
  overflow:hidden;
}
.medexp-summaryCard:hover{
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 1px 0 rgba(17,24,39,.02), 0 8px 20px rgba(2,6,23,.07), 0 16px 40px rgba(2,6,23,.04);
}
.medexp-summaryCard::before{
  content:""; position:absolute; inset:0; border-radius:inherit;
  background:
    radial-gradient(ellipse 70% 50% at 15% 0%, rgba(255,255,255,.55) 0%, transparent 60%),
    linear-gradient(135deg, color-mix(in srgb, var(--_a) 14%, transparent) 0%, color-mix(in srgb, var(--_b) 10%, transparent) 45%, rgba(255,255,255,.92) 100%);
  pointer-events:none;
}
.medexp-summaryCard::after{
  content:""; position:absolute; inset:0; border-radius:inherit; padding:1.5px;
  background:linear-gradient(135deg, var(--_a), var(--_b), var(--_a));
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  opacity:.30; pointer-events:none;
}

.medexp-summaryCard:nth-child(1){ --_a:#3BC6C2; --_b:#117673; }
.medexp-summaryCard:nth-child(2){ --_a:#FB7185; --_b:#F43F5E; }
.medexp-summaryCard:nth-child(3){ --_a:#7C3AED; --_b:#6D28D9; }

.medexp-summaryCard.is-overdue{ --_a:#FB7185; --_b:#F43F5E; border-color:rgba(244,63,94,.12); }

.medexp-summaryLabel{
  font-size:0.8rem; font-weight:900;
  letter-spacing:0.05em; text-transform:uppercase;
  position:relative; z-index:1;
  color:var(--_a) !important;
  -webkit-text-fill-color:var(--_a) !important;
}
.medexp-summaryValue{
  font-size:1.7rem; font-weight:900;
  color:rgba(15,23,42,0.92) !important;
  -webkit-text-fill-color:rgba(15,23,42,0.92) !important;
  line-height:1.1; letter-spacing:-0.025em;
  position:relative; z-index:1;
}
.medexp-summarySub{
  font-size:0.85rem; color:rgba(15,23,42,0.68) !important;
  -webkit-text-fill-color:rgba(15,23,42,0.68) !important;
  font-weight:600;
  position:relative; z-index:1;
}
.medexp-summaryFoot{
  font-size:0.82rem; color:rgba(15,23,42,0.60) !important;
  -webkit-text-fill-color:rgba(15,23,42,0.60) !important;
  margin-top:0.15rem;
  position:relative; z-index:1;
}
.medexp-summaryAction{
  margin-top:0.65rem; display:flex; gap:0.5rem; align-items:center;
  position:relative; z-index:1;
}
.medexp-summaryAction .tw-btn{
  font-size:.82rem; font-weight:800;
  padding:.45rem 1rem; border-radius:999px;
  height:36px; display:inline-flex; align-items:center;
}


/* --------------------------------------------------------------------------
   2.  Plan grid
   -------------------------------------------------------------------------- */
.medexp-planGrid{
  display:grid;
  grid-template-columns:minmax(420px, 1fr) minmax(420px, 1fr);
  gap:1.25rem; align-items:start;
}
@media (max-width:980px){ .medexp-planGrid{ grid-template-columns:1fr; } }


/* --------------------------------------------------------------------------
   3.  Calendar
   -------------------------------------------------------------------------- */
.medexp-cal{
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(10px);
  border:1.5px solid rgba(23,157,153,.10);
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 1px 0 rgba(17,24,39,.02), 0 4px 14px rgba(2,6,23,.05), 0 12px 32px rgba(2,6,23,.03);
}
@media (min-width:981px){ .medexp-cal{ position:sticky; top:1.25rem; } }

.medexp-calHead{
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem 1.25rem;
  border-bottom:1px solid rgba(148,163,184,0.14);
  background:linear-gradient(180deg, rgba(240,253,250,.50) 0%, rgba(255,255,255,.95) 100%);
  gap:.75rem;
}
.medexp-calHead > div:first-child{ min-width:0; }
.medexp-calTitle{
  font-weight:900; font-size:1.15rem;
  color:rgba(22,44,85,0.92); letter-spacing:-0.015em;
}
.medexp-calNav{ display:flex; align-items:center; gap:.45rem; flex-wrap:nowrap; }

.medexp-calNavBtn{
  width:38px; height:38px;
  display:inline-flex; align-items:center; justify-content:center;
  border:1.5px solid rgba(148,163,184,.18); border-radius:999px;
  background:rgba(255,255,255,.75);
  color:rgba(22,44,85,.65);
  cursor:pointer; transition:all .15s ease;
  padding:0; appearance:none; -webkit-appearance:none;
}
.medexp-calNavBtn:hover{
  border-color:rgba(23,157,153,.30); color:#179D99;
  background:#fff; box-shadow:0 2px 6px rgba(2,6,23,.06);
  transform:translateY(-1px);
}
.medexp-calNavBtn:active{ transform:translateY(0); }
.medexp-calNavBtn:focus-visible{ outline:2px solid #179D99; outline-offset:2px; }

.medexp-calRegenBtn{
  height:38px;
  display:inline-flex; align-items:center; justify-content:center;
  white-space:nowrap; padding:0 1rem;
  border-radius:999px; border:none;
  background:linear-gradient(135deg, #179D99 0%, #3BC6C2 100%);
  color:#fff; font-weight:900; font-size:.82rem;
  cursor:pointer;
  box-shadow:0 2px 8px rgba(23,157,153,.22);
  transition:all .18s cubic-bezier(.34,1.56,.64,1);
  line-height:1;
}
.medexp-calRegenBtn:hover{ transform:translateY(-2px) scale(1.02); box-shadow:0 4px 12px rgba(23,157,153,.30); }
.medexp-calRegenBtn:active{ transform:translateY(0) scale(.98); }
.medexp-calRegenBtn:focus-visible{ outline:2px solid #179D99; outline-offset:2px; }

.medexp-calDow{
  display:grid; grid-template-columns:repeat(7, 1fr);
  gap:0.4rem; padding:0.75rem 0.85rem 0.3rem;
  color:rgba(23,157,153,.55);
  font-size:0.7rem; font-weight:900;
  letter-spacing:0.06em; text-transform:uppercase;
  text-align:center;
}
.medexp-calGrid{
  display:grid; grid-template-columns:repeat(7, 1fr);
  gap:0.4rem; padding:0.35rem 0.85rem 0.85rem;
}

.medexp-calDay{
  border:1.5px solid rgba(148,163,184,0.12);
  background:rgba(255,255,255,.55);
  border-radius:14px;
  min-height:clamp(64px, 11vw, 88px);
  padding:0.5rem;
  display:flex; flex-direction:column;
  cursor:pointer;
  transition:transform .14s cubic-bezier(.34,1.56,.64,1), box-shadow .18s ease, background-color .15s ease, border-color .15s ease;
  position:relative;
}
.medexp-calDay:hover{
  background:rgba(255,255,255,.95);
  transform:translateY(-2px);
  box-shadow:0 4px 14px rgba(2,6,23,.08), 0 10px 24px rgba(2,6,23,.04);
  border-color:rgba(23,157,153,0.28);
}
.medexp-calDay:active{ transform:translateY(0px); }
.medexp-calDay.is-out{ opacity:0.25; cursor:default; }
.medexp-calDay.is-out:hover{ box-shadow:none; background:rgba(255,255,255,.55); transform:none; border-color:rgba(148,163,184,0.12); }
.medexp-calDay.is-selected{
  border-color:rgba(23,157,153,0.65);
  box-shadow:0 0 0 3px rgba(23,157,153,.12), 0 4px 12px rgba(23,157,153,.10);
  background:rgba(23,157,153,0.04);
}
.medexp-calDay.is-today{
  border-color:rgba(23,157,153,0.55);
  background:linear-gradient(135deg, rgba(23,157,153,.05) 0%, rgba(59,198,194,.03) 100%);
}
.medexp-calDay.is-today::before{
  content:"";
  position:absolute; top:4px; right:4px;
  width:6px; height:6px; border-radius:999px;
  background:#179D99;
  box-shadow:0 0 6px rgba(23,157,153,.40);
}

.medexp-calNum{ font-weight:900; font-size:0.92rem; color:rgba(15,23,42,0.85); }
.medexp-calDay.is-today .medexp-calNum{ color:#117673; }
.medexp-calDay.is-selected .medexp-calNum{ color:#179D99; }
.medexp-calSub{
  margin-top:0.15rem; font-size:0.7rem;
  font-weight:700; color:rgba(15,23,42,0.50);
}
.medexp-calDots{ margin-top:auto; display:flex; gap:0.25rem; align-items:center; }
.medexp-dot{
  width:5px; height:5px; border-radius:999px;
  background:rgba(148,163,184,0.25);
  transition:transform .15s ease, box-shadow .15s ease;
}
.medexp-dot.done{ background:#10B981; box-shadow:0 0 4px rgba(16,185,129,0.25); }
.medexp-dot.pending{ background:#179D99; box-shadow:0 0 4px rgba(23,157,153,0.20); }
.medexp-dot.overdue{ background:#F43F5E; box-shadow:0 0 4px rgba(244,63,94,0.25); }


/* --------------------------------------------------------------------------
   4.  Checklist
   -------------------------------------------------------------------------- */
.medexp-checklist{
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(10px);
  border:1.5px solid rgba(23,157,153,.10);
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 1px 0 rgba(17,24,39,.02), 0 4px 14px rgba(2,6,23,.05), 0 12px 32px rgba(2,6,23,.03);
  display:flex; flex-direction:column;
  min-height:420px;
}
.medexp-checklistHead{
  padding:1.1rem 1.25rem;
  border-bottom:1px solid rgba(148,163,184,0.14);
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:0.75rem;
  position:sticky; top:0;
  background:linear-gradient(180deg, rgba(240,253,250,.50) 0%, rgba(255,255,255,.92) 100%);
  backdrop-filter:blur(12px);
  z-index:2;
}
.medexp-checklistTitleWrap{ display:flex; align-items:center; gap:.65rem; min-width:0; }
.medexp-checklistRing{
  position:relative; width:36px; height:36px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.medexp-checklistRingPct{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-size:.65rem; font-weight:900;
  color:rgba(22,44,85,.75); letter-spacing:-.02em;
}
.medexp-checklistTitle{
  font-weight:900; font-size:1.15rem;
  color:rgba(22,44,85,0.92); letter-spacing:-0.015em;
}
.medexp-checklistDate{
  font-size:.82rem; font-weight:700;
  color:rgba(15,23,42,.55); margin-top:.1rem;
}
.medexp-checklistBody{ overflow:auto; max-height:calc(70vh - 78px); }

/* Empty state */
.medexp-checklistEmpty{
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center;
  padding:2.5rem 1.5rem;
  min-height:200px;
}
.medexp-checklistEmpty svg{ opacity:.5; margin-bottom:.6rem; }
.medexp-checklistEmpty__title{
  font-size:1.05rem; font-weight:900;
  color:rgba(22,44,85,.75);
}
.medexp-checklistEmpty__desc{
  font-size:.88rem; color:rgba(15,23,42,.50);
  margin-top:.25rem; max-width:320px;
}

/* Section dividers */
.medexp-checklistSection{
  display:flex; align-items:center;
  padding:.7rem 1rem;
  background:rgba(248,250,252,.85);
  border-bottom:1px solid rgba(148,163,184,.10);
}
.medexp-checklistSection--overdue{
  background:rgba(244,63,94,.03);
  border-bottom-color:rgba(244,63,94,.08);
}

/* Task rows */
.medexp-task{
  display:flex; align-items:flex-start; gap:0.8rem;
  padding:0.85rem 1.1rem;
  margin:0.35rem 0.65rem;
  border:1.5px solid rgba(148,163,184,.12);
  border-radius:14px;
  background:rgba(255,255,255,.60);
  transition:background .18s ease, border-color .18s ease, box-shadow .18s ease, transform .14s ease;
  position:relative;
}
.medexp-task:first-child{ margin-top:0.65rem; }
.medexp-task:last-child{ margin-bottom:0.65rem; }
.medexp-task:hover{
  background:rgba(255,255,255,.95);
  border-color:rgba(23,157,153,.18);
  box-shadow:0 2px 8px rgba(2,6,23,.04);
  transform:translateY(-1px);
}

/* Custom checkbox */
.medexp-task input[type="checkbox"]{
  -webkit-appearance:none; appearance:none;
  width:22px; height:22px; min-width:22px;
  border:2px solid rgba(23,157,153,.35); border-radius:7px;
  background:#fff; cursor:pointer;
  transition:all .15s ease;
  margin-top:1px; position:relative;
}
.medexp-task input[type="checkbox"]:hover{
  border-color:rgba(23,157,153,.55); background:rgba(23,157,153,.04);
}
.medexp-task input[type="checkbox"]:checked{
  background:linear-gradient(135deg, #179D99 0%, #3BC6C2 100%);
  border-color:transparent;
  box-shadow:0 2px 6px rgba(23,157,153,.25);
}
.medexp-task input[type="checkbox"]:checked::after{
  content:""; position:absolute;
  top:3px; left:6px;
  width:6px; height:10px;
  border:solid #fff; border-width:0 2.5px 2.5px 0;
  transform:rotate(45deg);
}

.medexp-taskTitle{
  font-weight:800; color:rgba(22,44,85,0.88); line-height:1.3;
  overflow:hidden; text-overflow:ellipsis;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
}
.medexp-taskTitle a.tw-link{
  color:rgba(22,44,85,0.88) !important;
  text-decoration:underline !important; text-decoration-color:rgba(23,157,153,.25) !important;
  text-underline-offset:2px; font-weight:800 !important;
  transition:color .12s ease, text-decoration-color .12s ease;
}
.medexp-taskTitle a.tw-link:hover{
  color:#179D99 !important;
  text-decoration-color:#179D99 !important;
}
.medexp-taskMeta{
  margin-top:0.35rem; display:flex; align-items:center;
  gap:0.45rem; flex-wrap:wrap;
  font-size:0.78rem; color:rgba(15,23,42,0.50);
  font-weight:700; letter-spacing:0.01em;
}

.medexp-taskBadge{
  display:inline-flex; align-items:center; gap:.3rem;
  padding:.15rem .5rem; border-radius:999px;
  font-size:.68rem; font-weight:900;
  letter-spacing:.02em; text-transform:uppercase;
  line-height:1.2; white-space:nowrap;
}
.medexp-taskBadgeIcon{ display:inline-flex; align-items:center; width:12px; height:12px; }
.medexp-taskBadgeIcon svg{ width:12px; height:12px; }
.medexp-taskTime{ font-size:.78rem; font-weight:700; color:rgba(15,23,42,.50); }
.medexp-taskOverdue{
  font-size:.68rem; font-weight:900;
  color:rgba(244,63,94,.85);
  text-transform:uppercase; letter-spacing:.02em;
}

.medexp-task.is-overdue{ border-left:3px solid rgba(244,63,94,.45); }
.medexp-task.is-done{
  opacity:.50;
  border-color:rgba(16,185,129,.15);
  background:rgba(16,185,129,.03);
}
.medexp-task.is-done .medexp-taskTitle,
.medexp-task.is-done .medexp-taskTitle a{
  text-decoration:line-through;
  color:rgba(15,23,42,0.38) !important;
}

.medexp-task .tw-btn-secondary{
  font-size:.78rem; font-weight:800;
  padding:.4rem .85rem; border-radius:999px;
  border:1.5px solid rgba(148,163,184,.18);
  white-space:nowrap;
  transition:all .15s ease;
}
.medexp-task .tw-btn-secondary:hover{
  border-color:rgba(23,157,153,.30);
  color:#179D99;
  transform:translateY(-1px);
  box-shadow:0 2px 6px rgba(2,6,23,.06);
}


/* --------------------------------------------------------------------------
   5.  Badges
   -------------------------------------------------------------------------- */
.medexp-badge{
  display:inline-flex; align-items:center; gap:0.35rem;
  padding:0.28rem 0.65rem;
  border-radius:999px;
  font-size:0.72rem; font-weight:900;
  border:1px solid rgba(23,157,153,0.18);
  background:rgba(23,157,153,.06);
  backdrop-filter:blur(6px);
  color:rgba(17,118,115,0.82);
}
.medexp-badge.overdue{
  border-color:rgba(244,63,94,.25);
  color:rgba(190,18,60,0.88);
  background:rgba(244,63,94,.06);
}


/* --------------------------------------------------------------------------
   5b.  Accessibility — focus rings, keyboard navigation
   -------------------------------------------------------------------------- */
.medexp-calDay:focus-visible,
.medexp-task input[type="checkbox"]:focus-visible,
.medexp-chip:focus-visible,
.medexp-wizStep:focus-visible{
  outline:2px solid #179D99;
  outline-offset:2px;
}
.medexp-summaryCard:focus-within{
  box-shadow:0 0 0 2px rgba(23,157,153,.25), 0 4px 14px rgba(2,6,23,.05);
}

/* Selected calendar day: higher contrast */
.medexp-calDay.is-selected .medexp-calNum{ color:#117673; font-weight:900; }
.medexp-calDay.is-selected .medexp-calSub{ color:rgba(17,118,115,.65); }


/* --------------------------------------------------------------------------
   6.  Modal overlay + card
   -------------------------------------------------------------------------- */
.medexp-modalOverlay{
  position:fixed; inset:0;
  background:rgba(22,44,85,.45);
  backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  padding:1.25rem;
  z-index:100000 !important;
}
.medexp-modalOverlay .medexp-modal{
  width:min(560px, 100%);
  background:linear-gradient(180deg, #fff 0%, #F8FAFB 100%);
  border:1px solid rgba(148,163,184,0.22);
  border-radius:22px;
  box-shadow:0 1px 0 rgba(17,24,39,.02), 0 16px 40px rgba(2,6,23,.14), 0 32px 64px rgba(2,6,23,.08);
  padding:0;
  position:relative; overflow:hidden;
  display:block !important; visibility:visible !important; opacity:1 !important;
}
.medexp-modalOverlay .medexp-modal::before{
  content:""; position:absolute;
  top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--wiz-c1, #179D99), var(--wiz-c2, #3BC6C2), var(--wiz-c1, #179D99));
  pointer-events:none;
}
.medexp-modalTitle{
  font-size:1.15rem; font-weight:900;
  color:rgba(22,44,85,0.92); letter-spacing:-0.01em;
}


/* --------------------------------------------------------------------------
   7.  Wide modal
   -------------------------------------------------------------------------- */
.medexp-modalOverlay .medexp-modal--wide{
  width:min(840px, calc(100% - 2rem));
  max-height:calc(100vh - 2.5rem);
  overflow:auto;
}


/* --------------------------------------------------------------------------
   20.  Responsive
   -------------------------------------------------------------------------- */

/* ---- 1024px: Large tablets ---- */
@media (max-width: 1024px){
  .medexp-summary{ gap:.85rem; }
  .medexp-planGrid{ gap:1rem; }
  .medexp-calHead{ padding:1rem 1.1rem; }
  .medexp-calRegenBtn{ font-size:.78rem; padding:0 .85rem; }
}

/* ---- 768px: Tablets ---- */
@media (max-width: 768px){
  .medexp-summary{ grid-template-columns:1fr; gap:.75rem; }
  .medexp-planGrid{ grid-template-columns:1fr; }
  .medexp-cal{ position:static !important; }
  .medexp-calGrid{ gap:.35rem; }
  .medexp-calDow{ gap:.35rem; font-size:.65rem; }
  .medexp-calNavBtn{ width:34px; height:34px; }
  .medexp-calRegenBtn{ height:34px; font-size:.78rem; }
  .medexp-checklistBody{ max-height:calc(60vh - 78px); }
}

/* ---- 680px: Large phones ---- */
@media (max-width: 680px){
  .medexp-planHero{ padding:1.25rem 1rem 1.1rem; }
  .medexp-planHero__title{ font-size:1.15rem; gap:.5rem; }
  .medexp-planHero__icon{ width:22px; height:22px; }
  .medexp-planHero__sub{ font-size:.84rem; opacity:.75; }

  .medexp-wizHero{ padding:1rem; }
  .medexp-wizOrb{ width:56px; height:56px; }
  .medexp-wizOrb__emoji{ font-size:24px; }
  .medexp-wizOrb__icon{ width:22px; height:22px; }
  .medexp-wizHero__title{ font-size:1.1rem; }
  .medexp-wizHero__motiv{ font-size:.82rem; }

  .medexp-wizStepper{
    flex-wrap:nowrap; overflow-x:auto; gap:0.5rem;
    padding:.75rem 1rem .75rem;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .medexp-wizStepper::-webkit-scrollbar{ display:none; }
  .medexp-wizStepper::before{ left:1rem; right:1rem; }
  .medexp-wizStep{ flex:0 0 auto; min-width:55px; }
  .medexp-wizStepLabel{ max-width:55px; font-size:0.66rem; }

  .medexp-wizBody{ padding:1rem; }
  .medexp-wizFoot{ padding:.75rem 1rem; }

  .medexp-wizRow{ grid-template-columns:1fr; }
  .medexp-wizSummaryRow{ flex-direction:column; align-items:flex-start; gap:0.25rem; }
  .medexp-wizSummaryV{ text-align:left; }
  .medexp-wizCheckboxGrid{ grid-template-columns:1fr; }

  .tw-studyPlanShell{ border-radius:18px; }
  .medexp-summaryCard{ border-radius:16px; padding:1rem; }
  .medexp-cal, .medexp-checklist{ border-radius:16px; }

  .medexp-calDay{ min-height:60px; padding:.4rem; }
  .medexp-calNum{ font-size:.84rem; }
  .medexp-calSub{ font-size:.62rem; }

  .medexp-celebrate{ padding:2rem 1.25rem; min-height:350px; }
  .medexp-celebrate__icon{ width:60px; height:60px; }
  .medexp-celebrate__title{ font-size:1.5rem; }
  .medexp-celebrate__desc{ font-size:.88rem; }

  .medexp-summaryAction .tw-btn{ width:100%; justify-content:center; }
}

/* ---- 480px: Small phones ---- */
@media (max-width: 480px){
  .medexp-summaryCard{ box-shadow:0 2px 8px rgba(2,6,23,.05); }
  .medexp-cal, .medexp-checklist{ box-shadow:0 2px 8px rgba(2,6,23,.05); border-radius:14px; }
  .medexp-task{ margin-left:.4rem; margin-right:.4rem; }
  .medexp-calDay{ min-height:54px; border-radius:10px; }
  .medexp-taskMeta{ flex-direction:column; align-items:flex-start; gap:.3rem; }
}
