/* KayraOne — Global responsive overrides
   Targets all 9 pages without rewriting component code.
   Strategy: scale type, collapse multi-col grids, stack hero columns. */

/* === Base === */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; max-width: 100vw; overflow-x: hidden; -webkit-font-smoothing: antialiased; }
img, svg { max-width: 100%; height: auto; }
a { color: inherit; }

/* ============== TABLET (≤1024px) ============== */
@media (max-width: 1024px) {
  /* Headlines & section titles scale down */
  h1 { font-size: 56px !important; line-height: 1.05 !important; letter-spacing: -0.03em !important; }
  h2 { font-size: 42px !important; line-height: 1.05 !important; }
  h3 { font-size: 24px !important; }

  /* Section padding tightens */
  section { padding-left: 28px !important; padding-right: 28px !important; }
  section[style*="padding"] { padding-top: 70px !important; padding-bottom: 70px !important; }

  /* Hero & two-col layouts collapse to single column */
  section > div[style*="grid-template-columns: 1.3fr 1fr"],
  section > div[style*="grid-template-columns: 1.5fr 1fr"],
  section > div[style*="grid-template-columns: 1fr 2fr"],
  section > div[style*="grid-template-columns: 1fr 2.4fr"],
  section > div[style*="grid-template-columns: 1fr 1.4fr"],
  section > div[style*="grid-template-columns: 2fr 1fr"],
  section > div[style*="grid-template-columns: 1.4fr 1fr"],
  section > div[style*="grid-template-columns: 1fr 3fr"],
  section > div[style*="grid-template-columns: 1.3fr 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }

  /* 3-col grids → 2-col */
  div[style*="grid-template-columns: repeat(3, 1fr)"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  /* 4-col grids → 2-col */
  div[style*="grid-template-columns: repeat(4, 1fr)"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  /* 6-col logo grids → 3-col */
  div[style*="grid-template-columns: repeat(6, 1fr)"] {
    grid-template-columns: repeat(3, 1fr) !important;
  }

  /* Industries row: 80px / 1fr / 2fr / 1fr → simpler */
  a[style*="grid-template-columns: 80px 1fr 2fr 1fr"] {
    grid-template-columns: 50px 1fr !important;
    gap: 16px !important;
  }
  a[style*="grid-template-columns: 80px 1fr 2fr 1fr"] > div:nth-child(3),
  a[style*="grid-template-columns: 80px 1fr 2fr 1fr"] > div:nth-child(4) {
    display: none !important;
  }

  /* Contact form 120px label / value */
  div[style*="grid-template-columns: 120px 1fr"] {
    grid-template-columns: 100px 1fr !important;
  }

  /* Sticky elements unstick (cause issues on small screens) */
  div[style*="position: sticky"] { position: static !important; }
}

/* ============== MOBILE (≤640px) ============== */
@media (max-width: 640px) {
  /* Headlines */
  h1 { font-size: 40px !important; letter-spacing: -0.025em !important; }
  h2 { font-size: 30px !important; }
  h3 { font-size: 20px !important; }
  p { font-size: 15px !important; }

  /* Section padding */
  section { padding-left: 20px !important; padding-right: 20px !important; }
  section[style*="padding"] { padding-top: 56px !important; padding-bottom: 56px !important; }

  /* Header - smaller padding */
  header > div { padding: 14px 20px !important; }

  /* === NAV — hide desktop links, show hamburger === */
  header nav {
    position: fixed !important;
    top: 64px !important; left: 0 !important; right: 0 !important;
    background: rgba(250,250,248,0.98) !important;
    backdrop-filter: blur(12px);
    flex-direction: column !important;
    gap: 0 !important;
    padding: 12px 0 !important;
    border-bottom: 1px solid #E5E3DD !important;
    transform: translateY(-150%);
    transition: transform 0.25s ease;
    align-items: stretch !important;
  }
  body.nav-open header nav { transform: translateY(0); }
  header nav a {
    padding: 14px 20px !important;
    font-size: 15px !important;
    border-bottom: 1px solid #E5E3DD !important;
  }
  header nav a:last-child {
    margin: 12px 20px 8px !important;
    text-align: center;
    border-bottom: none !important;
  }
  /* Hamburger button injected via JS */
  .ko-hamburger {
    display: inline-flex !important;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 38px; height: 38px;
    border: 1px solid #E5E3DD;
    border-radius: 8px;
    background: white;
    cursor: pointer;
  }
  .ko-hamburger span {
    display: block;
    width: 18px; height: 2px;
    background: #1A1A1A;
    margin: 0 auto;
    transition: transform 0.2s;
  }

  /* All multi-col grids → single column on mobile */
  div[style*="grid-template-columns: repeat(2, 1fr)"],
  div[style*="grid-template-columns: repeat(3, 1fr)"],
  div[style*="grid-template-columns: repeat(4, 1fr)"],
  div[style*="grid-template-columns: repeat(6, 1fr)"] {
    grid-template-columns: 1fr !important;
  }
  /* Logo wall: keep 2 cols on mobile so it's not a tall tower */
  div[style*="grid-template-columns: repeat(6, 1fr)"][style*="height"],
  section div[style*="grid-template-columns: repeat(6, 1fr)"]:has([style*="height: 110px"]) {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* Big stat numbers */
  div[style*="font-size: 80px"], div[style*="font-size: 88px"], div[style*="font-size: 64px"] {
    font-size: 40px !important;
  }

  /* Pill buttons stack */
  div[style*="display: flex"][style*="gap: 14px"] { flex-wrap: wrap !important; }

  /* CTA section */
  section[style*="background: rgb(225"] > div { gap: 32px !important; text-align: left !important; }
  section[style*="background: rgb(225"] div[style*="text-align: right"] { text-align: left !important; }

  /* Footer cols all stack */
  footer div[style*="grid-template-columns: 2fr 1fr 1fr 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  footer div[style*="justify-content: space-between"]:last-child {
    flex-direction: column !important;
    gap: 16px !important;
    align-items: flex-start !important;
  }

  /* Marquee items smaller */
  section[style*="overflow: hidden"] span { font-size: 12px !important; }

  /* PageHero padding */
  section > div[style*="padding: 90px"] { padding: 56px 0 !important; }
  section > div[style*="padding: 120px"] { padding: 56px 0 !important; }

  /* Modules / clients TOC dark grids */
  div[style*="background: rgb(34, 34, 34)"] { padding: 14px 14px !important; }

  /* Forms */
  div[style*="grid-template-columns: 1fr 1fr"] { grid-template-columns: 1fr !important; }
  /* Contact card padding */
  form, div[style*="padding: 48px"] { padding: 28px !important; }
  div[style*="padding: 60px"] { padding: 32px !important; }
  div[style*="padding: 80px 60px"] { padding: 40px 24px !important; }
  div[style*="padding: 50px 40px"] { padding: 32px 24px !important; }
  div[style*="padding: 40px 36px"] { padding: 28px 24px !important; }
  div[style*="padding: 36px 32px"] { padding: 26px 22px !important; }
}

/* ============== Tiny (≤380px) ============== */
@media (max-width: 380px) {
  h1 { font-size: 34px !important; }
  h2 { font-size: 26px !important; }
}
