/* ============================================================
   Menstrual Cycle Calculator — WordPress Plugin v1.0
   Cormorant Garamond + DM Sans · Teal palette
   Scoped to #mcc-app · !important throughout
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,600;0,700;1,600;1,700&family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

/* ── Reset ─────────────────────────────────────────────── */
#mcc-app, #mcc-app * { box-sizing: border-box !important; -webkit-font-smoothing: antialiased !important; }
#mcc-app button { -webkit-appearance: none !important; appearance: none !important; text-shadow: none !important; text-decoration: none !important; font-family: 'DM Sans', sans-serif !important; }

/* ── Wrapper ────────────────────────────────────────────── */
#mcc-app {
  display: flex !important; justify-content: center !important; width: 100% !important;
  padding: 32px 16px !important; font-family: 'DM Sans', sans-serif !important;
  background: #f0fdfa !important;
  background-image: radial-gradient(ellipse at 10% 10%, rgba(13,148,136,0.09) 0%, transparent 55%), radial-gradient(ellipse at 90% 90%, rgba(20,184,166,0.07) 0%, transparent 55%) !important;
}

/* ── Card ───────────────────────────────────────────────── */
#mcc-app .mcc-card {
  background: #fff !important; border-radius: 24px !important;
  box-shadow: 0 24px 64px rgba(13,148,136,0.13), 0 4px 20px rgba(0,0,0,0.07) !important;
  width: 100% !important; max-width: 600px !important;
  overflow: hidden !important; border: 1px solid rgba(13,148,136,0.12) !important;
}

/* ── Header ─────────────────────────────────────────────── */
#mcc-app .mcc-header {
  background: linear-gradient(145deg, #0d9488 0%, #0f766e 52%, #134e4a 100%) !important;
  padding: 34px 28px 28px !important; text-align: center !important;
  position: relative !important; overflow: hidden !important;
}
#mcc-app .mcc-header::before {
  content: '' !important; position: absolute !important; inset: 0 !important;
  background: radial-gradient(ellipse at 25% 0%, rgba(255,255,255,0.14) 0%, transparent 55%), radial-gradient(ellipse at 75% 110%, rgba(0,0,0,0.10) 0%, transparent 55%) !important;
  pointer-events: none !important;
}
#mcc-app .mcc-header-icon { width: 72px !important; height: 72px !important; margin: 0 auto 14px !important; position: relative !important; z-index: 1 !important; display: block !important; }
#mcc-app .mcc-icon-svg { width: 100% !important; height: 100% !important; display: block !important; }

/* Icon animations */
#mcc-app .mcc-moon-outer { animation: mccBreath 4s ease-in-out infinite !important; transform-origin: 40px 40px !important; }
#mcc-app .mcc-moon-inner { animation: mccBreath 4s ease-in-out infinite 0.3s !important; transform-origin: 40px 40px !important; }
#mcc-app .mcc-dot        { animation: mccDotFade 3s ease-in-out infinite !important; }
#mcc-app .mcc-dot--1 { animation-delay: 0s !important; }
#mcc-app .mcc-dot--2 { animation-delay: 0.2s !important; }
#mcc-app .mcc-dot--3 { animation-delay: 0.4s !important; }
#mcc-app .mcc-dot--4 { animation-delay: 0.6s !important; }
#mcc-app .mcc-dot--ov { animation: mccOvPulse 2s ease-in-out infinite !important; transform-origin: 40px 40px !important; }
#mcc-app .mcc-dot--5 { animation-delay: 0.8s !important; }
#mcc-app .mcc-dot--6 { animation-delay: 1s !important; }
#mcc-app .mcc-dot--7 { animation-delay: 1.2s !important; }
#mcc-app .mcc-dot--8 { animation-delay: 1.4s !important; }
#mcc-app .mcc-pulse-ring--1 { animation: mccPulse 3.5s ease-out infinite !important; transform-origin: 40px 40px !important; }
#mcc-app .mcc-pulse-ring--2 { animation: mccPulse 3.5s ease-out infinite 1.2s !important; transform-origin: 40px 40px !important; }

@keyframes mccBreath  { 0%,100%{transform:scale(1)}       50%{transform:scale(1.06)} }
@keyframes mccDotFade { 0%,100%{opacity:0.4}               50%{opacity:1} }
@keyframes mccOvPulse { 0%,100%{transform:scale(1)}        50%{transform:scale(1.3)} }
@keyframes mccPulse   { 0%{transform:scale(1);opacity:0.4} 70%,100%{transform:scale(1.35);opacity:0} }

#mcc-app .mcc-title {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 2rem !important; font-weight: 700 !important; font-style: italic !important;
  color: #fff !important; margin: 0 0 5px !important; padding: 0 !important;
  position: relative !important; z-index: 1 !important; line-height: 1.1 !important;
  text-shadow: 0 2px 12px rgba(0,0,0,0.2) !important;
  display: block !important; background: none !important; border: none !important; text-transform: none !important;
}
#mcc-app .mcc-subtitle {
  font-family: 'DM Sans', sans-serif !important; font-size: 0.84rem !important;
  color: rgba(255,255,255,0.82) !important; margin: 0 !important; padding: 0 !important;
  position: relative !important; z-index: 1 !important; display: block !important;
}

/* ── Form ───────────────────────────────────────────────── */
#mcc-app .mcc-form-body { padding: 26px 28px 28px !important; display: flex !important; flex-direction: column !important; gap: 22px !important; }

#mcc-app .mcc-field { display: flex !important; flex-direction: column !important; gap: 8px !important; }

#mcc-app .mcc-label {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 1.05rem !important; font-weight: 600 !important; color: #0f766e !important;
  display: flex !important; align-items: center !important; gap: 7px !important;
  margin: 0 !important; padding: 0 !important; border: none !important; background: none !important; text-transform: none !important; line-height: 1.2 !important;
}
#mcc-app .mcc-label-icon { width: 15px !important; height: 15px !important; flex-shrink: 0 !important; color: #14b8a6 !important; }
#mcc-app .mcc-field-hint { font-family: 'DM Sans', sans-serif !important; font-size: 0.74rem !important; color: #94a3b8 !important; }

/* Date input */
#mcc-app .mcc-input-wrap { position: relative !important; }
#mcc-app .mcc-date-inp {
  width: 100% !important; padding: 13px 16px !important;
  border: 1.5px solid #99f6e4 !important; border-radius: 10px !important;
  font-family: 'DM Sans', sans-serif !important; font-size: 1rem !important; font-weight: 600 !important;
  color: #0f172a !important; background: #f0fdfa !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  outline: none !important; box-shadow: none !important; display: block !important; cursor: pointer !important;
}
#mcc-app .mcc-date-inp:focus { border-color: #0d9488 !important; background: #fff !important; box-shadow: 0 0 0 3.5px rgba(13,148,136,0.15) !important; }
#mcc-app .mcc-date-inp::-webkit-calendar-picker-indicator { cursor: pointer !important; opacity: 0.6 !important; filter: invert(40%) sepia(80%) saturate(400%) hue-rotate(140deg) !important; }

/* ── Slider ─────────────────────────────────────────────── */
#mcc-app .mcc-slider-wrap { display: flex !important; flex-direction: column !important; gap: 6px !important; }
#mcc-app .mcc-slider-row  { display: flex !important; align-items: center !important; gap: 14px !important; }

#mcc-app .mcc-slider {
  flex: 1 !important; -webkit-appearance: none !important; appearance: none !important;
  height: 6px !important; border-radius: 50px !important; outline: none !important; cursor: pointer !important; border: none !important;
  background: linear-gradient(to right, #0d9488 0%, #0d9488 var(--pct,32%), #ccfbf1 var(--pct,32%), #ccfbf1 100%) !important;
}
#mcc-app .mcc-slider::-webkit-slider-thumb {
  -webkit-appearance: none !important; width: 22px !important; height: 22px !important;
  border-radius: 50% !important; background: #0d9488 !important;
  box-shadow: 0 2px 8px rgba(13,148,136,0.4) !important; cursor: pointer !important;
  border: 3px solid #fff !important; transition: transform 0.15s !important;
}
#mcc-app .mcc-slider::-moz-range-thumb {
  width: 22px !important; height: 22px !important; border-radius: 50% !important;
  background: #0d9488 !important; box-shadow: 0 2px 8px rgba(13,148,136,0.4) !important;
  cursor: pointer !important; border: 3px solid #fff !important;
}
#mcc-app .mcc-slider:hover::-webkit-slider-thumb { transform: scale(1.12) !important; }

#mcc-app .mcc-val-badge {
  display: flex !important; flex-direction: column !important; align-items: center !important;
  min-width: 54px !important; background: #0d9488 !important; border-radius: 10px !important; padding: 6px 10px !important;
}
#mcc-app .mcc-val-num {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 1.5rem !important; font-weight: 700 !important; font-style: italic !important;
  color: #fff !important; line-height: 1 !important; display: block !important;
}
#mcc-app .mcc-val-unit { font-family: 'DM Sans', sans-serif !important; font-size: 0.6rem !important; font-weight: 600 !important; color: rgba(255,255,255,0.78) !important; text-transform: uppercase !important; letter-spacing: 0.05em !important; }

#mcc-app .mcc-slider-ticks {
  display: flex !important; justify-content: space-between !important;
  font-family: 'DM Sans', sans-serif !important; font-size: 0.7rem !important; color: #94a3b8 !important; font-weight: 500 !important;
}

/* Quick pills */
#mcc-app .mcc-quick-pills { display: flex !important; gap: 6px !important; flex-wrap: wrap !important; }
#mcc-app .mcc-qpill {
  padding: 6px 13px !important; border-radius: 50px !important;
  border: 1.5px solid #99f6e4 !important; background: #fff !important;
  font-family: 'DM Sans', sans-serif !important; font-size: 0.79rem !important; font-weight: 600 !important;
  color: #0f766e !important; cursor: pointer !important; transition: all 0.18s !important;
  box-shadow: none !important; outline: none !important; line-height: 1.3 !important;
}
#mcc-app .mcc-qpill:hover:not(.active) { border-color: #0d9488 !important; color: #0d9488 !important; background: #f0fdfa !important; }
#mcc-app .mcc-qpill.active { background: #0d9488 !important; border-color: #0d9488 !important; color: #fff !important; box-shadow: 0 2px 8px rgba(13,148,136,0.28) !important; }

/* Error */
#mcc-app .mcc-error {
  padding: 11px 14px !important; background: #fef2f2 !important;
  border-left: 3px solid #ef4444 !important; border-radius: 0 8px 8px 0 !important;
  font-family: 'DM Sans', sans-serif !important; font-size: 0.84rem !important; color: #991b1b !important; font-weight: 500 !important;
  animation: mccShake 0.4s ease !important;
}
@keyframes mccShake { 0%,100%{transform:translateX(0)} 20%{transform:translateX(-5px)} 40%{transform:translateX(5px)} 60%{transform:translateX(-3px)} 80%{transform:translateX(3px)} }

/* Submit */
#mcc-app .mcc-submit-btn {
  width: 100% !important; padding: 15px !important;
  background: linear-gradient(135deg, #0d9488, #0f766e) !important;
  border: none !important; border-radius: 12px !important;
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 1.3rem !important; font-weight: 700 !important; font-style: italic !important;
  color: #fff !important; cursor: pointer !important; letter-spacing: 0.02em !important;
  box-shadow: 0 4px 18px rgba(13,148,136,0.40) !important;
  display: flex !important; align-items: center !important; justify-content: center !important; gap: 9px !important;
  margin-top: 2px !important; outline: none !important; line-height: 1.2 !important;
  transition: transform 0.22s ease, box-shadow 0.22s ease !important;
}
#mcc-app .mcc-submit-btn:hover { background: linear-gradient(135deg, #0f766e, #134e4a) !important; transform: translateY(-2px) !important; box-shadow: 0 8px 28px rgba(13,148,136,0.50) !important; color: #fff !important; }
#mcc-app .mcc-submit-btn:active { transform: translateY(0) !important; }

@keyframes mccSpin { to { transform: rotate(360deg); } }
#mcc-app .mcc-spinner { animation: mccSpin 0.8s linear infinite !important; flex-shrink: 0 !important; }

/* ── Result ─────────────────────────────────────────────── */
#mcc-app .mcc-result-panel { padding: 0 28px 28px !important; animation: mccFadeIn 0.4s ease !important; }
@keyframes mccFadeIn { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }

/* ── Hero ───────────────────────────────────────────────── */
#mcc-app .mcc-hero {
  display: flex !important; align-items: flex-start !important; gap: 20px !important;
  padding: 22px 0 20px !important; border-bottom: 1px solid #ccfbf1 !important; margin-bottom: 18px !important;
}

/* Ring */






/* Hero info */





#mcc-app .mcc-hero-stats { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 8px !important; }
#mcc-app .mcc-hstat {
  display: flex !important; align-items: flex-start !important; gap: 7px !important;
  padding: 9px 10px !important; background: #f0fdfa !important;
  border: 1px solid #ccfbf1 !important; border-radius: 10px !important;
}
#mcc-app .mcc-hstat svg { color: #14b8a6 !important; flex-shrink: 0 !important; margin-top: 2px !important; }
#mcc-app .mcc-hstat-lbl { font-family: 'DM Sans', sans-serif !important; font-size: 0.62rem !important; font-weight: 600 !important; color: #94a3b8 !important; text-transform: uppercase !important; letter-spacing: 0.05em !important; display: block !important; }
#mcc-app .mcc-hstat-val { font-family: 'DM Sans', sans-serif !important; font-size: 0.78rem !important; font-weight: 700 !important; color: #0f172a !important; display: block !important; line-height: 1.3 !important; }

/* ── Hero ───────────────────────────────────────────── */
#mcc-app .mcc-hero {
  padding: 20px 0 20px !important;
  border-bottom: 1px solid #ccfbf1 !important;
  margin-bottom: 18px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
}

/* Phase card */
#mcc-app .mcc-phase-card {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  background: linear-gradient(135deg, #0d9488, #0f766e) !important;
  border-radius: 16px !important;
  padding: 18px 20px !important;
  box-shadow: 0 6px 20px rgba(13,148,136,0.28) !important;
}

#mcc-app .mcc-phase-left { display: flex !important; flex-direction: column !important; gap: 4px !important; flex: 1 !important; }





/* Day badge */
#mcc-app .mcc-day-badge {
  display: flex !important; flex-direction: column !important; align-items: center !important;
  background: rgba(255,255,255,0.18) !important; border-radius: 12px !important;
  padding: 10px 16px !important; flex-shrink: 0 !important; min-width: 72px !important;
}
#mcc-app .mcc-day-num {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 2.4rem !important; font-weight: 700 !important; font-style: italic !important;
  color: #fff !important; line-height: 1 !important; display: block !important;
}
#mcc-app .mcc-day-txt {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.6rem !important; font-weight: 600 !important;
  color: rgba(255,255,255,0.75) !important; text-transform: uppercase !important;
  letter-spacing: 0.06em !important; display: block !important; margin-top: 2px !important;
}

/* Cycle progress bar */
#mcc-app .mcc-cycle-bar-wrap {
  position: relative !important;
  padding-bottom: 22px !important;
}

#mcc-app .mcc-cycle-bar {
  display: flex !important; height: 14px !important;
  border-radius: 50px !important; overflow: hidden !important;
  background: #e2e8f0 !important;
  animation: mccBarIn 0.8s ease !important;
}
@keyframes mccBarIn { from{opacity:0;transform:scaleX(0.95)} to{opacity:1;transform:scaleX(1)} }

/* Phase segments (injected by JS as flex children) */
#mcc-app .mcc-bar-seg { height: 100% !important; transition: width 0.9s cubic-bezier(0.4,0,0.2,1) !important; }
#mcc-app .mcc-bar-seg--menstrual  { background: #ef4444 !important; }
#mcc-app .mcc-bar-seg--follicular { background: #cbd5e1 !important; }
#mcc-app .mcc-bar-seg--fertile    { background: #14b8a6 !important; }
#mcc-app .mcc-bar-seg--peak       { background: #0d9488 !important; }
#mcc-app .mcc-bar-seg--ovulation  { background: #0f766e !important; }
#mcc-app .mcc-bar-seg--luteal     { background: #a5b4fc !important; }

/* Today marker */
#mcc-app .mcc-today-marker {
  position: absolute !important; top: 0 !important; transform: translateX(-50%) !important;
  display: flex !important; flex-direction: column !important; align-items: center !important;
  pointer-events: none !important;
  transition: left 0.9s cubic-bezier(0.4,0,0.2,1) !important;
}
#mcc-app .mcc-today-line {
  width: 2.5px !important; height: 20px !important;
  background: #0f172a !important; border-radius: 2px !important;
}
#mcc-app .mcc-today-lbl {
  font-family: 'DM Sans', sans-serif !important; font-size: 0.6rem !important;
  font-weight: 700 !important; color: #0f172a !important;
  background: #fff !important; border: 1px solid #e2e8f0 !important;
  border-radius: 4px !important; padding: 1px 5px !important;
  white-space: nowrap !important; margin-top: 2px !important;
}

#mcc-app .mcc-bar-labels {
  display: flex !important; justify-content: space-between !important;
  font-family: 'DM Sans', sans-serif !important; font-size: 0.68rem !important;
  color: #94a3b8 !important; font-weight: 500 !important;
  margin-top: 4px !important;
}

/* Stats grid */
#mcc-app .mcc-hero-stats {
  display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 8px !important;
}
#mcc-app .mcc-hstat {
  display: flex !important; align-items: flex-start !important; gap: 8px !important;
  padding: 10px 12px !important; background: #f0fdfa !important;
  border: 1px solid #ccfbf1 !important; border-radius: 10px !important;
}
#mcc-app .mcc-hstat svg { color: #14b8a6 !important; flex-shrink: 0 !important; margin-top: 2px !important; }
#mcc-app .mcc-hstat-lbl { font-family: 'DM Sans', sans-serif !important; font-size: 0.62rem !important; font-weight: 600 !important; color: #94a3b8 !important; text-transform: uppercase !important; letter-spacing: 0.05em !important; display: block !important; }
#mcc-app .mcc-hstat-val { font-family: 'DM Sans', sans-serif !important; font-size: 0.8rem !important; font-weight: 700 !important; color: #0f172a !important; display: block !important; line-height: 1.3 !important; }

/* Legend */
#mcc-app .mcc-legend { display: flex !important; flex-wrap: wrap !important; gap: 6px 12px !important; margin-bottom: 16px !important; }
#mcc-app .mcc-legend-item { display: flex !important; align-items: center !important; gap: 5px !important; font-family: 'DM Sans', sans-serif !important; font-size: 0.73rem !important; font-weight: 500 !important; color: #64748b !important; }
#mcc-app .mcc-legend-dot { width: 10px !important; height: 10px !important; border-radius: 50% !important; flex-shrink: 0 !important; display: inline-block !important; }

/* Calendar */
#mcc-app .mcc-cal-section { margin-bottom: 22px !important; }
#mcc-app .mcc-section-title {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 1.05rem !important; font-weight: 600 !important; color: #0f766e !important;
  display: flex !important; align-items: center !important; gap: 7px !important;
  margin: 0 0 12px !important; padding: 0 !important; border: none !important; background: none !important;
}
#mcc-app .mcc-section-title svg { color: #14b8a6 !important; flex-shrink: 0 !important; }

#mcc-app .mcc-calendar { display: grid !important; grid-template-columns: repeat(7,1fr) !important; gap: 4px !important; }
#mcc-app .mcc-cal-day {
  aspect-ratio: 1 !important; display: flex !important; align-items: center !important; justify-content: center !important;
  border-radius: 8px !important; font-family: 'DM Sans', sans-serif !important;
  font-size: 0.76rem !important; font-weight: 600 !important; cursor: default !important;
  position: relative !important; transition: transform 0.15s !important; min-height: 30px !important;
}
#mcc-app .mcc-cal-day--menstrual  { background: rgba(239,68,68,0.15)   !important; color: #ef4444 !important; }
#mcc-app .mcc-cal-day--follicular { background: rgba(148,163,184,0.12) !important; color: #64748b !important; }
#mcc-app .mcc-cal-day--fertile    { background: rgba(20,184,166,0.18)  !important; color: #0f766e !important; }
#mcc-app .mcc-cal-day--peak       { background: rgba(13,148,136,0.25)  !important; color: #0d9488 !important; font-weight: 700 !important; }
#mcc-app .mcc-cal-day--ovulation  { background: #0f766e !important; color: #fff !important; font-weight: 700 !important; box-shadow: 0 2px 8px rgba(13,148,136,0.40) !important; }
#mcc-app .mcc-cal-day--luteal     { background: rgba(99,102,241,0.12)  !important; color: #6366f1 !important; }
#mcc-app .mcc-cal-day--header     { background: transparent !important; color: #94a3b8 !important; font-size: 0.65rem !important; font-weight: 700 !important; }
#mcc-app .mcc-cal-day--today::after {
  content: '' !important; position: absolute !important; bottom: 3px !important; left: 50% !important;
  transform: translateX(-50%) !important; width: 4px !important; height: 4px !important;
  border-radius: 50% !important; background: currentColor !important;
}
#mcc-app .mcc-cal-day:not(.mcc-cal-day--header):hover { transform: scale(1.15) !important; z-index: 1 !important; }

/* Forecast */
#mcc-app .mcc-forecast-section { margin-bottom: 20px !important; }
#mcc-app .mcc-forecast-list { display: flex !important; flex-direction: column !important; gap: 8px !important; }

#mcc-app .mcc-forecast-row {
  display: grid !important; grid-template-columns: 36px 1fr auto !important; align-items: center !important; gap: 12px !important;
  padding: 13px 14px !important; background: #f8fffe !important;
  border: 1px solid #ccfbf1 !important; border-radius: 12px !important;
  animation: mccSlideIn 0.4s ease both !important;
}
#mcc-app .mcc-forecast-row--past { opacity: 0.55 !important; }
@keyframes mccSlideIn { from{opacity:0;transform:translateX(-6px)} to{opacity:1;transform:translateX(0)} }

#mcc-app .mcc-forecast-badge {
  width: 34px !important; height: 34px !important; border-radius: 50% !important;
  background: #0d9488 !important; display: flex !important; align-items: center !important; justify-content: center !important;
  font-family: 'DM Sans', sans-serif !important; font-size: 0.76rem !important; font-weight: 700 !important; color: #fff !important; flex-shrink: 0 !important;
}
#mcc-app .mcc-forecast-badge--past { background: #e2e8f0 !important; color: #94a3b8 !important; }

#mcc-app .mcc-forecast-info { display: flex !important; flex-direction: column !important; gap: 3px !important; }
#mcc-app .mcc-forecast-period {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 0.97rem !important; font-weight: 700 !important; color: #0d9488 !important; display: block !important;
}
#mcc-app .mcc-forecast-row--past .mcc-forecast-period { color: #94a3b8 !important; text-decoration: line-through !important; }
#mcc-app .mcc-forecast-ovul { font-family: 'DM Sans', sans-serif !important; font-size: 0.72rem !important; color: #64748b !important; display: block !important; }
#mcc-app .mcc-forecast-tag {
  font-family: 'DM Sans', sans-serif !important; font-size: 0.68rem !important; font-weight: 700 !important;
  color: #0f766e !important; background: #ccfbf1 !important; border-radius: 6px !important;
  padding: 3px 8px !important; white-space: nowrap !important; align-self: center !important;
}
#mcc-app .mcc-forecast-tag--next { background: #0d9488 !important; color: #fff !important; }

/* Disclaimer */
#mcc-app .mcc-disclaimer {
  display: flex !important; align-items: flex-start !important; gap: 8px !important;
  padding: 11px 14px !important; background: #f1f5f9 !important;
  border-radius: 10px !important; margin-bottom: 20px !important;
}
#mcc-app .mcc-disclaimer svg { color: #94a3b8 !important; flex-shrink: 0 !important; margin-top: 1px !important; }
#mcc-app .mcc-disclaimer span { font-family: 'DM Sans', sans-serif !important; font-size: 0.74rem !important; color: #64748b !important; line-height: 1.5 !important; }

/* Recalculate */
#mcc-app .mcc-recalc-btn {
  display: inline-flex !important; align-items: center !important; gap: 7px !important;
  background: transparent !important; border: 1.5px solid #99f6e4 !important; border-radius: 8px !important;
  padding: 9px 18px !important; font-family: 'DM Sans', sans-serif !important;
  font-size: 0.84rem !important; font-weight: 600 !important; color: #0f766e !important;
  cursor: pointer !important; transition: all 0.2s !important; box-shadow: none !important; outline: none !important; line-height: 1.3 !important;
}
#mcc-app .mcc-recalc-btn:hover { border-color: #0d9488 !important; color: #0d9488 !important; background: #f0fdfa !important; }

/* ── Responsive: tablet ─────────────────────────────────── */
@media screen and (max-width: 560px) {
  #mcc-app .mcc-form-body    { padding: 22px 20px 24px !important; gap: 18px !important; }
  #mcc-app .mcc-result-panel { padding: 0 20px 24px !important; }
  #mcc-app .mcc-header       { padding: 26px 20px 22px !important; }
  #mcc-app .mcc-title        { font-size: 1.72rem !important; }
  #mcc-app .mcc-hero         { gap: 14px !important; }
  #mcc-app .mcc-hero-stats   { grid-template-columns: 1fr !important; }
}

/* ── Responsive: phone ──────────────────────────────────── */
@media screen and (max-width: 420px) {
  #mcc-app                      { padding: 14px 8px !important; }
  #mcc-app .mcc-card            { border-radius: 18px !important; }
  #mcc-app .mcc-header          { padding: 22px 16px 20px !important; }
  #mcc-app .mcc-form-body       { padding: 18px 14px 20px !important; gap: 16px !important; }
  #mcc-app .mcc-result-panel    { padding: 0 14px 20px !important; }
  #mcc-app .mcc-title           { font-size: 1.5rem !important; }
  #mcc-app .mcc-hero            { flex-direction: column !important; align-items: center !important; }
  
  
  
  
  #mcc-app .mcc-cal-day         { font-size: 0.68rem !important; min-height: 26px !important; border-radius: 6px !important; }
  #mcc-app .mcc-forecast-row    { grid-template-columns: 32px 1fr !important; }
  #mcc-app .mcc-forecast-tag    { display: none !important; }
}
