/*
  Kintigher mobile adapter
  Only affects mobile / narrow screens.
  Load after /assets/site.css.
*/

@media (max-width: 768px) {
  html,
  body {
    max-width: 100%;
    overflow-x: hidden;
  }

  .container {
    width: 100% !important;
    max-width: none !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  body.home-page .site-header {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    background: linear-gradient(
      180deg,
      rgba(7, 12, 22, 0.46) 0%,
      rgba(16, 27, 47, 0.18) 72%,
      rgba(16, 27, 47, 0) 100%
    ) !important;
    border-bottom: none !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
  }

  body.home-page .site-header.is-scrolled {
    position: fixed !important;
    background: rgba(245, 243, 238, 0.97) !important;
    color: var(--primary, #1A2B48) !important;
    border-bottom: 1px solid var(--line, #D8D2C8) !important;
    box-shadow: 0 10px 26px rgba(29, 36, 51, 0.08) !important;
    backdrop-filter: blur(10px) !important;
  }

  .topbar {
    display: none !important;
  }

  .mainnav {
    height: 68px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  .brand {
    min-width: 0 !important;
    gap: 10px !important;
  }

  .brand-mark {
    width: 42px !important;
    height: 42px !important;
    font-size: 18px !important;
    flex: 0 0 auto !important;
  }

  .brand-title {
    font-size: 19px !important;
    line-height: 1.08 !important;
    white-space: nowrap !important;
  }

  .brand-subtitle {
    font-size: 10px !important;
    letter-spacing: 0.10em !important;
    white-space: nowrap !important;
  }

  .nav-links {
    display: none !important;
  }

  body.home-page .hero {
    min-height: 100svh !important;
  }

  body.home-page .hero-inner {
    min-height: 100svh !important;
    padding-top: 76px !important;
    align-items: center !important;
  }

  body.home-page .hero-copy {
    max-width: 100% !important;
    padding-top: 8vh !important;
  }

  body.home-page .eyebrow {
    font-size: 11px !important;
    letter-spacing: 0.22em !important;
  }

  body.home-page .hero h1 {
    margin-top: 16px !important;
    font-size: clamp(38px, 13vw, 56px) !important;
    line-height: 1.08 !important;
  }

  body.home-page .hero h1 span {
    margin-top: 10px !important;
    font-size: clamp(24px, 7.6vw, 34px) !important;
    line-height: 1.14 !important;
  }

  body.home-page .hero p {
    margin-top: 18px !important;
    font-size: 15px !important;
    line-height: 1.75 !important;
  }

  body.home-page .buttons {
    margin-top: 24px !important;
    gap: 12px !important;
  }

  body.home-page .button {
    padding: 11px 18px !important;
    font-size: 14px !important;
  }

  html.home-snap {
    scroll-snap-type: none !important;
  }

  .home-bottom {
    min-height: auto !important;
  }

  .overview-section {
    min-height: auto !important;
    padding: 52px 0 56px !important;
    align-items: stretch !important;
  }

  .section-head {
    padding-bottom: 14px !important;
    margin-bottom: 22px !important;
  }

  .label {
    font-size: 11px !important;
    letter-spacing: 0.22em !important;
  }

  h2 {
    font-size: 32px !important;
    line-height: 1.18 !important;
  }

  .cards {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .card {
    min-height: auto !important;
    border-radius: 22px !important;
    padding: 24px !important;
  }

  .card h3 {
    font-size: 24px !important;
  }

  .card p {
    font-size: 14px !important;
    line-height: 1.75 !important;
  }

  body.sub-page .site-header,
  body.utility-page .site-header {
    position: sticky !important;
    top: 0 !important;
    background: rgba(245, 243, 238, 0.97) !important;
    color: var(--primary, #1A2B48) !important;
    border-bottom: 1px solid var(--line, #D8D2C8) !important;
    box-shadow: 0 10px 26px rgba(29, 36, 51, 0.07) !important;
    backdrop-filter: blur(10px) !important;
  }

  body.sub-page .page-hero,
  body.utility-page .page-hero {
    padding: 68px 0 76px !important;
  }

  body.sub-page .page-hero h1,
  body.utility-page .page-hero h1 {
    font-size: 42px !important;
    line-height: 1.12 !important;
  }

  body.sub-page .page-hero p,
  body.utility-page .page-hero p {
    font-size: 15px !important;
    line-height: 1.8 !important;
  }

  .section {
    padding: 42px 0 64px !important;
  }

  .page-layout {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }

  .sidebar {
    position: static !important;
    border-radius: 20px !important;
    padding: 14px !important;
  }

  .sidebar-title {
    margin-bottom: 8px !important;
  }

  .sidebar a {
    display: inline-flex !important;
    margin: 4px 6px 4px 0 !important;
    padding: 8px 10px !important;
    font-size: 13px !important;
    background: #F8FAFC !important;
  }

  .content-block,
  .item {
    border-radius: 22px !important;
    padding: 24px !important;
    margin-bottom: 18px !important;
  }

  .content-block h2,
  .item h2 {
    font-size: 30px !important;
    line-height: 1.15 !important;
  }

  .content-block p,
  .item p {
    font-size: 14px !important;
    line-height: 1.8 !important;
  }

  .footer {
    padding: 34px 0 !important;
  }

  .footer-inner {
    flex-direction: column !important;
    gap: 14px !important;
  }

  .footer-title {
    font-size: 23px !important;
  }
}

@media (max-width: 420px) {
  .container {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .brand-title {
    font-size: 17px !important;
  }

  .brand-subtitle {
    font-size: 9px !important;
  }

  body.home-page .hero h1 {
    font-size: 36px !important;
  }

  body.home-page .hero h1 span {
    font-size: 23px !important;
  }

  body.home-page .button {
    width: 100% !important;
    justify-content: center !important;
  }
}

/* ===== Mobile language dropdown ===== */
@media (max-width: 768px) {
  .topbar {
    display: block !important;
    height: 28px !important;
    line-height: 28px !important;
  }

  .topbar-inner {
    height: 28px !important;
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 14px !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .language-menu summary,
  .topbar-search {
    font-size: 12px !important;
  }

  .language-options {
    top: calc(100% + 6px) !important;
    min-width: 132px !important;
    border-radius: 14px !important;
  }

  .language-options a {
    font-size: 13px !important;
    padding: 8px 10px !important;
  }

  .mainnav {
    height: 60px !important;
  }

  body.home-page .hero-inner {
    padding-top: 88px !important;
  }
}
