/* responsive.css — comprehensive breakpoints for Easy Intelligence site */

/* ── Base resets ── */
* { box-sizing: border-box; }
img, video, iframe { max-width: 100%; height: auto; }
body { margin: 0; padding: 0; width: 100%; overflow-x: hidden; }

/* ══════════════════════════════════════════════════════════════════════
   TABLET & BELOW  (≤ 1024px)
   ══════════════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {

  /* ── Hero ── */
  [data-hero-grid] {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
    padding: 88px 24px 56px !important;
  }
  [data-hero-headline] {
    font-size: clamp(40px, 7vw, 60px) !important;
  }
  [data-hero-atom] {
    max-width: 300px !important;
    margin: 0 auto !important;
  }
  [data-hero-atom] > div:first-child {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 !important;
  }

  /* ── Section padding ── */
  section, footer {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }

  /* ── About ── */
  [data-about-grid] {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
  }
  [data-about-sticky] {
    position: static !important;
    top: auto !important;
  }

  /* ── Services ── */
  [data-services-header] {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    align-items: start !important;
  }
  [data-services-intro] {
    justify-self: start !important;
    max-width: none !important;
  }
  [data-services-grid] {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* ── Methodology ── */
  [data-method-row] {
    grid-template-columns: 80px 1fr !important;
    gap: 20px !important;
  }
  [data-phase-circle] {
    width: 72px !important;
    height: 72px !important;
  }
  [data-method-glyph] {
    font-size: 28px !important;
  }

  /* ── Contact ── */
  [data-contact-grid] {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
  }
  [data-contact-heading] {
    font-size: clamp(36px, 7vw, 52px) !important;
  }

  /* ── Footer ── */
  .ei-footer-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 32px !important;
  }
  [data-footer-bottom] {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
  }
}

/* ══════════════════════════════════════════════════════════════════════
   LARGE MOBILE  (≤ 768px)
   ══════════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* ── Services → 1 col ── */
  [data-services-grid] {
    grid-template-columns: 1fr !important;
  }

  /* ── Methodology ── */
  [data-method-row] {
    grid-template-columns: 64px 1fr !important;
    gap: 16px !important;
  }
  [data-phase-circle] {
    width: 60px !important;
    height: 60px !important;
  }
  [data-method-glyph] {
    font-size: 24px !important;
  }
  [data-method-content] {
    padding-bottom: 40px !important;
  }

  /* ── Footer → 1 col ── */
  .ei-footer-grid {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }

  /* ── Hero Stats ── */
  [data-hero-stats] {
    flex-direction: column !important;
    gap: 16px !important;
  }
  [data-hero-stats] > div {
    border-left: none !important;
    border-top: 1px solid rgba(255,255,255,0.10) !important;
    padding: 12px 0 0 !important;
  }

  /* ── Page header ── */
  [data-page-header-title] {
    font-size: clamp(32px, 8vw, 48px) !important;
  }
}

/* ══════════════════════════════════════════════════════════════════════
   MOBILE  (≤ 640px)
   ══════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {

  /* ── Section padding ── */
  section, footer {
    padding-top: 64px !important;
    padding-bottom: 64px !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  /* ── Hero ── */
  [data-hero-grid] {
    padding: 80px 20px 48px !important;
  }
  [data-hero-headline] {
    font-size: clamp(32px, 9vw, 48px) !important;
    line-height: 1.06 !important;
  }
  [data-hero-sub] {
    font-size: 16px !important;
  }
  [data-hero-atom] {
    max-width: 240px !important;
  }

  /* ── Section headings ── */
  h1, h2 {
    font-size: clamp(28px, 8vw, 44px) !important;
    line-height: 1.1 !important;
  }
  h3 {
    font-size: clamp(18px, 5vw, 24px) !important;
  }

  /* ── About ── */
  [data-about-heading] {
    font-size: clamp(28px, 7vw, 36px) !important;
  }

  /* ── Services ── */
  [data-services-heading] {
    font-size: clamp(28px, 7vw, 40px) !important;
  }

  /* ── Methodology ── */
  [data-method-heading] {
    font-size: clamp(28px, 8vw, 40px) !important;
  }
  [data-method-row] {
    grid-template-columns: 52px 1fr !important;
    gap: 12px !important;
  }
  [data-phase-circle] {
    width: 48px !important;
    height: 48px !important;
  }
  [data-method-glyph] {
    font-size: 20px !important;
  }
  [data-method-name] {
    font-size: 20px !important;
  }
  [data-method-content] {
    padding-bottom: 32px !important;
  }

  /* ── Contact ── */
  [data-contact-heading] {
    font-size: clamp(28px, 8vw, 40px) !important;
  }
  [data-form-card] {
    padding: 24px !important;
  }

  /* ── Buttons — NOT full-width (breaks nav/toggles) ── */
  [data-hero-grid] a,
  form button[type="submit"] {
    width: 100% !important;
    max-width: 320px !important;
    text-align: center !important;
    justify-content: center !important;
  }

  /* ── Hero CTA row ── */
  [data-hero-cta] {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  /* ── General containers ── */
  .container, [data-container] {
    padding: 0 16px !important;
  }
}

/* ══════════════════════════════════════════════════════════════════════
   VERY SMALL PHONES  (≤ 480px)
   ══════════════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {

  section, footer {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  [data-hero-grid] {
    padding: 72px 16px 40px !important;
  }

  [data-hero-headline] {
    font-size: clamp(24px, 9vw, 36px) !important;
  }

  h1, h2 {
    font-size: clamp(22px, 8vw, 32px) !important;
  }

  /* ── Body text ── */
  p, li {
    font-size: 14px !important;
    line-height: 1.55 !important;
  }

  /* ── Nav ── */
  nav {
    padding: 0 12px !important;
  }

  /* ── Form inputs — prevent iOS zoom ── */
  input, textarea {
    font-size: 16px !important;
  }

  /* ── Hero stats ── */
  [data-hero-stats] [data-stat-num] {
    font-size: 20px !important;
  }

  /* ── Methodology ── */
  [data-method-row] {
    grid-template-columns: 44px 1fr !important;
    gap: 10px !important;
  }
  [data-phase-circle] {
    width: 40px !important;
    height: 40px !important;
  }
  [data-method-glyph] {
    font-size: 16px !important;
  }

  /* ── Footer bottom items ── */
  [data-footer-bottom] > div {
    flex-direction: column !important;
    gap: 8px !important;
  }

  /* ── Service card padding ── */
  [data-services-grid] article {
    padding: 24px !important;
    border-radius: 14px !important;
  }

  /* ── Contact ── */
  [data-contact-heading] {
    font-size: clamp(22px, 8vw, 32px) !important;
  }
}

/* ══════════════════════════════════════════════════════════════════════
   PRINT — for legal pages
   ══════════════════════════════════════════════════════════════════════ */
@media print {
  nav, footer, [data-tweaks-panel], button { display: none !important; }
  body { background: #fff !important; color: #000 !important; }
  * { background: transparent !important; color: #000 !important; box-shadow: none !important; }
}
