:root{-color-primary:#0d1b2a;-color-secondary:#1b263b;-color-accent:#415a77;-color-bg:#e0e5eb;-color-cta:#f4d35e;-color-surface:#f4f7fa;-color-white:#fff;-color-text:#0d1b2a;-color-muted:#4e5f74;-color-error:#b42318;-radius-sm:.7rem;-radius-md:1rem;-radius-lg:1.4rem;-shadow-soft:0 16px 38px #0d1b2a24;-container:min(1120px,92vw);-transition:220ms ease}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Poppins","Inter","Segoe UI",sans-serif;color:var(--color-text);background:radial-gradient(circle at 0% 0%,#415a772e 0%,transparent 38%),radial-gradient(circle at 95% 10%,#0d1b2a1f 0%,transparent 35%),var(--color-bg);line-height:1.55}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,p{margin:0}
ul{margin:0;padding:0;list-style:none}
.container{width:var(--container);margin:0 auto}
.section-space{padding:4.7rem 0}
.section-space-sm{padding:3.2rem 0}
.eyebrow{display:inline-block;margin-bottom:.8rem;font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent)}
.site-header{position:sticky;top:0;z-index:80;backdrop-filter:blur(12px);background-color:#e0e5ebeb;border-bottom:1px solid #415a7733}
.nav-wrap{min-height:4.4rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand-logo{height:2.2rem;width:auto}
.menu-toggle{border:0;background:transparent;cursor:pointer;padding:.25rem;display:inline-flex;flex-direction:column;gap:.3rem}
.menu-toggle span{width:1.45rem;height:2px;border-radius:10px;background:var(--color-primary);transition:var(--transition)}
.main-nav{position:absolute;left:0;right:0;top:4.4rem;display:none;flex-direction:column;gap:.2rem;padding:.9rem 1rem 1rem;background:#e0e5ebfa;border-bottom:1px solid #415a7742}
.main-nav.open{display:flex}
.nav-link{font-size:.95rem;font-weight:500;color:var(--color-secondary);padding:.56rem .24rem}
.nav-link:hover,.nav-link:focus-visible,.nav-link.is-active{color:var(--color-primary)}
.btn{border:0;display:inline-flex;justify-content:center;align-items:center;gap:.4rem;border-radius:999px;padding:.78rem 1.22rem;font-size:.92rem;font-weight:600;transition:transform var(--transition),box-shadow var(--transition),background-color var(--transition)}
.btn:hover,.btn:focus-visible{transform:translateY(-1px)}
.btn-primary{color:var(--color-primary);background-color:var(--color-cta);box-shadow:0 10px 24px #0d1b2a2e}
.btn-secondary{color:var(--color-primary);border:1px solid #0d1b2a33;background-color:var(--color-white)}
.btn-cta{color:var(--color-primary);background:var(--color-cta)}
.btn-nav{margin-top:.4rem}
.btn-full{width:100%}
.hero{position:relative;overflow:clip}
.hero::before{content:"";position:absolute;width:340px;height:340px;right:-170px;top:-90px;border-radius:50%;background:radial-gradient(circle at center,#415a7747,transparent 68%);pointer-events:none}
.hero-grid{display:grid;gap:1.25rem}
.hero-content h1{font-size:clamp(1.85rem,6vw,3rem);line-height:1.12;max-width:16ch}
.hero-subtitle{margin-top:1rem;color:var(--color-muted);max-width:48ch}
.hero-actions{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:.7rem}
.hero-panel{background:linear-gradient(140deg,var(--color-primary),var(--color-secondary));color:var(--color-white);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-soft)}
.hero-panel h2{font-size:1.05rem;margin-bottom:.72rem}
.hero-panel li{position:relative;padding-left:1.1rem;font-size:.95rem;color:#ffffffeb}
.hero-panel li + li{margin-top:.5rem}
.hero-panel li::before{content:"";width:.45rem;height:.45rem;border-radius:50%;background:var(--color-cta);position:absolute;left:0;top:.45rem}
.section-head h2{font-size:clamp(1.45rem,4.5vw,2.15rem);max-width:28ch}
.cards-grid{margin-top:1.8rem;display:grid;gap:1rem}
.card{background:#ffffffd9;border:1px solid #1b263b1a;border-radius:var(--radius-md);padding:1.15rem;box-shadow:0 10px 26px #0d1b2a14}
.icon-wrap{width:2.6rem;height:2.6rem;display:grid;place-content:center;border-radius:.8rem;color:var(--color-primary);background:#f4d35e59}
.icon-wrap svg{width:1.25rem;height:1.25rem}
.card h3{margin-top:.9rem;font-size:1.08rem}
.card p{margin-top:.6rem;color:var(--color-muted)}
.about-block{background:linear-gradient(180deg,#1b263b0a,#1b263b17);border-top:1px solid #0d1b2a14;border-bottom:1px solid #0d1b2a14}
.about-grid{display:grid;gap:1rem}
.about-grid h2{font-size:clamp(1.38rem,4.4vw,2rem);margin-bottom:.9rem}
.about-grid p{color:var(--color-muted);max-width:56ch}
.about-highlight{border-radius:var(--radius-md);padding:1.3rem;background:linear-gradient(130deg,#0d1b2aeb,#415a77e6)}
.about-highlight p{color:#fffffff2;margin:0}
.page-hero h1{font-size:clamp(1.8rem,5.8vw,2.8rem);line-height:1.16;max-width:20ch}
.page-hero p{color:var(--color-muted);margin-top:.9rem;max-width:58ch}
.service-detail-grid{display:grid;gap:1rem}
.service-detail{background:#ffffffe6;border:1px solid #1b263b21;border-radius:var(--radius-md);padding:1.2rem}
.service-detail h2{font-size:1.18rem}
.service-detail p{margin-top:.65rem;color:var(--color-muted)}
.service-detail ul{margin-top:.9rem;list-style:disc;padding-left:1.1rem}
.service-detail li + li{margin-top:.42rem}
.contact-grid{display:grid;gap:1rem}
.contact-card,.contact-info{background:#ffffffe6;border:1px solid #1b263b21;border-radius:var(--radius-md);padding:1.2rem}
.contact-card h2,.contact-info h2{font-size:1.22rem}
.contact-card p,.contact-info p{margin-top:.6rem;color:var(--color-muted)}
.contact-form{margin-top:1rem}
.form-group + .form-group{margin-top:.9rem}
.form-group label{display:block;font-size:.88rem;font-weight:500;margin-bottom:.35rem}
input,textarea{width:100%;border-radius:.75rem;border:1px solid #1b263b3d;background:#f8fafc;padding:.75rem .85rem;font-family:inherit;font-size:.95rem;color:var(--color-text);transition:border-color var(--transition),box-shadow var(--transition)}
input:focus,textarea:focus{outline:none;border-color:#415a77f2;box-shadow:0 0 0 3px #415a7729}
input.is-invalid,textarea.is-invalid{border-color:var(--color-error)}
.field-error{display:block;font-size:.76rem;min-height:1rem;margin-top:.25rem;color:var(--color-error)}
.form-status{margin-top:.7rem;font-size:.88rem;font-weight:500;min-height:1.25rem}
.form-status.error{color:var(--color-error)}
.form-status.success{color:#067647}
.contact-info ul{margin-top:1rem}
.contact-info li + li{margin-top:.65rem}
.contact-info a{color:var(--color-accent);text-decoration:underline;text-decoration-thickness:1px}
.cta-band-wrap{border-radius:var(--radius-md);background:linear-gradient(120deg,var(--color-secondary),var(--color-primary));color:var(--color-white);padding:1.35rem;display:flex;flex-direction:column;gap:.9rem;align-items:flex-start}
.cta-band-wrap p{font-size:1.04rem;font-weight:500}
.site-footer{padding:1.25rem 0;border-top:1px solid #1b263b2e;background:#ffffff8c}
.footer-wrap{display:grid;gap:.7rem;justify-items:start}
.footer-wrap p{color:var(--color-muted);font-size:.88rem}
.wa-float{position:fixed;right:1rem;bottom:1rem;z-index:85;background:var(--color-cta);color:var(--color-primary);font-weight:700;border-radius:999px;padding:.78rem 1rem;box-shadow:0 14px 26px #0d1b2a38}
.reveal{opacity:0;transform:translateY(18px);transition:opacity 400ms ease,transform 400ms ease}
.reveal.is-visible{opacity:1;transform:none}
@media (min-width: 768px) {
.section-space{padding:5.6rem 0}
.menu-toggle{display:none}
.main-nav{position:static;display:flex;flex-direction:row;gap:1rem;align-items:center;border:0;background:transparent;padding:0}
.btn-nav{margin-top:0}
.hero-grid{grid-template-columns:calc(60% - 0.5rem) calc(40% - 0.5rem);align-items:center}
.cards-3{grid-template-columns:calc((100% - 2rem) / 3) calc((100% - 2rem) / 3) calc((100% - 2rem) / 3)}
.about-grid{grid-template-columns:calc(58% - 0.5rem) calc(42% - 0.5rem);align-items:stretch}
.service-detail-grid{grid-template-columns:calc((100% - 1rem) / 2) calc((100% - 1rem) / 2)}
.service-detail:last-child{grid-column:1 / -1}
.contact-grid{grid-template-columns:calc(60% - 0.5rem) calc(40% - 0.5rem);align-items:start}
.cta-band-wrap{flex-direction:row;align-items:center;justify-content:space-between}
.footer-wrap{grid-template-columns:auto auto auto;justify-content:space-between;align-items:center}
}
@media (min-width: 1024px) {
.brand-logo{height:2.45rem}
.hero-panel{padding:1.55rem}
.card,.service-detail,.contact-card,.contact-info{padding:1.45rem}
}