/*
 Theme Name:   Divi CCP Child Theme
 Description:  Custom Child Theme for California Custom Processing
 Author:       John Nino
 Template:     Divi
 Version:      1.5.0
*/

/* ===================================================
   CSS VARIABLES
   =================================================== */
:root {
  --red:        #C0392B;
  --red-dark:   #96281B;
  --charcoal:   #2C3E50;
  --charcoal2:  #1A1A1A;
  --charcoal-dark: #1a252f;
  --offwhite:   #F4F4F2;
  --lightgrey:  #E8E6E3;
  --teal:       #1ABC9C;
  --teal-dark:  #148F77;
  --green:      #4A7C59;
  --white:      #fff;
  --text:       #333;
  --font:       'Montserrat', sans-serif;
  --font-head:  'Montserrat', sans-serif;
  --font-body:  'Montserrat', sans-serif;
  --radius:     8px;
  --transition: 0.3s ease;
  --shadow:     0 8px 40px rgba(0,0,0,0.12);
  --shadow-lg:  0 20px 80px rgba(0,0,0,0.18);
}

/* ===================================================
   RESET & BASE
   =================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--font); color: var(--text); background: var(--white); line-height: 1.7; overflow-x: hidden; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }
ul { list-style: none; }
section { position: relative; }

/* ===================================================
   TYPOGRAPHY
   =================================================== */
h1 { font-size: clamp(2.2rem, 5vw, 4rem); font-weight: 900; line-height: 1.1; }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: 800; line-height: 1.2; }
h3 { font-size: 1.3rem; font-weight: 700; }
h4 { font-size: 1rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
p  { margin-bottom: 1rem; }

/* Utility text helpers from HTML files */
.label {
  font-family: var(--font-head);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--red);
  display: block;
  margin-bottom: 16px;
}
.eyebrow { display: block; font-size: .75rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--red); margin-bottom: .75rem; }
.eyebrow.teal { color: var(--teal); }
.red         { color: var(--red); }
.center      { text-align: center; }
.text-white  { color: var(--white); }
.text-red    { color: var(--red); }
.text-center { text-align: center; }

/* ===================================================
   CONTAINER
   =================================================== */
.container { width: 100%; max-width: 1280px; margin: 0 auto; padding: 0 2rem; }
#main-content .container:before { display: none !important; }

/* ===================================================
   BUTTONS
   =================================================== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-head);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 14px 32px;
  border-radius: var(--radius);
  transition: var(--transition);
  cursor: pointer;
  border: 2px solid transparent;
  white-space: nowrap;
}
.btn svg { width: 16px; height: 16px; flex-shrink: 0; }
.btn-red          { background: var(--red); color: #fff; border-color: var(--red); }
.btn-red:hover    { background: var(--red-dark); border-color: var(--red-dark); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(192,57,43,.4); }
.btn-outline      { border: 2px solid #fff; color: #fff; }
.btn-outline:hover { background: #fff; color: var(--charcoal); }
.btn-outline-white       { background: transparent; color: var(--white); border-color: rgba(255,255,255,0.7); }
.btn-outline-white:hover { background: var(--white); color: var(--charcoal); border-color: var(--white); }
.btn-outline-red         { background: transparent; color: var(--red); border-color: var(--red); }
.btn-outline-red:hover   { background: var(--red); color: var(--white); }
.btn-teal         { background: var(--teal); color: #fff; }
.btn-teal:hover   { background: var(--teal-dark); }
.btn-white        { background: #fff; color: var(--charcoal); }
.btn-white:hover  { background: var(--offwhite); }
.btn-sm           { padding: .6rem 1.2rem; font-size: .8rem; }
/* Legacy alias used in some HTML files */
.btn-quote {
  font-family: var(--font);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  background: #C0211B;
  color: #fff !important;
  padding: 10px 22px;
  border-radius: 8px;
  text-decoration: none;
  display: inline-block;
  transition: background .3s;
  white-space: nowrap;
}
.btn-quote:hover { background: var(--red-dark); }
.nav-cta {
  font-family: var(--font-head);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  background: var(--red);
  color: var(--white);
  padding: 11px 24px;
  border-radius: var(--radius);
  transition: var(--transition);
}
.nav-cta:hover { background: var(--red-dark); }

/* ===================================================
   DIVI THEME BUILDER HEADER
   =================================================== */
.et_pb_section_0_tb_header {
  background: rgba(26,37,47,0.95) !important;
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,0.1);
  position: fixed !important;
  top: 0; left: 0; width: 100%;
  z-index: 9999;
  transition: padding .3s;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
.et_pb_row_0_tb_header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0.4rem !important;
  max-width: 100% !important;
  width: 100% !important;
  min-height: unset !important;
}
.et_pb_column_0_tb_header,
.et_pb_column_1_tb_header,
.et_pb_column_2_tb_header { padding: 0 !important; }

.et_pb_text_0_tb_header p,
.et_pb_text_1_tb_header p,
.et_pb_text_2_tb_header p { margin-bottom: 0 !important; }

.et_pb_text_0_tb_header .et_pb_text_inner p {
  margin-bottom: 0 !important;
  line-height: 1 !important;
  display: flex;
  align-items: center;
}
.et_pb_column_0_tb_header img { max-height: 55px; width: auto; display: block; }

/* Nav links */
#main-nav { display: flex; align-items: center; gap: 1.5rem; }
#main-nav a {
  font-family: var(--font);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.85);
  text-decoration: none;
  padding: 0.4rem 0;
  border-bottom: 2px solid transparent;
  transition: border-color .3s, color .3s;
  white-space: nowrap;
}
#main-nav a:hover { color: #fff; border-bottom-color: var(--red); }

/* Hamburger — hidden on desktop */
#mobileToggle {
  display: none !important;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: 2px solid rgba(255,255,255,0.7);
  border-radius: 6px;
  padding: 8px 10px;
  cursor: pointer;
  flex-shrink: 0;
}
#mobileToggle span {
  display: block;
  width: 18px;
  height: 2px;
  background: #fff;
  border-radius: 2px;
  flex-shrink: 0;
}

/* Page container offset */
body.et_fixed_nav #page-container { padding-top: 0 !important; }
.et-l--header + * { margin-top: 0 !important; }
#page-container { padding-top: 0 !important; margin-top: 0 !important; }

/* Override Divi injected padding on first page section */
.et_pb_section_0.et_pb_section {
  padding-right: 0 !important;
  padding-left: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin-top: 0 !important;
}
.et_pb_section_0 .et_pb_code_0 { padding: 0 !important; margin: 0 !important; }
.et_pb_section_0 .et_pb_code_inner { padding: 0 !important; }

/* ===================================================
   MOBILE HEADER  (max-width: 980px)
   =================================================== */
@media only screen and (max-width: 980px) {
  #page-container { padding-top: 70px !important; }

  .et_pb_row_0_tb_header { flex-wrap: wrap !important; padding: 0.6rem 1rem !important; position: relative; }

  .et_pb_column_0_tb_header {
    width: 100% !important; max-width: 100% !important; flex: 0 0 100% !important;
    display: flex !important; align-items: center !important; justify-content: space-between !important;
  }
  .et_pb_text_0_tb_header,
  .et_pb_text_0_tb_header .et_pb_text_inner { width: 100%; display: flex; align-items: center; justify-content: space-between; }

  #mobileToggle {
    display: flex !important;
    flex-direction: column;
    gap: 4px;
    background: none;
    border: 1.5px solid rgba(255,255,255,0.7);
    border-radius: 5px;
    padding: 6px 8px;
    cursor: pointer;
    flex-shrink: 0;
    width: 36px; height: 32px;
    align-items: center; justify-content: center;
    box-sizing: border-box;
  }

  .et_pb_column_1_tb_header,
  .et_pb_column_2_tb_header {
    display: none !important;
    width: 100% !important; max-width: 100% !important; flex: 0 0 100% !important;
  }
  .et_pb_column_1_tb_header.open { display: flex !important; flex-direction: column; background: var(--charcoal-dark); }
  .et_pb_column_2_tb_header.open {
    display: flex !important; justify-content: center;
    background: var(--charcoal-dark);
    padding: 0.75rem 1rem !important;
    border-top: 1px solid rgba(255,255,255,0.08);
  }

  #main-nav { flex-direction: column; align-items: flex-start; gap: 0; width: 100%; }
  #main-nav a {
    display: block; width: 100%;
    padding: 0.9rem 1.5rem !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
    letter-spacing: 1px; font-size: 13px !important;
  }
  #main-nav a:hover { background: rgba(255,255,255,0.05); }

  .btn-quote { display: block; text-align: center; width: 100%; }
  .et_pb_column_0_tb_header img { max-height: 45px; width: auto; }
}

/* ===================================================
   HERO (homepage full-screen)
   =================================================== */
#hero { position: relative; height: 100vh; min-height: 600px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.hero-video-bg { position: absolute; inset: 0; }
.hero-img      { width: 100%; height: 100%; object-fit: cover; }
.hero-overlay  { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(26,37,47,.85) 40%, rgba(192,57,43,.3) 100%); }
.hero-content  { position: relative; z-index: 2; text-align: center; color: #fff; padding: 2rem; max-width: 900px; }
.hero-eyebrow  { font-size: .8rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.7); margin-bottom: 1rem; }
.hero-sub      { font-size: 1.1rem; font-weight: 300; margin: 1.5rem 0 2.5rem; opacity: .9; line-height: 1.7; }
.hero-ctas     { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.hero-scroll-indicator {
  position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  color: rgba(255,255,255,.6); font-size: .7rem; letter-spacing: .1em; text-transform: uppercase;
}
.scroll-line { width: 1px; height: 40px; background: linear-gradient(to bottom, rgba(255,255,255,.6), transparent); animation: scrollPulse 2s infinite; }
@keyframes scrollPulse { 0%,100%{opacity:1} 50%{opacity:.3} }

/* ===================================================
   PAGE HERO (inner pages — used in Code modules)
   =================================================== */
.page-hero {
  /* Break out of Divi container avoiding JS margin conflicts */
  width: 100vw !important;
  max-width: 100vw !important;
  position: relative !important;
  left: 50% !important;
  right: auto !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  transform: translateX(-50%) !important;
  /* Keep your original styling below */
  height: 460px;
  min-height: 420px;
  padding-top: 80px;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  text-align: center !important;
  background: linear-gradient(135deg, rgba(26,37,47,1) 0%, rgba(192,57,43,0.8) 100%);
  margin-top: 0 !important;
}
/* Per-page colour variants */
.ph-srv   { background: linear-gradient(140deg, #0d0d0d 0%, #1a0808 60%, #0d0d0d 100%); }
.ph-qual  { background: linear-gradient(140deg, #050810 0%, #0d1220 60%, #050810 100%); }
.ph-sus   { background: linear-gradient(140deg, #050e07 0%, #0a1a0d 60%, #050e07 100%); }
.ph-abt   { background: linear-gradient(140deg, #100d08 0%, #201808 60%, #100d08 100%); }
.ph-fac   { background: linear-gradient(140deg, #0d0d0d 0%, #1a1a1a 60%, #0d0d0d 100%); }
/* Legacy variants */
.ph-about    { background: linear-gradient(135deg, #1a1008, #2a1a08, #1a1a08); }
.ph-services { background: linear-gradient(135deg, #0d0d0d, #1a0808, #0d0d0d); }
.ph-quality  { background: linear-gradient(135deg, #0d0d12, #0d1218, #0d0d12); }
.ph-sustain  { background: linear-gradient(135deg, #081008, #102010, #081008); }

.page-hero-overlay {
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(135deg, rgba(26,37,47,.88), rgba(192,57,43,.5)) !important;
  z-index: 1 !important;
}
.page-hero-bg            { position: absolute; inset: 0; width: 100%; height: 100%; }
.page-hero-bg img        { width: 100%; height: 100%; object-fit: cover; display: block; }
.page-hero-content       { position: relative !important; z-index: 2 !important; color: #fff !important; max-width: 800px !important; width: 100% !important; padding: 0 1rem !important; }
.page-hero-content h1    { color: #fff !important; margin-bottom: 1rem !important; font-size: clamp(1.8rem, 4vw, 3.5rem) !important; line-height: 1.2 !important; }
.page-hero-content p     { font-size: 1.1rem !important; opacity: .9 !important; max-width: 600px !important; margin: 0 auto !important; line-height: 1.7 !important; color: rgba(255,255,255,.8) !important; }

@media (max-width: 980px) {
  .page-hero { height: 380px; }
}
@media (max-width: 600px) {
  .page-hero { height: 320px; padding-top: 70px; }
  .page-hero-content h1 { font-size: clamp(1.4rem, 6vw, 2rem) !important; }
  .page-hero-content p  { font-size: 0.9rem !important; }
}

/* ===================================================
   STATS BAR
   =================================================== */
#stats-bar   { background: var(--charcoal); padding: 3rem 2rem; }
.stats-inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: repeat(5,1fr); gap: 1rem; text-align: center; }
.stat-item   { padding: 1rem; }
.stat-num    { display: block; font-size: 2rem; font-weight: 900; color: var(--red); line-height: 1.1; }
.stat-label  { font-size: .75rem; color: rgba(255,255,255,.7); letter-spacing: .05em; text-transform: uppercase; margin-top: .5rem; }
/* Richer stats bar variant */
.stats-bar         { background: var(--charcoal2); padding: 0; overflow: hidden; }
.stats-inner-rich  { display: grid; grid-template-columns: repeat(5,1fr); border-left: 1px solid rgba(255,255,255,.05); }
.stat-item-rich    { padding: 52px 32px; border-right: 1px solid rgba(255,255,255,.05); position: relative; transition: background .3s; }
.stat-item-rich:hover { background: rgba(255,255,255,.02); }
.stat-item-rich::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .4s ease; }
.stat-item-rich:hover::before { transform:scaleX(1); }
.stat-number { font-family: var(--font-head); font-size: 48px; font-weight: 900; color: var(--red); line-height: 1; margin-bottom: 8px; display: block; }
.stat-label-rich { font-family: var(--font-head); font-size: 11px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.5); }

/* ===================================================
   CERT BAR
   =================================================== */
#cert-bar  { background: var(--offwhite); padding: 1.5rem 2rem; border-bottom: 3px solid var(--red); }
.cert-inner { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; gap: 2rem; flex-wrap: wrap; justify-content: center; }
.cert-label { font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--charcoal); }
.cert-badges { display: flex; gap: 1rem; flex-wrap: wrap; }
.cert-badge { background: var(--charcoal); color: #fff; font-size: .7rem; font-weight: 700; letter-spacing: .08em; padding: .4rem 1rem; border-radius: 4px; text-transform: uppercase; }

/* ===================================================
   CORE SERVICES (homepage grid)
   =================================================== */
#core-services     { padding: 6rem 2rem; background: #fff; }
.section-header    { margin-bottom: 3.5rem; }
.section-header h2 { margin-top: .5rem; }
.section-header p  { font-size: 1.05rem; color: #666; max-width: 600px; margin: .75rem auto 0; }
.services-grid     { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.5rem; max-width: 1200px; margin: 0 auto; }
.service-card      { display: flex; flex-direction: column; border-radius: 12px; overflow: hidden; background: #fff; box-shadow: 0 4px 24px rgba(0,0,0,.08); transition: .3s; cursor: pointer; }
.service-card:hover { transform: translateY(-8px); box-shadow: 0 16px 48px rgba(0,0,0,.15); }
.service-img-wrap  { position: relative; height: 200px; overflow: hidden; }
.service-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: .5s; }
.service-card:hover .service-img-wrap img { transform: scale(1.08); }
.service-card-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(44,62,80,.7), transparent); }
.service-icon      { position: absolute; bottom: 1rem; left: 1.2rem; font-size: 1.8rem; color: #fff; z-index: 1; }
.service-card-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.service-card-body h3      { color: var(--charcoal); margin-bottom: .4rem; }
.service-card-body > p     { font-size: .78rem; color: var(--red); font-weight: 700; text-transform: uppercase; letter-spacing: .06em; margin-bottom: .8rem; }
.service-card-body ul      { flex: 1; }
.service-card-body ul li   { font-size: .85rem; color: #555; padding: .3rem 0; border-bottom: 1px solid var(--offwhite); }
.service-card-body ul li:last-child { border: none; }
.card-link { display: inline-block; margin-top: 1rem; font-size: .82rem; font-weight: 700; color: var(--red); letter-spacing: .05em; text-transform: uppercase; }
.service-card:hover .card-link { letter-spacing: .1em; }

/* ===================================================
   SERVICES FULL (inner page detail blocks)
   =================================================== */
.services-full { padding: 100px 0; background: var(--white); }
.sfb { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; padding: 80px 0; border-bottom: 1px solid var(--lightgrey); }
.sfb:last-child { border-bottom: none; }
.sfb.rev { direction: rtl; }
.sfb.rev > * { direction: ltr; }
.sfp { border-radius: 16px; height: 380px; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 16px; box-shadow: var(--shadow); overflow: hidden; }
.sfp-1 { background: linear-gradient(135deg,#1a0d0d,#3a1818); }
.sfp-2 { background: linear-gradient(135deg,#0d1a0d,#183a18); }
.sfp-3 { background: linear-gradient(135deg,#1a1a0d,#3a3818); }
.sfp-4 { background: linear-gradient(135deg,#0d0d1a,#18183a); }
.sfp-icon { color: rgba(255,255,255,.15); width: 72px; height: 72px; }
.sfp-cap  { font-family: var(--font-head); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.18); text-align: center; padding: 0 32px; }
.sfc .label { margin-bottom: 12px; }
.sfc h2    { font-size: clamp(28px,3vw,42px); margin-bottom: 20px; }
.sfc p     { color: #666; font-size: 17px; margin-bottom: 28px; line-height: 1.8; }
.app-tags  { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 28px; }
.app-tag   { font-family: var(--font-head); font-size: 11px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; background: var(--offwhite); border: 1px solid var(--lightgrey); color: #888; border-radius: 4px; padding: 5px 14px; }
.sbullets  { list-style: none; display: flex; flex-direction: column; gap: 10px; margin-bottom: 32px; }
.sbullets li { font-size: 15px; color: #555; display: flex; align-items: flex-start; gap: 12px; line-height: 1.5; }
.sbullets li::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--red); flex-shrink: 0; margin-top: 8px; }
.app-strip { background: var(--offwhite); padding: 80px 0; border-top: 1px solid var(--lightgrey); }
.app-strip-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; margin-top: 48px; }
.app-card  { background: var(--white); border-radius: 12px; padding: 32px 24px; border: 1px solid var(--lightgrey); text-align: center; transition: border-color .2s, box-shadow .2s, transform .2s; }
.app-card:hover { border-color: var(--red); box-shadow: var(--shadow); transform: translateY(-4px); }
.app-card-icon     { width: 48px; height: 48px; margin: 0 auto 16px; color: var(--red); }
.app-card-icon svg { width: 100%; height: 100%; }
.app-card h4 { font-size: 15px; margin-bottom: 8px; }
.app-card p  { font-size: 13px; color: #888; line-height: 1.6; }

/* ===================================================
   QUALITY PAGE
   =================================================== */
.qual-intro { padding: 100px 0; background: var(--white); }
.qual-grid  { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.qual-visual { height: 420px; border-radius: 16px; background: linear-gradient(135deg,#050810,#0d1828); display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 20px; box-shadow: var(--shadow-lg); }
.qual-visual svg { width: 80px; height: 80px; color: rgba(255,255,255,.1); }
.qual-visual-cap { font-family: var(--font-head); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.15); text-align: center; padding: 0 40px; }
.quality-protocols { padding: 100px 0; background: var(--white); }
.protocols-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 32px; margin-top: 64px; }
.protocol-card { padding: 40px 36px; border: 1px solid var(--lightgrey); border-radius: 12px; transition: border-color .3s, box-shadow .3s, transform .3s; }
.protocol-card:hover { border-color: var(--charcoal); box-shadow: var(--shadow); transform: translateY(-4px); }
.protocol-num   { font-family: var(--font-head); font-size: 48px; font-weight: 900; color: rgba(192,33,27,.12); line-height: 1; margin-bottom: 24px; }
.protocol-title { font-family: var(--font-head); font-size: 18px; font-weight: 700; margin-bottom: 12px; color: var(--charcoal); }
.protocol-desc  { font-size: 14px; color: #888; line-height: 1.7; }
.cert-deep { padding: 100px 0; background: var(--charcoal2); }
.cert-deep-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 32px; margin-top: 64px; }
.cdc { border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 40px 32px; text-align: center; transition: border-color .3s, background .3s; }
.cdc:hover { border-color: var(--red); background: rgba(192,33,27,.05); }
.cdc-badge  { width: 80px; height: 80px; border-radius: 12px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; font-family: var(--font-head); font-size: 12px; font-weight: 900; color: rgba(255,255,255,.6); text-align: center; line-height: 1.3; }
.cdc-title  { font-family: var(--font-head); font-size: 16px; font-weight: 700; color: var(--white); margin-bottom: 12px; }
.cdc-desc   { font-size: 14px; color: rgba(255,255,255,.4); line-height: 1.7; }
.steam-vs { padding: 100px 0; background: var(--offwhite); }
.svt { display: grid; grid-template-columns: 1fr 1fr; border-radius: 16px; overflow: hidden; box-shadow: var(--shadow); margin-top: 56px; }
.svt-col    { padding: 48px 40px; }
.svt-ppo    { background: #f8f8f8; border: 1px solid var(--lightgrey); }
.svt-steam  { background: var(--charcoal2); }
.svt-hdr    { font-family: var(--font-head); font-size: 13px; font-weight: 900; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 32px; display: flex; align-items: center; gap: 12px; }
.svt-hdr-ppo   { color: #aaa; }
.svt-hdr-steam { color: var(--white); }
.svt-tbad   { background: rgba(0,0,0,.06); color: #aaa; padding: 3px 12px; border-radius: 4px; font-size: 11px; }
.svt-tgood  { background: rgba(192,33,27,.2); color: var(--red); padding: 3px 12px; border-radius: 4px; font-size: 11px; }
.svt-row    { display: flex; align-items: flex-start; gap: 12px; padding: 16px 0; border-bottom: 1px solid rgba(0,0,0,.06); }
.svt-steam .svt-row { border-color: rgba(255,255,255,.06); }
.svt-row:last-child { border-bottom: none; }
.ic-bad  { color: #ccc; flex-shrink: 0; width: 18px; height: 18px; margin-top: 2px; }
.ic-good { color: #6aba85; flex-shrink: 0; width: 18px; height: 18px; margin-top: 2px; }
.tx-bad  { font-size: 14px; color: #aaa; line-height: 1.5; }
.tx-good { font-size: 14px; color: rgba(255,255,255,.7); line-height: 1.5; }

/* ===================================================
   SUSTAINABILITY PAGE
   =================================================== */
.sus-intro { padding: 100px 0; background: var(--white); }
.sus-intro-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: center; }
.sus-bs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 40px; }
.sus-bs     { padding: 28px 24px; border-radius: 12px; background: var(--offwhite); border: 1px solid var(--lightgrey); }
.sus-bs-num { font-family: var(--font-head); font-size: 36px; font-weight: 900; color: var(--green); line-height: 1; margin-bottom: 6px; }
.sus-bs-lbl { font-family: var(--font-head); font-size: 11px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: #aaa; }
.sus-vis    { background: linear-gradient(135deg,#081008,#102010); border-radius: 16px; height: 460px; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 20px; box-shadow: var(--shadow-lg); position: relative; overflow: hidden; }
.sus-glow   { position: absolute; width: 300px; height: 300px; border-radius: 50%; background: radial-gradient(circle,rgba(74,124,89,.25),transparent); filter: blur(60px); pointer-events: none; }
.sus-tech   { padding: 100px 0; background: var(--charcoal2); }
.sus-tech-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; margin-top: 64px; }
.stc h3     { color: var(--white); font-size: 28px; margin-bottom: 20px; }
.stc p      { color: rgba(255,255,255,.55); font-size: 16px; line-height: 1.8; margin-bottom: 20px; }
.stc-hl     { border-left: 3px solid var(--green); padding: 20px 24px; background: rgba(74,124,89,.07); border-radius: 0 8px 8px 0; margin-top: 28px; font-family: var(--font-head); font-size: 14px; font-weight: 600; color: #6aba85; line-height: 1.7; }
.sus-steps  { display: flex; flex-direction: column; }
.sus-step   { display: flex; gap: 24px; padding: 28px 0; border-bottom: 1px solid rgba(255,255,255,.06); }
.sus-step:last-child { border-bottom: none; }
.sus-step-num   { font-family: var(--font-head); font-size: 32px; font-weight: 900; color: rgba(74,124,89,.3); line-height: 1; flex-shrink: 0; width: 40px; }
.sus-step-title { font-family: var(--font-head); font-size: 16px; font-weight: 700; color: var(--white); margin-bottom: 6px; }
.sus-step-desc  { font-size: 14px; color: rgba(255,255,255,.45); line-height: 1.6; }
.sus-scope  { padding: 80px 0; background: var(--green); }
.sus-scope-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.sus-scope h2 { color: var(--white); margin-bottom: 20px; }
.sus-scope p  { color: rgba(255,255,255,.75); font-size: 17px; line-height: 1.8; }
.sus-scope-stats { display: flex; flex-direction: column; gap: 20px; }
.sss     { background: rgba(255,255,255,.1); border-radius: 12px; padding: 20px 24px; display: flex; align-items: center; gap: 20px; }
.sss-num { font-family: var(--font-head); font-size: 28px; font-weight: 900; color: var(--white); flex-shrink: 0; }
.sss-lbl { font-size: 14px; color: rgba(255,255,255,.7); line-height: 1.5; }

/* ===================================================
   ABOUT PAGE
   =================================================== */
.mission { padding: 100px 0; background: var(--offwhite); }
.mission-quote { max-width: 900px; margin: 0 auto; text-align: center; }
.mission-quote blockquote { font-family: var(--font-head); font-size: clamp(22px,3vw,36px); font-weight: 700; line-height: 1.4; color: var(--charcoal); margin-bottom: 32px; position: relative; }
.mission-quote blockquote::before { content: '\201C'; font-size: 120px; color: rgba(192,33,27,.12); font-family: Georgia,serif; position: absolute; top: -40px; left: -20px; line-height: 1; }
.mission-attribution { font-family: var(--font-head); font-size: 13px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: #aaa; }
.about-story { padding: 100px 0; background: var(--white); }
.about-story-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.about-points { display: flex; flex-direction: column; gap: 20px; margin-top: 32px; }
.about-point  { display: flex; align-items: flex-start; gap: 16px; }
.about-point-icon { width: 36px; height: 36px; border-radius: 50%; background: rgba(192,33,27,.08); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--red); }
.about-point-icon svg { width: 16px; height: 16px; }
.about-point-title { font-family: var(--font-head); font-size: 14px; font-weight: 700; margin-bottom: 4px; color: var(--charcoal); }
.about-point-desc  { font-size: 14px; color: #888; line-height: 1.6; }
.abt-columns    { display: grid; grid-template-columns: 1.5fr 1fr; gap: 80px; align-items: start; }
.abt-story-full { padding: 100px 0; background: var(--white); }
.abt-story-full h2 { margin-bottom: 24px; }
.abt-story-full p  { color: #666; font-size: 17px; margin-bottom: 20px; line-height: 1.8; }
.abt-sidebar-box   { background: var(--offwhite); border-radius: 16px; padding: 40px 36px; border: 1px solid var(--lightgrey); position: sticky; top: 120px; }
.abt-sidebar-box h4 { font-size: 18px; margin-bottom: 20px; }
.asb-stat { padding: 16px 0; border-bottom: 1px solid var(--lightgrey); }
.asb-stat:last-child { border-bottom: none; }
.asb-num  { font-family: var(--font-head); font-size: 28px; font-weight: 900; color: var(--red); line-height: 1; }
.asb-lbl  { font-family: var(--font-head); font-size: 11px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: #aaa; margin-top: 4px; }
.journey  { padding: 100px 0; background: var(--offwhite); }
.journey-steps { display: grid; grid-template-columns: repeat(4,1fr); margin-top: 64px; position: relative; }
.journey-steps::before { content:''; position:absolute; top:40px; left:12.5%; right:12.5%; height:2px; background:var(--lightgrey); z-index:0; }
.js      { text-align: center; padding: 0 16px; position: relative; z-index: 1; }
.js-num  { width:80px; height:80px; border-radius:50%; background:var(--white); border:2px solid var(--lightgrey); display:flex; align-items:center; justify-content:center; margin:0 auto 24px; font-family:var(--font-head); font-size:24px; font-weight:900; color:var(--red); box-shadow:0 4px 20px rgba(0,0,0,.08); transition:border-color .2s,box-shadow .2s; }
.js:hover .js-num { border-color:var(--red); box-shadow:0 4px 20px rgba(192,33,27,.2); }
.js h4 { font-size:16px; margin-bottom:8px; }
.js p  { font-size:13px; color:#888; line-height:1.6; }

/* ===================================================
   SOLAR STEAM (homepage)
   =================================================== */
#solar-steam  { background: var(--charcoal-dark); padding: 0; overflow: hidden; }
.solar-split  { display: grid; grid-template-columns: 1fr 1fr; min-height: 600px; }
.solar-visual { position: relative; overflow: hidden; }
.solar-visual img { width:100%; height:100%; object-fit:cover; opacity:.8; }
.solar-badge  { position:absolute; bottom:2rem; right:2rem; background:rgba(26,188,156,.95); color:#fff; padding:1rem 1.5rem; border-radius:12px; display:flex; align-items:center; gap:.8rem; font-size:.85rem; font-weight:700; line-height:1.3; }
.solar-badge-icon { font-size: 2rem; }
.solar-content { padding:4rem 3rem; color:#fff; display:flex; flex-direction:column; justify-content:center; }
.solar-content h2 { color:#fff; margin-bottom:1.2rem; }
.solar-content p  { color:rgba(255,255,255,.8); font-size:.95rem; }
.solar-stats  { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin:2rem 0; }
.solar-stat   { background:rgba(255,255,255,.06); border-radius:8px; padding:1rem 1.2rem; border-left:3px solid var(--teal); }
.solar-stat strong { display:block; font-size:1.6rem; font-weight:900; color:var(--teal); }
.solar-stat span   { font-size:.78rem; color:rgba(255,255,255,.7); text-transform:uppercase; letter-spacing:.04em; }

/* ===================================================
   FACILITY BANNER
   =================================================== */
#facility-banner { position:relative; height:480px; overflow:hidden; display:flex; align-items:flex-end; }
.facility-bg  { position:absolute; inset:0; }
.facility-bg img { width:100%; height:100%; object-fit:cover; }
.facility-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(26,37,47,.92) 30%,rgba(26,37,47,.3) 100%); }
.facility-content { position:relative; z-index:2; color:#fff; padding:3rem 4rem; max-width:700px; }
.facility-content h2 { color:#fff; margin-bottom:1rem; }
.facility-content p  { color:rgba(255,255,255,.85); margin-bottom:1.5rem; }

/* ===================================================
   PROCESS FLOW
   =================================================== */
#process-flow { padding:6rem 2rem; background:var(--offwhite); }
.process-steps { display:flex; align-items:flex-start; gap:1rem; justify-content:center; flex-wrap:wrap; max-width:1100px; margin:0 auto; }
.process-step  { background:#fff; border-radius:12px; padding:2rem 1.5rem; text-align:center; flex:1; min-width:180px; max-width:220px; box-shadow:0 4px 16px rgba(0,0,0,.06); position:relative; }
.step-num  { position:absolute; top:1rem; right:1rem; font-size:.7rem; font-weight:900; color:var(--red); letter-spacing:.05em; }
.step-icon { font-size:2.5rem; margin-bottom:1rem; }
.process-step h3 { color:var(--charcoal); font-size:1rem; margin-bottom:.5rem; }
.process-step p  { font-size:.82rem; color:#666; line-height:1.5; }
.process-arrow   { font-size:1.5rem; color:var(--red); padding-top:3rem; flex-shrink:0; }

/* ===================================================
   WHY CCP
   =================================================== */
#why-ccp   { padding:6rem 2rem; background:#fff; }
.why-grid  { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; max-width:1200px; margin:0 auto; }
.why-content h2   { margin-top:.5rem; margin-bottom:1rem; }
.why-content > p  { color:#555; margin-bottom:2rem; }
.why-points { display:flex; flex-direction:column; gap:1.2rem; margin-bottom:2rem; }
.why-point  { display:flex; gap:1rem; align-items:flex-start; }
.why-icon   { width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.9rem; color:#fff; flex-shrink:0; margin-top:.2rem; }
.why-icon.red     { background:var(--red); }
.why-point strong { display:block; color:var(--charcoal); margin-bottom:.2rem; }
.why-point p      { font-size:.88rem; color:#666; margin:0; }
.why-visual { position:relative; }
.why-visual img   { border-radius:12px; box-shadow:0 20px 60px rgba(0,0,0,.15); }
.why-quote-card   { position:absolute; bottom:-2rem; left:-2rem; background:var(--charcoal); color:#fff; padding:1.5rem; border-radius:12px; max-width:320px; border-left:4px solid var(--red); }
.why-quote-card blockquote { font-style:italic; font-size:.85rem; line-height:1.6; margin-bottom:.5rem; }
.why-quote-card cite { font-size:.75rem; color:var(--red); font-weight:700; font-style:normal; }

/* ===================================================
   CTA SECTION
   =================================================== */
.cta-section { padding:140px 0; background:var(--charcoal2); text-align:center; position:relative; overflow:hidden; }
.cta-section::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(192,33,27,0.1),transparent); pointer-events:none; }
.cta-section h2 { color:var(--white); margin-bottom:20px; position:relative; }
.cta-section p  { color:rgba(255,255,255,.5); font-size:20px; max-width:600px; margin:0 auto 48px; position:relative; }
.cta-btns { display:flex; align-items:center; justify-content:center; gap:20px; flex-wrap:wrap; position:relative; }

/* ===================================================
   HOME CTA
   =================================================== */
#home-cta         { background:var(--red); padding:5rem 2rem; color:#fff; }
#home-cta .eyebrow { color:rgba(255,255,255,.7); }
#home-cta h2      { color:#fff; margin:.5rem 0 1rem; }
#home-cta p       { color:rgba(255,255,255,.85); max-width:560px; margin:0 auto 2rem; }
.mini-form-row    { display:flex; gap:.75rem; flex-wrap:wrap; justify-content:center; max-width:900px; margin:0 auto; }
.mini-form-row input,.mini-form-row select { flex:1; min-width:180px; padding:.85rem 1rem; border:none; border-radius:8px; font-family:var(--font); font-size:.9rem; background:rgba(255,255,255,.15); color:#fff; backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,.3); }
.mini-form-row input::placeholder { color:rgba(255,255,255,.7); }
.mini-form-row select option { background:var(--charcoal); color:#fff; }
.mini-form-row .btn { flex-shrink:0; background:#fff; color:var(--red); }
.mini-form-row .btn:hover { background:var(--offwhite); }

/* ===================================================
   FOOTER
   =================================================== */
#site-footer { background:var(--charcoal-dark); }
.footer-main { max-width:1280px; margin:0 auto; padding:4rem 2rem; display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:3rem; }
.footer-logo .logo-ccp  { font-size:1.4rem; color:var(--red); }
.footer-logo .logo-text { font-size:.7rem; color:rgba(255,255,255,.7); text-transform:uppercase; letter-spacing:.05em; }
.footer-tagline { font-size:.82rem; color:rgba(255,255,255,.6); line-height:1.7; margin-bottom:1rem; }
.footer-cert-row { display:flex; gap:.5rem; flex-wrap:wrap; }
.fcert { background:rgba(255,255,255,.1); color:rgba(255,255,255,.8); font-size:.65rem; font-weight:700; padding:.3rem .7rem; border-radius:4px; letter-spacing:.05em; text-transform:uppercase; }
.footer-col h4  { color:#fff; margin-bottom:1.2rem; font-size:.82rem; letter-spacing:.1em; }
.footer-links li { margin-bottom:.5rem; }
.footer-links a  { font-size:.82rem; color:rgba(255,255,255,.6); transition:.2s; }
.footer-links a:hover { color:var(--red); }
.footer-col p   { font-size:.82rem; color:rgba(255,255,255,.6); margin-bottom:.5rem; }
.footer-col a   { color:rgba(255,255,255,.6); }
.footer-col a:hover { color:var(--red); }
.footer-bottom  { border-top:1px solid rgba(255,255,255,.08); padding:1.5rem 2rem; text-align:center; font-size:.75rem; color:rgba(255,255,255,.4); }
.footer-bottom a { color:rgba(255,255,255,.4); }
.footer-bottom a:hover { color:var(--red); }
/* Richer footer variant */
footer { background:var(--charcoal2); padding:80px 0 0; color:rgba(255,255,255,.6); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:60px; padding-bottom:60px; border-bottom:1px solid rgba(255,255,255,.06); }
.footer-cert { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); border-radius:6px; padding:6px 12px; font-family:var(--font-head); font-size:10px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:rgba(255,255,255,.4); }

/* ===================================================
   SECTION UTILITIES
   =================================================== */
.section-light { background:var(--offwhite); padding:5rem 2rem; }
.section-white { background:#fff; padding:5rem 2rem; }
.section-dark  { width:100%; background:var(--charcoal); padding:5rem 2rem; color:#fff; }
.section-dark h2, .section-dark h3 { color:#fff; }
.section-dark p { color:rgba(255,255,255,.8); }

/* ===================================================
   SPEC TABLE
   =================================================== */
.spec-table { width:100%; border-collapse:collapse; margin-top:1.5rem; border-radius:12px; overflow:hidden; box-shadow:0 2px 20px rgba(0,0,0,.06); }
.spec-table th { background:var(--charcoal); color:#fff; padding:.8rem 1.2rem; text-align:left; font-size:.82rem; letter-spacing:.05em; text-transform:uppercase; }
.spec-table td { padding:.8rem 1.2rem; border-bottom:1px solid #eee; font-size:.9rem; }
.spec-table tr:nth-child(even) td { background:var(--offwhite); }
.spec-table td:first-child { font-weight:700; color:var(--charcoal); }
.spec-table tbody tr:hover { background:var(--offwhite); }

/* ===================================================
   ICON GRID
   =================================================== */
.icon-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1.5rem; max-width:1100px; margin:2rem auto 0; }
.icon-card { background:#fff; border-radius:12px; padding:2rem; text-align:center; box-shadow:0 4px 16px rgba(0,0,0,.06); border-top:3px solid var(--red); }
.icon-card .big-icon { font-size:2.5rem; margin-bottom:.8rem; }
.icon-card h3 { font-size:1rem; color:var(--charcoal); margin-bottom:.5rem; }
.icon-card p  { font-size:.85rem; color:#666; margin:0; }

/* ===================================================
   TWO COL / GRID HELPERS
   =================================================== */
.two-col  { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; max-width:1200px; margin:0 auto; }
.two-col img { border-radius:12px; box-shadow:0 12px 40px rgba(0,0,0,.12); }
.grid-2   { display:grid; grid-template-columns:1fr 1fr; gap:3rem; }

/* ===================================================
   CERT WALL
   =================================================== */
.cert-wall  { display:flex; flex-wrap:wrap; gap:1.5rem; justify-content:center; max-width:900px; margin:2rem auto 0; }
.cert-tile  { background:var(--charcoal); color:#fff; padding:1.5rem 2.5rem; border-radius:12px; text-align:center; min-width:150px; }
.cert-tile strong { display:block; font-size:1.2rem; color:var(--red); margin-bottom:.3rem; }
.cert-tile span   { font-size:.78rem; opacity:.8; text-transform:uppercase; letter-spacing:.06em; }

/* ===================================================
   CONTACT FORM
   =================================================== */
.contact-grid    { display:grid; grid-template-columns:1fr 1.5fr; gap:4rem; max-width:1100px; margin:0 auto; }
.contact-info h3 { color:var(--charcoal); margin-bottom:1rem; }
.contact-info p  { font-size:.9rem; color:#555; margin-bottom:.8rem; display:flex; gap:.6rem; }
.contact-form-wrap h3 { color:var(--charcoal); margin-bottom:1.5rem; }
.form-row  { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:1rem; }
.form-group { display:flex; flex-direction:column; gap:.4rem; margin-bottom:1rem; }
.form-group label { font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--charcoal); }
.form-group input, .form-group select, .form-group textarea { padding:.85rem 1rem; border:1px solid #ddd; border-radius:8px; font-family:var(--font); font-size:.9rem; color:var(--text); transition:.3s; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(192,57,43,.1); }
.form-group textarea { min-height:130px; resize:vertical; }

/* ===================================================
   ANIMATIONS
   =================================================== */
.fade-in         { opacity:0; transform:translateY(30px); transition:opacity .7s ease,transform .7s ease; }
.fade-in.visible { opacity:1; transform:none; }
.fade-in-delay-1 { transition-delay:.1s; }
.fade-in-delay-2 { transition-delay:.2s; }
.fade-in-delay-3 { transition-delay:.3s; }
.fade-in-delay-4 { transition-delay:.4s; }
@keyframes scrollDown {
  0%  { transform:scaleY(0); transform-origin:top; }
  50% { transform:scaleY(1); transform-origin:top; }
  51% { transform:scaleY(1); transform-origin:bottom; }
  100%{ transform:scaleY(0); transform-origin:bottom; }
}

/* ===================================================
   RESPONSIVE — consolidated
   =================================================== */
@media (max-width: 1024px) {
  .container      { padding: 0 24px; }
  .services-grid  { grid-template-columns: repeat(2,1fr); }
  .solar-split, .why-grid, .two-col, .contact-grid, .facility-grid { grid-template-columns: 1fr; }
  .stats-inner    { grid-template-columns: repeat(3,1fr); }
  .footer-main, .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .solar-visual   { min-height: 350px; }
  .about-story-grid, .sus-intro-grid, .sus-tech-grid, .abt-columns, .fac-overview-grid, .fac-loc-grid, .sus-scope-inner { grid-template-columns: 1fr; gap: 48px; }
  .svt            { grid-template-columns: 1fr; }
  .app-strip-grid { grid-template-columns: repeat(2,1fr); }
  .journey-steps  { grid-template-columns: repeat(2,1fr); gap: 32px; }
  .journey-steps::before { display: none; }
  .cert-deep-grid, .protocols-grid { grid-template-columns: repeat(2,1fr); }
  .abt-sidebar-box { position: static; }
  .sfb, .sfb.rev  { grid-template-columns: 1fr; direction: ltr; }
  .qual-grid      { grid-template-columns: 1fr; gap: 40px; }
  .contact-grid   { grid-template-columns: 1fr; gap: 48px; }
  .grid-2         { display: flex !important; flex-direction: column !important; gap: 3rem !important; }
}

@media (max-width: 768px) {
  .services-grid  { grid-template-columns: 1fr; }
  .stats-inner    { grid-template-columns: 1fr 1fr; }
  .process-arrow  { display: none; }
  .why-quote-card { position: static; margin-top: 1rem; }
  .mini-form-row  { flex-direction: column; }
  .form-row       { grid-template-columns: 1fr; }
  .footer-main, .footer-grid { grid-template-columns: 1fr; }
  .facility-content { padding: 2rem; }
  .app-strip-grid, .cert-deep-grid, .fac-tech-grid, .sus-bs-grid, .fac-nums { grid-template-columns: 1fr; }
  .journey-steps  { grid-template-columns: 1fr; }
  .svt-col        { padding: 32px 24px; }
  .contact-form   { padding: 32px 24px; }
  .protocols-grid { grid-template-columns: 1fr; }
  .certs-row      { gap: 32px; }
}