/* ============================================================
   MediCore – Custom Styles on top of Bootstrap 5
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Sora:wght@400;600;700;800&display=swap');

/* ── Root Variables ─────────────────────────────────────── */
:root {
  --mc-primary:       #0ea5e9;
  --mc-primary-dark:  #0284c7;
  --mc-primary-light: #e0f2fe;
  --mc-secondary:     #6366f1;
  --mc-accent:        #10b981;
  --mc-accent-dark:   #059669;
  --mc-danger:        #ef4444;
  --mc-warning:       #f59e0b;
  --mc-dark:          #0f172a;
  --mc-dark2:         #1e293b;
  --mc-dark3:         #334155;
  --mc-gray:          #64748b;
  --mc-gray-light:    #94a3b8;
  --mc-border:        #e2e8f0;
  --mc-bg:            #f8fafc;
  --mc-white:         #ffffff;
  --mc-grad-1:        linear-gradient(135deg, #0ea5e9 0%, #6366f1 100%);
  --mc-grad-2:        linear-gradient(135deg, #10b981 0%, #0ea5e9 100%);
  --mc-grad-hero:     linear-gradient(135deg, #0f172a 0%, #1e293b 50%, #0c4a6e 100%);
}

/* ── Base ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', sans-serif;
  background: var(--mc-bg);
  color: var(--mc-dark);
  overflow-x: hidden;
  opacity: 0;
  transition: opacity .35s ease;
}
body.loaded { opacity: 1; }
h1,h2,h3,h4,h5,h6 { font-family: 'Sora', sans-serif; font-weight: 700; }
a { text-decoration: none; }
p { color: var(--mc-gray); line-height: 1.75; }

/* ── Text helpers ────────────────────────────────────────── */
.text-gradient {
  background: var(--mc-grad-1);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.text-accent-gradient {
  background: var(--mc-grad-2);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Bootstrap overrides ─────────────────────────────────── */
.btn { border-radius: 50rem; font-weight: 600; font-size: .9rem; transition: all .25s ease; }
.btn-primary   { background: var(--mc-grad-1); border: none; color: #fff; box-shadow: 0 4px 14px rgba(14,165,233,.35); }
.btn-primary:hover   { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(14,165,233,.45); background: var(--mc-grad-1); }
.btn-outline-light:hover { background: rgba(255,255,255,.15); }
.btn-outline-primary { border-color: var(--mc-primary); color: var(--mc-primary); }
.btn-outline-primary:hover { background: var(--mc-primary); color: #fff; transform: translateY(-2px); }
.btn-dark { background: var(--mc-dark); border: none; }
.btn-dark:hover { background: var(--mc-dark2); transform: translateY(-2px); }
.btn-success { background: var(--mc-grad-2); border: none; }
.btn-lg { padding: 14px 32px; font-size: 1rem; }
.btn-sm { padding: 8px 20px; font-size: .82rem; }

/* Badge */
.badge-soft-primary { background: var(--mc-primary-light); color: var(--mc-primary-dark); font-size: .78rem; font-weight: 600; padding: 6px 14px; border-radius: 50rem; }
.badge-soft-accent  { background: #d1fae5; color: var(--mc-accent-dark); font-size: .78rem; font-weight: 600; padding: 6px 14px; border-radius: 50rem; }
.badge-soft-purple  { background: #ede9fe; color: #4f46e5; font-size: .78rem; font-weight: 600; padding: 6px 14px; border-radius: 50rem; }
.badge-soft-warning { background: #fef3c7; color: #b45309; font-size: .78rem; font-weight: 600; padding: 6px 14px; border-radius: 50rem; }

/* Form controls */
.form-control, .form-select {
  border-radius: 10px;
  border: 1.5px solid var(--mc-border);
  padding: 12px 16px;
  font-size: .92rem;
  transition: border-color .2s, box-shadow .2s;
}
.form-control:focus, .form-select:focus {
  border-color: var(--mc-primary);
  box-shadow: 0 0 0 3px rgba(14,165,233,.15);
}
.form-label { font-weight: 600; font-size: .88rem; color: var(--mc-dark3); margin-bottom: 6px; }
.form-text { font-size: .78rem; }

/* ── Navbar ─────────────────────────────────────────────── */
.mc-navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1050;
  padding: 0 24px;
  transition: background .3s ease, box-shadow .3s ease;
}
.mc-navbar .navbar-inner {
  max-width: 1200px;
  margin: 0 auto;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.mc-navbar.transparent { background: transparent; }
.mc-navbar.scrolled {
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(18px);
  box-shadow: 0 2px 20px rgba(0,0,0,.08);
}
.mc-navbar.scrolled .nav-link { color: var(--mc-gray) !important; }
.mc-navbar.scrolled .nav-link:hover { color: var(--mc-primary) !important; }
.mc-navbar.scrolled .logo-text { color: var(--mc-dark) !important; }
.mc-navbar.scrolled .logo-text span { color: var(--mc-primary) !important; }

.logo { display: flex; align-items: center; gap: 10px; }
.logo-icon {
  width: 40px; height: 40px;
  background: var(--mc-grad-1);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: white; font-size: 1.1rem; flex-shrink: 0;
}
.logo-text {
  font-family: 'Sora', sans-serif;
  font-weight: 800; font-size: 1.25rem;
  color: white; transition: color .3s;
}
.logo-text span { color: var(--mc-primary-light); }

.mc-nav-link {
  padding: 7px 15px !important;
  border-radius: 50rem;
  font-weight: 500; font-size: .88rem;
  color: rgba(255,255,255,.85) !important;
  transition: background .2s, color .2s;
}
.mc-nav-link:hover, .mc-nav-link.active {
  background: rgba(255,255,255,.15);
  color: #fff !important;
}
.mc-navbar.scrolled .mc-nav-link.active {
  background: var(--mc-primary-light);
  color: var(--mc-primary-dark) !important;
}

/* ── Hero ───────────────────────────────────────────────── */
.mc-hero {
  background: var(--mc-grad-hero);
  min-height: 100vh;
  padding: 120px 0 80px;
  position: relative;
  overflow: hidden;
}
.mc-hero::before {
  content: '';
  position: absolute; top: -30%; right: -10%;
  width: 650px; height: 650px;
  background: radial-gradient(circle, rgba(14,165,233,.14) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.mc-hero::after {
  content: '';
  position: absolute; bottom: -30%; left: -10%;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(99,102,241,.1) 0%, transparent 70%);
  border-radius: 50%; pointer-events: none;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.2);
  color: white; padding: 7px 16px;
  border-radius: 50rem; font-size: .82rem; font-weight: 500;
  backdrop-filter: blur(8px); margin-bottom: 22px;
}
.hero-badge .dot {
  width: 7px; height: 7px;
  background: var(--mc-accent); border-radius: 50%;
  animation: pulse-dot 2s infinite;
}
@keyframes pulse-dot {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.5; transform:scale(1.4); }
}
.hero-title { color: white; font-size: clamp(2rem,4.5vw,3.6rem); line-height: 1.15; margin-bottom: 20px; }
.hero-title span { color: var(--mc-primary); }
.hero-desc { color: rgba(255,255,255,.75); font-size: 1.05rem; line-height: 1.8; margin-bottom: 36px; }

/* Dashboard card */
.hero-dashboard {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 20px; padding: 24px;
  backdrop-filter: blur(18px);
  box-shadow: 0 40px 80px rgba(0,0,0,.35);
  animation: float 6s ease-in-out infinite;
}
@keyframes float {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-10px); }
}
.dash-stat-card {
  background: rgba(255,255,255,.08);
  border-radius: 12px; padding: 14px; text-align: center;
}
.dash-stat-card .num { font-family: 'Sora', sans-serif; font-size: 1.4rem; font-weight: 700; color: white; }
.dash-stat-card .lbl { font-size: .68rem; color: rgba(255,255,255,.5); margin-top: 2px; }
.dash-stat-card.blue .num { color: var(--mc-primary); }
.dash-stat-card.green .num { color: var(--mc-accent); }
.dash-stat-card.purple .num { color: #a78bfa; }

.appt-row {
  display: flex; align-items: center; gap: 10px;
  background: rgba(255,255,255,.06);
  border-radius: 10px; padding: 9px 10px;
  margin-bottom: 7px;
}
.appt-av {
  width: 34px; height: 34px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .78rem; font-weight: 700; color: white; flex-shrink: 0;
}
.appt-av.a1 { background: linear-gradient(135deg,#0ea5e9,#6366f1); }
.appt-av.a2 { background: linear-gradient(135deg,#10b981,#0ea5e9); }
.appt-av.a3 { background: linear-gradient(135deg,#f59e0b,#ef4444); }
.appt-name { font-size: .8rem; font-weight: 600; color: white; }
.appt-type { font-size: .7rem; color: rgba(255,255,255,.5); }
.appt-time { font-size: .72rem; color: rgba(255,255,255,.6); }
.status-pill { font-size: .67rem; padding: 2px 8px; border-radius: 50rem; font-weight: 700; }
.status-pill.confirmed { background: rgba(16,185,129,.2); color: #34d399; }
.status-pill.pending   { background: rgba(245,158,11,.2); color: #fbbf24; }

/* Floating cards */
.float-card {
  position: absolute;
  background: white; border-radius: 14px;
  padding: 12px 16px; box-shadow: 0 12px 30px rgba(0,0,0,.15);
  display: flex; align-items: center; gap: 10px;
  font-size: .8rem; font-weight: 600; color: var(--mc-dark);
  animation: float-card 4s ease-in-out infinite;
  white-space: nowrap; z-index: 2;
}
.float-card .fc-icon { width: 30px; height: 30px; border-radius: 7px; display: flex; align-items: center; justify-content: center; font-size: .85rem; }
.float-card.fc1 { top: -10px; left: -30px; animation-delay: 0s; }
.float-card.fc2 { bottom: 20px; right: -20px; animation-delay: 2s; }
@keyframes float-card {
  0%,100% { transform: translateY(0) rotate(-1deg); }
  50%      { transform: translateY(-8px) rotate(1deg); }
}

/* ── Section commons ─────────────────────────────────────── */
.section-py { padding: 90px 0; }
.section-py-sm { padding: 60px 0; }
.section-header { max-width: 620px; margin: 0 auto 56px; text-align: center; }
.section-header h2 { color: var(--mc-dark); margin-bottom: 14px; }
.section-header p  { font-size: 1.05rem; }

/* ── Trusted logos ───────────────────────────────────────── */
.trusted-section { background: white; padding: 50px 0; }
.trusted-logo { display: flex; align-items: center; gap: 8px; font-weight: 700; font-size: 1rem; color: var(--mc-gray-light); opacity: .6; transition: opacity .2s, color .2s; }
.trusted-logo:hover { opacity: 1; color: var(--mc-primary); }
.trusted-label { font-size: .78rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--mc-gray-light); }

/* ── Stats ───────────────────────────────────────────────── */
.stats-section { background: white; padding: 70px 0; border-top: 1px solid var(--mc-border); border-bottom: 1px solid var(--mc-border); }
.stat-num { font-family: 'Sora', sans-serif; font-size: 2.6rem; font-weight: 800; color: var(--mc-dark); line-height: 1; }
.stat-num span { color: var(--mc-primary); }
.stat-lbl { font-size: .88rem; color: var(--mc-gray); margin-top: 6px; }

/* ── Pain cards ──────────────────────────────────────────── */
.pain-section { background: var(--mc-dark); position: relative; }
.pain-section::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background: linear-gradient(90deg,transparent,rgba(14,165,233,.5),transparent); }
.pain-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px; padding: 30px; height: 100%;
  transition: border-color .3s, transform .3s;
  position: relative; overflow: hidden;
}
.pain-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background: var(--mc-grad-1); transform:scaleX(0); transition:transform .3s; }
.pain-card:hover { border-color: rgba(14,165,233,.35); transform: translateY(-4px); }
.pain-card:hover::before { transform:scaleX(1); }
.pain-icon { width:50px; height:50px; border-radius:12px; background:rgba(239,68,68,.15); display:flex; align-items:center; justify-content:center; color:#f87171; font-size:1.2rem; margin-bottom:18px; }
.pain-card h5 { color: white; margin-bottom: 10px; }
.pain-card p  { color: rgba(255,255,255,.55); font-size: .88rem; }
.pain-solution { display:flex; align-items:center; gap:8px; margin-top:18px; padding:9px 12px; background:rgba(16,185,129,.1); border-radius:8px; border:1px solid rgba(16,185,129,.2); font-size:.8rem; color:#34d399; font-weight:500; }

/* ── Feature mini cards ──────────────────────────────────── */
.feature-mini-card {
  background: white; border: 1px solid var(--mc-border);
  border-radius: 16px; padding: 26px;
  display: flex; gap: 16px; align-items: flex-start;
  height: 100%; transition: transform .25s, box-shadow .25s, border-color .25s;
}
.feature-mini-card:hover { transform: translateY(-4px); box-shadow: 0 12px 30px rgba(0,0,0,.09); border-color: var(--mc-primary); }
.fmc-icon { width: 46px; height: 46px; border-radius: 10px; display:flex; align-items:center; justify-content:center; font-size: 1.1rem; flex-shrink: 0; }
.fmc-text h6 { color: var(--mc-dark); margin-bottom: 6px; font-size: .92rem; }
.fmc-text p  { font-size: .82rem; margin: 0; }

/* ── How it works steps ──────────────────────────────────── */
.step-card { text-align: center; }
.step-num { width: 68px; height: 68px; background: var(--mc-grad-1); color: white; font-family: 'Sora', sans-serif; font-size: 1.4rem; font-weight: 800; border-radius: 50%; display:flex; align-items:center; justify-content:center; margin: 0 auto 18px; box-shadow: 0 8px 20px rgba(14,165,233,.3); transition: transform .25s; }
.step-card:hover .step-num { transform: scale(1.1); }
.step-card h5 { color: var(--mc-dark); }

/* ── Security cards ──────────────────────────────────────── */
.security-card { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: 14px; padding: 26px; text-align: center; transition: background .25s, border-color .25s; height: 100%; }
.security-card:hover { background: rgba(255,255,255,.09); border-color: rgba(14,165,233,.4); }
.security-card i { font-size: 1.8rem; color: var(--mc-primary); display:block; margin-bottom: 12px; }
.security-card h6 { color: white; margin-bottom: 8px; }
.security-card p  { font-size: .82rem; color: rgba(255,255,255,.5); margin:0; }

/* ── Testimonial cards ───────────────────────────────────── */
.testi-card { background: white; border: 1px solid var(--mc-border); border-radius: 16px; padding: 30px; height: 100%; position: relative; transition: transform .25s, box-shadow .25s; }
.testi-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(0,0,0,.09); }
.testi-card::after { content: '"'; position:absolute; top: 10px; right: 20px; font-size: 5rem; color: var(--mc-primary-light); font-family: Georgia,serif; line-height:1; }
.testi-stars { color: #fbbf24; font-size: .82rem; margin-bottom: 14px; }
.testi-text { font-style: italic; color: var(--mc-dark); font-size: .92rem; line-height: 1.75; margin-bottom: 22px; }
.testi-av { width: 44px; height: 44px; border-radius: 50%; display:flex; align-items:center; justify-content:center; font-weight: 700; font-size: .85rem; color: white; flex-shrink: 0; }
.testi-name { font-weight: 700; font-size: .88rem; color: var(--mc-dark); }
.testi-role { font-size: .76rem; color: var(--mc-gray); }

/* ── Integration cards ───────────────────────────────────── */
.integration-card { background: white; border: 1px solid var(--mc-border); border-radius: 14px; padding: 22px 14px; text-align: center; transition: border-color .2s, transform .2s, box-shadow .2s; }
.integration-card:hover { border-color: var(--mc-primary); transform: translateY(-3px); box-shadow: 0 8px 20px rgba(0,0,0,.07); }
.integration-card i { font-size: 1.7rem; margin-bottom: 8px; display: block; }
.integration-card span { font-size: .78rem; font-weight: 600; color: var(--mc-gray); }

/* ── CTA section ─────────────────────────────────────────── */
.cta-section { background: var(--mc-grad-1); position: relative; overflow: hidden; }
.cta-section::before { content:''; position:absolute; top:-50%; right:-10%; width:600px; height:600px; background:radial-gradient(circle, rgba(255,255,255,.1) 0%, transparent 70%); border-radius:50%; }
.cta-trust-item { display:flex; align-items:center; gap:6px; color:rgba(255,255,255,.85); font-size:.86rem; }
.cta-trust-item i { color: var(--mc-accent); }
.btn-cta-white { background: white; color: var(--mc-primary-dark); font-weight: 700; padding: 16px 36px; border-radius: 50rem; display:inline-flex; align-items:center; gap: 8px; font-size: .98rem; transition: transform .25s, box-shadow .25s; box-shadow: 0 8px 25px rgba(0,0,0,.15); }
.btn-cta-white:hover { transform: translateY(-3px); box-shadow: 0 15px 35px rgba(0,0,0,.2); color: var(--mc-primary-dark); }

/* ── Pricing ─────────────────────────────────────────────── */
.pricing-hero { background: var(--mc-grad-hero); padding: 130px 0 70px; position: relative; overflow: hidden; }
.pricing-hero::before { content:''; position:absolute; top:-40%; left:50%; transform:translateX(-50%); width:800px; height:800px; background:radial-gradient(circle, rgba(99,102,241,.1) 0%, transparent 70%); }
.billing-toggle { display:inline-flex; align-items:center; background:rgba(255,255,255,.1); border-radius:50rem; padding:4px; gap:4px; backdrop-filter:blur(10px); border:1px solid rgba(255,255,255,.15); }
.billing-btn { padding:9px 22px; border-radius:50rem; font-size:.88rem; font-weight:600; color:rgba(255,255,255,.7); background:transparent; border:none; cursor:pointer; transition:.2s; }
.billing-btn.active { background:white; color:var(--mc-dark); box-shadow:0 2px 8px rgba(0,0,0,.15); }
.save-badge { font-size:.7rem; background:var(--mc-accent); color:white; padding:2px 7px; border-radius:50rem; margin-left:5px; font-weight:700; }
.trust-pill { display:inline-flex; align-items:center; gap:7px; padding:8px 18px; background:rgba(255,255,255,.08); border-radius:50rem; border:1px solid rgba(255,255,255,.15); color:rgba(255,255,255,.85); font-size:.82rem; font-weight:500; backdrop-filter:blur(8px); }
.trust-pill i { color: var(--mc-accent); }

.pricing-card { background: white; border: 2px solid var(--mc-border); border-radius: 20px; padding: 36px 30px; transition: transform .3s, box-shadow .3s; height: 100%; }
.pricing-card:hover { transform: translateY(-5px); box-shadow: 0 20px 50px rgba(0,0,0,.1); }
.pricing-card.popular { border-color: var(--mc-primary); box-shadow: 0 0 0 4px rgba(14,165,233,.1), 0 20px 50px rgba(0,0,0,.1); }
.popular-ribbon { position:absolute; top:0; left:50%; transform:translateX(-50%); background:var(--mc-grad-1); color:white; padding:5px 20px; border-radius:0 0 10px 10px; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; white-space:nowrap; }
.plan-icon { width:50px; height:50px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.2rem; margin-bottom:18px; }
.plan-name-label { font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--mc-gray); margin-bottom:6px; }
.price-amount { font-family:'Sora',sans-serif; font-size:3.2rem; font-weight:800; color:var(--mc-dark); line-height:1; }
.price-currency { font-size:1.1rem; font-weight:700; color:var(--mc-dark); vertical-align:top; line-height:2.2; }
.price-period { font-size:.86rem; color:var(--mc-gray); }
.plan-desc { font-size:.88rem; color:var(--mc-gray); line-height:1.65; margin-bottom:26px; }
.plan-feature-item { display:flex; align-items:flex-start; gap:9px; font-size:.87rem; color:var(--mc-dark3); margin-bottom:10px; }
.plan-feature-item .chk { color:var(--mc-accent); font-size:.78rem; margin-top:3px; flex-shrink:0; }
.plan-feature-item .crs { color:var(--mc-gray-light); font-size:.78rem; margin-top:3px; flex-shrink:0; }
.plan-feature-item.disabled { color:var(--mc-gray-light); }
.enterprise-card { background: var(--mc-grad-hero); border-color: var(--mc-dark2); }
.enterprise-card .price-amount,.enterprise-card .price-currency { color:white; }
.enterprise-card .price-period,.enterprise-card .plan-name-label,.enterprise-card .plan-desc { color:rgba(255,255,255,.65); }
.enterprise-card .plan-feature-item { color:rgba(255,255,255,.88); }
.enterprise-card hr { border-color: rgba(255,255,255,.12); }
.price-annual { display:none; }
body.annual .price-monthly { display:none; }
body.annual .price-annual  { display:block; }
body.annual .annual-note   { display:block !important; }

/* Compare table */
.compare-table th { background:var(--mc-bg); font-size:.8rem; font-weight:700; color:var(--mc-dark); }
.compare-table th.hl { background:var(--mc-primary-light); color:var(--mc-primary-dark); }
.compare-table td { font-size:.87rem; }
.compare-table td.hl { background:#f0f9ff; }
.compare-table .chk { color:var(--mc-accent); }
.compare-table .crs { color:var(--mc-gray-light); }

/* FAQ */
.faq-item .accordion-button { font-weight:600; font-size:.95rem; color:var(--mc-dark); background:white; border-radius:12px !important; }
.faq-item .accordion-button:not(.collapsed) { color:var(--mc-primary); background:#f0f9ff; box-shadow:none; }
.faq-item .accordion-button::after { filter:none; }
.faq-item .accordion-collapse { border-top:1px solid var(--mc-border); }
.faq-item .accordion-body { font-size:.88rem; color:var(--mc-gray); }
.faq-item .accordion-item { border:1px solid var(--mc-border) !important; border-radius:12px !important; margin-bottom:10px; overflow:hidden; }

/* Add-on cards */
.addon-card { background:white; border:1px solid var(--mc-border); border-radius:14px; padding:22px; height:100%; transition:border-color .25s, transform .25s, box-shadow .25s; }
.addon-card:hover { border-color:var(--mc-primary); transform:translateY(-3px); box-shadow:0 10px 25px rgba(0,0,0,.08); }
.addon-icon { width:42px; height:42px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1rem; flex-shrink:0; }
.addon-price { font-size:.84rem; font-weight:700; color:var(--mc-primary); margin-top:6px; }

/* ── Features page ───────────────────────────────────────── */
.features-hero { background: var(--mc-grad-hero); padding: 130px 0 70px; position: relative; overflow: hidden; }
.feature-tab-nav { display:flex; justify-content:center; gap:8px; flex-wrap:wrap; margin-bottom: 50px; }
.feature-tab-btn { padding:9px 22px; border-radius:50rem; font-weight:500; font-size:.87rem; background:white; color:var(--mc-gray); border:1px solid var(--mc-border); transition:.25s; cursor:pointer; display:flex; align-items:center; gap:7px; }
.feature-tab-btn:hover,.feature-tab-btn.active { background:var(--mc-primary); color:white; border-color:var(--mc-primary); box-shadow:0 4px 14px rgba(14,165,233,.3); }
.showcase-visual { background:var(--mc-bg); border:1px solid var(--mc-border); border-radius:20px; padding:28px; }
.showcase-label { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--mc-gray); margin-bottom:14px; }
.cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:4px; }
.cal-day { aspect-ratio:1; border-radius:6px; display:flex; align-items:center; justify-content:center; font-size:.72rem; font-weight:500; color:var(--mc-gray); }
.cal-day.appt { background:var(--mc-primary-light); color:var(--mc-primary-dark); font-weight:700; }
.cal-day.today { background:var(--mc-primary); color:white; }
.cal-day.hdr  { color:var(--mc-gray-light); font-size:.62rem; font-weight:700; text-transform:uppercase; }
.ehr-avatar2 { width:40px; height:40px; border-radius:50%; background:var(--mc-grad-1); display:flex; align-items:center; justify-content:center; color:white; font-weight:700; }
.ehr-entry { background:white; border:1px solid var(--mc-border); border-radius:10px; padding:10px 12px; margin-bottom:8px; }
.ehr-dot { width:9px; height:9px; border-radius:50%; margin-top:4px; flex-shrink:0; }
.analytics-mini { background:white; border:1px solid var(--mc-border); border-radius:10px; padding:14px; }
.analytics-mini .val { font-family:'Sora',sans-serif; font-size:1.3rem; font-weight:800; color:var(--mc-dark); }
.analytics-mini .lbl { font-size:.7rem; color:var(--mc-gray); }
.analytics-mini .trend { font-size:.7rem; color:var(--mc-accent); font-weight:600; }
.chart-bars { display:flex; align-items:flex-end; gap:5px; height:72px; padding:6px 0; }
.chart-bar-wrap { flex:1; display:flex; flex-direction:column; align-items:center; gap:4px; }
.chart-bar { width:100%; border-radius:4px 4px 0 0; background:var(--mc-primary-light); transition:height .8s ease; }
.chart-bar.active { background:var(--mc-grad-1); }
.chart-bar-lbl { font-size:.58rem; color:var(--mc-gray); }
.ai-msg { padding:9px 13px; border-radius:14px; font-size:.8rem; line-height:1.6; max-width:92%; }
.ai-msg.user { background:var(--mc-primary); color:white; align-self:flex-end; border-radius:14px 14px 4px 14px; margin-left:auto; }
.ai-msg.bot  { background:var(--mc-bg); color:var(--mc-dark); border:1px solid var(--mc-border); align-self:flex-start; border-radius:14px 14px 14px 4px; }
.ai-typing span { display:inline-block; width:6px; height:6px; border-radius:50%; background:var(--mc-gray-light); animation:bounce 1.2s infinite; margin-right:3px; }
.ai-typing span:nth-child(2) { animation-delay:.2s; }
.ai-typing span:nth-child(3) { animation-delay:.4s; }
@keyframes bounce { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-5px)} }
.numbered-feat { display:flex; gap:16px; align-items:flex-start; margin-bottom:18px; }
.nf-num { width:34px; height:34px; border-radius:50%; background:var(--mc-grad-1); color:white; font-family:'Sora',sans-serif; font-weight:700; font-size:.82rem; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.nf-text h6 { color:var(--mc-dark); margin-bottom:3px; }
.nf-text p  { font-size:.83rem; margin:0; }
.feature-full-card { background:white; border:1px solid var(--mc-border); border-radius:18px; overflow:hidden; height:100%; transition:transform .25s, box-shadow .25s, border-color .25s; }
.feature-full-card:hover { transform:translateY(-5px); box-shadow:0 16px 40px rgba(0,0,0,.09); border-color:var(--mc-primary); }
.ffc-head { padding:28px 28px 0; }
.ffc-icon { width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:1.3rem; flex-shrink:0; }
.ffc-head h5 { color:var(--mc-dark); margin-bottom:5px; font-size:1rem; }
.ffc-head p  { font-size:.83rem; color:var(--mc-gray); margin:0; }
.ffc-body { padding:20px 28px 28px; }
.ffc-list li { display:flex; align-items:flex-start; gap:8px; font-size:.84rem; color:var(--mc-dark3); margin-bottom:8px; }
.ffc-list li i { color:var(--mc-accent); margin-top:2px; font-size:.72rem; flex-shrink:0; }
.ffc-metric { background:var(--mc-bg); border-radius:10px; padding:12px 14px; display:flex; align-items:center; gap:12px; margin-top:18px; }
.ffc-metric-val { font-family:'Sora',sans-serif; font-weight:700; font-size:1.05rem; color:var(--mc-dark); }
.ffc-metric-lbl { font-size:.73rem; color:var(--mc-gray); }

/* ── Signup / Onboarding form page ───────────────────────── */
.signup-hero { background: var(--mc-grad-hero); padding: 130px 0 60px; position: relative; overflow: hidden; }
.signup-hero::before { content:''; position:absolute; top:-30%; right:-10%; width:500px; height:500px; background:radial-gradient(circle, rgba(14,165,233,.12) 0%, transparent 70%); border-radius:50%; pointer-events:none; }
.signup-progress { display:flex; align-items:center; justify-content:center; gap:0; margin-bottom: 36px; }
.prog-step { display:flex; flex-direction:column; align-items:center; position:relative; }
.prog-circle { width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.85rem; transition:.3s; }
.prog-circle.done   { background:var(--mc-grad-1); color:white; }
.prog-circle.active { background:var(--mc-primary); color:white; box-shadow:0 0 0 4px rgba(14,165,233,.25); }
.prog-circle.todo   { background:var(--mc-bg); color:var(--mc-gray); border:2px solid var(--mc-border); }
.prog-label { font-size:.68rem; font-weight:600; margin-top:5px; color:var(--mc-gray); white-space:nowrap; }
.prog-label.active-lbl { color:var(--mc-primary); }
.prog-line { width:70px; height:2px; background:var(--mc-border); margin-top: -18px; }
.prog-line.done { background:var(--mc-primary); }

.signup-card { background:white; border-radius:24px; box-shadow:0 25px 60px rgba(0,0,0,.12); padding: 48px; }
@media(max-width:576px) { .signup-card { padding:28px 20px; } }
.signup-step { display:none; }
.signup-step.active { display:block; }
.form-section-title { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--mc-gray); border-bottom:1px solid var(--mc-border); padding-bottom:10px; margin-bottom:20px; }

/* Input icon wrapper */
.input-icon-wrap { position:relative; }
.input-icon-wrap i { position:absolute; left:14px; top:50%; transform:translateY(-50%); color:var(--mc-gray-light); font-size:.9rem; pointer-events:none; }
.input-icon-wrap .form-control { padding-left: 40px; }

/* Success state */
.success-screen { text-align:center; padding: 20px 0; }
.success-icon { width:90px; height:90px; background:var(--mc-grad-2); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 24px; animation:pop .5s cubic-bezier(.34,1.56,.64,1); }
@keyframes pop { 0%{transform:scale(0); opacity:0} 100%{transform:scale(1); opacity:1} }
.success-icon i { font-size:2.2rem; color:white; }
.ref-code { background:var(--mc-bg); border:1px dashed var(--mc-border); border-radius:10px; padding:12px 20px; display:inline-flex; align-items:center; gap:10px; font-family:monospace; font-size:1.1rem; font-weight:700; color:var(--mc-dark); letter-spacing:.05em; }
.next-steps-list li { display:flex; align-items:flex-start; gap:12px; padding:14px 0; border-bottom:1px solid var(--mc-border); font-size:.9rem; color:var(--mc-dark3); }
.next-steps-list li:last-child { border:none; }
.ns-icon { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:.85rem; }

/* ── Footer ──────────────────────────────────────────────── */
.mc-footer { background:var(--mc-dark); padding: 72px 0 0; }
.footer-brand p { color:rgba(255,255,255,.55); font-size:.87rem; margin:14px 0 22px; line-height:1.7; }
.social-link { width:36px; height:36px; border-radius:8px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.55); font-size:.82rem; transition:.2s; }
.social-link:hover { background:var(--mc-primary); border-color:var(--mc-primary); color:white; }
.footer-heading { color:white; font-size:.86rem; font-weight:700; margin-bottom:18px; }
.footer-link { color:rgba(255,255,255,.5); font-size:.85rem; display:block; margin-bottom:9px; transition:color .2s, padding-left .2s; }
.footer-link:hover { color:var(--mc-primary); padding-left:4px; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.08); padding:22px 0; }

/* ── Scroll animations ───────────────────────────────────── */
.fade-up { opacity:0; transform:translateY(28px); transition:opacity .65s ease, transform .65s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }
.fade-left { opacity:0; transform:translateX(-36px); transition:opacity .65s ease, transform .65s ease; }
.fade-left.visible { opacity:1; transform:translateX(0); }
.fade-right { opacity:0; transform:translateX(36px); transition:opacity .65s ease, transform .65s ease; }
.fade-right.visible { opacity:1; transform:translateX(0); }

/* ── Spinner ─────────────────────────────────────────────── */
.btn-spinner { display:none; width:16px; height:16px; border:2px solid rgba(255,255,255,.4); border-top-color:white; border-radius:50%; animation:spin .6s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ── Toast ───────────────────────────────────────────────── */
.mc-toast { position:fixed; bottom:28px; right:28px; background:var(--mc-dark); color:white; padding:14px 22px; border-radius:14px; box-shadow:0 20px 50px rgba(0,0,0,.25); display:flex; align-items:center; gap:10px; font-size:.88rem; font-weight:500; z-index:9999; transform:translateY(100px); opacity:0; transition:.3s cubic-bezier(.4,0,.2,1); }
.mc-toast.show { transform:translateY(0); opacity:1; }
.mc-toast i { color:var(--mc-accent); }

/* ── Misc ────────────────────────────────────────────────── */
.divider-line { height:1px; background: linear-gradient(90deg,transparent,var(--mc-border),transparent); margin:0; }
.guarantee-box { border:2px solid var(--mc-accent); border-radius:20px; padding:36px; }
.guarantee-icon { width:72px; height:72px; background:#d1fae5; border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--mc-accent); font-size:1.8rem; flex-shrink:0; }
.stat-bar-track { background:var(--mc-border); border-radius:50rem; height:7px; overflow:hidden; }
.stat-bar-fill  { height:100%; border-radius:50rem; background:var(--mc-grad-1); transition:width 1.4s cubic-bezier(.4,0,.2,1); }
.billing-table th { font-size:.72rem; color:var(--mc-gray); font-weight:600; text-transform:uppercase; border-bottom:1px solid var(--mc-border); padding:6px 4px; }
.billing-table td { padding:8px 4px; font-size:.8rem; color:var(--mc-dark3); }
.bill-paid    { background:#d1fae5; color:#059669; padding:2px 8px; border-radius:50rem; font-size:.68rem; font-weight:700; }
.bill-pending { background:#fef3c7; color:#b45309; padding:2px 8px; border-radius:50rem; font-size:.68rem; font-weight:700; }

@media(max-width:991.98px) {
  .mc-hero { padding:100px 0 60px; min-height:auto; }
  .section-py { padding:64px 0; }
}
@media(max-width:575.98px) {
  .section-py { padding:48px 0; }
  .signup-card { padding:28px 18px; }
  .hero-title { font-size:2rem; }
}
