.btn-dashboard {
    box-shadow: var(--shadow-primary);
    border: 1px solid #00bcd4;
}
.btn-dashboard:hover {
    transform: translateY(-4px);
}

.btn-dashboard:active {
    transform: translateY(0);
}
.dashboard-icon{
    fill:#00BCD4;
}
.section-title{
    color:#0D47A1;
}
.legal-header {
    text-align: center;
}
.section-subtitle {
max-width: unset!important;
    
}

.section-img {
    width: 70%;
    display: block;
    margin: 0 auto 15px auto; /* centers + spacing below */
}
/* =========================================
   ðŸ“± HERO â€” FINAL PRODUCTION PWA VERSION
========================================= */

@media (max-width: 768px) {

  /* HERO SPACING */
  .hero {
    padding: 110px 0 50px;
    overflow: hidden;
  }

  /* FULL WIDTH */
  .hero .container {
    max-width: 100%;
    padding: 0 16px;
  }

  /* LAYOUT */
  .hero-container {
    display: flex;
    flex-direction: column;
    gap: 10px; /* ðŸ”¥ ONLY CHANGE â€” reduced gap */
  }

  /* VISUAL FIRST */
  .hero-visual {
    order: 1;
    display: flex;
    justify-content: center;
    margin-bottom: 0;
  }

  .hero-content {
    order: 2;
    text-align: center;
    padding: 0 14px;
  }

  /* =========================================
     PHONE WRAPPER (UNCHANGED)
  ========================================= */
  .hero-image-wrapper {
    position: relative;
    display: inline-block;
  }

  /* PHONE â€” DO NOT MODIFY */
  .hero-phone {
    /* untouched */
    transform: scale(0.90);   /* ðŸ”¥ slight reduction */
    transform-origin: center top;
  }

  /* =========================================
     FLOATING CARDS â€” UNCHANGED
  ========================================= */

  .floating-card {
    position: absolute;
    z-index: 3;
    display: flex !important;
    align-items: center;
    gap: 6px;
    font-size: 10px;
    padding: 6px 8px;
    border-radius: 8px;
    max-width: 160px;
    white-space: normal;
    line-height: 1.3;
  }

  .floating-card svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
  }

  .floating-card span {
    display: inline-block;
    word-break: break-word;
  }

  /* LEFT CARD */
  .card-1 {
    position: absolute;
    top: 18%;
    left: -20px;
    right: auto;
    transform: scale(0.85);
  }

  /* RIGHT CARD */
  .card-2 {
    position: absolute;
    bottom: 14%;
    right: -20px;
    left: auto;
    transform: scale(0.85);
  }

  /* =========================================
     TYPOGRAPHY
  ========================================= */

  .hero-title {
    font-size: clamp(22px, 6vw, 30px);
    line-height: 1.25;
    margin-bottom: 14px;
  }

  .hero-subtitle {
    font-size: clamp(13px, 3.6vw, 15px);
    line-height: 1.6;
    margin-bottom: 20px;
  }

  /* =========================================
     CTA
  ========================================= */

  .hero-ctas {
    display: flex;
    gap: 12px;
    width: 100%;
    padding: 0 8px;
    margin-bottom: 14px;
  }

  .hero-ctas .btn {
    flex: 1;
    font-size: clamp(12px, 3vw, 14px);
    padding: 12px 10px;
    border-radius: 10px;
    justify-content: center;
  }

  .hero-ctas svg {
    width: 16px;
    height: 16px;
  }

  /* =========================================
     TRUST BADGES
  ========================================= */

  .trust-badges {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 4px;
  }

  .trust-badge {
    font-size: 11px;
    padding: 5px 7px;
  }

  /* BACKGROUND */
  .hero-bg-shapes {
    opacity: 0.5;
  }

 
}


/* =========================================
   ðŸ“± SMALL DEVICES (â‰¤ 420px)
========================================= */

@media (max-width: 420px) {

  .hero {
    padding: 95px 0 40px;
  }

  .hero-container {
    gap: 6px; /* ðŸ”¥ tighter for small devices */
  }

  .floating-card {
    font-size: 11px;
    max-width: 200px;
    padding: 8px 6px;
    font-weight: bolder;
  }

  /* LEFT CARD */
  .card-1 {
    top: 16%;
    left: -1%;
    transform: scale(0.75);
  }

  /* RIGHT CARD */
  .card-2 {
    bottom: 20%;
    right: -1%;
    transform: scale(0.75);
  }

  .hero-title {
    font-size: 20px;
  }

  .hero-subtitle {
    font-size: 13px;
    margin-bottom: 16px;
  }

  .hero-ctas .btn {
    font-size: 12px;
    padding: 10px 8px;
  }

 
}

/* =========================================
   DASHBOARD BUTTON — FINAL
========================================= */

/* DESKTOP (DEFAULT) */
.dashboard-button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.dashboard-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  display: block;
}

/* =========================================
   📱 MOBILE / PWA (ICON ONLY)
========================================= */

@media (max-width: 768px) {

  .dashboard-button {
    padding: 10px;
    justify-content: center;
  }

  /* 🔥 HIDE TEXT CLEANLY */
  .dashboard-text {
    display: none;
  }

  /* ICON SIZE */
  .dashboard-icon {
    width: 20px;
    height: 20px;
  }
 .header-actions {
    gap: 2px;          /* 🔥 reduced from large spacing */
  } 
}

/* SMALL DEVICES */

@media (max-width: 420px) {

  .dashboard-button {
    border-radius: 5px;
    padding: 2px;
  }

  .dashboard-icon {
    width: 20px;
    height: 20px;
  }
}

/* =========================================
   📱 REMINDER CARD — CALL UI STYLE (PWA ONLY)
   (NO BACKGROUND CHANGE)
========================================= */

@media (max-width: 768px) {

  .reminder-card {
    display: flex;
    align-items: center;
    gap: 10px;

    padding: 12px;
    border-radius: 14px;

    /* 🔥 combined animations */
    animation: callShake 1.8s ease-in-out infinite,
               pulse-glow 2s ease-in-out infinite;
  }

  /* 🔔 shake (ring feel) */
  @keyframes callShake {
    0%, 100% { transform: translateX(0); }
    20% { transform: translateX(-1px); }
    40% { transform: translateX(1px); }
    60% { transform: translateX(-1px); }
    80% { transform: translateX(1px); }
  }

  /* ✨ cyan pulse glow (your version polished) */
  @keyframes pulse-glow {
    0%, 100% {
      box-shadow: 0 0 0 0 rgba(0, 188, 212, 0.25);
    }
    50% {
      box-shadow: 0 0 18px 4px rgba(0, 188, 212, 0.18);
    }
  }

  /* ICON */
  .reminder-icon {
    flex-shrink: 0;
    position: relative;
  }

  /* 🔵 ringing glow around icon */
  .reminder-icon::after {
    content: "";
    position: absolute;
    inset: -6px;
    border-radius: 50%;
    border: 2px solid rgba(0, 188, 212, 0.4);
    animation: ringPulse 1.6s infinite;
  }

  @keyframes ringPulse {
    0% {
      transform: scale(0.8);
      opacity: 0.8;
    }
    70% {
      transform: scale(1.4);
      opacity: 0;
    }
    100% {
      opacity: 0;
    }
  }

  /* TEXT BLOCK */
  .reminder-info {
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex: 1;
  }

  .reminder-label {
    font-size: 10px;
    color: #111827;
    font-weight: bolder;
  }

  .reminder-title {
    font-size: 20px;
    font-weight: 700;
    color: #0D47A1;
    line-height: 1.2;
  }

  .reminder-subtitle {
    font-size: 12px;
    color: #555;
  }

  /* ACTION BUTTONS */
  .reminder-actions {
    display: flex;
    gap: 8px;
    flex-shrink: 0;
  }

  .call-btn {
    width: 34px;
    height: 34px;
    border-radius: 50%;

    display: flex;
    align-items: center;
    justify-content: center;
  }

  .call-btn.decline {
    background: #f44336;
    color: #fff;
  }

  .call-btn.accept {
    background: #4CAF50;
    color: #fff;

    position: relative;
    animation: acceptPulse 1.5s infinite;
  }

  /* glow behind accept button */
  .call-btn.accept::after {
    content: "";
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    background: rgba(76, 175, 80, 0.3);
    animation: acceptGlow 1.5s infinite;
    z-index: -1;
  }

  @keyframes acceptPulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.08); }
  }

  @keyframes acceptGlow {
    0% {
      transform: scale(0.9);
      opacity: 0.7;
    }
    70% {
      transform: scale(1.5);
      opacity: 0;
    }
    100% {
      opacity: 0;
    }
  }

}

/* ===================================================================
   📱 BENEFITS — FINAL PWA FIX (2 CARDS PER ROW)
   ✔ Guaranteed override
   ✔ Desktop untouched
   ✔ Place this at VERY END of CSS
=================================================================== */

@media screen and (max-width: 768px) {

  /* =========================
     SECTION SPACING
  ========================= */

  .benefits {
    padding: 64px 0 56px;
  }

  .benefits .container {
    padding-left: 16px;
    padding-right: 16px;
  }

  /* =========================
     HEADER
  ========================= */

  .section-header {
    text-align: center;
    margin-bottom: 28px;
  }

  .section-title {
    font-size: clamp(22px, 5vw, 28px);
    line-height: 1.25;
  }
 
  .section-subtitle {
    font-size: 14px;
    line-height: 1.6;
  }
.benefits-grid {
    display: grid !important;          /* force grid */
    flex: none !important;             /* kill flex */
    width: 100% !important;

    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;

    overflow: visible !important;
  }

  /* 🔥 STEP 2: FORCE CHILD INTO GRID CELLS */
  .benefits-grid > .benefit-card {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;

    flex: none !important;             /* CRITICAL */
    grid-column: auto !important;

    margin: 0 !important;
    padding: 14px !important;

    box-sizing: border-box !important;
  }
  
  .benefit-card:active {
    transform: scale(0.96);
  box-shadow: 0 6px 14px rgba(0,0,0,0.05);
  }

  /* =========================
     CONTENT ALIGNMENT
  ========================= */

  .benefit-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
  }

  .benefit-icon {
    width: 32px;
    height: 32px;
    flex-shrink: 0;

    display: flex;
    align-items: center;
    justify-content: center;
  }

  .benefit-icon svg {
    width: 18px;
    height: 18px;
  }

  .benefit-title {
    font-size: 14px;
    font-weight: 600;
    line-height: 1.3;
  }

  .benefit-desc {
    font-size: 12.5px;
    line-height: 1.5;
    color: #555;
    margin-top: 4px;
  }

}


/* =========================
   OPTIONAL: SMALL DEVICES
========================= */

@media screen and (max-width: 420px) {

  /* 👉 choose ONE option */

  /* OPTION A: keep 2 cards (tight app feel) */
  
  .benefits-grid {
    grid-template-columns: 1fr 1fr !important;
  }
  

  /* OPTION B: 1 card (recommended readability) 
  .benefits-grid {
    grid-template-columns: 1fr !important;
  }*/

}


/* =========================================
   📱 BENEFIT CARD — CURVED BOTTOM
========================================= */

@media (max-width: 768px) {

  .benefit-card {
    position: relative;
    overflow: hidden;
  }

  /* 🔥 CURVED BOTTOM */
  .benefit-card::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;

    width: 100%;
    height: 50px;

    background: #ffffff;

    /* smooth curve */
    border-top-left-radius: 60% 40px;
    border-top-right-radius: 60% 40px;

    z-index: 1;
  }

  /* keep content above */
  .benefit-card > * {
    position: relative;
    z-index: 2;
  }

}
/* =========================================
   📱 BENEFIT CARD — FULL ACTIVE STYLE DEFAULT
========================================= */

@media (max-width: 768px) {

  .benefit-card {

    /* 🔥 elevation */
    transform: translateY(-2px);

    box-shadow:
      0 4px 10px rgba(0,0,0,0.04),
      0 10px 20px rgba(0,0,0,0.06);

    /* 🔥 border highlight */
    border: 1px solid rgba(0, 188, 212, 0.25);

    /* 🔥 top accent line */
    background-image: linear-gradient(
      to bottom,
      #00BCD4 3px,
      #ffffff 3px
    );
    background-repeat: no-repeat;

    transition: all 0.25s ease;
  }

  /* =========================
     ICON — ACTIVE STYLE
  ========================= */
.benefit-icon {
  transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(0, 188, 212, 0.2);
  background: var(--gradient-primary);
  color: #ffffff;
  border-radius: 100px;
}
}
/* ===============================================================================================================================
   📱 HOW IT WORKS — PWA PREMIUM UI
   (Mobile Only — Desktop Untouched)
================================================================================================================================ */
/* =====================================================
   📱 HOW IT WORKS — ANIMATED ONBOARDING FLOW
===================================================== */

@media (max-width: 768px) {

  /* =========================
     TIMELINE BASE
  ========================= */

  .steps-grid {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 18px;
    padding-left: 28px;
  }

  /* =========================
     ANIMATED LINE
  ========================= */

  .steps-grid::before {
    content: "";
    position: absolute;
    left: 10px;
    top: 8px;
    bottom: 8px;
    width: 2px;

    background: linear-gradient(
      to bottom,
      #00BCD4,
      #0D47A1
    );

    transform: scaleY(0);
    transform-origin: top;

    animation: growLine 1.2s ease forwards;
  }

  @keyframes growLine {
    to { transform: scaleY(1); }
  }

  /* =========================
     STEP CARD ENTRY
  ========================= */

  .step-card {
    position: relative;

    opacity: 0;
    transform: translateY(20px);

    animation: fadeUp 0.6s ease forwards;
  }

  .step-card:nth-child(1) { animation-delay: 0.2s; }
  .step-card:nth-child(2) { animation-delay: 0.4s; }
  .step-card:nth-child(3) { animation-delay: 0.6s; }

  @keyframes fadeUp {
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  /* =========================
     DOT (ANIMATED)
  ========================= */

  .step-card::before {
    content: "";
    position: absolute;
    left: -18px;
    top: 20px;

    width: 10px;
    height: 10px;
    border-radius: 50%;

    background: #00BCD4;

    box-shadow: 0 0 0 0 rgba(0,188,212,0.4);

    animation: pulseDot 2s infinite;
  }

  .step-card:nth-child(1)::before { animation-delay: 0.3s; }
  .step-card:nth-child(2)::before { animation-delay: 0.6s; }
  .step-card:nth-child(3)::before { animation-delay: 0.9s; }

  @keyframes pulseDot {
    0%   { box-shadow: 0 0 0 0 rgba(0,188,212,0.4); }
    70%  { box-shadow: 0 0 0 10px rgba(0,188,212,0); }
    100% { box-shadow: 0 0 0 0 rgba(0,188,212,0); }
  }

  /* =========================
     CARD STYLE (PREMIUM)
  ========================= */

  .step-card {
    padding: 18px;
    border-radius: 20px;

    background: linear-gradient(
      145deg,
      rgba(255,255,255,0.95),
      rgba(248,252,255,0.9)
    );

    border: 1px solid rgba(0,0,0,0.04);

    box-shadow:
      0 6px 18px rgba(0,0,0,0.04),
      0 20px 40px rgba(0,0,0,0.05);

    transition: all 0.3s ease;
  }

  .step-card:active {
    transform: scale(0.97);
  }
  /* =========================================
   📱 STEP CARD — WAVY BOTTOM BACKGROUND
========================================= */

@media (max-width: 768px) {

  .step-card {
    position: relative;
    overflow: hidden;
    background: #ffffff;
  }

/* 🔥 PERFECT CURVE (CSS IMPROVED) */
.step-card::after {
  content: "";
  position: absolute;
  left: -10%;
  bottom: 0;

  width: 120%;
  height: 120px;

  background: linear-gradient(
    135deg,
    rgba(0,188,212,0.12),
    rgba(13,71,161,0.10)
  );

  /* 🔥 smoother natural curve */
  border-radius: 60% 60% 0 0 / 100% 100% 0 0;

  transform: translateY(30%);

  z-index: 1;
}

  /* keep content above */
  .step-card > * {
    position: relative;
    z-index: 2;
  }

}

  /* =========================
     ICON
  ========================= */

  .step-icon {
    width: 42px;
    height: 42px;

    border-radius: 14px;

    background: linear-gradient(
      135deg,
      rgba(0,188,212,0.18),
      rgba(13,71,161,0.15)
    );

    display: flex;
    align-items: center;
    justify-content: center;

    transition: all 0.3s ease;
  }

  .step-card:active .step-icon {
    transform: scale(1.08);
  }

}
/* =========================================
   📱 HOW IT WORKS — REMOVE TOP GAP
========================================= */

@media (max-width: 768px) {

  /* reduce section top space */
  .how-it-works {
    padding-top: 40px !important;   /* was ~80px */
    padding-bottom: 40px !important;
  }

  /* remove extra spacing from header */
  .how-it-works .section-header {
    margin-top: 0 !important;
  }
  .step-desc {
      font-weight:500;
      
  }

}
/* =====================================================/* =====================================================/* ==============================================


/* ================================================================================================================================
   📱 FEATURES — FINAL ULTRA PWA UI (REFINED)
   ✔ Clean
   ✔ Premium
   ✔ Consistent
   ✔ No conflicts
===================================================== */

@media screen and (max-width: 768px) {

  /* =========================
     SECTION
  ========================= */

  .features {
    padding: 64px 0 56px;
  }

  .features .container {
    padding-left: 16px;
    padding-right: 16px;
  }

  /* =========================
     LAYOUT
  ========================= */

  .features-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 28px;
  }

  /* =========================
     TEXT
  ========================= */

/* =========================
   TEXT — CENTERED FINAL
========================= */

.features-text {
  text-align: center;
  margin: 0 auto;
  max-width: 520px; /* 🔥 keeps it clean & readable */
}

.features-text .section-label {
  font-size: var(--font-size-sm);
  letter-spacing: 0.6px;
  text-transform: uppercase;
  opacity: 0.7;

  text-align: center;
}

.features-text .section-title {
  font-size: clamp(22px, 5vw, 28px);
  line-height: 1.25;

  margin-top: 6px;
  margin-left: auto;
  margin-right: auto;

  text-align: center;
}

.features-text .section-subtitle {
  font-size: 14px;
  line-height: 1.6;

  margin-top: 10px;
  margin-left: auto;
  margin-right: auto;

  color: #5f6b7a;

  text-align: center;
}
  /* =========================
     FEATURE LIST — PREMIUM
  ========================= */

  .feature-list {
    margin-top: 18px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 0;
    list-style: none;
  }

  .feature-item {
    position: relative;

    display: flex;
    align-items: center;
    gap: 12px;

    padding: 14px;
    border-radius: 16px;

    background: linear-gradient(145deg, #ffffff, #f7fbff);

    border: 1px solid rgba(0, 188, 212, 0.12);

    box-shadow:
      0 6px 14px rgba(0,0,0,0.04),
      0 14px 28px rgba(0,0,0,0.05);

    transition: all 0.25s ease;
    overflow: hidden;

    -webkit-tap-highlight-color: transparent;
  }

  /* subtle glow */
  .feature-item::after {
    content: "";
    position: absolute;
    right: -40px;
    bottom: -40px;

    width: 120px;
    height: 120px;

    background: radial-gradient(
      circle,
      rgba(0,188,212,0.10),
      transparent 70%
    );

    border-radius: 50%;
  }

  /* interaction */
  .feature-item:active {
    transform: scale(0.96);
    box-shadow:
      0 8px 18px rgba(0,0,0,0.05),
      0 16px 32px rgba(0,0,0,0.06);
  }

  /* ICON TILE */
  .feature-item svg {
    width: 24px;
    height: 24px;
    flex-shrink: 0;

    padding: 6px;
    border-radius: 10px;

    background: rgba(0,188,212,0.10);
    box-shadow: 0 4px 10px rgba(0,188,212,0.15);
  }

  /* TEXT */
  .feature-item span {
    font-size: 13.8px;
    line-height: 1.5;
    font-weight: 500;
    color: #0A2540;
  }

  /* =========================
     CTA
  ========================= */

  .features-text .btn {
    margin-top: 18px;
    width: 100%;
    justify-content: center;
  }

  /* =========================
     VISUAL (WIDER)
  ========================= */

  .features-visual {
    width: calc(100% + 24px);
    margin-left: -12px;
    margin-right: -12px;
    padding-left: 12px;
    padding-right: 12px;
  }

  .dashboard-mockup {
    border-radius: 20px;
    overflow: hidden;

    box-shadow:
      0 10px 24px rgba(0,0,0,0.06),
      0 24px 48px rgba(0,0,0,0.08);
  }

  /* =========================
     DASHBOARD SIMPLIFY
  ========================= */

  .dashboard-sidebar {
    display: none !important;
  }

  .dashboard-content {
    display: block !important;
  }

  .dashboard-main {
    padding: 12px;
  }

  /* =========================
     STAT CARDS
  ========================= */

  .stat-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .stat-card {
    position: relative;

    padding: 10px;
    border-radius: 14px;

    background: linear-gradient(145deg, #ffffff, #f8fbff);

    border: 1px solid rgba(0,188,212,0.12);

    box-shadow:
      0 4px 12px rgba(0,0,0,0.04),
      0 10px 20px rgba(0,0,0,0.05);

    transition: all 0.25s ease;
    overflow: hidden;
  }

  .stat-card::after {
    content: "";
    position: absolute;
    right: -30px;
    bottom: -30px;

    width: 100px;
    height: 100px;

    background: radial-gradient(
      circle,
      rgba(0,188,212,0.12),
      transparent 70%
    );
  }

  .stat-card:active {
    transform: scale(0.96);
  }

  .stat-label {
    font-size: 11px;
  }

  .stat-value {
    font-size: 18px;
    font-weight: 800;
  }

  /* progress */
  .stat-card .bg-gray-100 {
    background: rgba(0,0,0,0.06) !important;
    height: 6px;
    border-radius: 999px;
  }

  .stat-card .bg-gradient-to-r {
    border-radius: 999px;
    background: linear-gradient(90deg, #00BCD4, #0D47A1) !important;
    transition: width 0.6s ease;
  }

  /* =========================
     UPCOMING LIST
  ========================= */

  .bg-white.rounded-xl.p-3.border {
    border-radius: 16px;

    box-shadow:
      0 6px 16px rgba(0,0,0,0.05),
      0 18px 32px rgba(0,0,0,0.06);

    border: 1px solid rgba(0,188,212,0.10);
  }

  .flex.items-center.justify-between.py-2 {
    padding: 10px 0;
    border-bottom: 1px solid rgba(0,0,0,0.05) !important;
    transition: all 0.2s ease;
  }

  .flex.items-center.justify-between.py-2:active {
    transform: scale(0.98);
  }

  .flex.items-center.justify-between span:first-child {
    font-size: 11px;
    font-weight: 700;

    color: #00BCD4;

    background: rgba(0,188,212,0.08);
    padding: 3px 8px;
    border-radius: 999px;
  }

  .flex.items-center.justify-between span:nth-child(2) {
    font-size: 12px;
    font-weight: 500;
  }

  .flex.items-center.justify-between span:last-child {
    font-size: 11px;
    color: #9ca3af;
  }

}


/* =====================================================
   📱 SMALL DEVICES
===================================================== */

@media screen and (max-width: 420px) {

  .features {
    padding: 56px 0 48px;
  }

  .features-content {
    gap: 24px;
  }

  .feature-item {
    padding: 12px;
  }

  .feature-item span {
    font-size: 13px;
  }

  .stat-value {
    font-size: 16px;
  }

}

/* =========================
   REMOVE TOP SPACE — FEATURES SECTION
========================= */

@media (max-width: 768px) {

  .features {
    padding-top: 30px !important;  /* 🔥 reduced from large default */
  }

}
/* =====================================================/* =====================================================/* =====================================================
/* =====================================================/* =====================================================/* =====================================================


/* =====================================================
   📱 PRICING — ELITE PREMIUM PWA UI (FINAL FIXED)
===================================================== */

@media screen and (max-width: 768px) {

  /* =========================
     GLOBAL SAFETY (PWA FIX)
  ========================= */

  html, body {
    max-width: 100%;
    overflow-x: hidden;
  }

  *, *::before, *::after {
    box-sizing: border-box;
  }

  /* =========================
     SECTION
  ========================= */

  .pricing {
    padding: 64px 0 56px;
    overflow: hidden; /* prevents glow overflow */
  }

  .pricing .container {
    padding: 0 16px;
  }

  /* =========================
     HEADER
  ========================= */

  .pricing .section-header {
    text-align: center;
    margin-bottom: 28px;
  }

  .pricing .section-title {
    font-size: clamp(22px, 5vw, 28px);
    line-height: 1.25;
  }

  .pricing .section-subtitle {
    font-size: 14px;
    color: #5f6b7a;
    margin-top: 8px;
  }

  /* =====================================================
     🔥 TOGGLE — iOS STYLE (FIXED)
  ===================================================== */

  .pricing-toggle {
    position: relative;
    display: flex;
    width: 100%;
    max-width: 260px;
    margin: 20px auto 30px;

    background: #f1f5f9;
    padding: 4px;
    border-radius: 999px;

    overflow: hidden; /* FIX */
  }

  .toggle-btn {
    flex: 1;
    font-size: 12px;
    font-weight: 600;

    padding: 8px 6px;

    border: none;
    background: transparent;

    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;

    position: relative;
    z-index: 2;
  }

  .toggle-btn.active {
    color: #0A2540;
  }

  .toggle-btn:active {
    transform: scale(0.96);
  }

  .save-badge {
    font-size: 9px;
    padding: 2px 6px;
    border-radius: 999px;

    background: rgba(0,188,212,0.1);
    color: #00BCD4;
  }

  .toggle-bg {
    position: absolute;
    top: 4px;
    left: 4px;

    width: calc(50% - 4px);
    height: calc(100% - 8px);

    background: #fff;
    border-radius: 999px;

    box-shadow: 0 4px 10px rgba(0,0,0,0.08);

    transition: transform 0.3s ease;
  }

  .pricing-toggle[data-active="annual"] .toggle-bg {
    transform: translateX(100%);
  }

  /* =========================
     CARDS STACK
  ========================= */

  .pricing-cards {
    display: flex;
    flex-direction: column;
    gap: 18px;
  }

  /* =========================
     CARD BASE (FIXED)
  ========================= */

  .pricing-card {
    position: relative;
    overflow: hidden; /* CRITICAL FIX */

    padding: 20px;
    border-radius: 20px;

    background: linear-gradient(145deg, #ffffff, #f7fbff);

    border: 1px solid rgba(0,188,212,0.12);

    box-shadow:
      0 8px 20px rgba(0,0,0,0.04),
      0 24px 48px rgba(0,0,0,0.06);

    transition: all 0.3s ease;
  }

  /* =========================
     LIGHT SYSTEM (CONTAINED)
  ========================= */

  .pricing-card::before {
    content: "";
    position: absolute;
    top: -40px;
    right: -40px;

    width: 140px;
    height: 140px;

    background: radial-gradient(
      circle,
      rgba(0,188,212,0.18),
      transparent 70%
    );

    pointer-events: none;
  }

  .pricing-card::after {
    content: "";
    position: absolute;
    bottom: -40px;
    left: -40px;

    width: 140px;
    height: 140px;

    background: radial-gradient(
      circle,
      rgba(13,71,161,0.12),
      transparent 70%
    );

    pointer-events: none;
  }

  /* =========================
     INTERACTION
  ========================= */

  .pricing-card:active {
    transform: scale(0.97);
  }

  /* =========================
     POPULAR PLAN
  ========================= */

  .pricing-card.popular {
    border: 2px solid #00BCD4;

    background: linear-gradient(145deg, #ffffff, #f0fbff);

    box-shadow:
      0 12px 30px rgba(0,188,212,0.18),
      0 28px 60px rgba(0,0,0,0.08);
    overflow:visible;
  }

  /* =========================
     BADGE
  ========================= */

  .popular-badge {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);

    font-size: 10px;
    font-weight: 600;

    padding: 5px 12px;
    border-radius: 999px;

    background: #00BCD4;
    color: #fff;

    box-shadow:
      0 6px 14px rgba(0,188,212,0.3),
      0 0 0 4px rgba(0,188,212,0.08);

    z-index: 5;
  }

  /* =========================
     TEXT
  ========================= */

  .plan-name {
    font-size: 17px;
    font-weight: 700;
    color: #0A2540;
  }

  .plan-desc {
    font-size: 13px;
    color: #6b7280;
    margin-top: 4px;
  }

  /* =========================
     PRICE
  ========================= */

  .pricing-amount {
    margin: 16px 0 4px;
  }

  .price {
    font-size: 30px;
    font-weight: 800;
    letter-spacing: -0.5px;
  }

  .currency {
    font-size: 14px;
    margin-right: 2px;
  }

  .period {
    font-size: 12px;
    color: #6b7280;
  }

  /* =========================
     FEATURES
  ========================= */

  .plan-features {
    margin-top: 14px;
    display: flex;
    flex-direction: column;
    gap: 10px;
  }

  .plan-features li {
    font-size: 13px;
    line-height: 1.5;
  }

  /* =========================
     CTA
  ========================= */

  .pricing-card .btn {
    margin-top: 16px;
  }
}


/* =====================================================
   📱 SMALL DEVICES
===================================================== */

@media screen and (max-width: 420px) {

  .pricing {
    padding: 56px 0 48px;
  }

  .price {
    font-size: 24px;
  }

}


/* =========================
   BILLING NOTE
========================= */

.billing-note,
.billing-note.annual {
  display: inline-flex;
  align-items: center;

  font-size: 10px;
  font-weight: 600;

  padding: 4px 10px;
  border-radius: 999px;

  background: rgba(0,188,212,0.08);
  color: #00BCD4;

  box-shadow: 0 2px 6px rgba(0,188,212,0.15);
}
/* =====================================================/* =====================================================/* =====================================================
*/
@media screen and (max-width: 768px) {

  .testimonials {
    padding: 55px 0 56px;
  }

}
/* =====================================================/* =====================================================/* =====================================================



/* =====================================================
   📱 FAQ — ELITE PWA UI
   (Accordion • Premium • App Feel)
===================================================== */

@media screen and (max-width: 768px) {

  /* =========================
     SECTION
  ========================= */

  .faq {
    padding: 64px 0 56px;
  }

  .faq .container {
    padding: 0 16px;
  }

  /* =========================
     HEADER
  ========================= */

  .faq .section-header {
    text-align: center;
    margin-bottom: 28px;
  }

  .faq .section-title {
    font-size: clamp(22px, 5vw, 28px);
    line-height: 1.25;
  }

  /* =========================
     FAQ LIST
  ========================= */

  .faq-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  /* =========================
     FAQ ITEM (CARD STYLE)
  ========================= */

  .faq-item {
    border-radius: 16px;
    overflow: hidden;

    background: linear-gradient(145deg, #ffffff, #f8fbff);

    border: 1px solid rgba(0,188,212,0.12);

    box-shadow:
      0 6px 16px rgba(0,0,0,0.04),
      0 18px 32px rgba(0,0,0,0.05);

    transition: all 0.25s ease;
  }

  /* press feel */

  .faq-item:active {
    transform: scale(0.98);
  }

  /* =========================
     QUESTION BUTTON
  ========================= */

  .faq-question {
    width: 100%;

    padding: 16px;

    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;

    background: transparent;
    border: none;

    text-align: left;

    font-size: 14px;
    font-weight: 600;
    color: #0A2540;
  }

  .faq-question span {
    flex: 1;
    line-height: 1.4;
  }

  /* =========================
     ICON
  ========================= */

  .faq-icon {
    width: 20px;
    height: 20px;

    transition: transform 0.25s ease;
    flex-shrink: 0;
  }

  /* rotate when open */

  .faq-question[aria-expanded="true"] .faq-icon {
    transform: rotate(180deg);
  }

  /* =========================
     ANSWER
  ========================= */

  .faq-answer {
    max-height: 0;
    overflow: hidden;

    transition: all 0.3s ease;

    padding: 0 16px;
  }

  .faq-answer p {
    font-size: 13px;
    line-height: 1.6;
    color: #5f6b7a;

    padding-bottom: 14px;
  }

  /* =========================
     OPEN STATE
  ========================= */

  .faq-question[aria-expanded="true"] + .faq-answer {
    max-height: 300px;
    padding-top: 4px;
  }

  /* =========================
     ACTIVE CARD HIGHLIGHT
  ========================= */

  .faq-item:has(.faq-question[aria-expanded="true"]) {
    border: 1px solid rgba(0,188,212,0.3);

    box-shadow:
      0 10px 24px rgba(0,188,212,0.15),
      0 24px 48px rgba(0,0,0,0.06);
  }

}
/* =====================================================/* =====================================================/* =====================================================
/* =====================================================
   📱 CTA — FINAL ELITE PWA UI (PRESERVE + ENHANCE)
   ✔ Desktop safe
   ✔ Layered design retained
   ✔ Premium mobile polish
===================================================== */

@media screen and (max-width: 768px) {

  /* =========================
     SECTION
  ========================= */

  .cta-section {
    padding: 72px 16px 64px;
    position: relative;
  }

  /* =========================
     BACKGROUND (PRESERVE CORE)
  ========================= */

  .cta-bg {
    position: absolute;
    inset: 0;

    border-radius: 24px 24px 0px 0px;

    /* 🔥 KEEP EXISTING BACKGROUND IF ANY */
    /* (only fallback if not present) */
    background: linear-gradient(
      135deg,
      #0D47A1,
      #1976D2,
      #00BCD4
    );

    overflow: hidden;
    z-index: 0;
  }

  /* =========================
     SOFT GLOW SYSTEM (ENHANCED)
  ========================= */

  .cta-bg::before {
    content: "";
    position: absolute;
    top: -40px;
    right: -40px;

    width: 140px;
    height: 140px;

    background: radial-gradient(
      circle,
      rgba(255,255,255,0.18),
      transparent 70%
    );

    pointer-events: none;
  }

  .cta-bg::after {
    content: "";
    position: absolute;
    bottom: -40px;
    left: -40px;

    width: 140px;
    height: 140px;

    background: radial-gradient(
      circle,
      rgba(255,255,255,0.12),
      transparent 70%
    );

    pointer-events: none;
  }

  /* =========================
     CONTENT
  ========================= */

  .cta-content {
    position: relative;
    z-index: 2;

    text-align: center;

    padding: 30px 20px;

    border-radius: 24px;
  }

  /* =========================
     TITLE
  ========================= */

  .cta-title {
    font-size: clamp(22px, 5vw, 28px);
    line-height: 1.3;

    font-weight: 700;
    color: #ffffff;

    margin-bottom: 12px;
  }

  /* =========================
     SUBTITLE
  ========================= */

  .cta-subtitle {
    font-size: 14px;
    line-height: 1.6;

    color: rgba(255,255,255,0.85);

    margin-bottom: 22px;
  }

  /* =========================
     BUTTON GROUP
  ========================= */

  .cta-buttons {
    display: flex;
    flex-direction: column;
    gap: 12px;

    margin-top: 10px;
    margin-bottom: 14px;
  }

  /* =========================
     BUTTONS (APP STYLE)
  ========================= */

  .cta-buttons .btn {
    width: 100%;
    justify-content: center;

    font-size: 14px;
    font-weight: 600;

    padding: 13px 16px;

    border-radius: 14px;

    display: flex;
    align-items: center;
    gap: 8px;

    transition: all 0.25s ease;
  }

  /* PRIMARY BUTTON */

  .btn-white {
    background: #ffffff;
    color: #0D47A1;

    box-shadow:
      0 6px 16px rgba(0,0,0,0.15),
      0 12px 24px rgba(0,0,0,0.10);
  }

  /* subtle press feel */

  .cta-buttons .btn:active {
    transform: scale(0.96);
  }

  /* =========================
     ICON
  ========================= */

  .cta-buttons svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
  }

  /* =========================
     NOTE
  ========================= */

  .cta-note {
    font-size: 12px;
    color: rgba(255,255,255,0.75);

    margin-top: 12px;
  }
/* =========================
   CTA BUTTON GROUP
========================= */

.cta-buttons {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* =========================
   BASE BUTTON
========================= */

.cta-buttons .btn {
  width: 100%;
  justify-content: center;

  display: flex;
  align-items: center;
  gap: 10px;

  padding: 14px 16px;

  font-size: 14px;
  font-weight: 600;

  border-radius: 14px;

  transition: all 0.25s ease;
}

/* =========================
   PRIMARY BUTTON (MAIN CTA)
========================= */

.cta-btn-primary {
  background: #ffffff;
  color: #0D47A1;

  box-shadow:
    0 8px 20px rgba(0,0,0,0.18),
    0 16px 32px rgba(0,0,0,0.12);
}

/* hover feel (mobile subtle) */

.cta-btn-primary:active {
  transform: scale(0.96);
}

/* arrow animation */

.cta-btn-primary svg {
  transition: transform 0.25s ease;
}

.cta-btn-primary:active svg {
  transform: translateX(3px);
}

/* =========================
   SECONDARY BUTTON
========================= */

.cta-btn-secondary {
  background: rgba(255,255,255,0.12);
  color: #ffffff;

  border: 1px solid rgba(255,255,255,0.25);

  backdrop-filter: blur(6px);
}

/* press effect */

.cta-btn-secondary:active {
  transform: scale(0.96);
}

/* =========================
   ICONS
========================= */

.cta-buttons svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}


}

/* =====================================================/* =====================================================/* =====================================================
/* =====================================================
   📱 FOOTER — ELITE PWA UI (2 COLUMN SYSTEM)
   (FINAL CLEAN — NO CONFLICTS)
===================================================== */

@media screen and (max-width: 768px) {

  /* =========================
     SECTION
  ========================= */

  .footer {
    padding: 56px 16px 32px;
  }

  .footer .container {
    padding: 0;
  }

  /* =========================
     GRID → FINAL SYSTEM
  ========================= */



  .footer-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;

    max-width: 420px;
    margin: 0 auto;

    padding: 0 8px; /* 🔥 KEY FIX */

    gap: 20px 12px;
  }

  .footer-links,
  .footer-contact {
    flex: 0 0 calc(50% - 6px);
  }



  /* =========================
     BRAND BLOCK
  ========================= */

  .footer-brand {
    text-align: center;
    margin-bottom: 20px !important;
    width: 100%; /* ensure full row */
  }

  .footer-brand .logo-img {
    margin: 0 auto 12px;
  }

  /* =========================
     SOCIAL LINKS
  ========================= */

  .social-links {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-top: 10px;
  }

  .social-link {
    width: 36px;
    height: 36px;

    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 10px;
    background: rgba(0,188,212,0.08);

    transition: all 0.25s ease;
  }

  .social-link:active {
    transform: scale(0.92);
  }

  /* =========================
     TRUST BADGE
  ========================= */

  .footer-trust {
    margin-top: 12px;
  }

  .trust-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;

    font-size: 12px;
    color: #5f6b7a;
  }

  /* =========================
     HEADINGS
  ========================= */

  .footer-links h3,
  .footer-contact h3 {
    font-size: 13px;
    font-weight: bolder;
    margin-bottom: 10px;
  }

  /* =========================
     LINKS
  ========================= */

  .footer-links ul {
    display: flex;
    flex-direction: column;
    gap: 6px;
  }

  .footer-links a {
    font-size: 13px;
    transition: color 0.2s ease;
  }

  .footer-links a:active {
    color: #00BCD4;
  }

  /* =========================
     CONTACT
  ========================= */

  .footer-contact address p {
    display: flex;
    align-items: center;
    gap: 6px;

    font-size: 13px;
    color: #5f6b7a;

    margin-bottom: 6px;
  }

  .footer-contact svg {
    width: 16px;
    height: 16px;
  }

  /* =========================
     FOOTER BOTTOM
  ========================= */

  .footer-bottom {
    margin-top: 20px;
    text-align: center;
  }

  .footer-legal {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;

    margin-bottom: 10px;
  }

  .footer-legal a {
    font-size: 12px;
    color: #5f6b7a;
  }

  .hipaa-notice {
    font-size: 11px;
    line-height: 1.5;
    color: #8a94a6;

    padding: 0 10px;
  }

  /* =========================
     COPYRIGHT
  ========================= */

  .footer-copyright {
    text-align: center;
    margin-top: 16px;
  }

  .footer-copyright p {
    font-size: 12px;
    color: #8a94a6;
  }

}