/* CPCP — Racing-inspired plumbing site, tuned for phone-first browsing */
:root {
  --navy: #061126;
  --navy-2: #081d43;
  --blue: #075be9;
  --electric: #00bfee;
  --orange: #ff5a1f;
  --yellow: #ffed17;
  --gold: #ffbd0a;
  --white: #ffffff;
  --ink: #071326;
  --gray: #5a6a82;
  --line: #cbd8ea;
  --shell: min(1180px, calc(100% - 40px));
  --title: "Barlow Condensed", Impact, sans-serif;
  --body: "Rajdhani", Arial, sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 104px; }
body { margin: 0; background: #f6f9ff; color: var(--ink); font-family: var(--body); font-size: 18px; font-weight: 600; line-height: 1.35; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, input, select, textarea { font: inherit; }
.shell { width: var(--shell); margin: 0 auto; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; clip: rect(0,0,0,0); overflow: hidden; white-space: nowrap; border: 0; }
.skip-link { position: fixed; z-index: 1000; top: 8px; left: 8px; padding: 10px 14px; color: var(--ink); background: var(--yellow); transform: translateY(-160%); font-weight: 900; }
.skip-link:focus { transform: translateY(0); }

/* Header */
.announcement-bar { position: relative; z-index: 20; background: var(--yellow); color: var(--navy); border-bottom: 3px solid var(--orange); }
.announcement-bar__inner { min-height: 32px; display: flex; align-items: center; justify-content: space-between; gap: 18px; font-size: 13px; font-weight: 900; letter-spacing: .08em; }
.announcement-bar p { margin: 0; }
.announcement-bar a { white-space: nowrap; }
.announcement-bar a span { color: var(--orange); font-size: 17px; }
.pulse { display: inline-block; width: 9px; height: 9px; margin: 0 7px 1px 0; background: var(--orange); transform: rotate(45deg); }
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(4, 11, 26, .97); border-bottom: 1px solid rgba(255,255,255,.12); box-shadow: 0 7px 16px rgba(0,0,0,.15); backdrop-filter: blur(12px); }
.header__inner { min-height: 78px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.site-logo { display: block; width: 218px; flex: 0 0 218px; }
.site-logo img { width: 100%; height: auto; }
.site-nav { display: flex; align-items: center; gap: 25px; color: #fff; font-size: 15px; font-weight: 900; letter-spacing: .055em; }
.site-nav > a:not(.nav-call) { position: relative; }
.site-nav > a:not(.nav-call)::after { content: ""; position: absolute; height: 2px; left: 0; bottom: -6px; width: 0; background: var(--yellow); transition: width .18s ease; }
.site-nav > a:not(.nav-call):hover::after { width: 100%; }
.nav-call { padding: 11px 15px; background: var(--orange); color: #fff; font-family: var(--title); font-size: 18px; font-style: italic; font-weight: 900; clip-path: polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%); }
.nav-call span { color: var(--yellow); }
.nav-toggle { display: none; width: 45px; height: 43px; padding: 7px; border: 1px solid rgba(255,255,255,.35); background: transparent; cursor: pointer; }
.nav-toggle span:not(.sr-only) { display: block; width: 24px; height: 3px; margin: 4px auto; background: var(--yellow); }

/* Type and reusable pieces */
.kicker { margin: 0 0 12px; color: var(--electric); font-size: 14px; font-weight: 900; letter-spacing: .12em; }
.kicker > span { display: inline-block; width: 25px; height: 4px; margin-right: 8px; vertical-align: middle; background: var(--orange); }
.kicker--dark { color: var(--blue); }
h1,h2,h3 { margin: 0; font-family: var(--title); font-style: italic; font-weight: 900; line-height: .86; letter-spacing: -.02em; }
h1 { font-size: clamp(64px, 8.4vw, 116px); }
h2 { color: var(--ink); font-size: clamp(53px, 6vw, 78px); }
h1 em,h2 em { color: var(--yellow); font-style: inherit; }
.button { min-height: 52px; display: inline-flex; align-items: center; justify-content: center; gap: 14px; padding: 13px 19px; border: 0; font-family: var(--title); font-size: 20px; font-style: italic; font-weight: 900; letter-spacing: .03em; cursor: pointer; transition: transform .18s ease, box-shadow .18s ease; clip-path: polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%); }
.button:hover { transform: translate(-3px,-3px); box-shadow: 5px 5px 0 var(--blue); }
.button--yellow { color: var(--ink); background: linear-gradient(105deg,var(--yellow),var(--gold)); }
.button--yellow span { color: var(--orange); font-size: 25px; }
.button--ghost { color: #fff; background: rgba(255,255,255,.08); outline: 2px solid rgba(255,255,255,.85); outline-offset: -2px; }
.button--ghost span { color: var(--electric); }
.section { padding: 100px 0; }
.section-heading { display: flex; justify-content: space-between; align-items: end; gap: 38px; margin-bottom: 42px; }
.section-heading > p { max-width: 390px; margin: 0; color: #40516b; font-size: 20px; line-height: 1.2; }
.section-heading--single { display: block; }

/* Hero */
.hero { position: relative; isolation: isolate; overflow: hidden; min-height: 680px; color: #fff; background: radial-gradient(circle at 76% 15%,rgba(17,89,225,.52),transparent 26%), linear-gradient(125deg,#030812 7%,#071d4b 55%,#030914 100%); }
.hero::after { content:""; position:absolute; z-index:-1; left:0; right:0; bottom:0; height:200px; background:linear-gradient(to top,rgba(0,0,0,.38),transparent); pointer-events:none; }
.hero__grid { position: absolute; z-index: -1; inset: 0; opacity: .28; background-image: linear-gradient(rgba(255,255,255,.10) 1px,transparent 1px), linear-gradient(90deg,rgba(255,255,255,.10) 1px,transparent 1px); background-size: 54px 54px; mask-image: linear-gradient(to right,#000 0%,rgba(0,0,0,.6) 64%,transparent 100%); }
.hero__racing-arcs { position: absolute; z-index: -1; right: -14vw; top: -240px; width: min(102vw, 1360px); height: 760px; border: 16px solid var(--orange); border-left: 0; border-bottom: 0; border-radius: 60% 42% 0 0; transform: rotate(10deg); opacity: .97; }
.hero__racing-arcs::before { content:""; position:absolute; inset:30px 28px auto auto; width:calc(100% - 54px); height:100%; border: 13px solid var(--blue); border-left:0; border-bottom:0; border-radius:60% 42% 0 0; }
.hero__racing-arcs::after { content:""; position:absolute; inset:66px 57px auto auto; width:calc(100% - 109px); height:100%; border: 5px solid var(--yellow); border-left:0; border-bottom:0; border-radius:60% 42% 0 0; }
.hero__finish-line { position:absolute; z-index:-1; left:-65px; bottom:45px; width:275px; height:150px; opacity:.98; background:repeating-conic-gradient(#fff 0 25%,transparent 0 50%) 50%/32px 32px; transform:skewX(-24deg); mask-image:linear-gradient(to right,#000,transparent 82%); }
.hero__speed-bars { position:absolute; z-index:-1; top:70px; left:-66px; display:grid; gap:14px; transform:rotate(-17deg); }
.hero__speed-bars i { display:block; height:9px; background:var(--orange); }
.hero__speed-bars i:nth-child(1){width:140px}.hero__speed-bars i:nth-child(2){width:240px;background:var(--yellow)}.hero__speed-bars i:nth-child(3){width:185px;background:var(--electric)}
.hero__layout { position: relative; z-index:1; min-height: 635px; display:grid; grid-template-columns:minmax(0,1.05fr) minmax(350px,.95fr); align-items:center; gap:46px; padding:66px 0 76px; }
.hero__copy h1 { text-shadow: 5px 5px 0 rgba(0,0,0,.31); }
.hero__lede { max-width:590px; margin:22px 0 27px; color:#d5e0f0; font-size:clamp(20px,2.15vw,24px); line-height:1.16; }
.hero__actions { display:flex; flex-wrap:wrap; gap:12px; }
.hero__proof { display:grid; grid-template-columns:repeat(3,1fr); max-width:630px; margin-top:33px; border-top:1px solid rgba(255,255,255,.4); }
.hero__proof > div { padding:13px 14px 0 0; }
.hero__proof > div + div { padding-left:14px; border-left:1px solid rgba(255,255,255,.28); }
.hero__proof strong { display:block; font-family:var(--title); font-size:23px; line-height:.95; font-style:italic; letter-spacing:.02em; }
.hero__proof span { display:block; margin-top:4px; color:#b7c7dc; font-size:14px; line-height:1.1; }
.hero__brand-panel { position:relative; max-width:525px; justify-self:end; width:100%; padding:30px 24px 16px; background:linear-gradient(145deg,rgba(3,10,23,.88),rgba(3,8,18,.56)); border:1px solid rgba(255,255,255,.42); box-shadow:16px 16px 0 var(--orange),27px 27px 0 var(--blue); overflow:hidden; }
.hero__brand-panel::before { content:""; position:absolute; z-index:-1; inset:0; opacity:.28; background:repeating-linear-gradient(135deg,transparent 0 16px,rgba(0,191,238,.8) 17px 21px,transparent 22px 44px); }
.hero__brand-panel img { position:relative; z-index:1; width:100%; height:auto; }
.brand-panel__flag { position:absolute; top:0; right:0; width:102px; height:18px; background:repeating-conic-gradient(#fff 0 25%,#0c1424 0 50%) 50%/18px 18px; transform:skewX(-28deg) translateX(9px); }
.brand-panel__line { position:absolute; height:5px; transform:skewX(-30deg); }
.brand-panel__line--top { top:14px; left:-10px; width:170px; background:var(--yellow); }
.brand-panel__line--bottom { bottom:36px; right:-30px; width:200px; background:var(--electric); }
.brand-panel__caption { position:relative; z-index:1; display:flex; justify-content:space-between; gap:10px; margin-top:10px; color:#e7eff8; font-size:11px; font-weight:900; letter-spacing:.07em; }
.brand-panel__caption span:last-child { color:var(--yellow); text-align:right; }
.service-ticker { position:absolute; z-index:2; bottom:0; left:0; right:0; overflow:hidden; border-top:3px solid var(--orange); background:var(--yellow); color:var(--navy); }
.service-ticker__track { display:flex; align-items:center; gap:17px; min-width:max-content; min-height:43px; padding:0 22px; font-size:13px; font-weight:900; letter-spacing:.11em; animation: ticker 28s linear infinite; }
.service-ticker i { display:block; width:8px; height:8px; flex:0 0 8px; background:var(--orange); transform:rotate(45deg); }
@keyframes ticker { from { transform:translateX(0) } to { transform:translateX(-35%) } }

/* Services */
.services { background:linear-gradient(120deg,#eef7ff 0%,#fff 56%,#edf3ff 100%); }
.service-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.service-card { position:relative; min-height:326px; display:flex; flex-direction:column; overflow:hidden; padding:22px; color:#fff; clip-path:polygon(0 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%); box-shadow:0 12px 25px rgba(5,27,70,.14); }
.service-card::before { content:""; position:absolute; width:155px; height:60px; right:-35px; bottom:38px; opacity:.25; transform:rotate(-42deg); background:repeating-linear-gradient(90deg,transparent 0 9px,#fff 10px 18px,transparent 19px 27px); }
.service-card--blue { background:linear-gradient(145deg,#0644b7,#086ff2); }
.service-card--orange { background:linear-gradient(145deg,#d93113,#ff8218); }
.service-card--cyan { background:linear-gradient(145deg,#0073b8,#02bce1); }
.service-card--yellow { color:var(--ink); background:linear-gradient(145deg,#ffea09,#ffbd0a); }
.service-card__number { position:relative; z-index:1; color:inherit; font-family:var(--title); font-size:21px; font-style:italic; font-weight:900; opacity:.85; }
.service-icon { position:relative; z-index:1; width:52px; height:52px; display:grid; place-items:center; margin:22px 0 16px; border:2px solid rgba(255,255,255,.76); transform:skewX(-12deg); }
.service-card--yellow .service-icon { border-color:rgba(7,19,38,.65); }
.service-icon svg { width:34px; height:34px; fill:none; stroke:currentColor; stroke-width:3.2; stroke-linecap:round; stroke-linejoin:round; transform:skewX(12deg); }
.service-card h3 { position:relative; z-index:1; font-size:40px; }
.service-card p { position:relative; z-index:1; margin:16px 0 auto; font-size:16.5px; line-height:1.13; }
.service-card a { position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; gap:8px; margin-top:20px; padding-top:12px; border-top:1px solid rgba(255,255,255,.6); font-family:var(--title); font-size:16px; font-style:italic; font-weight:900; letter-spacing:.05em; }
.service-card a span { color:var(--yellow); font-size:22px; }
.service-card--yellow a { border-color:rgba(7,19,38,.45); }.service-card--yellow a span { color:var(--orange); }

/* Why CPCP */
.why-cpcp { position:relative; overflow:hidden; padding:102px 0; color:#fff; background:radial-gradient(circle at 12% 88%,rgba(0,191,238,.32),transparent 27%),radial-gradient(circle at 84% 10%,rgba(255,90,31,.22),transparent 22%),#06142f; }
.why-cpcp__checkers { position:absolute; right:-95px; top:-70px; width:455px; height:510px; opacity:.18; transform:rotate(22deg); background:repeating-conic-gradient(#fff 0 25%,transparent 0 50%) 50%/36px 36px; mask-image:linear-gradient(to bottom,rgba(0,0,0,.9),transparent 85%); }
.why-cpcp__orange-line { position:absolute; left:-10px; bottom:52px; width:440px; height:18px; background:var(--orange); transform:skewX(-28deg); }
.why-cpcp__orange-line::after { content:""; position:absolute; left:36px; top:29px; width:275px; height:6px; background:var(--yellow); }
.why-cpcp__grid { position:relative; display:grid; grid-template-columns:.87fr 1.13fr; gap:85px; }
.why-cpcp h2 { color:#fff; }.why-cpcp h2 em { color:var(--yellow); }
.why-cpcp__intro { max-width:630px; margin:0 0 28px; color:#d8e6f5; font-size:24px; line-height:1.18; }
.feature-list { border-top:1px solid rgba(255,255,255,.22); }
.feature { display:flex; gap:21px; padding:21px 0; border-bottom:1px solid rgba(255,255,255,.22); }
.feature > span { flex:0 0 42px; color:var(--yellow); font-family:var(--title); font-size:30px; font-style:italic; font-weight:900; }
.feature h3 { color:#fff; font-size:29px; }.feature p { margin:5px 0 0; color:#c0cee0; font-size:17px; line-height:1.14; }

/* Process */
.process { position:relative; overflow:hidden; background:#fff; }.process::before { content:""; position:absolute; top:70px; left:-100px; width:320px; height:320px; border:34px solid rgba(7,91,233,.07); transform:rotate(45deg); }
.process-grid { position:relative; z-index:1; display:grid; grid-template-columns:repeat(3,1fr); list-style:none; margin:0; padding:0; border-top:3px solid var(--ink); border-bottom:1px solid var(--line); }
.process-grid li { min-height:162px; display:flex; gap:18px; padding:26px 22px 22px 0; }.process-grid li + li { padding-left:22px; border-left:1px solid var(--line); }
.process-grid > li > span { color:var(--orange); font-family:var(--title); font-size:61px; font-style:italic; font-weight:900; line-height:.75; }.process-grid h3 { color:var(--ink); font-size:31px; }.process-grid p { margin:7px 0 0; color:#43536c; font-size:17px; line-height:1.12; }

/* Inquiry */
.inquiry { position:relative; overflow:hidden; color:#fff; background:linear-gradient(108deg,#061126 0%,#09245b 45%,#eff6ff 45%,#fff 100%); }
.inquiry__finish { position:absolute; left:-55px; top:26px; width:370px; height:340px; opacity:.19; transform:rotate(-18deg); background:repeating-conic-gradient(#fff 0 25%,transparent 0 50%) 50%/38px 38px; }
.inquiry__grid { position:relative; display:grid; grid-template-columns:.82fr 1.18fr; gap:64px; align-items:center; }.inquiry__copy { padding:16px 0 16px 10px; }.inquiry__copy h2 { color:#fff; }.inquiry__copy p:not(.kicker) { max-width:420px; margin:22px 0 0; color:#d8e8fa; font-size:20px; line-height:1.2; }.inquiry__call { display:flex; align-items:center; gap:13px; margin-top:30px; }.checkered-mini { width:49px; height:49px; flex:0 0 49px; border:3px solid var(--yellow); background:repeating-conic-gradient(#fff 0 25%,#0a152c 0 50%) 50%/16px 16px; transform:skewX(-15deg); }.inquiry__call strong { display:block; color:var(--yellow); font-family:var(--title); font-size:19px; font-style:italic; letter-spacing:.04em; }.inquiry__call a { display:block; margin-top:3px; color:#fff; font-family:var(--title); font-size:31px; font-style:italic; font-weight:900; line-height:.9; }
.inquiry-form { position:relative; z-index:1; padding:29px; color:var(--ink); background:#fff; border-top:6px solid var(--yellow); box-shadow:16px 16px 0 var(--orange); }.form-header { display:flex; justify-content:space-between; gap:16px; margin-bottom:20px; padding-bottom:15px; border-bottom:2px solid #ccd9ec; color:var(--blue); font-family:var(--title); font-size:17px; font-style:italic; font-weight:900; letter-spacing:.06em; }.form-header b { color:var(--orange); }
.form-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:16px; }.form-grid .full { grid-column:1/-1; }.form-grid label > span { display:block; margin-bottom:6px; color:#152946; font-family:var(--title); font-size:16px; font-style:italic; font-weight:900; letter-spacing:.04em; }.form-grid b { color:var(--orange); }.form-grid input,.form-grid select,.form-grid textarea { width:100%; border:1px solid #9db4d0; border-radius:0; padding:12px 13px; color:var(--ink); background:#f7fbff; font:700 16px var(--body); outline:none; transition:border-color .18s ease, box-shadow .18s ease, background .18s ease; }.form-grid textarea { min-height:106px; resize:vertical; }.form-grid select { appearance:none; background-image:linear-gradient(45deg,transparent 50%,var(--orange) 50%),linear-gradient(135deg,var(--orange) 50%,transparent 50%); background-position:calc(100% - 18px) 19px,calc(100% - 12px) 19px; background-size:6px 6px; background-repeat:no-repeat; }.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus { border-color:var(--blue); background:#fff; box-shadow:4px 4px 0 rgba(7,91,233,.15); }.contact-choice { display:flex; align-items:center; gap:15px; margin:20px 0; padding:0; border:0; }.contact-choice legend { margin-right:9px; padding:0; color:#152946; font-family:var(--title); font-size:16px; font-style:italic; font-weight:900; letter-spacing:.04em; white-space:nowrap; }.contact-choice label { display:inline-flex; align-items:center; gap:5px; cursor:pointer; font-family:var(--title); font-size:16px; font-style:italic; font-weight:900; }.contact-choice input { accent-color:var(--orange); }.inquiry-form__submit { width:100%; }.form-note { margin:13px 0 0; color:#566780; font-size:13px; line-height:1.15; text-align:center; }.form-status { min-height:1.1em; margin:9px 0 0; color:var(--blue); font-size:14px; font-weight:800; text-align:center; }

/* Contact + footer */
.contact { position:relative; overflow:hidden; padding:94px 0; color:#fff; background:linear-gradient(125deg,#061126,#093083 63%,#05132e); }.contact__lines { position:absolute; inset:0; opacity:.30; transform:translateX(38%); background:repeating-linear-gradient(-25deg,transparent 0 60px,rgba(0,191,238,.72) 61px 66px,transparent 67px 125px); }.contact__grid { position:relative; display:grid; grid-template-columns:1.14fr .86fr; align-items:center; gap:70px; }.contact h2 { color:#fff; }.contact p:not(.kicker) { max-width:620px; color:#d5e4f4; font-size:20px; line-height:1.22; }.contact-card { position:relative; overflow:hidden; padding:32px 29px; background:#050b18; border-top:5px solid var(--yellow); box-shadow:15px 15px 0 var(--orange); }.contact-card::before { content:""; position:absolute; width:175px; height:175px; right:-48px; bottom:-54px; border:24px solid rgba(0,191,238,.3); transform:rotate(45deg); }.contact-card > * { position:relative; z-index:1; }.contact-card__flag { width:84px; height:17px; margin-bottom:17px; background:repeating-conic-gradient(#fff 0 25%,#111 0 50%) 50%/17px 17px; transform:skewX(-18deg); }.contact-card > span { display:block; color:var(--electric); font-size:13px; font-weight:900; letter-spacing:.12em; }.contact-card__phone { display:block; margin:4px 0 20px; font-family:var(--title); font-size:clamp(45px,4vw,63px); font-style:italic; font-weight:900; line-height:.9; }.button--full { width:100%; }.contact-card__text { display:block; margin-top:15px; color:var(--yellow); font-family:var(--title); font-size:18px; font-style:italic; font-weight:900; letter-spacing:.05em; text-align:center; }.contact-card__text span { color:var(--orange); }.contact-card p { margin:18px 0 0; color:#a9b9cc !important; font-size:15px !important; line-height:1.14 !important; }
.site-footer { background:#030711; border-top:3px solid var(--yellow); color:#aebfd4; }.site-footer__grid { min-height:134px; display:grid; grid-template-columns:245px 1fr auto; align-items:center; gap:34px; }.footer-logo { display:block; width:245px; }.footer-logo img { width:100%; height:auto; }.footer-center strong { display:block; color:#fff; font-family:var(--title); font-size:19px; font-style:italic; letter-spacing:.04em; }.footer-center p { margin:4px 0 0; font-size:13px; }.back-top { color:var(--yellow); font-size:13px; font-weight:900; letter-spacing:.08em; }
.mobile-action-bar { display:none; }

/* Responsive */
@media (max-width: 1020px) {
  .site-logo { width:198px; flex-basis:198px; }.site-nav { gap:16px; }.hero__layout { gap:30px; }.hero__brand-panel { max-width:455px; }.service-grid { grid-template-columns:repeat(2,1fr); }.service-card { min-height:280px; }.why-cpcp__grid { gap:48px; }.inquiry { background:linear-gradient(180deg,#061126 0%,#0a2d6c 35%,#edf6ff 35%,#fff 100%); }.inquiry__grid { grid-template-columns:1fr; gap:36px; }.inquiry__copy { padding:0 0 10px; }.inquiry__copy p:not(.kicker) { max-width:625px; }.inquiry__finish { left:auto; right:-56px; top:-75px; }.contact__grid { gap:45px; }
}
@media (max-width: 780px) {
  html { scroll-padding-top:80px; } body { padding-bottom:70px; }.announcement-bar__inner { justify-content:center; min-height:30px; }.announcement-bar p { display:none; }.site-header { top:0; }.header__inner { min-height:68px; }.site-logo { width:168px; flex-basis:168px; }.nav-toggle { display:block; }.site-nav { display:none; position:absolute; top:100%; left:0; right:0; padding:15px 20px 20px; background:#061126; border-bottom:3px solid var(--yellow); flex-direction:column; align-items:stretch; gap:15px; }.site-nav.is-open { display:flex; }.site-nav > a { padding:5px 0; }.site-nav > a:not(.nav-call)::after { display:none; }.nav-call { text-align:center; }.hero { min-height:0; }.hero__layout { min-height:0; display:block; padding:46px 0 70px; }.hero__racing-arcs { right:-300px; top:-195px; width:860px; height:580px; opacity:.78; }.hero__finish-line { left:-75px; bottom:50px; width:230px; height:125px; opacity:.78; }.hero__speed-bars { top:44px; left:-92px; opacity:.85; }.hero__copy h1 { font-size:clamp(58px,15vw,85px); }.hero__lede { max-width:530px; font-size:20px; }.hero__proof { max-width:none; margin-top:26px; }.hero__proof strong { font-size:18px; }.hero__proof span { font-size:12px; }.hero__brand-panel { max-width:480px; margin:40px auto 0; padding:21px 16px 13px; box-shadow:10px 10px 0 var(--orange),18px 18px 0 var(--blue); }.brand-panel__caption { font-size:9px; }.service-ticker__track { min-height:39px; font-size:12px; }.section { padding:72px 0; }.section-heading { display:block; margin-bottom:31px; }.section-heading > p { margin-top:16px; }.service-grid { grid-template-columns:1fr; gap:12px; }.service-card { min-height:248px; padding:21px; }.service-card h3 { font-size:39px; }.why-cpcp { padding:74px 0; }.why-cpcp__grid { display:block; }.why-cpcp__content { margin-top:35px; }.why-cpcp__intro { font-size:21px; }.why-cpcp__orange-line { bottom:34px; width:250px; }.process-grid { display:block; }.process-grid li,.process-grid li + li { min-height:0; padding:22px 0; border-left:0; border-bottom:1px solid var(--line); }.process-grid li:last-child { border-bottom:0; }.inquiry { padding-top:70px; padding-bottom:76px; }.inquiry__copy h2 { font-size:clamp(52px,14vw,70px); }.inquiry__copy p:not(.kicker) { font-size:19px; }.inquiry-form { padding:23px 18px; box-shadow:10px 10px 0 var(--orange); }.form-header { font-size:15px; }.form-grid { grid-template-columns:1fr; }.form-grid .full { grid-column:auto; }.contact-choice { flex-wrap:wrap; gap:10px 15px; }.contact-choice legend { flex-basis:100%; }.contact { padding:72px 0; }.contact__grid { display:block; }.contact-card { margin-top:40px; padding:28px 22px; box-shadow:10px 10px 0 var(--orange); }.site-footer__grid { min-height:188px; display:flex; flex-wrap:wrap; align-content:center; gap:10px 22px; }.footer-logo { width:220px; }.footer-center { flex-basis:100%; order:3; }.back-top { margin-left:auto; }.mobile-action-bar { position:fixed; z-index:60; left:0; right:0; bottom:0; height:67px; display:grid; grid-template-columns:repeat(3,1fr); border-top:3px solid var(--yellow); background:#061126; box-shadow:0 -7px 18px rgba(0,0,0,.22); }.mobile-action-bar a { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px; color:#fff; border-right:1px solid rgba(255,255,255,.18); font-family:var(--title); font-size:16px; font-style:italic; font-weight:900; letter-spacing:.05em; }.mobile-action-bar a:last-child { border-right:0; background:var(--orange); }.mobile-action-bar span { color:var(--yellow); font-family:var(--body); font-size:18px; font-style:normal; line-height:1; }.mobile-action-bar a:last-child span { color:#fff; }
}
@media (max-width: 440px) {
  :root { --shell:min(100% - 28px,1180px); }.site-logo { width:154px; flex-basis:154px; }.nav-toggle { width:42px; height:40px; }.hero__actions { display:grid; grid-template-columns:1fr; }.hero__actions .button { width:100%; }.hero__proof > div { padding-right:8px; }.hero__proof > div + div { padding-left:8px; }.hero__proof strong { font-size:15px; }.hero__proof span { font-size:10px; }.brand-panel__caption { display:block; line-height:1.5; }.brand-panel__caption span:last-child { display:block; text-align:left; }.service-card h3 { font-size:37px; }.form-header { font-size:13px; }.contact-card__phone { font-size:44px; }.footer-logo { width:196px; }.footer-center strong { font-size:17px; }
}
@media (prefers-reduced-motion: reduce) { *,*::before,*::after { scroll-behavior:auto!important; animation-duration:.01ms!important; animation-iteration-count:1!important; transition-duration:.01ms!important; } }
