:root {
    --qpu-primary: #0B5FFF;
    --qpu-primary-dark: #082B72;
    --qpu-secondary: #1C78FF;
    --qpu-ink: #15284C;
    --qpu-muted: #5B6578;
    --qpu-line: #D6DCE7;
    --qpu-bg: #F2F2F2;
    --qpu-white: #FFFFFF;
    --qpu-success: #0F8B4C;
    --qpu-error: #B42318;
    --qpu-info: #0F5BC1;
    --qpu-radius: 2px;
    --qpu-shadow: 0 0 0 rgba(0,0,0,0);
    --qpu-container: 1200px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.qpu-theme,
body {
    margin: 0;
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--qpu-ink);
    background: #ededed;
    line-height: 1.5;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--qpu-primary); text-decoration: none; }
a:hover { color: var(--qpu-primary-dark); }
.qpu-container { width: min(100% - 60px, var(--qpu-container)); margin-inline: auto; }
.qpu-skip-link {
    position: absolute; left: -999px; top: 12px; background: var(--qpu-ink); color: #fff; padding: 10px 14px; z-index: 9999;
}
.qpu-skip-link:focus { left: 12px; }
.screen-reader-text { border:0; clip: rect(1px,1px,1px,1px); clip-path: inset(50%); height:1px; margin:-1px; overflow:hidden; padding:0; position:absolute; width:1px; }

.qpu-site-header {
    position: sticky; top: 0; z-index: 100; background: #fff; border-bottom: 1px solid #d7dce6;
}
.admin-bar .qpu-site-header { top: 32px; }
.qpu-header-inner { min-height: 88px; display: flex; align-items: center; gap: 22px; }
.qpu-brand { flex: 0 0 auto; display: flex; align-items: center; }
.qpu-logo img, .custom-logo-link img { width: 255px; max-height: 72px; object-fit: contain; }
.qpu-primary-nav { margin-left: auto; }
.qpu-menu { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; gap: 18px; }
.qpu-menu a { color: var(--qpu-ink); font-weight: 700; font-size: 0.95rem; padding: 4px 0; }
.qpu-menu .current-menu-item > a, .qpu-menu a:hover { color: var(--qpu-primary); }
.qpu-menu-toggle { display: none; width: 44px; height: 44px; border: 1px solid var(--qpu-line); background: #fff; cursor: pointer; }
.qpu-menu-toggle span:not(.screen-reader-text) { display: block; height: 2px; background: var(--qpu-ink); margin: 5px 0; }

.qpu-button,
button.qpu-button,
input[type="submit"].qpu-button {
    display: inline-flex; align-items: center; justify-content: center; border: 0; background: var(--qpu-primary); color: #fff; padding: 14px 28px; font-weight: 800; cursor: pointer; transition: background .15s ease;
}
.qpu-button:hover { color: #fff; background: var(--qpu-primary-dark); }
.qpu-button-light { background: #fff; color: var(--qpu-primary-dark); }
.qpu-button-light:hover { background: #f2f6ff; color: var(--qpu-primary-dark); }
.qpu-button-wide { width: 100%; }

.qpu-home-hero {
    min-height: 370px; background-size: cover; background-position: center; display: flex; align-items: center; border-bottom: 1px solid #d7dce6;
}
.qpu-hero-card {
    width: min(100%, 470px); background: linear-gradient(135deg, rgba(3,32,86,.98), rgba(4,27,69,.97)); color: #fff; padding: 34px 42px; margin: 46px 0;
}
.qpu-hero-card h1 { font-size: clamp(2.3rem, 4vw, 4rem); line-height: .98; margin: 0 0 18px; letter-spacing: -.05em; }
.qpu-hero-card p { margin: 0 0 24px; font-size: 1.15rem; color: rgba(255,255,255,.85); }

.qpu-section { padding: 28px 0; }
.qpu-center-title { text-align: center; font-size: clamp(2rem, 3vw, 3.2rem); line-height: 1.05; letter-spacing: -.05em; margin: 0 0 26px; }

.qpu-features-band { background: #efefef; }
.qpu-feature-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; }
.qpu-feature-card { text-align: center; padding: 10px 18px 0; }
.qpu-feature-icon { width: 64px; height: 64px; border: 2px solid rgba(11,95,255,.45); display: grid; place-items: center; margin: 0 auto 16px; color: var(--qpu-primary); font-size: 1.6rem; }
.qpu-feature-card h3 { margin: 0 0 8px; font-size: 1.25rem; }
.qpu-feature-card p { margin: 0; color: var(--qpu-muted); font-size: .98rem; }

.qpu-mosaic-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; }
.qpu-mosaic-panel { min-height: 250px; border: 1px solid #d7dce6; overflow: hidden; }
.qpu-mosaic-cta { background: linear-gradient(135deg, var(--qpu-primary), var(--qpu-secondary)); color: #fff; padding: 42px 42px; display:flex; flex-direction:column; justify-content:center; }
.qpu-mosaic-cta h2 { margin: 0 0 16px; font-size: clamp(2rem, 3vw, 3rem); line-height: 1.02; letter-spacing: -.05em; max-width: 8ch; }
.qpu-mosaic-cta p { margin: 0 0 24px; max-width: 26ch; color: rgba(255,255,255,.87); }
.qpu-mosaic-image img { width: 100%; height: 100%; object-fit: cover; }
.qpu-mosaic-dark { background: #08254f; color: #fff; padding: 34px 30px; display:flex; flex-direction:column; justify-content:center; }
.qpu-mosaic-dark h3 { margin: 0 0 12px; font-size: 2rem; line-height:1.05; letter-spacing:-.04em; }
.qpu-mosaic-dark p { color: rgba(255,255,255,.86); margin: 0 0 14px; }
.qpu-mini-checks { list-style:none; padding:0; margin: 8px 0 0; display:grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.qpu-mini-checks li { padding-left: 20px; position: relative; font-weight: 600; }
.qpu-mini-checks li::before { content:'✓'; position:absolute; left:0; color: var(--qpu-primary); font-weight:800; }

.qpu-services-section { background: #efefef; }
.qpu-services-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.qpu-service-card { display:grid; grid-template-columns: 56px 1fr 16px; gap:16px; align-items:center; background:#fff; border:1px solid #d7dce6; padding:20px 18px; }
.qpu-service-icon { width: 50px; height: 50px; display:grid; place-items:center; color: var(--qpu-primary); font-size: 1.6rem; }
.qpu-service-card h3 { margin:0 0 4px; font-size:1.12rem; }
.qpu-service-card p { margin:0; color:var(--qpu-muted); font-size:.95rem; }
.qpu-service-card span { font-size: 2rem; color: var(--qpu-ink); line-height:1; }

.qpu-quote-strip { display:grid; grid-template-columns: 400px 1fr; border:1px solid #d7dce6; background:#fff; }
.qpu-quote-intro { background: linear-gradient(135deg, var(--qpu-primary), var(--qpu-secondary)); color:#fff; padding: 32px 36px; position:relative; }
.qpu-quote-intro h2 { font-size: clamp(2rem,3vw,3rem); line-height:1.02; letter-spacing:-.05em; margin:0 0 14px; max-width:9ch; }
.qpu-quote-intro p { margin:0; max-width: 28ch; color: rgba(255,255,255,.88); }
.qpu-sa-map { width: 175px; height: 110px; border: 2px solid rgba(255,255,255,.5); border-top-left-radius: 80px 60px; border-top-right-radius: 60px 40px; border-bottom-left-radius: 40px 30px; border-bottom-right-radius: 90px 65px; transform: skewX(-12deg) rotate(-4deg); margin: 28px auto 0; opacity: .65; position: relative; }
.qpu-sa-map::before, .qpu-sa-map::after { content:''; position:absolute; background:#fff; width:10px; height:10px; border-radius:50%; }
.qpu-sa-map::before { left:30px; top:45px; }
.qpu-sa-map::after { right:35px; top:30px; }
.qpu-quote-calculator-wrap { padding: 24px 26px; }
.qpu-compact-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 16px; }
.qpu-field { margin: 0; }
.qpu-field label { display:block; font-size:.82rem; font-weight:700; margin-bottom: 6px; color: var(--qpu-ink); }
input[type="text"], input[type="email"], input[type="tel"], input[type="number"], input[type="date"], input[type="time"], select, textarea {
    width:100%; border:1px solid #ccd3df; background:#fff; padding: 11px 12px; font: inherit; color: var(--qpu-ink);
}
textarea { resize: vertical; }
input:focus, select:focus, textarea:focus { outline:none; border-color: var(--qpu-primary); }
.qpu-compact-grid-bottom { align-items: end; margin-top: 12px; grid-template-columns: 1.2fr 1fr 220px; }
.qpu-estimate-box { border: 1px solid #bcc9dc; background: #edf4ff; padding: 18px; text-align:center; }
.qpu-estimate-box span { display:block; font-size:.8rem; font-weight:700; color: var(--qpu-ink); text-transform: uppercase; letter-spacing: .04em; }
.qpu-estimate-box strong { display:block; margin: 8px 0 4px; font-size: 2.4rem; line-height: 1; letter-spacing: -.05em; }
.qpu-estimate-box small { color: var(--qpu-muted); }
.qpu-compact-actions { display:flex; justify-content: space-between; align-items: center; gap: 18px; margin-top: 18px; }
.qpu-calc-breakdown-hidden { display:none; }
.qpu-rate-date { margin:0; color: var(--qpu-muted); font-size:.86rem; }

.qpu-testimonials-section { background-size: cover; background-position:center; position:relative; }
.qpu-testimonials-section::before { content:''; position:absolute; inset:0; background: rgba(6,25,61,.78); }
.qpu-testimonials-section .qpu-container { position: relative; }
.qpu-testimonial-heading { text-align:center; color:#fff; margin-bottom: 18px; }
.qpu-testimonial-heading h2 { margin:0 0 6px; font-size: clamp(2rem,3vw,3rem); line-height:1.02; letter-spacing:-.04em; }
.qpu-testimonial-heading p { margin:0; color: rgba(255,255,255,.8); }
.qpu-testimonial-grid { display:grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.qpu-testimonial-card { background:#fff; border: 1px solid #d7dce6; padding: 28px 26px; }
.qpu-testimonial-card p { margin:0 0 16px; font-size:1rem; }
.qpu-testimonial-card strong { display:block; color: var(--qpu-primary-dark); }
.qpu-testimonial-card span { color: var(--qpu-muted); font-size:.9rem; }

.qpu-booking-card, .qpu-card, .qpu-content-wrap, .qpu-post-card, .qpu-tracking-form { background:#fff; border:1px solid #d7dce6; }
.qpu-booking-card { padding: 28px; }
.qpu-booking-heading h2 { font-size: clamp(2rem,3vw,3rem); line-height:1.02; letter-spacing:-.04em; margin:0 0 10px; }
.qpu-booking-heading p { margin:0 0 18px; color: var(--qpu-muted); }
.qpu-form-grid { display:grid; grid-template-columns: repeat(2, 1fr); gap: 14px 16px; }
.qpu-field-full { grid-column: 1 / -1; }
.qpu-checkbox-field { display:flex; align-items:center; }
.qpu-checkbox-field label { display:flex; align-items:center; gap:10px; margin:0; }
.qpu-alert { padding:14px 16px; margin-bottom:16px; font-weight:700; }
.qpu-alert-success { background: rgba(15,139,76,.08); color: var(--qpu-success); }
.qpu-alert-error { background: rgba(180,35,24,.08); color: var(--qpu-error); }
.qpu-alert-info { background: rgba(15,91,193,.08); color: var(--qpu-info); }
.qpu-inline-form { display:flex; gap:10px; flex-wrap:wrap; }
.qpu-inline-form input { flex:1 1 240px; }

.qpu-page-hero { background:#fff; border-bottom:1px solid #d7dce6; padding: 50px 0 24px; }
.qpu-page-hero h1 { margin:0; font-size: clamp(2.1rem, 3vw, 3rem); line-height:1.05; letter-spacing:-.04em; }
.qpu-page-hero .qpu-eyebrow { color: var(--qpu-primary); text-transform: uppercase; letter-spacing:.08em; font-weight:800; font-size:.78rem; }
.qpu-content-wrap, .qpu-post-card { padding: 28px; }
.qpu-post-list { display:grid; gap:16px; }
.qpu-post-meta { color: var(--qpu-muted); }

.qpu-site-footer { background:#08254f; color:#fff; }
.qpu-footer-grid { display:grid; grid-template-columns: 360px 1fr; gap: 0; }
.qpu-footer-contact { padding: 32px 36px; }
.qpu-footer-contact h2 { margin:0 0 16px; font-size: clamp(2rem, 3vw, 3rem); line-height:1.02; letter-spacing:-.04em; }
.qpu-contact-list { list-style:none; padding:0; margin:0 0 24px; display:grid; gap:8px; color: rgba(255,255,255,.88); }
.qpu-footer-building img { width:100%; height:100%; object-fit:cover; min-height: 230px; }
.qpu-footer-bottom { border-top:1px solid rgba(255,255,255,.15); padding: 16px 0 22px; color: rgba(255,255,255,.76); }
.qpu-footer-bottom p { margin:0; }

@media (max-width: 1100px) {
    .qpu-feature-grid { grid-template-columns: repeat(2,1fr); }
    .qpu-services-grid { grid-template-columns: repeat(2,1fr); }
    .qpu-quote-strip { grid-template-columns: 1fr; }
    .qpu-footer-grid { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
    .admin-bar .qpu-site-header { top: 46px; }
    .qpu-menu-toggle { display:inline-flex; align-items:center; justify-content:center; }
    .qpu-primary-nav { position:absolute; left:20px; right:20px; top: calc(100% + 8px); background:#fff; border:1px solid #d7dce6; padding:12px; opacity:0; pointer-events:none; }
    .qpu-primary-nav.is-open { opacity:1; pointer-events:auto; }
    .qpu-menu { flex-direction:column; align-items:flex-start; gap:12px; }
    .qpu-header-cta { margin-left:auto; }
    .qpu-mosaic-grid, .qpu-testimonial-grid, .qpu-services-grid, .qpu-form-grid, .qpu-compact-grid, .qpu-compact-grid-bottom { grid-template-columns: 1fr; }
    .qpu-mini-checks { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
    .qpu-container { width: min(100% - 30px, var(--qpu-container)); }
    .qpu-logo img, .custom-logo-link img { width: 210px; }
    .qpu-header-inner { min-height: 78px; gap: 12px; }
    .qpu-home-hero { min-height: auto; }
    .qpu-hero-card { padding: 24px 24px; width: 100%; }
    .qpu-feature-grid { grid-template-columns: 1fr; gap: 18px; }
    .qpu-compact-actions { flex-direction: column; align-items:flex-start; }
    .qpu-compact-grid-bottom { margin-top: 0; }
}
