/* =====================================================
   TRIAD CUSTOM APPAREL — Design System
   triadcustomtshirts.com
   ===================================================== */

/* ── Variables ── */
:root {
  --primary:       #0F1F3D;
  --primary-mid:   #1B3460;
  --primary-light: #264A8A;
  --orange:        #E85D2F;
  --orange-light:  #FF7A50;
  --orange-dark:   #C4491F;
  --white:         #FFFFFF;
  --off-white:     #F8F9FC;
  --light:         #F0F4FB;
  --gray-100:      #E9EDF6;
  --gray-200:      #D1D9E8;
  --gray-400:      #8A96AD;
  --text:          #1A2B4A;
  --text-body:     #3D4F6E;
  --text-muted:    #7484A0;
  --border:        #DDE3EF;
  --shadow-sm:     0 1px 6px rgba(15,31,61,.07);
  --shadow:        0 3px 16px rgba(15,31,61,.10);
  --shadow-md:     0 6px 28px rgba(15,31,61,.14);
  --shadow-lg:     0 12px 48px rgba(15,31,61,.18);
  --radius-sm:     6px;
  --radius:        8px;
  --radius-lg:     10px;
  --radius-xl:     14px;
  --transition:    0.28s ease;
  --max-w:         1200px;
}

/* ── Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
  color: var(--text-body);
  background: var(--white);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 3px solid rgba(232,93,47,.45);
  outline-offset: 3px;
}
ul { list-style: none; }
button { cursor: pointer; font-family: inherit; }
input, select, textarea { font-family: inherit; }

/* ── Typography ── */
h1,h2,h3,h4,h5,h6 { color: var(--text); font-weight: 800; line-height: 1.22; letter-spacing: -.02em; }
h1 { font-size: clamp(2rem, 5vw, 3.4rem); }
h2 { font-size: clamp(1.55rem, 3.5vw, 2.5rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.55rem); }
h4 { font-size: 1.15rem; font-weight: 700; }
p  { color: var(--text-body); }

/* ── Layout ── */
.container {
  width: 100%;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 20px;
}
@media (min-width:768px) { .container { padding: 0 32px; } }
@media (min-width:1200px) { .container { padding: 0 40px; } }

section { padding: 72px 0; }
@media (min-width:768px) { section { padding: 96px 0; } }

.section-label {
  display: inline-block;
  background: rgba(232,93,47,.12);
  color: var(--orange);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 100px;
  margin-bottom: 16px;
}
.section-title { margin-bottom: 16px; }
.section-subtitle { color: var(--text-muted); font-size: 1.08rem; max-width: 640px; }
.section-header { margin-bottom: 52px; }
.section-header.center { text-align: center; }
.section-header.center .section-subtitle { margin: 0 auto; }

.section-dark { background: var(--primary); }
.section-dark h1,.section-dark h2,.section-dark h3,.section-dark h4 { color: var(--white); }
.section-dark p, .section-dark .section-subtitle { color: rgba(255,255,255,.72); }
.section-dark .section-label { background: rgba(255,255,255,.12); color: rgba(255,255,255,.9); }
.section-light { background: var(--off-white); }
.section-navy  { background: var(--primary-mid); }
.section-navy h2,.section-navy h3 { color: var(--white); }
.section-navy p, .section-navy .section-subtitle { color: rgba(255,255,255,.75); }
.section-navy .section-label { background: rgba(255,255,255,.15); color: #fff; }

/* ── Buttons ── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 28px;
  border-radius: var(--radius);
  font-size: .95rem;
  font-weight: 700;
  letter-spacing: .01em;
  transition: var(--transition);
  border: 2px solid transparent;
  white-space: nowrap;
  text-decoration: none;
}
.btn-primary { background: var(--orange); color: #fff; border-color: var(--orange); }
.btn-primary:hover { background: var(--orange-dark); border-color: var(--orange-dark); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(232,93,47,.4); }
.btn-outline { background: transparent; color: var(--white); border-color: rgba(255,255,255,.55); }
.btn-outline:hover { background: var(--white); color: var(--primary); border-color: var(--white); transform: translateY(-2px); }
.btn-outline-dark { background: transparent; color: var(--primary); border-color: var(--primary); }
.btn-outline-dark:hover { background: var(--primary); color: var(--white); transform: translateY(-2px); }
.btn-lg { padding: 16px 36px; font-size: 1.05rem; border-radius: var(--radius-lg); }
.btn-sm { padding: 9px 20px; font-size: .85rem; }
.btn-block { width: 100%; justify-content: center; }

/* ── Navigation ── */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: rgba(15,31,61,.97);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  transition: var(--transition);
}
.nav.scrolled { background: rgba(15,31,61,.99); box-shadow: 0 2px 20px rgba(0,0,0,.25); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 68px; gap: 24px; }
.nav-logo { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.nav-logo-mark { width: 38px; height: 38px; background: var(--orange); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; }
.nav-logo-text { display: flex; flex-direction: column; line-height: 1.15; }
.nav-logo-name { color: #fff; font-weight: 800; font-size: .95rem; letter-spacing: -.01em; }
.nav-logo-tagline { color: rgba(255,255,255,.55); font-size: .68rem; font-weight: 500; letter-spacing: .03em; text-transform: uppercase; }
.nav-links { display: none; align-items: center; gap: 4px; }
@media (min-width:1024px) { .nav-links { display: flex; } }
.nav-link { color: rgba(255,255,255,.82); font-size: .82rem; font-weight: 600; padding: 8px 8px; border-radius: var(--radius-sm); transition: var(--transition); }
.nav-link:hover { color: #fff; background: rgba(255,255,255,.10); }
.nav-link.active { color: var(--orange); }
.nav-cta { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.nav-cta .btn { display: none; }
@media (min-width:768px) { .nav-cta .btn { display: inline-flex; } }
.nav-toggle { display: flex; flex-direction: column; gap: 5px; width: 32px; padding: 4px; background: none; border: none; }
@media (min-width:1024px) { .nav-toggle { display: none; } }
.nav-toggle span { display: block; height: 2px; background: #fff; border-radius: 2px; transition: var(--transition); }
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.nav-mobile { display: none; flex-direction: column; background: var(--primary); border-top: 1px solid rgba(255,255,255,.08); padding: 12px 0 20px; }
.nav-mobile.open { display: flex; }
.nav-mobile-link { color: rgba(255,255,255,.85); font-size: .95rem; font-weight: 500; padding: 12px 24px; transition: var(--transition); border-left: 3px solid transparent; }
.nav-mobile-link:hover { color: #fff; background: rgba(255,255,255,.06); border-left-color: var(--orange); }
.nav-mobile-cta { padding: 12px 24px; margin-top: 8px; }
.nav-mobile-cta .btn { width: 100%; justify-content: center; }

/* ── Hero ── */
.hero {
  min-height: 100vh;
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-mid) 55%, #1C3D7A 100%);
  display: flex; align-items: center;
  position: relative; overflow: hidden;
  padding-top: 68px;
}
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 60% at 70% 50%, rgba(232,93,47,.13) 0%, transparent 60%),
              radial-gradient(ellipse 50% 80% at 10% 80%, rgba(26,52,96,.6) 0%, transparent 60%);
}
.hero-grid { display: grid; grid-template-columns: 1fr; gap: 48px; align-items: center; position: relative; z-index: 2; padding: 80px 0; }
@media (min-width:960px) { .hero-grid { grid-template-columns: 1fr 1fr; gap: 64px; padding: 100px 0; } }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 8px; background: rgba(232,93,47,.15); border: 1px solid rgba(232,93,47,.3); color: #FFA07A; font-size: .78rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: 7px 14px; border-radius: 100px; margin-bottom: 24px; }
.hero-title { color: #fff; margin-bottom: 24px; }
.hero-title span { color: var(--orange-light); }
.hero-desc { color: rgba(255,255,255,.75); font-size: 1.1rem; margin-bottom: 36px; max-width: 560px; line-height: 1.7; }
.hero-ctas { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 44px; }
.hero-trust { display: flex; flex-wrap: wrap; gap: 20px; }
.hero-trust-item { display: flex; align-items: center; gap: 8px; color: rgba(255,255,255,.72); font-size: .85rem; font-weight: 500; }
.hero-trust-check { width: 20px; height: 20px; background: rgba(232,93,47,.25); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .65rem; color: var(--orange-light); flex-shrink: 0; }
.hero-visual { display: block; position: relative; }
.hero-visual-card { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius-lg); backdrop-filter: blur(8px); padding: 24px; color: #fff; max-width: 620px; margin-left: auto; }
.hero-visual-card-title { font-size: 1rem; font-weight: 800; margin-bottom: 14px; color: #fff; letter-spacing: .01em; }
.hero-service-chips { display: flex; flex-wrap: wrap; gap: 8px; max-width: 560px; }
.hero-chip { background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.15); color: rgba(255,255,255,.86); padding: 7px 12px; border-radius: 100px; font-size: .78rem; line-height: 1.15; font-weight: 650; transition: var(--transition); white-space: nowrap; word-break: normal; overflow-wrap: normal; hyphens: none; }
.hero-chip:hover { background: var(--orange); border-color: var(--orange); }
.hero-stats { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 10px; margin-top: 22px; }
@media (min-width:1180px) { .hero-stats { grid-template-columns: repeat(4,minmax(0,1fr)); } }
.hero-stat { min-height: 96px; text-align: center; padding: 16px 10px 14px; background: rgba(255,255,255,.075); border-radius: var(--radius); border: 1px solid rgba(255,255,255,.13); display: flex; flex-direction: column; align-items: center; justify-content: center; }
.hero-stat-value { font-size: clamp(1.6rem, 2.7vw, 2.25rem); font-weight: 900; color: var(--orange-light); line-height: 1.05; letter-spacing: 0; white-space: normal; word-break: normal; overflow-wrap: normal; hyphens: none; }
.hero-stat-label { font-size: .82rem; color: rgba(255,255,255,.68); font-weight: 650; margin-top: 8px; line-height: 1.25; max-width: 132px; word-break: normal; overflow-wrap: normal; hyphens: none; }
.hero-stat-note { margin: 16px auto 0; color: rgba(255,255,255,.74); font-size: .9rem; line-height: 1.55; text-align: center; max-width: 520px; }
.hero-workwear-cta { margin-top: 20px; padding: 20px; border-radius: var(--radius-lg); background: linear-gradient(135deg, rgba(15,31,61,.86), rgba(27,52,96,.74)); border: 1px solid rgba(255,255,255,.16); display: grid; gap: 18px; align-items: center; }
@media (min-width:1100px) { .hero-workwear-cta { grid-template-columns: 1fr auto; } }
.hero-workwear-label { color: #fff; font-size: 1.02rem; font-weight: 850; margin-bottom: 8px; line-height: 1.25; }
.hero-workwear-cta p { color: rgba(255,255,255,.72); font-size: .88rem; line-height: 1.6; margin-bottom: 12px; }
.hero-workwear-points { display: flex; flex-wrap: wrap; gap: 8px; }
.hero-workwear-points span { display: inline-flex; align-items: center; gap: 6px; padding: 5px 9px; border-radius: 100px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.11); color: rgba(255,255,255,.82); font-size: .74rem; font-weight: 650; line-height: 1.2; white-space: nowrap; }
.hero-workwear-points span::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--orange-light); flex-shrink: 0; }
.hero-workwear-actions { display: flex; flex-direction: column; gap: 10px; }
.hero-workwear-actions .btn { justify-content: center; white-space: normal; text-align: center; }

/* ── Page Hero (interior) ── */
.page-hero { background: linear-gradient(135deg, var(--primary) 0%, var(--primary-mid) 100%); padding: 120px 0 72px; position: relative; overflow: hidden; }
.page-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 70% 60% at 80% 50%, rgba(232,93,47,.1) 0%, transparent 60%); }
.page-hero .container { position: relative; z-index: 2; }
.page-hero h1 { color: #fff; margin-bottom: 20px; }
.page-hero-desc { color: rgba(255,255,255,.75); font-size: 1.08rem; max-width: 620px; margin-bottom: 32px; }
.page-hero-ctas { display: flex; flex-wrap: wrap; gap: 12px; }
.breadcrumb { display: flex; align-items: center; gap: 8px; color: rgba(255,255,255,.5); font-size: .82rem; margin-bottom: 20px; }
.breadcrumb a { color: rgba(255,255,255,.65); transition: var(--transition); }
.breadcrumb a:hover { color: #fff; }
.breadcrumb-sep { color: rgba(255,255,255,.3); }
.page-hero-label { font-size: .78rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--orange-light); margin-bottom: 16px; }

/* ── Trust Bar ── */
.trust-bar { background: var(--off-white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 22px 0; }
.trust-bar-inner { display: flex; flex-wrap: wrap; justify-content: center; gap: 24px 40px; }
.trust-item { display: flex; align-items: center; gap: 10px; font-size: .88rem; font-weight: 600; color: var(--text); }
.trust-icon { font-size: 1.3rem; }

/* ── Cards ── */
.card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); transition: var(--transition); overflow: hidden; }
.card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); border-color: var(--gray-200); }
.card-body { padding: 28px; }
.card-icon { width: 52px; height: 52px; background: linear-gradient(135deg, rgba(232,93,47,.12), rgba(232,93,47,.06)); border-radius: var(--radius); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; margin-bottom: 18px; flex-shrink: 0; }
.card-title { font-size: 1.1rem; font-weight: 700; color: var(--text); margin-bottom: 10px; }
.card-desc { font-size: .92rem; color: var(--text-muted); line-height: 1.6; margin-bottom: 18px; }
.card-link { font-size: .88rem; font-weight: 700; color: var(--orange); display: inline-flex; align-items: center; gap: 6px; transition: var(--transition); }
.card-link:hover { gap: 10px; }

.services-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); gap: 24px; }
@media (min-width:768px) { .services-grid { grid-template-columns: repeat(3,1fr); } }
@media (min-width:1100px) { .services-grid { grid-template-columns: repeat(4,1fr); } }

/* ── Contractor workwear ── */
.workwear-section .section-subtitle { margin-bottom: 18px; }
.workwear-copy { margin: 0 0 24px; color: var(--text-body); line-height: 1.75; }
.workwear-ctas { display: flex; flex-wrap: wrap; gap: 12px; }
.workwear-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-xl); box-shadow: var(--shadow-md); overflow: hidden; }
.workwear-photo { width: 100%; height: 290px; object-fit: cover; }
.workwear-card-body { padding: 26px; }
.workwear-card-body h3 { margin-bottom: 10px; }
.workwear-card-body p { color: var(--text-muted); font-size: .94rem; line-height: 1.65; }
.workwear-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
@media (min-width:900px) { .workwear-grid { grid-template-columns: repeat(4,1fr); } }
.workwear-mini { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 18px; box-shadow: var(--shadow-sm); transition: var(--transition); }
.workwear-mini:hover { border-color: var(--orange); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.workwear-mini strong { display: block; color: var(--text); font-size: .92rem; margin-bottom: 6px; }
.workwear-mini span { display: block; color: var(--text-muted); font-size: .82rem; line-height: 1.45; }

/* ── Reviews placeholder ── */
.reviews-section { background: var(--white); }
.review-placeholder { display: grid; gap: 20px; align-items: center; max-width: 980px; margin: 0 auto; padding: 30px; border: 1px solid var(--border); border-radius: var(--radius-xl); background: var(--off-white); box-shadow: var(--shadow-sm); }
@media (min-width:820px) { .review-placeholder { grid-template-columns: auto 1fr auto; } }
.review-placeholder-icon { width: 58px; height: 58px; display: flex; align-items: center; justify-content: center; border-radius: var(--radius); background: rgba(232,93,47,.1); }
.review-placeholder-icon img { width: 38px; height: 38px; object-fit: contain; }
.review-placeholder h3 { margin-bottom: 6px; font-size: 1.15rem; }
.review-placeholder p { color: var(--text-muted); font-size: .94rem; max-width: 560px; }
.review-actions { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-start; }
@media (min-width:820px) { .review-actions { justify-content: flex-end; } }

/* ── Who We Help ── */
.who-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; }
@media (min-width:640px) { .who-grid { grid-template-columns: repeat(3,1fr); } }
@media (min-width:960px) { .who-grid { grid-template-columns: repeat(4,1fr); } }
.who-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 28px 20px; text-align: center; transition: var(--transition); box-shadow: var(--shadow-sm); }
.who-card:hover { border-color: var(--orange); box-shadow: 0 4px 20px rgba(232,93,47,.15); transform: translateY(-3px); }
.who-icon { width: 60px; height: 60px; margin: 0 auto 12px; display: block; }
.who-title { font-size: .95rem; font-weight: 700; color: var(--text); }
.who-desc { font-size: .82rem; color: var(--text-muted); margin-top: 6px; }

/* ── Featured Services ── */
.featured-grid { display: grid; gap: 28px; }
@media (min-width:768px) { .featured-grid { grid-template-columns: repeat(3,1fr); } }
.featured-card-inner { background: linear-gradient(160deg, var(--primary-mid) 0%, var(--primary) 100%); padding: 40px 32px; border-radius: var(--radius-xl); height: 100%; position: relative; overflow: hidden; display: flex; flex-direction: column; }
.featured-card-inner::before { content: ''; position: absolute; top: -40px; right: -40px; width: 200px; height: 200px; background: rgba(232,93,47,.08); border-radius: 50%; pointer-events: none; }
.featured-badge { display: inline-block; background: rgba(232,93,47,.2); color: var(--orange-light); font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: 5px 12px; border-radius: 100px; margin-bottom: 20px; align-self: flex-start; }
.featured-card-inner .featured-icon { font-size: 2.4rem; margin-bottom: 16px; }
.featured-card-inner h3 { color: #fff; margin-bottom: 14px; font-size: 1.3rem; }
.featured-card-inner p { color: rgba(255,255,255,.7); font-size: .92rem; line-height: 1.7; margin-bottom: 24px; flex: 1; }
.featured-card-inner .btn { margin-top: auto; align-self: flex-start; }

/* ── How It Works ── */
.steps-grid { display: grid; gap: 24px; }
@media (min-width:640px) { .steps-grid { grid-template-columns: repeat(2,1fr); } }
@media (min-width:960px) { .steps-grid { grid-template-columns: repeat(auto-fit,minmax(190px,1fr)); } }
.step-card { text-align: center; padding: 32px 20px; border-radius: var(--radius-lg); background: var(--white); border: 1px solid var(--border); box-shadow: var(--shadow-sm); position: relative; transition: var(--transition); }
.step-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.step-num { width: 52px; height: 52px; background: linear-gradient(135deg, var(--orange), var(--orange-dark)); color: #fff; font-size: 1.2rem; font-weight: 900; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 12px; box-shadow: 0 4px 14px rgba(232,93,47,.4); }
.step-icon { width: 52px; height: 52px; margin: 0 auto 8px; display: block; }
.step-title { font-weight: 700; font-size: .98rem; color: var(--text); margin-bottom: 8px; }
.step-desc { font-size: .85rem; color: var(--text-muted); line-height: 1.55; }

/* ── Portfolio ── */
.portfolio-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
@media (min-width:640px) { .portfolio-grid { grid-template-columns: repeat(3,1fr); } }
@media (min-width:900px) { .portfolio-grid { grid-template-columns: repeat(4,1fr); } }
.portfolio-item { border-radius: var(--radius-lg); overflow: hidden; position: relative; aspect-ratio: 1; cursor: pointer; }
.portfolio-placeholder { width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; padding: 16px; text-align: center; transition: var(--transition) transform; }
.portfolio-ph-icon { font-size: 2.5rem; }
.portfolio-ph-label { font-size: .82rem; font-weight: 600; color: var(--text-body); line-height: 1.3; }
.portfolio-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(15,31,61,.85) 100%); display: flex; align-items: flex-end; padding: 16px; opacity: 0; transition: var(--transition); }
.portfolio-item:hover .portfolio-overlay { opacity: 1; }
.portfolio-item:hover .portfolio-placeholder { transform: scale(1.06); }
.portfolio-label { color: #fff; font-size: .88rem; font-weight: 700; }
.ph-1 { background: linear-gradient(135deg,#E8F4FE,#CCDFF6); }
.ph-2 { background: linear-gradient(135deg,#FEF0E8,#F6D9CC); }
.ph-3 { background: linear-gradient(135deg,#E8FAF0,#C8EDDB); }
.ph-4 { background: linear-gradient(135deg,#F3E8FE,#DFCCF6); }
.ph-5 { background: linear-gradient(135deg,#FEFBE8,#F6EFCC); }
.ph-6 { background: linear-gradient(135deg,#E8F8FE,#CCE9F6); }
.ph-7 { background: linear-gradient(135deg,#FEE8F4,#F6CCDE); }
.ph-8 { background: linear-gradient(135deg,#EBFEE8,#CCF6D2); }
.ph-9 { background: linear-gradient(135deg,#FEF3E8,#F6E2CC); }
.ph-10{ background: linear-gradient(135deg,#E8EFFE,#CCD6F6); }

/* ── Why Choose Us ── */
.why-grid { display: grid; gap: 24px; }
@media (min-width:640px) { .why-grid { grid-template-columns: repeat(2,1fr); } }
@media (min-width:960px) { .why-grid { grid-template-columns: repeat(3,1fr); } }
.why-card { padding: 32px 28px; border-radius: var(--radius-lg); background: var(--white); border: 1px solid var(--border); box-shadow: var(--shadow-sm); transition: var(--transition); text-align: center; }
.why-card:hover { border-color: var(--orange); box-shadow: 0 4px 20px rgba(232,93,47,.12); transform: translateY(-3px); }
.why-icon { width: 64px; height: 64px; display: block; margin: 0 auto 14px; }
.why-title { font-size: 1.05rem; font-weight: 700; color: var(--text); margin-bottom: 10px; }
.why-desc { font-size: .9rem; color: var(--text-muted); line-height: 1.6; }

/* ── Quote Form ── */
.quote-section { background: var(--off-white); }
.quote-layout { display: grid; gap: 48px; align-items: start; }
@media (min-width:960px) { .quote-layout { grid-template-columns: 1fr 2fr; } }
.quote-sidebar { background: var(--primary); border-radius: var(--radius-xl); padding: 36px; color: #fff; }
.quote-sidebar h3 { color: #fff; margin-bottom: 20px; }
.quote-sidebar-list { display: flex; flex-direction: column; gap: 14px; }
.quote-sidebar-item { display: flex; align-items: flex-start; gap: 10px; }
.quote-sidebar-icon { width: 34px; height: 34px; margin-top: 1px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; border-radius: 50%; background: rgba(255,255,255,.12); }
.quote-sidebar-icon img { width: 20px; height: 20px; object-fit: contain; filter: brightness(0) invert(1); }
.quote-sidebar-text strong { color: rgba(255,255,255,.9); font-size: .9rem; font-weight: 700; display: block; }
.quote-sidebar-text span { color: rgba(255,255,255,.6); font-size: .82rem; }
.quote-form { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 40px; box-shadow: var(--shadow-md); }
@media (max-width:640px) { .quote-form { padding: 24px 18px; } }
.form-grid { display: grid; gap: 20px; }
@media (min-width:640px) { .form-grid { grid-template-columns: 1fr 1fr; } }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group.full { grid-column: 1/-1; }
.form-label { font-size: .85rem; font-weight: 600; color: var(--text); }
.form-label .req { color: var(--orange); }
.form-input, .form-select, .form-textarea { width: 100%; padding: 12px 16px; border: 1.5px solid var(--border); border-radius: var(--radius); font-size: .95rem; color: var(--text); background: var(--white); transition: var(--transition); outline: none; -webkit-appearance: none; appearance: none; }
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color: var(--orange); box-shadow: 0 0 0 3px rgba(232,93,47,.12); }
.form-textarea { resize: vertical; min-height: 120px; }
.form-select { cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237484A0' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 40px; }
.upload-label { display: flex; align-items: center; gap: 12px; padding: 14px 18px; border: 2px dashed var(--border); border-radius: var(--radius); cursor: pointer; transition: var(--transition); font-size: .9rem; color: var(--text-muted); }
.upload-label:hover { border-color: var(--orange); color: var(--orange); }
.upload-label input[type="file"] { display: none; }
.form-note { font-size: .8rem; color: var(--text-muted); margin-top: 4px; }
.inline-icon { width: 20px; height: 20px; flex-shrink: 0; color: var(--orange); }
.btn-icon { width: 18px; height: 18px; flex-shrink: 0; color: currentColor; filter: none; }
.hidden-field { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }
.form-success { background: var(--white); border: 1px solid var(--border); border-left: 4px solid var(--orange); border-radius: var(--radius-lg); padding: 32px; box-shadow: var(--shadow-sm); }
.form-success h3 { margin-bottom: 10px; }
.form-success a { color: var(--orange); font-weight: 700; }

/* ── FAQ ── */
.faq-list { display: flex; flex-direction: column; gap: 10px; }
.faq-item { border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--white); overflow: hidden; transition: border-color var(--transition); }
.faq-item.open { border-color: var(--orange); box-shadow: 0 2px 12px rgba(232,93,47,.12); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 20px 24px; background: none; border: none; font-size: .98rem; font-weight: 600; color: var(--text); text-align: left; cursor: pointer; transition: color var(--transition); }
.faq-q:hover { color: var(--orange); }
.faq-icon { width: 28px; height: 28px; flex-shrink: 0; background: var(--light); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.4rem; line-height: 1; color: var(--text-muted); transition: var(--transition); font-weight: 300; }
.faq-item.open .faq-icon { background: rgba(232,93,47,.12); color: var(--orange); transform: rotate(45deg); }
.faq-a { display: none; padding: 0 24px 20px; font-size: .93rem; color: var(--text-body); line-height: 1.7; }
.faq-item.open .faq-a { display: block; }

/* ── Local SEO ── */
.local-content { display: grid; gap: 48px; }
@media (min-width:768px) { .local-content { grid-template-columns: 1fr 1fr; align-items: center; } }
.local-text h2 { color: #fff; margin-bottom: 16px; }
.local-text p { color: rgba(255,255,255,.72); line-height: 1.75; margin-bottom: 14px; }
.service-area-heading { color: #fff; font-size: 1rem; margin: 22px 0 10px; }
.area-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px; }
.area-tag { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15); color: rgba(255,255,255,.8); padding: 6px 14px; border-radius: 100px; font-size: .82rem; font-weight: 600; display: inline-flex; align-items: center; gap: 6px; }
.area-tag img { width: 14px; height: 14px; object-fit: contain; filter: brightness(0) invert(1); opacity: .85; }
.area-tag-light { background: var(--light); color: var(--text); border-color: var(--border); }
.area-tag-light img { filter: none; opacity: 1; }
.local-card { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius-xl); padding: 36px; }
.local-card h3 { color: #fff; margin-bottom: 20px; font-size: 1.15rem; }
.contact-list { display: flex; flex-direction: column; gap: 16px; }
.contact-row { display: flex; align-items: flex-start; gap: 12px; }
.contact-row-icon { width: 34px; height: 34px; margin-top: 2px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; border-radius: 50%; background: rgba(255,255,255,.12); }
.contact-row-icon img { width: 20px; height: 20px; object-fit: contain; filter: brightness(0) invert(1); }
.contact-row strong { color: rgba(255,255,255,.9); font-size: .88rem; display: block; }
.contact-row span,.contact-row a { color: rgba(255,255,255,.65); font-size: .85rem; }
.contact-row a { color: var(--orange-light); }
.contact-row a:hover { color: #fff; }

/* ── CTA Banner ── */
.cta-banner { background: linear-gradient(135deg, var(--orange-dark) 0%, var(--orange) 60%, var(--orange-light) 100%); padding: 72px 0; text-align: center; }
.cta-banner h2 { color: #fff; margin-bottom: 16px; }
.cta-banner p { color: rgba(255,255,255,.9); font-size: 1.05rem; margin-bottom: 32px; max-width: 560px; margin-left: auto; margin-right: auto; }
.cta-banner .ctas { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; }
.btn-white { background: #fff; color: var(--orange-dark); border-color: #fff; }
.btn-white:hover { background: var(--off-white); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,.15); }

/* ── Stats ── */
.stats-row { display: grid; grid-template-columns: repeat(2,1fr); gap: 20px; }
@media (min-width:640px) { .stats-row { grid-template-columns: repeat(4,1fr); } }
.stat-card { text-align: center; padding: 32px 16px; background: var(--white); border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); transition: var(--transition); }
.stat-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.stat-value { font-size: 2.3rem; font-weight: 900; color: var(--orange); line-height: 1; margin-bottom: 8px; }
.stat-label { font-size: .88rem; color: var(--text-muted); font-weight: 500; }

/* ── Footer ── */
footer { background: var(--primary); padding: 64px 0 0; }
.footer-grid { display: grid; gap: 40px; padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,.08); }
@media (min-width:640px) { .footer-grid { grid-template-columns: repeat(2,1fr); } }
@media (min-width:960px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; } }
.footer-brand-logo { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.footer-logo-mark { width: 38px; height: 38px; background: var(--orange); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; flex-shrink: 0; }
.footer-brand-name { color: #fff; font-weight: 800; font-size: .95rem; }
.footer-tagline { color: rgba(255,255,255,.55); font-size: .88rem; margin-bottom: 18px; line-height: 1.6; }
.footer-contact-list { display: flex; flex-direction: column; gap: 8px; }
.footer-contact-list a { color: rgba(255,255,255,.6); font-size: .88rem; transition: var(--transition); }
.footer-contact-list a:hover { color: var(--orange-light); }
.footer-col-title { color: #fff; font-size: .82rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 16px; }
.footer-links { display: flex; flex-direction: column; gap: 10px; }
.footer-link { color: rgba(255,255,255,.58); font-size: .88rem; transition: var(--transition); }
.footer-link:hover { color: rgba(255,255,255,.9); }
.footer-bottom { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 10px; padding: 20px 0; border-top: 1px solid rgba(255,255,255,.05); }
.footer-copy { color: rgba(255,255,255,.4); font-size: .8rem; }
.footer-legal { display: flex; gap: 16px; }
.footer-legal a { color: rgba(255,255,255,.4); font-size: .8rem; transition: var(--transition); }
.footer-legal a:hover { color: rgba(255,255,255,.7); }

/* ── Mobile Sticky CTA ── */
.mobile-sticky { position: fixed; bottom: 0; left: 0; right: 0; z-index: 999; display: flex; }
@media (min-width:768px) { .mobile-sticky { display: none; } }
.sticky-btn { flex: 1; display: flex; align-items: center; justify-content: center; gap: 8px; padding: 16px 12px; font-size: .9rem; font-weight: 700; border: none; cursor: pointer; text-decoration: none; transition: var(--transition); font-family: inherit; }
.sticky-icon { width: 18px; height: 18px; object-fit: contain; filter: brightness(0) invert(1); }
.sticky-call { background: var(--orange); color: #fff; }
.sticky-call:hover { background: var(--orange-dark); }
.sticky-quote { background: var(--primary); color: #fff; border-left: 1px solid rgba(255,255,255,.15); }
.sticky-quote:hover { background: var(--primary-mid); }

/* ── Back to top ── */
.back-top { position: fixed; bottom: 72px; right: 18px; width: 44px; height: 44px; background: var(--primary); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.1rem; box-shadow: var(--shadow-md); transition: var(--transition); opacity: 0; pointer-events: none; z-index: 900; border: none; cursor: pointer; }
.back-top.visible { opacity: 1; pointer-events: all; }
.back-top:hover { background: var(--orange); transform: translateY(-3px); }
@media (min-width:768px) { .back-top { bottom: 24px; } }

/* ── Scroll Animations ── */
.fade-up { opacity: 0; transform: translateY(32px); transition: opacity .65s ease, transform .65s ease; }
.fade-up.in-view { opacity: 1; transform: translateY(0); }
.fade-left { opacity: 0; transform: translateX(-32px); transition: opacity .65s ease, transform .65s ease; }
.fade-left.in-view { opacity: 1; transform: translateX(0); }
.fade-right { opacity: 0; transform: translateX(32px); transition: opacity .65s ease, transform .65s ease; }
.fade-right.in-view { opacity: 1; transform: translateX(0); }
.fade-in { opacity: 0; transition: opacity .65s ease; }
.fade-in.in-view { opacity: 1; }
.stagger > * { transition-delay: var(--d, 0s); }
.stagger > *:nth-child(1)  { --d: .05s; }
.stagger > *:nth-child(2)  { --d: .10s; }
.stagger > *:nth-child(3)  { --d: .15s; }
.stagger > *:nth-child(4)  { --d: .20s; }
.stagger > *:nth-child(5)  { --d: .25s; }
.stagger > *:nth-child(6)  { --d: .30s; }
.stagger > *:nth-child(7)  { --d: .35s; }
.stagger > *:nth-child(8)  { --d: .40s; }
.stagger > *:nth-child(9)  { --d: .45s; }
.stagger > *:nth-child(10) { --d: .50s; }
.stagger > *:nth-child(11) { --d: .55s; }
.stagger > *:nth-child(12) { --d: .60s; }

/* ── Benefits List ── */
.benefits-list { display: flex; flex-direction: column; gap: 12px; }
.benefit-item { display: flex; align-items: flex-start; gap: 12px; }
.benefit-check { width: 22px; height: 22px; background: linear-gradient(135deg, var(--orange), var(--orange-dark)); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; color: #fff; font-size: .65rem; font-weight: 900; }
.benefit-text { font-size: .95rem; color: var(--text-body); line-height: 1.55; }

/* ── Service page layouts ── */
.service-intro-grid { display: grid; gap: 48px; align-items: center; }
@media (min-width:768px) { .service-intro-grid { grid-template-columns: 1fr 1fr; } }
.service-visual { border-radius: var(--radius-xl); overflow: hidden; aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; }
.service-visual-inner { width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; padding: 40px; text-align: center; }
.service-visual-icon { width: 90px; height: 90px; margin: 0 auto; display: block; }
.service-visual-label { font-size: 1rem; font-weight: 700; color: var(--text-muted); }
.related-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
@media (min-width:640px) { .related-grid { grid-template-columns: repeat(3,1fr); } }
@media (min-width:900px) { .related-grid { grid-template-columns: repeat(4,1fr); } }
.related-card { padding: 20px 16px; border: 1px solid var(--border); border-radius: var(--radius-lg); text-align: center; transition: var(--transition); background: var(--white); display: block; }
.related-card:hover { border-color: var(--orange); transform: translateY(-3px); box-shadow: var(--shadow-sm); }
.related-icon { width: 52px; height: 52px; margin: 0 auto 8px; display: block; }
.related-name { font-size: .88rem; font-weight: 700; color: var(--text); }
.two-col { display: grid; gap: 48px; }
@media (min-width:768px) { .two-col { grid-template-columns: 1fr 1fr; align-items: center; } }

/* ── Use cases grid ── */
.use-cases-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px; }
@media (min-width:640px) { .use-cases-grid { grid-template-columns: repeat(3,1fr); } }
.use-case-item { display: flex; align-items: center; gap: 10px; padding: 14px 16px; background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); font-size: .88rem; font-weight: 600; color: var(--text); transition: var(--transition); }
.use-case-item:hover { border-color: var(--orange); background: rgba(232,93,47,.04); }
.use-case-icon { flex-shrink: 0; width: 36px; height: 36px; display: block; }

/* ── Inline CTA strip ── */
.cta-strip { background: var(--light); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 28px 32px; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 20px; }
.cta-strip h3 { font-size: 1.2rem; margin: 0; }
.cta-strip p { font-size: .92rem; color: var(--text-muted); margin: 4px 0 0; }
.cta-strip-btns { display: flex; flex-wrap: wrap; gap: 12px; flex-shrink: 0; }

/* ── Page-specific background gradients for service visuals ── */
.vis-tshirt  { background: linear-gradient(135deg,#E8F4FE,#CCDFF6); }
.vis-hoodie  { background: linear-gradient(135deg,#F3E8FE,#DFCCF6); }
.vis-hats    { background: linear-gradient(135deg,#FEFBE8,#F6EFCC); }
.vis-work    { background: linear-gradient(135deg,#E8FAF0,#C8EDDB); }
.vis-safety  { background: linear-gradient(135deg,#FEF0E8,#F6D9CC); }
.vis-cards   { background: linear-gradient(135deg,#E8EFFE,#CCD6F6); }
.vis-banner  { background: linear-gradient(135deg,#FEE8F4,#F6CCDE); }
.vis-yard    { background: linear-gradient(135deg,#EBFEE8,#CCF6D2); }
.vis-door    { background: linear-gradient(135deg,#FEF3E8,#F6E2CC); }
.vis-decal   { background: linear-gradient(135deg,#E8F8FE,#CCE9F6); }
.vis-metal   { background: linear-gradient(135deg,#F0F0F4,#D8DADF); }
.vis-brand   { background: linear-gradient(135deg,#FEE8E8,#F6CCCC); }

/* ── Utilities ── */
.mt-8  { margin-top:  8px; }
.mt-16 { margin-top: 16px; }
.mt-24 { margin-top: 24px; }
.mt-32 { margin-top: 32px; }
.mb-8  { margin-bottom:  8px; }
.mb-16 { margin-bottom: 16px; }
.mb-24 { margin-bottom: 24px; }
.mb-32 { margin-bottom: 32px; }
.text-center { text-align: center; }
.text-orange { color: var(--orange); }
.text-white  { color: #fff; }

/* ── Body pad for fixed nav ── */
body { padding-top: 68px; }
.hero, .page-hero { margin-top: -68px; padding-top: calc(68px + 40px); }
@media (min-width:960px) { .hero { padding-top: 68px; } }

/* ── Real logo ── */
.nav-logo-img { height: 36px; width: auto; display: block; }
.footer-logo-img { height: 30px; width: auto; display: block; filter: brightness(0) invert(1); }

/* ── Trust bar — full image ── */
.trust-bar-img { max-width: 100%; height: auto; display: block; margin: 0 auto; }

/* ── How It Works — full image ── */
.how-it-works-img { max-width: 860px; width: 100%; height: auto; display: block; margin: 0 auto 40px; }

/* ── Individual icon images ── */
.card-icon-img { display: block; width: 68px; height: 68px; margin: 0 auto 16px; }
.services-grid .card-body { text-align: center; }
.trust-icon-img { width: 40px; height: 40px; flex-shrink: 0; display: block; }
.footer-contact-icon { width: 16px; height: 16px; vertical-align: middle; margin-right: 6px; display: inline; }
.footer-contact-list .footer-contact-icon,
.nav.scrolled .footer-contact-icon { filter: brightness(0) invert(1); }
footer .footer-contact-icon { filter: brightness(0) invert(1); }

/* ── Portfolio real photos ── */
.portfolio-photo {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}
.portfolio-item.photo-item { background: #111; }

/* ── Featured section real photos ── */
.featured-photo {
  width: 100%; height: 220px;
  object-fit: cover; border-radius: var(--radius-lg);
  margin-bottom: 20px; display: block;
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  .fade-up, .fade-left, .fade-right, .fade-in {
    opacity: 1;
    transform: none;
  }
}

/* =====================================================
   MOBILE OPTIMIZATIONS (< 640px)
   ===================================================== */
@media (max-width: 639px) {

  /* Body padding for mobile sticky bar */
  body { padding-bottom: 68px; }

  /* Sections — reduce vertical spacing */
  section { padding: 48px 0; }
  .section-header { margin-bottom: 32px; }
  .section-subtitle { font-size: 1rem; }

  /* Hero — less tall, less padding */
  .hero { min-height: auto; }
  .hero-grid { padding: 32px 0 16px; gap: 28px; }
  .hero-desc { font-size: 1rem; margin-bottom: 24px; }
  .hero-ctas { gap: 10px; flex-direction: column; }
  .hero-ctas .btn { width: 100%; justify-content: center; }
  .hero-trust { gap: 12px 18px; }
  .hero-visual-card { padding: 18px; margin: 0; }
  .hero-service-chips { gap: 7px; }
  .hero-chip { font-size: .74rem; padding: 7px 10px; }
  .hero-stats { grid-template-columns: repeat(2,minmax(0,1fr)); gap: 9px; margin-top: 18px; }
  .hero-stat { min-height: 88px; padding: 14px 8px 12px; }
  .hero-stat-value { font-size: clamp(1.55rem, 7vw, 1.9rem); }
  .hero-stat-label { font-size: .76rem; max-width: 120px; }
  .hero-stat-note { font-size: .84rem; text-align: left; }
  .hero-workwear-cta { padding: 16px; gap: 14px; }
  .hero-workwear-label { font-size: .98rem; }
  .hero-workwear-cta p { font-size: .84rem; }
  .hero-workwear-points { gap: 7px; }
  .hero-workwear-points span { white-space: normal; font-size: .72rem; }
  .hero-workwear-actions .btn { width: 100%; }

  /* Page hero — interior pages */
  .page-hero { padding: 88px 0 44px; }
  .page-hero-ctas { flex-direction: column; gap: 10px; }
  .page-hero-ctas .btn { width: 100%; justify-content: center; }

  /* Services grid — 2 columns on phone */
  .services-grid { grid-template-columns: repeat(2,1fr); gap: 12px; }
  .card-body { padding: 16px 14px; }
  .card-icon-img { width: 52px; height: 52px; margin-bottom: 10px; }
  .card-title { font-size: 1rem; margin-bottom: 6px; }
  .card-desc { font-size: .82rem; margin-bottom: 12px; }

  .workwear-ctas { flex-direction: column; }
  .workwear-ctas .btn { width: 100%; justify-content: center; white-space: normal; text-align: center; }
  .workwear-photo { height: 190px; }
  .workwear-card-body { padding: 20px; }
  .workwear-grid { grid-template-columns: 1fr; }
  .review-placeholder { padding: 22px 18px; }
  .review-actions { flex-direction: column; }
  .review-actions .btn { width: 100%; justify-content: center; white-space: normal; text-align: center; }

  /* Trust bar — wrap nicely */
  .trust-bar { padding: 16px 0; }
  .trust-bar-inner { gap: 14px 28px; }
  .trust-icon-img { width: 32px; height: 32px; }
  .trust-item { font-size: .8rem; gap: 7px; }

  /* Who we help */
  .who-card { padding: 20px 12px; }
  .who-icon { width: 48px; height: 48px; margin-bottom: 10px; }

  /* Steps */
  .steps-grid { grid-template-columns: repeat(2,1fr); gap: 12px; }
  .step-card { padding: 20px 12px; }
  .step-num { width: 42px; height: 42px; font-size: 1rem; margin-bottom: 10px; }
  .step-icon { width: 40px; height: 40px; margin-bottom: 6px; }
  .step-title { font-size: .9rem; }
  .step-desc { font-size: .8rem; }

  /* Featured services */
  .featured-card-inner { padding: 24px 18px; }
  .featured-photo { height: 160px; }

  /* Portfolio */
  .portfolio-grid { gap: 8px; }

  /* Why cards */
  .why-grid { grid-template-columns: repeat(2,1fr); gap: 12px; }
  .why-card { padding: 20px 14px; }
  .why-icon { width: 48px; height: 48px; margin-bottom: 10px; }
  .why-title { font-size: .95rem; }
  .why-desc { font-size: .82rem; }

  /* Quote form */
  .quote-form { padding: 20px 16px; }
  .quote-sidebar { padding: 24px 18px; }

  /* CTA banner — stack buttons */
  .cta-banner { padding: 44px 0; }
  .cta-banner .ctas { flex-direction: column; align-items: center; }
  .cta-banner .ctas .btn { width: 100%; max-width: 340px; justify-content: center; }

  /* Service intro */
  .service-intro-grid { gap: 28px; }
  .service-visual { aspect-ratio: 3/2; }
  .service-visual-icon { width: 64px; height: 64px; }

  /* Related grid */
  .related-card { padding: 16px 10px; }
  .related-icon { width: 40px; height: 40px; }

  /* Use cases */
  .use-cases-grid { gap: 8px; }
  .use-case-item { padding: 10px 12px; font-size: .82rem; gap: 8px; }
  .use-case-icon { width: 28px; height: 28px; }

  /* CTA strip */
  .cta-strip { padding: 20px; flex-direction: column; align-items: flex-start; gap: 14px; }

  /* Footer */
  .footer-grid { gap: 24px; }
  footer { padding: 44px 0 0; }

  /* Two-col sections */
  .two-col { gap: 28px; }

  /* Reduce section-header bottom on interior pages */
  .page-hero-desc { font-size: 1rem; }

  /* Back to top above sticky bar */
  .back-top { bottom: 84px; }
}
