/* Agency kit — responsive layout.
   Layout-level rules live here (not inline) so media queries can override them.
   Cosmetic one-offs stay inline in the JSX.
   Breakpoints: 980 (heroes/splits stack, grids 3→2), 800 (nav links hide,
   footer 2-col), 640 (single-column card grids), 480 (footer single col). */

html, body { overflow-x: hidden; }
html { scroll-behavior: smooth; }

/* ---- Shared wrappers ---- */
/* Horizontal page padding (max-width/margins stay inline — they never change) */
.agc-wrap { padding-left: 40px; padding-right: 40px; }

/* ---- Fluid display headings (replace fixed inline font sizes) ---- */
.agc-h-72 { font-size: clamp(40px, 9.5vw, 72px); }
.agc-h-64 { font-size: clamp(38px, 8.5vw, 64px); }
.agc-h-58 { font-size: clamp(35px, 8vw, 58px); }
.agc-h-56 { font-size: clamp(34px, 8vw, 56px); }
.agc-h-52 { font-size: clamp(33px, 7vw, 52px); }
.agc-h-48 { font-size: clamp(32px, 6.5vw, 48px); }
.agc-h-44 { font-size: clamp(30px, 6vw, 44px); }
.agc-h-40 { font-size: clamp(28px, 5.5vw, 40px); }
.agc-h-38 { font-size: clamp(27px, 5.5vw, 38px); }
.agc-h-34 { font-size: clamp(26px, 5vw, 34px); }
.agc-sec-title { font-size: clamp(30px, 6vw, 48px); }

/* ---- Nav / footer ---- */
.agc-nav-inner {
  max-width: 1280px; margin: 0 auto; padding: 18px 40px;
  display: flex; align-items: center; gap: 40px;
}
.agc-nav-links { display: flex; align-items: center; gap: 30px; margin-left: 20px; }
.agc-nav-right { margin-left: auto; display: flex; align-items: center; gap: 14px; }
.agc-footer-grid {
  max-width: 1280px; margin: 0 auto; padding: 80px 40px 40px;
  display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 48px;
}
.agc-footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.08); padding: 24px 40px;
  max-width: 1280px; margin: 0 auto;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px;
}

/* ---- Generic card grids ---- */
.agc-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); }
.agc-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); }
.agc-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); }
/* 2-col splits of wide panels — stack earlier (980) than card grids */
.agc-2col { display: grid; grid-template-columns: 1fr 1fr; }
.agc-split-50 { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; }

/* ---- Landing ---- */
.agc-hero-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 72px; align-items: center; }
.agc-hero-visual { position: relative; height: 520px; }
.agc-hero-dash { position: absolute; inset: 10px 0 40px 0; }
.agc-ribbon { display: flex; align-items: center; gap: 14px; }
.agc-trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.agc-trust-cell + .agc-trust-cell { border-left: 1px solid var(--border); }
.agc-why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: flex-start; }
.agc-diff-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.agc-compare-wrap { overflow-x: auto; }
.agc-compare { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; }
.agc-cta-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: center; }
.agc-sticky-inner {
  pointer-events: auto; display: flex; align-items: center; gap: 20px;
  padding: 12px 14px 12px 24px;
}

/* ---- CTA / panel paddings ---- */
.agc-cta-pad-lg { padding: 64px 56px; }
.agc-cta-pad-md { padding: 56px 48px; }
.agc-cta-pad-sm { padding: 48px 40px; }
.agc-cta-pad-48 { padding: 48px; }
.agc-pad-40 { padding: 40px; }
.agc-pad-36 { padding: 36px; }

/* ---- Service detail ---- */
.agc-sd-hero-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 64px; align-items: center; }

/* ---- Pricing ---- */
.agc-pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); }

/* ---- Insights ---- */
.agc-featured { display: grid; grid-template-columns: 1.1fr 1fr; }

/* ---- About ---- */
.agc-about-hero { display: grid; grid-template-columns: 1.4fr 1fr; gap: 64px; align-items: center; }

/* ---- Contact ---- */
.agc-contact-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; align-items: flex-start; }
.agc-contact-left { display: flex; flex-direction: column; gap: 28px; position: sticky; top: 96px; }
.agc-form-row { display: grid; grid-template-columns: 1fr 1fr; }
.agc-budget-grid { display: grid; grid-template-columns: repeat(4, 1fr); }

/* ================= breakpoints ================= */

@media (max-width: 980px) {
  .agc-wrap { padding-left: 24px; padding-right: 24px; }

  /* Heroes / splits stack */
  .agc-hero-grid { grid-template-columns: 1fr; gap: 48px; }
  .agc-hero-visual { height: 440px; max-width: 560px; }
  .agc-hero-dash { inset: 0; }
  /* Floating quote card + ribbon use negative offsets that clip at the
     viewport edge in single-column mode — show the dashboard alone. */
  .agc-float, .agc-ribbon { display: none; }
  .agc-why-grid { grid-template-columns: 1fr; gap: 40px; }
  .agc-cta-grid { grid-template-columns: 1fr; gap: 28px; }
  .agc-split-50 { grid-template-columns: 1fr; gap: 36px; }
  .agc-2col { grid-template-columns: 1fr; }
  .agc-sd-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .agc-about-hero { grid-template-columns: 1fr; gap: 36px; }
  .agc-featured { grid-template-columns: 1fr; }
  .agc-contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .agc-contact-left { position: static; }
  .agc-pricing-grid { grid-template-columns: 1fr; }

  /* Card grids 3/4 → 2 */
  .agc-grid-3 { grid-template-columns: repeat(2, 1fr); }
  .agc-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .agc-trust-grid { grid-template-columns: 1fr 1fr; }
  .agc-trust-cell:nth-child(2n+1) { border-left: none; }
  .agc-trust-cell:nth-child(n+3) { border-top: 1px solid var(--border); }
}

@media (max-width: 800px) {
  .agc-nav-links { display: none; }
  .agc-nav-email { display: none; }
  .agc-nav-inner { padding: 14px 20px; gap: 16px; }
  .agc-footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; padding: 56px 24px 32px; }
  .agc-footer-bottom { padding: 20px 24px; }
  /* Comparison table scrolls inside its rounded container instead of squishing */
  .agc-compare { min-width: 680px; }
}

@media (max-width: 640px) {
  .agc-wrap { padding-left: 20px; padding-right: 20px; }

  .agc-grid-2, .agc-grid-3, .agc-grid-4, .agc-diff-grid { grid-template-columns: 1fr; }
  .agc-trust-grid { grid-template-columns: 1fr; }
  .agc-trust-cell + .agc-trust-cell { border-left: none; }
  .agc-trust-cell:nth-child(n+2) { border-top: 1px solid var(--border); }
  .agc-budget-grid { grid-template-columns: repeat(2, 1fr); }
  .agc-hero-visual { height: 400px; }

  .agc-cta-pad-lg { padding: 40px 24px; }
  .agc-cta-pad-md { padding: 36px 22px; }
  .agc-cta-pad-sm { padding: 32px 20px; }
  .agc-cta-pad-48 { padding: 32px 20px; }
  .agc-pad-40 { padding: 26px 20px; }
  .agc-pad-36 { padding: 26px 18px; }

  .agc-sticky-inner { gap: 12px; padding: 10px 12px 10px 16px; }
}

@media (max-width: 480px) {
  .agc-footer-grid { grid-template-columns: 1fr; }
  .agc-form-row { grid-template-columns: 1fr; }
  .agc-sticky-sub { display: none; }
}
