/* ============================================================
   BMI Calculator WordPress Plugin — v2.0
   Exact port of local HTML design
   All rules scoped to #bmic-app with !important to beat WP
   ============================================================ */

@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');

/* ── Hard reset inside plugin scope ──────────────────────── */
#bmic-app,
#bmic-app * {
  box-sizing: border-box !important;
  -webkit-font-smoothing: antialiased !important;
}

/* ── Wrapper ─────────────────────────────────────────────── */
#bmic-app {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  padding: 32px 16px !important;
  background: #f0fdfa !important;
  font-family: 'DM Sans', sans-serif !important;
}

/* ── Card ────────────────────────────────────────────────── */
#bmic-app .bmic-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: 500px !important;
  overflow: hidden !important;
  border: 1px solid rgba(13,148,136,0.12) !important;
}

/* ── Header ──────────────────────────────────────────────── */
#bmic-app .bmic-header {
  background: linear-gradient(145deg, #0d9488 0%, #0f766e 50%, #134e4a 100%) !important;
  padding: 32px 28px 28px !important;
  text-align: center !important;
  position: relative !important;
  overflow: hidden !important;
}

#bmic-app .bmic-header::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    radial-gradient(ellipse at 25% 0%,   rgba(255,255,255,0.13) 0%, transparent 55%),
    radial-gradient(ellipse at 75% 110%, rgba(0,0,0,0.10)       0%, transparent 55%) !important;
  pointer-events: none !important;
}

#bmic-app .bmic-header-icon {
  width: 56px !important;
  height: 70px !important;
  margin: 0 auto 14px !important;
  position: relative !important;
  z-index: 1 !important;
  display: block !important;
}

#bmic-app .bmic-body-svg {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  filter: drop-shadow(0 4px 14px rgba(0,0,0,0.22)) !important;
}

/* Body animation */
#bmic-app .bmic-svg-head   { animation: bmicBreathe 3.5s ease-in-out infinite !important;       transform-origin: 40px 14px !important; }
#bmic-app .bmic-svg-body   { animation: bmicBreathe 3.5s ease-in-out infinite 0.2s !important;  transform-origin: 40px 52px !important; }
#bmic-app .bmic-svg-arm-l  { animation: bmicArmL    3.5s ease-in-out infinite !important;       transform-origin: 26px 34px !important; }
#bmic-app .bmic-svg-arm-r  { animation: bmicArmR    3.5s ease-in-out infinite !important;       transform-origin: 54px 34px !important; }
#bmic-app .bmic-pulse-ring { animation: bmicPulse   2.8s ease-out   infinite !important;       transform-origin: 40px 14px !important; }

@keyframes bmicBreathe { 0%,100%{transform:scaleY(1);opacity:1}       50%{transform:scaleY(1.04);opacity:0.9} }
@keyframes bmicArmL    { 0%,100%{transform:rotate(0deg)}               50%{transform:rotate(-8deg)} }
@keyframes bmicArmR    { 0%,100%{transform:rotate(0deg)}               50%{transform:rotate(8deg)} }
@keyframes bmicPulse   { 0%{transform:scale(1);opacity:0.6} 60%,100%{transform:scale(1.9);opacity:0} }

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

#bmic-app .bmic-subtitle {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.86rem !important;
  color: rgba(255,255,255,0.82) !important;
  position: relative !important;
  z-index: 1 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}

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

/* ── Unit Toggle ─────────────────────────────────────────── */
#bmic-app .bmic-unit-toggle {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  background: #ccfbf1 !important;
  border-radius: 12px !important;
  padding: 5px !important;
  gap: 5px !important;
  border: none !important;
}

/* WP button full reset */
#bmic-app button,
#bmic-app .bmic-unit-btn,
#bmic-app .bmic-submit-btn,
#bmic-app .bmic-recalc-btn {
  -webkit-appearance: none !important;
  appearance: none !important;
  text-shadow: none !important;
  text-decoration: none !important;
}

#bmic-app .bmic-unit-btn {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 2px !important;
  padding: 10px 8px !important;
  border: none !important;
  border-radius: 8px !important;
  background: transparent !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.88rem !important;
  font-weight: 600 !important;
  color: #64748b !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  box-shadow: none !important;
  outline: none !important;
  line-height: 1.3 !important;
}

#bmic-app .bmic-hint {
  font-size: 0.7rem !important;
  opacity: 0.75 !important;
  display: block !important;
}

#bmic-app .bmic-unit-btn:hover:not(.active) {
  background: rgba(13,148,136,0.1) !important;
  color: #0d9488 !important;
}

#bmic-app .bmic-unit-btn.active {
  background: #0d9488 !important;
  color: #fff !important;
  box-shadow: 0 4px 14px rgba(13,148,136,0.38) !important;
}

/* ── Fields ──────────────────────────────────────────────── */
#bmic-app .bmic-field {
  display: flex !important;
  flex-direction: column !important;
  gap: 7px !important;
}

#bmic-app .bmic-label {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 1.05rem !important;
  font-weight: 600 !important;
  font-style: normal !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;
}

#bmic-app .bmic-label svg {
  color: #14b8a6 !important;
  flex-shrink: 0 !important;
}

#bmic-app .bmic-input-wrap {
  position: relative !important;
}

#bmic-app .bmic-inp {
  width: 100% !important;
  padding: 13px 52px 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;
  -moz-appearance: textfield !important;
  outline: none !important;
  box-shadow: none !important;
  display: block !important;
}

#bmic-app .bmic-inp::-webkit-inner-spin-button,
#bmic-app .bmic-inp::-webkit-outer-spin-button {
  -webkit-appearance: none !important;
  margin: 0 !important;
}

#bmic-app .bmic-inp:focus {
  border-color: #0d9488 !important;
  background: #fff !important;
  box-shadow: 0 0 0 3.5px rgba(13,148,136,0.16) !important;
  outline: none !important;
}

#bmic-app .bmic-inp-unit {
  position: absolute !important;
  right: 16px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.78rem !important;
  font-weight: 700 !important;
  color: #94a3b8 !important;
  pointer-events: none !important;
}

/* ── Error ───────────────────────────────────────────────── */
#bmic-app .bmic-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: bmicShake 0.4s ease !important;
}

@keyframes bmicShake { 0%,100%{transform:translateX(0)} 20%{transform:translateX(-6px)} 40%{transform:translateX(6px)} 60%{transform:translateX(-4px)} 80%{transform:translateX(4px)} }

/* ── Submit Button ───────────────────────────────────────── */
#bmic-app .bmic-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;
  transition: transform 0.22s ease, box-shadow 0.22s ease !important;
  outline: none !important;
  line-height: 1.2 !important;
}

#bmic-app .bmic-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;
}

#bmic-app .bmic-submit-btn:active {
  transform: translateY(0) !important;
}

#bmic-app .bmic-submit-btn svg {
  flex-shrink: 0 !important;
}

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

/* ── Result Panel ────────────────────────────────────────── */
#bmic-app .bmic-result-panel {
  padding: 0 28px 28px !important;
}

/* ── Gauge ───────────────────────────────────────────────── */
#bmic-app .bmic-gauge-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  padding-top: 10px !important;
  margin-bottom: 4px !important;
}

#bmic-app .bmic-gauge-svg {
  width: 100% !important;
  max-width: 420px !important;
  height: auto !important;
  display: block !important;
  overflow: visible !important;
}

/* Needle — pivot at (210,210), starts pointing LEFT */
#bmic-app #bmic-needle-g {
  transform-origin: 210px 210px !important;
  transition: transform 1.4s cubic-bezier(0.34, 1.15, 0.64, 1) !important;
}

/* Curved text */
#bmic-app .bmic-tp-num {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  fill: #475569 !important;
}

#bmic-app .bmic-tp-zone {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 9.5px !important;
  font-weight: 600 !important;
  fill: #1e293b !important;
  letter-spacing: 0.05em !important;
}

/* BMI number below gauge */
#bmic-app .bmic-gauge-value {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  margin-top: -8px !important;
  margin-bottom: 8px !important;
}

#bmic-app .bmic-bmi-number {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 3.6rem !important;
  font-weight: 700 !important;
  font-style: italic !important;
  color: #0d9488 !important;
  line-height: 1 !important;
  display: block !important;
  transition: color 0.5s ease !important;
}

#bmic-app .bmic-bmi-label {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.68rem !important;
  font-weight: 700 !important;
  color: #94a3b8 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.14em !important;
  margin-top: 2px !important;
  display: block !important;
}

/* ── Category badge ──────────────────────────────────────── */
#bmic-app .bmic-cat-wrap {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 4px !important;
  margin-bottom: 20px !important;
}

#bmic-app .bmic-cat-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 8px 20px !important;
  border-radius: 50px !important;
  background: #f0fdfa !important;
  border: 1.5px solid #99f6e4 !important;
  animation: bmicBadgeIn 0.5s 0.3s ease both !important;
}

@keyframes bmicBadgeIn { from{opacity:0;transform:scale(0.85)} to{opacity:1;transform:scale(1)} }

#bmic-app .bmic-cat-dot {
  width: 10px !important;
  height: 10px !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
  transition: background 0.4s !important;
  display: inline-block !important;
}

#bmic-app .bmic-cat-text {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 1.15rem !important;
  font-weight: 700 !important;
  color: #0f172a !important;
}

#bmic-app .bmic-range-text {
  font-size: 0.76rem !important;
  color: #94a3b8 !important;
  font-weight: 500 !important;
  display: block !important;
}

/* ── Stats grid ──────────────────────────────────────────── */
#bmic-app .bmic-stats {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 12px !important;
  margin-bottom: 16px !important;
}

#bmic-app .bmic-stat-card {
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  padding: 13px !important;
  background: #f8fffe !important;
  border: 1px solid #ccfbf1 !important;
  border-radius: 12px !important;
  animation: bmicStatIn 0.5s ease both !important;
}

#bmic-app .bmic-stat-card:nth-child(1) { animation-delay: 0.15s !important; }
#bmic-app .bmic-stat-card:nth-child(2) { animation-delay: 0.25s !important; }

@keyframes bmicStatIn { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }

#bmic-app .bmic-stat-icon {
  width: 18px !important;
  height: 18px !important;
  flex-shrink: 0 !important;
  color: #0d9488 !important;
  margin-top: 2px !important;
}

#bmic-app .bmic-stat-body {
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
}

#bmic-app .bmic-stat-lbl {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.68rem !important;
  font-weight: 600 !important;
  color: #94a3b8 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  display: block !important;
}

#bmic-app .bmic-stat-val {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  font-style: italic !important;
  color: #0f766e !important;
  display: block !important;
}

/* ── Advice ──────────────────────────────────────────────── */
#bmic-app .bmic-advice {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  padding: 13px 16px !important;
  background: #f0fdfa !important;
  border-left: 3px solid #0d9488 !important;
  border-radius: 0 12px 12px 0 !important;
  margin-bottom: 20px !important;
  animation: bmicAdviceIn 0.5s 0.4s ease both !important;
}

@keyframes bmicAdviceIn { from{opacity:0;transform:translateX(-10px)} to{opacity:1;transform:translateX(0)} }

#bmic-app .bmic-advice-icon {
  width: 18px !important;
  height: 18px !important;
  flex-shrink: 0 !important;
  color: #0d9488 !important;
  margin-top: 2px !important;
}

#bmic-app .bmic-advice-text {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 0.87rem !important;
  color: #374151 !important;
  font-weight: 500 !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ── Recalculate ─────────────────────────────────────────── */
#bmic-app .bmic-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: #64748b !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  box-shadow: none !important;
  outline: none !important;
  line-height: 1.3 !important;
}

#bmic-app .bmic-recalc-btn:hover {
  border-color: #0d9488 !important;
  color: #0d9488 !important;
  background: #f0fdfa !important;
}

/* ── Responsive: tablet ──────────────────────────────────── */
@media screen and (max-width: 560px) {
  #bmic-app .bmic-title           { font-size: 1.7rem !important; }
  #bmic-app .bmic-form-body       { padding: 22px 20px 24px !important; }
  #bmic-app .bmic-result-panel    { padding: 0 20px 24px !important; }
  #bmic-app .bmic-header          { padding: 26px 20px 22px !important; }
}

/* ── Responsive: phone ───────────────────────────────────── */
@media screen and (max-width: 420px) {
  #bmic-app                        { padding: 16px 8px !important; }
  #bmic-app .bmic-card            { border-radius: 18px !important; }
  #bmic-app .bmic-header          { padding: 22px 16px 20px !important; }
  #bmic-app .bmic-form-body       { padding: 18px 16px 20px !important; gap: 14px !important; }
  #bmic-app .bmic-result-panel    { padding: 0 16px 20px !important; }
  #bmic-app .bmic-title           { font-size: 1.55rem !important; }
  #bmic-app .bmic-bmi-number      { font-size: 2.8rem !important; }
  #bmic-app .bmic-stats           { grid-template-columns: 1fr !important; }
  #bmic-app .bmic-gauge-svg       { max-width: 340px !important; }
}
