/*
  GASKILL MOBILE — Ground-Up Rebuild
  Loaded AFTER all inline <style> blocks, so !important here wins.
  Desktop (>768px) is 100% untouched.
*/

/* ================================================================
   BASE
   ================================================================ */
@media (max-width: 768px) {
  *, *::before, *::after { box-sizing: border-box; }
  body { overflow-x: hidden; -webkit-text-size-adjust: 100%; }
  .container { padding: 0 18px !important; max-width: 100% !important; }
  .section { padding: 60px 0 !important; }
  .section-sm { padding: 44px 0 !important; }
  .section-head { margin-bottom: 32px !important; }
  .section-head h2 { font-size: clamp(1.9rem, 7.5vw, 2.5rem) !important; line-height: 1.12 !important; }
  .section-head p { font-size: 15.5px !important; line-height: 1.7 !important; }
  h1 { font-size: clamp(2.5rem, 9vw, 3.4rem) !important; line-height: 1.04 !important; }
  h2 { font-size: clamp(1.85rem, 7vw, 2.4rem) !important; }
}

/* ================================================================
   NAV — logo absolutely centered; phone left, contact right
   Social cluster hidden on mobile (available in footer)
   ================================================================ */
@media (max-width: 768px) {
  nav { overflow: visible !important; }
  .nav-inner {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 0 14px !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    position: relative !important;
  }
  /* Logo absolutely centered — doesn't push flex items */
  .nav-logo-center {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    z-index: 1 !important;
  }
  .nav-logo-center img {
    height: 26px !important;
    width: auto !important;
    display: block !important;
  }
  .nav-left { flex: 0 0 auto !important; position: relative !important; z-index: 2 !important; }
  .nav-right {
    flex: 0 0 auto !important;
    display: flex !important;
    align-items: center !important;
    gap: 0 !important;
    position: relative !important;
    z-index: 2 !important;
  }
  /* hide social in nav — users find it in the footer */
  .nav-right .social-cluster { display: none !important; }
  .hamburger { display: none !important; }
  .mobile-menu { display: none !important; }
  .nav-phone { display: block !important; font-size: 10.5px !important; letter-spacing: 0 !important; font-weight: 700 !important; }
  .nav-right .btn {
    display: flex !important;
    padding: 8px 14px !important;
    font-size: 10.5px !important;
    letter-spacing: 0.05em !important;
    white-space: nowrap !important;
    min-height: 36px !important;
  }
  .nav-gs-wrap { position: static !important; }
}

/* ================================================================
   HERO — INDEX.HTML
   Mascot fills the full hero height. Content centered left.
   ================================================================ */
@media (max-width: 768px) {
  .hero {
    min-height: 100svh !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    padding-top: 88px !important;
    padding-bottom: 60px !important;
    position: relative !important;
    overflow: hidden !important;
  }
  .mascot-hero {
    position: absolute !important;
    right: -8% !important;
    top: 60px !important;
    bottom: 0 !important;
    height: auto !important;
    max-height: calc(100% - 60px) !important;
    width: auto !important;
    opacity: 0.46 !important;
    z-index: 0 !important;
    pointer-events: none !important;
    transform: none !important;
    left: auto !important;
  }
  .hero .container {
    width: 100% !important;
    position: relative !important;
    z-index: 2 !important;
  }
  .hero-inner {
    width: 100% !important;
    position: relative !important;
    z-index: 2 !important;
  }
  .hero-content {
    position: relative !important;
    z-index: 2 !important;
    max-width: 72% !important;
  }
  .hero-sub {
    font-size: 15px !important;
    line-height: 1.65 !important;
    max-width: 100% !important;
    margin-bottom: 24px !important;
  }
  .hero-cta-row {
    display: flex !important;
    flex-direction: column !important;
    gap: 11px !important;
    max-width: 280px !important;
  }
  .hero-cta-btn {
    width: 100% !important;
    justify-content: center !important;
    min-height: 52px !important;
    font-size: 13px !important;
    letter-spacing: 0.07em !important;
    display: flex !important;
    align-items: center !important;
  }
  .hero-visual { display: none !important; }
}

/* ================================================================
   HERO STATS (index.html proof strip)
   ================================================================ */
@media (max-width: 768px) {
  .hero-stats {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 0 !important;
    margin-top: 36px !important;
    border-top: 1px solid rgba(255,255,255,0.1) !important;
    border-radius: 0 !important;
  }
  .hero-stat {
    padding: 18px 14px !important;
    border-right: 1px solid rgba(255,255,255,0.1) !important;
    border-bottom: 1px solid rgba(255,255,255,0.1) !important;
    text-align: center !important;
    flex-direction: column !important;
    align-items: center !important;
  }
  .hero-stat:nth-child(even) { border-right: none !important; }
  .hero-stat:nth-last-child(-n+2) { border-bottom: none !important; }
  .stat-num { font-size: 1.9rem !important; line-height: 1 !important; }
  .stat-label { font-size: 11px !important; margin-top: 4px !important; }
  .proof-div { display: none !important; }
}

/* ================================================================
   PICK YOUR PATH (index.html)
   Flat HTML structure — must use column (stacked) layout
   ================================================================ */
@media (max-width: 768px) {
  .path-grid {
    grid-template-columns: 1fr !important;
    overflow: hidden !important;
  }
  .path-card {
    display: flex !important;
    flex-direction: column !important;
    text-align: left !important;
    padding: 24px 20px !important;
    border-right: none !important;
    border-radius: 0 !important;
    border-bottom: 1px solid var(--border) !important;
    gap: 0 !important;
  }
  .path-card:last-child { border-bottom: none !important; }
  .path-card-icon {
    font-size: 1.6rem !important;
    margin-bottom: 10px !important;
    line-height: 1 !important;
  }
  .path-card-type {
    font-size: 9.5px !important;
    letter-spacing: 0.14em !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    margin-bottom: 6px !important;
  }
  .path-card h3 {
    font-size: 1.15rem !important;
    margin-bottom: 8px !important;
    line-height: 1.2 !important;
  }
  .path-card-desc {
    font-size: 13.5px !important;
    line-height: 1.6 !important;
    color: var(--light) !important;
    margin-bottom: 14px !important;
  }
  .path-price {
    font-size: 1.5rem !important;
    font-weight: 900 !important;
    margin-bottom: 4px !important;
  }
  .path-price span {
    font-size: 13px !important;
    font-weight: 500 !important;
    opacity: 0.75 !important;
  }
  .path-note {
    font-size: 11.5px !important;
    color: var(--gray) !important;
    margin-bottom: 14px !important;
    line-height: 1.5 !important;
  }
  .path-arrow {
    font-size: 11.5px !important;
    font-weight: 700 !important;
    letter-spacing: 0.07em !important;
    text-transform: uppercase !important;
  }
  /* App grid — override inline styles */
  .app-home-grid {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .app-home-grid > div { padding: 24px 20px !important; }
  .app-home-grid-3 { grid-template-columns: repeat(2, 1fr) !important; gap: 8px !important; }
}

/* ================================================================
   BUTTONS
   ================================================================ */
@media (max-width: 768px) {
  .btn { min-height: 52px !important; font-size: 13px !important; }
  .cta-actions {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 11px !important;
    max-width: 340px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .cta-actions .btn { justify-content: center !important; }
  .page-actions { flex-direction: column !important; gap: 11px !important; }
  .page-actions .btn { justify-content: center !important; width: 100% !important; }
}

/* ================================================================
   CARDS — generous padding, single column
   ================================================================ */
@media (max-width: 768px) {
  .service-cards { grid-template-columns: 1fr !important; gap: 14px !important; }
  .service-card { padding: 24px 20px !important; }
  .feature-card { padding: 26px 22px !important; }
  .review-card { padding: 24px 20px !important; }
  .inc-item { padding: 16px 18px !important; }
  .step-card { padding: 28px 22px !important; }
}

/* ================================================================
   PRICING
   ================================================================ */
@media (max-width: 768px) {
  .pricing-grid { grid-template-columns: 1fr !important; gap: 18px !important; }
  .pricing-card { padding: 32px 24px !important; }
  .pricing-card.featured { order: -1 !important; }
  .p-price { font-size: 3.4rem !important; }
  .p-features { gap: 12px !important; }
  .p-features li { font-size: 14.5px !important; }
  .pricing-badge { font-size: 10px !important; padding: 5px 14px !important; }
}

/* ================================================================
   ANNUAL PITCH
   ================================================================ */
@media (max-width: 768px) {
  .annual-pitch {
    flex-direction: column !important;
    text-align: center !important;
    padding: 24px 20px !important;
    gap: 14px !important;
    border-radius: var(--r-lg) !important;
  }
  .annual-pitch-icon { font-size: 2.4rem !important; }
  .annual-pitch-headline { font-size: 1rem !important; }
  .annual-pitch-sub { font-size: 14px !important; }
  .annual-pitch-math { text-align: center !important; font-size: 12.5px !important; }
}

/* ================================================================
   COMPARISON V3 TABLES
   Stacked: Gaskill top (green tint) / Competitors bottom
   ================================================================ */
@media (max-width: 768px) {
  .comp-v3-head { display: none !important; }

  .comp-v3-row {
    display: flex !important;
    flex-direction: column !important;
    border-bottom: 1px solid rgba(255,255,255,0.07) !important;
  }

  .comp-v3-cell {
    width: 100% !important;
    padding: 15px 16px !important;
    border-right: none !important;
    border-left: none !important;
    font-size: 14.5px !important;
    line-height: 1.55 !important;
    flex-wrap: wrap !important;
    align-items: flex-start !important;
    row-gap: 0 !important;
    gap: 10px !important;
  }

  /* Label above each cell */
  .cv3-us::before {
    content: 'GASKILL' !important;
    display: block !important;
    width: 100% !important;
    order: -1 !important;
    font-size: 8.5px !important;
    font-weight: 900 !important;
    letter-spacing: 0.15em !important;
    color: var(--green) !important;
    margin-bottom: 6px !important;
  }
  .cv3-them::before {
    content: 'COMPETITORS' !important;
    display: block !important;
    width: 100% !important;
    order: -1 !important;
    font-size: 8.5px !important;
    font-weight: 900 !important;
    letter-spacing: 0.15em !important;
    color: rgba(255,255,255,0.35) !important;
    margin-bottom: 6px !important;
  }

  .cv3-us { background: rgba(45,179,74,0.07) !important; }
  .cv3-them {
    background: rgba(0,0,0,0.15) !important;
    border-top: 1px solid rgba(255,255,255,0.05) !important;
    opacity: 0.8 !important;
  }
  .comp-v3-icon { font-size: 16px !important; flex-shrink: 0 !important; margin-top: 2px !important; }
  .comp-v3-text { font-size: 14.5px !important; line-height: 1.55 !important; flex: 1 !important; }

  /* Footer row */
  .comp-v3-footer { display: flex !important; flex-direction: column !important; }
  .comp-v3-footer-cell {
    width: 100% !important;
    padding: 15px 16px !important;
    border: none !important;
  }
  .comp-v3-footer-cell.cv3-them {
    border-top: 1px solid rgba(255,255,255,0.07) !important;
  }

  .comp-v3-disclaimer { margin: 12px 0 0 !important; padding: 14px 16px !important; border-radius: var(--r) !important; }
  .comp-v3-disclaimer p { font-size: 12px !important; }
}

/* ================================================================
   OLD COMP TABLE (index.html service tabs)
   ================================================================ */
@media (max-width: 768px) {
  .comp-head, .comp-row { grid-template-columns: 1.6fr 1fr 1fr !important; }
  .comp-head > div, .comp-row > div { padding: 11px 9px !important; font-size: 11.5px !important; }
  .their-price .pn, .our-price .pn { font-size: 0.95rem !important; }
  .comp-footer { flex-direction: column !important; text-align: center !important; gap: 10px !important; }
  .comp-name { font-size: 12.5px !important; }
  .comp-sub { font-size: 10.5px !important; }
}

/* ================================================================
   REVIEWS
   ================================================================ */
@media (max-width: 768px) {
  .reviews-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
  .reviews-footer {
    flex-direction: column !important;
    text-align: center !important;
    gap: 14px !important;
    align-items: center !important;
  }
  .reviews-footer .g-rating { justify-content: center !important; }
}

/* ================================================================
   CTA SECTION
   ================================================================ */
@media (max-width: 768px) {
  .cta-mascot { display: none !important; }
  .cta-section h2 { font-size: clamp(1.9rem, 7vw, 2.4rem) !important; }
  .cta-section p { font-size: 15px !important; margin-bottom: 32px !important; }
}

/* ================================================================
   FOOTER
   ================================================================ */
@media (max-width: 768px) {
  footer { padding: 48px 0 28px !important; }
  .footer-grid { grid-template-columns: 1fr !important; gap: 28px !important; margin-bottom: 32px !important; }
  .footer-bottom {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    gap: 14px !important;
  }
  .footer-social { justify-content: center !important; }
  .footer-desc { max-width: 100% !important; }
}

/* ================================================================
   INNER PAGE HEROES (gf / pt / yf stat strips)
   ================================================================ */
@media (max-width: 768px) {
  .gf-hero-content,
  .pt-hero-content,
  .yf-hero-content {
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .gf-hero-actions,
  .pt-hero-actions,
  .yf-hero-actions {
    flex-direction: column !important;
    gap: 11px !important;
  }
  .gf-hero-actions .btn,
  .pt-hero-actions .btn,
  .yf-hero-actions .btn {
    width: 100% !important;
    justify-content: center !important;
    min-height: 54px !important;
  }
  /* stat strips — 2 clean columns */
  .gf-stat-strip-inner,
  .pt-stat-strip-inner,
  .yf-stat-strip-inner {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .gf-stat-item,
  .pt-stat-item,
  .yf-stat-item {
    padding: 18px 14px !important;
    border-bottom: 1px solid rgba(255,255,255,0.07) !important;
  }
}

/* ================================================================
   PAGE HERO (faq.html etc)
   ================================================================ */
@media (max-width: 768px) {
  .page-hero { padding: 100px 0 44px !important; }
  .page-sub { font-size: 15px !important; }
  .page-hero-inner { grid-template-columns: 1fr !important; }
  .page-hero-mascot { display: none !important; }
  .final-cta { padding: 56px 0 !important; }
}

/* ================================================================
   MISC LAYOUT
   ================================================================ */
@media (max-width: 768px) {
  .included-grid { grid-template-columns: 1fr !important; gap: 10px !important; }
  .form-row { grid-template-columns: 1fr !important; }
  .app-home-grid { grid-template-columns: 1fr !important; }
  .app-home-grid-3 { grid-template-columns: repeat(2, 1fr) !important; }
  .app-meal-grid { grid-template-columns: 1fr !important; }
  .platform-badges { flex-direction: column !important; align-items: flex-start !important; gap: 10px !important; }
  .final-cta-inner { grid-template-columns: 1fr !important; gap: 40px !important; }
  .comp-savings-head,
  .comp-row-s { grid-template-columns: 1.5fr 1fr 1fr !important; font-size: 12px !important; }
  .comp-savings-head > div,
  .comp-row-s > div { padding: 10px 8px !important; font-size: 11.5px !important; }
}

/* ================================================================
   INLINE GRID OVERRIDES
   Attribute selectors target divs with inline style grids that
   have no CSS class for us to hook onto.
   ================================================================ */
@media (max-width: 768px) {
  /* 3-column feature grids (e.g. "Built Around You" on gf page) */
  [style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns: repeat(3"] {
    grid-template-columns: 1fr !important;
  }
  /* 2-col grids with explicit max-width (pricing card containers) */
  [style*="max-width:760px"][style*="grid-template-columns"],
  [style*="max-width: 760px"][style*="grid-template-columns"],
  [style*="max-width:900px"][style*="grid-template-columns"],
  [style*="max-width: 900px"][style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
    max-width: 100% !important;
  }
  /* 2-column grids (feature cards, etc.) that have no CSS class */
  [style*="grid-template-columns:repeat(2"],
  [style*="grid-template-columns: repeat(2"] {
    grid-template-columns: 1fr !important;
  }
  /* Wide-gap side-by-side layouts (e.g. pricing + benefits, gap:48px) */
  [style*="gap:48px"][style*="grid-template-columns"],
  [style*="gap: 48px"][style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }
}

/* ================================================================
   BOTTOM BAR + HINT
   ================================================================ */
@media (max-width: 768px) {
  .bb-link { min-height: 50px !important; font-size: 10px !important; padding: 10px 4px !important; }
  .bb-link .bb-icon { font-size: 20px !important; line-height: 1 !important; }

  .bb-hint {
    display: flex !important;
    align-items: center !important;
    gap: 7px !important;
    position: fixed !important;
    bottom: calc(var(--bottom-bar) + 10px) !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    background: rgba(18,18,18,0.97) !important;
    border: 1px solid rgba(255,255,255,0.14) !important;
    color: rgba(255,255,255,0.82) !important;
    font-size: 11.5px !important;
    font-weight: 600 !important;
    letter-spacing: 0.03em !important;
    padding: 9px 18px !important;
    border-radius: 24px !important;
    z-index: 850 !important;
    pointer-events: none !important;
    white-space: nowrap !important;
    opacity: 0 !important;
    transition: opacity 0.5s ease !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    box-shadow: 0 4px 24px rgba(0,0,0,0.55) !important;
  }
  .bb-hint-show { opacity: 1 !important; }
}

/* ================================================================
   SMALL PHONES (≤ 480px)
   ================================================================ */
@media (max-width: 480px) {
  .container { padding: 0 16px !important; }
  h1 { font-size: clamp(2.2rem, 9.5vw, 2.8rem) !important; }
  .mascot-hero { top: 55px !important; right: -12% !important; opacity: 0.42 !important; }
  .hero-content { max-width: 76% !important; }
  .btn { min-height: 52px !important; }
  .faq-q { min-height: 52px !important; font-size: 15px !important; padding: 18px 0 !important; }
  .bb-link { font-size: 9.5px !important; }
  .pricing-card { padding: 26px 18px !important; }
  .p-price { font-size: 3rem !important; }
  .review-card { padding: 20px 16px !important; }
  .feature-card { padding: 22px 16px !important; }
  .path-card { padding: 18px 16px !important; gap: 14px !important; }
  .annual-pitch { padding: 18px 16px !important; }
  .comp-v3-cell { padding: 13px 14px !important; font-size: 14px !important; }
  .section { padding: 52px 0 !important; }
  .section-sm { padding: 38px 0 !important; }
}
