/**
 * Yellow Turtle — responsive baseline: phones, tablets, notches, fold-style narrow viewports.
 * Load after Bootstrap + agency.min.css (and after page inline blocks if they need overrides).
 */

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  overflow-x: clip;
}

body {
  overflow-x: clip;
  overflow-x: hidden; /* fallback */
}

img,
svg,
video,
canvas {
  max-width: 100%;
  height: auto;
}

/* Safe areas: fixed chrome */
#mainNav.navbar-fixed-top {
  padding-left: max(0px, env(safe-area-inset-left, 0px));
  padding-right: max(0px, env(safe-area-inset-right, 0px));
}

.navbar-header {
  max-width: 100%;
}

.navbar-brand.yt-navbar-brand {
  max-width: none;
  white-space: nowrap;
  line-height: 1;
  font-size: inherit !important;
  word-break: normal;
}

/* Bootstrap 3 rows can pull past viewport on some DPR + padding combos */
.container {
  max-width: 100%;
  padding-left: max(15px, env(safe-area-inset-left, 15px));
  padding-right: max(15px, env(safe-area-inset-right, 15px));
}

/* Hero: fluid type + padding (fold / small phones) */
@media (max-width: 767px) {
  header .intro-text {
    padding-top: max(72px, env(safe-area-inset-top, 0px) + 56px);
    padding-bottom: 40px;
    padding-left: max(8px, env(safe-area-inset-left, 0px));
    padding-right: max(8px, env(safe-area-inset-right, 0px));
  }

  header .intro-text .intro-lead-in {
    font-size: clamp(13px, 4.2vw, 22px) !important;
    line-height: 1.35 !important;
    margin-bottom: 18px;
    overflow-wrap: anywhere;
    word-break: break-word;
    padding: 0 4px;
  }

  header .intro-text .intro-heading {
    font-size: clamp(22px, 9vw, 50px) !important;
    line-height: 1.08 !important;
    margin-bottom: 20px;
  }

  header .btn-xl {
    width: 100%;
    max-width: 320px;
    box-sizing: border-box;
  }
}

@media (max-width: 360px) {
  header .intro-text .intro-lead-in {
    font-size: clamp(12px, 3.9vw, 18px) !important;
  }
}

/* Section copy: avoid horizontal overflow from long words / !important sizes */
#services p,
section p {
  overflow-wrap: anywhere;
  word-break: break-word;
  max-width: 100%;
}

section h2.section-heading {
  font-size: clamp(1.35rem, 5.5vw, 2.5rem);
  line-height: 1.15;
  padding-left: 4px;
  padding-right: 4px;
}

section h3.section-subheading {
  margin-bottom: clamp(24px, 6vw, 75px);
  padding-left: 6px;
  padding-right: 6px;
}


/* Modals: never wider than viewport */
.modal-dialog {
  margin: 10px auto;
  width: auto;
  max-width: calc(100vw - 20px);
}

.modal-content {
  max-width: 100%;
}

/* WhatsApp FAB */
.whatsapp-button {
  bottom: calc(8px + max(16px, env(safe-area-inset-bottom, 0px))) !important;
  right: calc(8px + max(16px, env(safe-area-inset-right, 0px))) !important;
}

@media (max-width: 380px) {
  .whatsapp-button {
    width: 50px !important;
    height: 50px !important;
    line-height: 50px !important;
    font-size: 24px !important;
  }
}

/* Navbar toggle: comfortable tap target */
.navbar-toggle {
  min-height: 44px;
  min-width: 44px;
  margin-top: 8px;
  margin-bottom: 8px;
}

/* --- Portfolio subpages (.yt-subpage) --- */
body.yt-subpage {
  padding-left: env(safe-area-inset-left, 0px);
  padding-right: env(safe-area-inset-right, 0px);
}

body.yt-subpage .page-wrap {
  width: min(1220px, calc(100% - 16px));
  padding-left: max(0px, env(safe-area-inset-left, 0px));
  padding-right: max(0px, env(safe-area-inset-right, 0px));
  box-sizing: border-box;
}

body.yt-subpage .hero {
  padding-top: max(64px, env(safe-area-inset-top, 0px) + 40px);
  padding-bottom: 24px;
}

body.yt-subpage .top-nav,
body.yt-subpage .chip-row {
  gap: 8px;
}

body.yt-subpage .chip,
body.yt-subpage .btn-top-back {
  font-size: 12px;
  padding: 8px 12px;
}

@media (max-width: 520px) {
  body.yt-subpage .chip,
  body.yt-subpage .btn-top-back {
    font-size: 11px;
    padding: 7px 10px;
  }

  body.yt-subpage .hero h1 {
    font-size: clamp(26px, 8vw, 42px) !important;
  }
}

@media (max-width: 360px) {
  body.yt-subpage .page-wrap {
    width: 100%;
    padding-left: 8px;
    padding-right: 8px;
  }
}

/* Lightbox safe padding */
.lightbox {
  padding-top: max(16px, env(safe-area-inset-top, 0px)) !important;
  padding-right: max(16px, env(safe-area-inset-right, 0px)) !important;
  padding-bottom: max(16px, env(safe-area-inset-bottom, 0px)) !important;
  padding-left: max(16px, env(safe-area-inset-left, 0px)) !important;
}

.lightbox button {
  top: calc(8px + env(safe-area-inset-top, 0px)) !important;
  right: calc(8px + env(safe-area-inset-right, 0px)) !important;
}

/* Websites listing: calmer motion on touch devices */
@media (hover: none) and (pointer: coarse) {
  body.yt-websites-page .project-card {
    animation: none !important;
  }
}

body.yt-websites-page .page-wrap {
  width: min(1220px, calc(100% - 16px));
  padding-left: max(8px, env(safe-area-inset-left, 0px));
  padding-right: max(8px, env(safe-area-inset-right, 0px));
  padding-top: max(48px, env(safe-area-inset-top, 0px) + 24px);
  box-sizing: border-box;
}

@media (max-width: 420px) {
  body.yt-websites-page .top-row {
    flex-direction: column;
    align-items: stretch;
  }

  body.yt-websites-page .chip-row {
    justify-content: flex-start;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
