*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0c1117;--bg2:#111820;--bg3:#182028;
  --steel:#3a7bd5;--steel2:#5a9ae6;--steel3:#2a5fa8;
  --slate:#64748b;--concrete:#94a3b8;--light:#e2e8f0;
  --white:#f8fafc;--accent:#f97316;--accent2:#fb923c;
  --red:#ef4444;--green:#10b981;
  --heading:'Oswald',sans-serif;
  --serif:'Source Serif 4',Georgia,serif;
  --body:'DM Sans',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--bg);color:var(--concrete);line-height:1.7;overflow-x:hidden}

body::after{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");opacity:.5}

.reveal{opacity:0;transform:translateY(25px);transition:opacity .7s ease,transform .7s ease}
.reveal.vis{opacity:1;transform:translateY(0)}

.demo{background:var(--accent);color:#000;text-align:center;padding:.4rem;font-size:.75rem;font-weight:600;letter-spacing:.04em;position:relative;z-index:10000}
.demo a{color:#000;text-decoration:underline}

/* Marquee */
.marquee{position:fixed;top:28px;left:0;right:0;z-index:999;background:var(--bg2);border-bottom:1px solid rgba(58,123,213,.08);overflow:hidden;height:32px;display:flex;align-items:center}
.marquee-track{display:flex;gap:2.5rem;white-space:nowrap;animation:scroll 38s linear infinite;font-family:var(--heading);font-size:.78rem;letter-spacing:.18em;color:var(--steel2);font-weight:500}
.marquee-track .accent{color:var(--accent)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

nav{position:fixed;top:60px;left:0;right:0;z-index:1000;padding:0 3rem;height:60px;display:flex;align-items:center;justify-content:space-between;background:rgba(12,17,23,.92);backdrop-filter:blur(16px);border-bottom:1px solid rgba(58,123,213,.08)}
.nav-logo{font-family:var(--heading);font-size:1.4rem;font-weight:700;color:var(--white);letter-spacing:.08em;text-decoration:none;display:flex;align-items:center;gap:.6rem}
.nav-logo .mark{width:28px;height:28px;background:var(--steel);clip-path:polygon(50% 0%,100% 100%,0% 100%);position:relative}
.nav-logo .mark::after{content:'';position:absolute;inset:0;background:var(--accent);clip-path:polygon(50% 0%,100% 100%,0% 100%);transform:scale(0);transform-origin:center;transition:transform .4s}
.nav-logo:hover .mark::after{transform:scale(.5)}
.nav-mid{display:flex;gap:2.5rem;list-style:none}
.nav-mid a{color:var(--slate);text-decoration:none;font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;transition:color .3s;position:relative}
.nav-mid a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--accent);transition:width .3s}
.nav-mid a:hover{color:var(--steel2)}
.nav-mid a:hover::after{width:100%}
.nav-cta{background:var(--accent);color:#000;padding:.5rem 1.6rem;font-family:var(--heading);font-size:.85rem;font-weight:600;letter-spacing:.1em;text-decoration:none;transition:all .3s;position:relative;overflow:hidden}
.nav-cta::before{content:'';position:absolute;inset:0;background:var(--accent2);transform:translateX(-100%);transition:transform .3s}
.nav-cta:hover::before{transform:translateX(0)}
.nav-cta span{position:relative;z-index:1}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding:9rem 5vw 4rem}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,rgba(58,123,213,.08) 0%,transparent 40%),radial-gradient(ellipse at 80% 30%,rgba(58,123,213,.06),transparent 50%),linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%)}
.hero-slash{position:absolute;right:-5%;top:0;width:50%;height:100%;background:linear-gradient(160deg,transparent 40%,rgba(58,123,213,.03) 40.5%,rgba(58,123,213,.03) 42%,transparent 42.5%);pointer-events:none}
.hero-grid{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 79px,rgba(58,123,213,.015) 79px,rgba(58,123,213,.015) 80px),repeating-linear-gradient(90deg,transparent,transparent 79px,rgba(58,123,213,.015) 79px,rgba(58,123,213,.015) 80px);pointer-events:none}
.hero-content{position:relative;z-index:2;max-width:700px}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(58,123,213,.1);border:1px solid rgba(58,123,213,.2);padding:.4rem 1rem;font-size:.7rem;font-weight:600;letter-spacing:.12em;color:var(--steel2);text-transform:uppercase;margin-bottom:2rem}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--accent);border-radius:50%;animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(249,115,22,.6)}50%{opacity:.7;box-shadow:0 0 0 8px rgba(249,115,22,0)}}
.hero h1{font-family:var(--heading);font-size:clamp(3.5rem,8vw,6.5rem);color:var(--white);line-height:.95;letter-spacing:.02em;margin-bottom:1.5rem;font-weight:700}
.hero h1 .accent{color:var(--steel2);position:relative;display:inline-block}
.hero h1 .accent::after{content:'';position:absolute;bottom:.1em;left:0;right:0;height:.08em;background:var(--accent)}
.hero-desc{font-size:1.05rem;color:var(--concrete);max-width:520px;line-height:1.9;margin-bottom:2.5rem;font-weight:300}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.btn-primary{background:var(--accent);color:#000;padding:1rem 2.5rem;font-family:var(--heading);font-size:1rem;letter-spacing:.12em;font-weight:600;text-decoration:none;transition:all .3s;position:relative;overflow:hidden;border:none;cursor:pointer;display:inline-block}
.btn-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);transform:translateX(-120%);transition:transform .6s}
.btn-primary:hover::before{transform:translateX(120%)}
.btn-primary:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 8px 30px rgba(249,115,22,.25)}
.btn-outline{border:1px solid var(--steel3);color:var(--steel2);padding:1rem 2.5rem;font-family:var(--heading);font-size:1rem;letter-spacing:.12em;text-decoration:none;transition:all .3s;background:transparent;display:inline-block}
.btn-outline:hover{background:rgba(58,123,213,.1);border-color:var(--steel2);transform:translateY(-2px)}

/* TRUST BAR */
.trust{background:var(--bg2);border-top:1px solid rgba(58,123,213,.06);border-bottom:1px solid rgba(58,123,213,.06);padding:2.5rem 5vw}
.trust-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:center;gap:4rem;flex-wrap:wrap;align-items:center}
.trust-item{text-align:center;position:relative}
.trust-item:not(:last-child)::after{content:'';position:absolute;right:-2rem;top:25%;height:50%;width:1px;background:rgba(58,123,213,.15)}
.trust-num{font-family:var(--heading);font-size:2.5rem;color:var(--white);font-weight:700;line-height:1}
.trust-num .plus{color:var(--accent)}
.trust-label{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);margin-top:.25rem}

/* SERVICES */
.services{padding:6rem 5vw;max-width:1200px;margin:0 auto}
.section-tag{font-family:var(--heading);font-size:.75rem;letter-spacing:.25em;color:var(--steel);margin-bottom:.75rem;text-transform:uppercase}
.section-title{font-family:var(--heading);font-size:clamp(2.2rem,4.5vw,3.5rem);color:var(--white);letter-spacing:.02em;margin-bottom:.75rem}
.section-sub{font-family:var(--serif);font-size:1.1rem;color:var(--steel2);font-style:italic;margin-bottom:3.5rem}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(58,123,213,.06)}
.svc-card{background:var(--bg2);padding:2.5rem;position:relative;overflow:hidden;transition:all .4s}
.svc-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .4s}
.svc-card:hover::after{transform:scaleX(1)}
.svc-card:hover{background:var(--bg3);transform:translateY(-4px)}
.svc-icon{width:48px;height:48px;margin-bottom:1.25rem;transition:transform .4s}
.svc-card:hover .svc-icon{transform:translateY(-3px) rotate(-4deg)}
.svc-icon svg{width:100%;height:100%;color:var(--steel)}
.svc-card:hover .svc-icon svg{color:var(--steel2)}
.svc-name{font-family:var(--heading);font-size:1.15rem;color:var(--white);letter-spacing:.06em;margin-bottom:.75rem}
.svc-desc{font-size:.88rem;color:var(--slate);line-height:1.8;font-weight:300;margin-bottom:1rem}
.svc-link{font-family:var(--heading);font-size:.75rem;letter-spacing:.18em;color:var(--accent);text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;transition:gap .3s}
.svc-link:hover{gap:.7rem}

/* WHY US */
.why{padding:6rem 5vw;background:var(--bg2);position:relative}
.why::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,transparent,var(--steel),var(--accent),transparent)}
.why-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.why-visual{position:relative;aspect-ratio:4/3;background:var(--bg3);border:1px solid rgba(58,123,213,.08);overflow:hidden;transition:transform .5s}
.why-visual:hover{transform:scale(1.02)}
.why-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(58,123,213,.1),transparent 60%),linear-gradient(135deg,var(--bg3),var(--bg2))}
.why-visual svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60%;opacity:.1;color:var(--steel)}
.why-visual .badge{position:absolute;bottom:1.5rem;left:1.5rem;background:var(--accent);color:#000;padding:.5rem 1.2rem;font-family:var(--heading);font-size:.8rem;letter-spacing:.1em;font-weight:600}
.why-visual .credit-row{position:absolute;top:1.5rem;right:1.5rem;display:flex;gap:.4rem}
.why-visual .credit{font-size:.55rem;letter-spacing:.15em;text-transform:uppercase;color:var(--steel);font-weight:600;padding:.3rem .55rem;border:1px solid var(--steel3);background:rgba(12,17,23,.7)}
.why-text .point{margin-bottom:2rem;padding-left:1.5rem;border-left:2px solid rgba(58,123,213,.15);transition:all .3s}
.why-text .point:hover{border-left-color:var(--accent);padding-left:1.75rem}
.why-text .point h3{font-family:var(--heading);font-size:1.1rem;color:var(--white);letter-spacing:.06em;margin-bottom:.4rem}
.why-text .point p{font-size:.9rem;color:var(--slate);font-weight:300;line-height:1.8}

/* MATERIALS */
.materials{padding:6rem 5vw;max-width:1200px;margin:0 auto}
.mat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:2rem}
.mat-card{background:var(--bg2);border:1px solid rgba(58,123,213,.08);padding:1.75rem;text-align:center;transition:all .4s;position:relative;overflow:hidden}
.mat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--steel);transform:scaleX(0);transform-origin:right;transition:transform .4s}
.mat-card:hover{border-color:rgba(58,123,213,.3);transform:translateY(-4px);background:var(--bg3)}
.mat-card:hover::before{transform:scaleX(1);transform-origin:left}
.mat-icon{width:60px;height:60px;margin:0 auto 1rem;color:var(--steel2)}
.mat-card h4{font-family:var(--heading);font-size:1rem;color:var(--white);letter-spacing:.1em;margin-bottom:.4rem}
.mat-card .lifespan{font-family:var(--serif);font-size:.85rem;color:var(--accent);font-style:italic;margin-bottom:.75rem}
.mat-card p{font-size:.78rem;color:var(--slate);font-weight:300;line-height:1.6}

/* WORK / GALLERY */
.work{padding:6rem 5vw;max-width:1200px;margin:0 auto}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:240px 240px;gap:6px}
.work-item{position:relative;overflow:hidden;background:var(--bg2);transition:all .4s;cursor:pointer}
.work-item.wide{grid-column:span 2}
.work-item::before{content:'';position:absolute;inset:0;z-index:1;transition:transform .6s}
.work-item:hover::before{transform:scale(1.06)}
.w1::before{background:linear-gradient(135deg,rgba(58,123,213,.12),rgba(17,24,32,.9)),radial-gradient(circle at 40% 60%,rgba(58,123,213,.15),transparent 60%)}
.w2::before{background:linear-gradient(180deg,rgba(249,115,22,.08),rgba(17,24,32,.95)),radial-gradient(ellipse at 50% 40%,rgba(249,115,22,.1),transparent 50%)}
.w3::before{background:linear-gradient(135deg,rgba(17,24,32,.85),rgba(58,123,213,.08)),radial-gradient(circle at 70% 50%,rgba(58,123,213,.12),transparent 40%)}
.w4::before{background:linear-gradient(45deg,rgba(58,123,213,.08),rgba(17,24,32,.9)),radial-gradient(circle at 30% 60%,rgba(249,115,22,.08),transparent 50%)}
.work-item svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40%;opacity:.08;color:var(--steel);z-index:1;transition:opacity .4s,transform .4s}
.work-item:hover svg{opacity:.18;transform:translate(-50%,-50%) scale(1.08)}
.work-item .w-label{position:absolute;bottom:1rem;left:1.2rem;z-index:3;font-family:var(--heading);font-size:.75rem;letter-spacing:.15em;color:var(--steel2)}
.work-item .w-type{position:absolute;top:1rem;right:1.2rem;z-index:3;font-size:.6rem;letter-spacing:.15em;color:var(--accent);text-transform:uppercase;background:rgba(12,17,23,.7);padding:.25rem .55rem;border:1px solid var(--steel3)}
.work-item .w-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(12,17,23,0) 60%,rgba(12,17,23,.95));opacity:0;transition:opacity .35s;display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem;gap:.4rem}
.work-item:hover .w-overlay{opacity:1}
.w-overlay .w-meta{font-family:var(--serif);font-size:.85rem;color:var(--concrete);font-style:italic}

/* TESTIMONIALS */
.testimonials{padding:5rem 5vw;background:var(--bg2);border-top:1px solid rgba(58,123,213,.06)}
.testi-inner{max-width:1100px;margin:0 auto}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.testi-card{background:var(--bg);border:1px solid rgba(58,123,213,.08);padding:2rem;position:relative;transition:all .4s}
.testi-card::before{content:'★★★★★';position:absolute;top:1.5rem;left:2rem;font-size:1rem;color:var(--accent);letter-spacing:.1em}
.testi-card:hover{border-color:rgba(58,123,213,.25);transform:translateY(-3px)}
.testi-card .quote{font-family:var(--serif);font-size:1rem;color:var(--light);line-height:1.7;margin-top:2.5rem;margin-bottom:1.25rem;font-weight:400}
.testi-card .meta{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(58,123,213,.08);padding-top:1rem}
.testi-card .author{font-family:var(--heading);font-size:.85rem;color:var(--white);letter-spacing:.1em}
.testi-card .source{font-size:.7rem;color:var(--slate);letter-spacing:.1em;text-transform:uppercase}

/* CTA */
.cta{padding:8rem 5vw;text-align:center;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(58,123,213,.06),transparent 50%)}
.cta-inner{position:relative;z-index:1}
.cta h2{font-family:var(--heading);font-size:clamp(2.5rem,6vw,5rem);color:var(--white);letter-spacing:.02em;line-height:.95;margin-bottom:1rem}
.cta h2 .accent{color:var(--steel2)}
.cta .sub{font-family:var(--serif);font-size:1.15rem;color:var(--steel2);font-style:italic;margin-bottom:2.5rem}
.cta .phone{font-family:var(--heading);font-size:2.5rem;color:var(--accent);letter-spacing:.08em;text-decoration:none;display:inline-block;margin-top:2rem;transition:color .3s}
.cta .phone:hover{color:var(--accent2)}
.cta .addr{font-size:.82rem;color:var(--slate);margin-top:1rem;font-weight:300}

/* FOOTER */
footer{border-top:1px solid rgba(58,123,213,.06);padding:2.5rem 5vw;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.foot-left{font-size:.75rem;color:var(--slate);font-weight:300}
.foot-right{font-size:.72rem;color:var(--slate)}
.foot-right a{color:var(--steel);text-decoration:none;transition:color .2s}
.foot-right a:hover{color:var(--steel2)}

/* SUB-PAGE / SHARED */
.subhero{padding:11rem 5vw 5rem;text-align:center;background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%);position:relative;overflow:hidden;border-bottom:1px solid rgba(58,123,213,.06)}
.subhero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 30%,rgba(58,123,213,.08),transparent 60%);pointer-events:none}
.subhero-tag{font-family:var(--heading);font-size:.75rem;letter-spacing:.25em;color:var(--steel);margin-bottom:1rem;position:relative;text-transform:uppercase}
.subhero h1{font-family:var(--heading);font-size:clamp(3rem,7vw,5rem);color:var(--white);letter-spacing:.02em;margin-bottom:1rem;position:relative;font-weight:700}
.subhero h1 .accent{color:var(--steel2)}
.subhero p{font-family:var(--serif);font-size:1.15rem;color:var(--steel2);font-style:italic;max-width:600px;margin:0 auto;position:relative}

.crumbs{padding:1.5rem 5vw;font-family:var(--heading);font-size:.75rem;letter-spacing:.15em;color:var(--slate);text-transform:uppercase;font-weight:500}
.crumbs a{color:var(--steel);text-decoration:none;transition:color .3s}
.crumbs a:hover{color:var(--steel2)}

/* SERVICE DETAIL */
.svc-detail{padding:5rem 5vw;max-width:1100px;margin:0 auto}
.svc-block{background:var(--bg2);border:1px solid rgba(58,123,213,.08);margin-bottom:1rem;overflow:hidden;transition:all .4s}
.svc-block:hover{border-color:rgba(58,123,213,.2)}
.svc-block-inner{display:grid;grid-template-columns:200px 1fr;gap:0}
.svc-block-side{background:var(--bg3);padding:2rem;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;border-right:1px solid rgba(58,123,213,.08)}
.svc-block-side .icon{width:60px;height:60px;color:var(--steel);margin-bottom:1rem}
.svc-block-side h3{font-family:var(--heading);font-size:1.1rem;color:var(--white);letter-spacing:.08em;margin-bottom:.5rem}
.svc-block-side .pricing{font-family:var(--serif);font-size:1rem;color:var(--accent);font-style:italic}
.svc-block-body{padding:2rem}
.svc-block-body p{font-size:.95rem;color:var(--concrete);font-weight:300;line-height:1.85;margin-bottom:1rem}
.svc-block-body ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.5rem 1.5rem}
.svc-block-body ul li{font-size:.82rem;color:var(--slate);font-weight:300;padding-left:1.3rem;position:relative}
.svc-block-body ul li::before{content:'✓';position:absolute;left:0;color:var(--accent);font-weight:700}

/* PROCESS */
.process{padding:5rem 5vw;background:var(--bg2);border-top:1px solid rgba(58,123,213,.06)}
.process-inner{max-width:1100px;margin:0 auto}
.process-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:.8rem;margin-top:3rem;position:relative}
.process-steps::before{content:'';position:absolute;top:35px;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,var(--steel3),transparent);z-index:0}
.step{text-align:center;position:relative;z-index:1}
.step-num{width:70px;height:70px;border:1px solid var(--steel3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--heading);font-size:1.5rem;color:var(--steel2);margin:0 auto 1rem;background:var(--bg2);font-weight:600;transition:all .3s}
.step:hover .step-num{background:var(--accent);color:#000;border-color:var(--accent);transform:scale(1.05)}
.step h4{font-family:var(--heading);font-size:.95rem;color:var(--white);letter-spacing:.12em;margin-bottom:.5rem}
.step p{font-size:.78rem;color:var(--slate);font-weight:300;line-height:1.65}

/* FAQ */
.faq{padding:5rem 5vw;max-width:850px;margin:0 auto}
.faq-item{border-bottom:1px solid rgba(58,123,213,.1);padding:1.5rem 0}
.faq-q{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:var(--heading);font-size:1.05rem;color:var(--light);letter-spacing:.05em;transition:color .3s}
.faq-q:hover{color:var(--steel2)}
.faq-q .icon{font-family:var(--heading);font-size:1.5rem;color:var(--accent);line-height:1;transition:transform .3s}
.faq-item.open .faq-q .icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s}
.faq-item.open .faq-a{max-height:300px;padding-top:1rem}
.faq-a p{font-size:.92rem;color:var(--slate);line-height:1.85;font-weight:300}

/* QUOTE FORM */
.quote-form{padding:5rem 5vw;max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.quote-info h2{font-family:var(--heading);font-size:clamp(2rem,3.5vw,2.8rem);color:var(--white);letter-spacing:.02em;margin-bottom:1rem;font-weight:700}
.quote-info .lead{font-family:var(--serif);font-size:1.05rem;color:var(--steel2);font-style:italic;line-height:1.7;margin-bottom:2rem}
.quote-info .point{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.25rem}
.quote-info .point .icon{width:32px;height:32px;background:rgba(58,123,213,.1);border:1px solid rgba(58,123,213,.2);border-radius:50%;color:var(--accent);display:flex;align-items:center;justify-content:center;font-family:var(--heading);font-size:.85rem;flex-shrink:0}
.quote-info .point h4{font-family:var(--heading);font-size:.95rem;color:var(--white);letter-spacing:.08em;margin-bottom:.2rem}
.quote-info .point p{font-size:.85rem;color:var(--slate);font-weight:300;line-height:1.7}

.quote-card{background:var(--bg2);border:1px solid rgba(58,123,213,.1);padding:2.5rem}
.quote-card .step-progress{display:flex;justify-content:space-between;margin-bottom:2rem;position:relative}
.quote-card .step-progress::before{content:'';position:absolute;top:50%;left:5%;right:5%;height:1px;background:rgba(58,123,213,.1);z-index:0}
.qstep{position:relative;z-index:1;background:var(--bg2);padding:0 .5rem}
.qstep .dot{width:32px;height:32px;border:1px solid var(--steel3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--heading);font-size:.78rem;color:var(--slate);background:var(--bg2);transition:all .3s}
.qstep.done .dot{background:var(--accent);color:#000;border-color:var(--accent)}
.qstep.active .dot{background:var(--steel);color:#000;border-color:var(--steel)}
.qstep .lbl{font-family:var(--heading);font-size:.65rem;letter-spacing:.18em;color:var(--slate);margin-top:.4rem;text-align:center}
.qstep.active .lbl,.qstep.done .lbl{color:var(--white)}

.qfield{margin-bottom:1.25rem}
.qfield label{display:block;font-family:var(--heading);font-size:.7rem;letter-spacing:.18em;color:var(--steel);text-transform:uppercase;margin-bottom:.5rem;font-weight:500}
.qfield input,.qfield select,.qfield textarea{width:100%;background:var(--bg);border:1px solid rgba(58,123,213,.15);color:var(--light);padding:.85rem 1rem;font-family:var(--body);font-size:.92rem;transition:border-color .3s}
.qfield input:focus,.qfield select:focus,.qfield textarea:focus{outline:none;border-color:var(--steel)}
.qoptions{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}
.qopt{background:var(--bg);border:1px solid rgba(58,123,213,.15);padding:.85rem;text-align:center;cursor:pointer;font-family:var(--heading);font-size:.78rem;letter-spacing:.1em;color:var(--concrete);transition:all .3s}
.qopt:hover{border-color:var(--steel2)}
.qopt.selected{background:var(--accent);color:#000;border-color:var(--accent)}
.qsubmit{display:block;width:100%;background:var(--accent);color:#000;border:none;padding:1.1rem;font-family:var(--heading);font-size:1rem;letter-spacing:.15em;cursor:pointer;margin-top:1rem;transition:all .3s;font-weight:600}
.qsubmit:hover{background:var(--accent2);box-shadow:0 8px 20px rgba(249,115,22,.2)}
.qmsg{margin-top:1rem;font-size:.85rem;color:var(--green);text-align:center;opacity:0;transition:opacity .3s;letter-spacing:.05em;font-weight:500}
.qmsg.vis{opacity:1}

@media(max-width:900px){
  .marquee{display:none}
  nav{top:28px;padding:0 1.5rem}
  .nav-mid{display:none}
  .trust-inner{gap:2.5rem}
  .trust-item:not(:last-child)::after{display:none}
  .svc-grid{grid-template-columns:1fr}
  .why-inner{grid-template-columns:1fr;gap:3rem}
  .mat-grid{grid-template-columns:repeat(2,1fr)}
  .work-grid{grid-template-columns:1fr;grid-template-rows:repeat(4,180px)}
  .work-item.wide{grid-column:span 1}
  .testi-grid{grid-template-columns:1fr}
  .svc-block-inner{grid-template-columns:1fr}
  .svc-block-side{border-right:none;border-bottom:1px solid rgba(58,123,213,.08)}
  .svc-block-body ul{grid-template-columns:1fr}
  .process-steps{grid-template-columns:repeat(2,1fr);gap:1.5rem}
  .process-steps::before{display:none}
  .quote-form{grid-template-columns:1fr;gap:2rem}
  .qoptions{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .hero h1{font-size:3rem}
  .hero-actions{flex-direction:column;align-items:stretch}
  .trust-inner{flex-direction:column;gap:1.5rem}
}
