:root{--c1:#2a2566;--c2:#f3efe2;--c3:#e45f2b;--text:#1b1b1b;--text-inv:#ffffff}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:var(--c2)}
.wrap{max-width:1120px;margin:0 auto;padding:1.25rem}
.site-header{background:linear-gradient(135deg,var(--c1),#201d50);color:var(--text-inv)}
.site-header .wrap{display:grid;gap:.75rem;grid-template-columns:1fr;align-items:center}
.brand{font-weight:700;color:var(--text-inv);font-size:1.125rem;text-decoration:none}
.nav a{color:var(--text-inv);text-decoration:none;margin-right:.75rem}
.nav a.active{text-decoration:underline}
.meta{display:flex;gap:1rem;flex-wrap:wrap;font-size:.95rem;opacity:.9}
.meta-item i{margin-right:.35rem}
.hero{background:linear-gradient(135deg,var(--c1),#5238bf);color:var(--text-inv)}
.hero-grid{display:grid;gap:2rem;grid-template-columns:1.1fr .9fr;align-items:center}
.hero h1{font-size:2.4rem;line-height:1.15;margin:0 0 .75rem}
.hero p{opacity:.95}
.hero-visual{position:relative}
.hero .decor{position:absolute;inset:-12% auto auto -12%;width:220px;height:220px;background:radial-gradient(circle at 30% 30%,var(--c3),transparent 60%);filter:blur(10px);border-radius:50%}
.hero-visual img{width:100%;border-radius:18px;box-shadow:0 18px 60px rgba(0,0,0,.25)}
.btn{display:inline-block;background:var(--c3);color:var(--text-inv);padding:.85rem 1.1rem;border-radius:12px;text-decoration:none;font-weight:600;border:0}
.stripe{background:#fff}
.content{background:var(--c2)}
.content.alt{background:#fff}
.grid-2{display:grid;gap:2rem;grid-template-columns:1fr 1fr;align-items:center}
.panel{background:#fff;border-radius:16px;box-shadow:0 8px 30px rgba(0,0,0,.08);padding:1rem}
.panel img{width:100%;border-radius:12px}
.cards{display:grid;gap:1.25rem;grid-template-columns:repeat(3,1fr)}
.card{background:#fff;border-radius:16px;padding:1.25rem;box-shadow:0 8px 24px rgba(0,0,0,.06)}
.card h3{margin:.25rem 0 .5rem}
.stats{background:linear-gradient(135deg,#ffffff,rgba(255,255,255,.6))}
.stat{background:#fff;border-radius:16px;padding:1.25rem;text-align:center;box-shadow:0 6px 18px rgba(0,0,0,.05)}
.stat-num{font-weight:700;font-size:1.6rem;color:var(--c1)}
.steps{background:#fff}
.stepper{display:grid;gap:.75rem;counter-reset:s}
.stepper li{list-style:none;background:var(--c2);padding:.9rem 1rem;border-radius:12px;position:relative}
.stepper li:before{counter-increment:s;content:counter(s);position:absolute;left:.6rem;top:.55rem;background:var(--c1);color:#fff;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-weight:700;transform:translateX(-120%)}
.cta{background:linear-gradient(135deg,var(--c1),#1d1848);color:#fff}
.cta h2{margin-top:0}
.cta .grid-2{grid-template-columns:1.3fr .7fr}
.cta .panel.panel-accent{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25)}
.contact{background:#fff}
.form{display:grid;gap:1rem;max-width:760px; grid-template-columns: minmax(0,1fr)}
.form-row{display:grid;gap:.35rem}
input,textarea{padding:.85rem 1rem;border-radius:12px;border:1px solid #d5d5d5;background:#fff;font:inherit}
textarea{resize:vertical}
.contact-meta{margin-top:1rem;opacity:.85}
.page-hero{background:#fff;padding:2.5rem 0}
.page-hero h1{margin:.25rem 0 0}
.gallery{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}
.legal-page h1{margin-top:1.2rem}
.site-footer{background:#0e0d2a;color:#cfd1ff;margin-top:2rem}
.footer-grid{display:grid;gap:1.5rem;grid-template-columns:1.3fr .7fr .7fr}
.foot-links{margin:0;padding:0;list-style:none}
.foot-links li{margin:.25rem 0}
.foot-links a{color:#cfd1ff;text-decoration:none}
.legal{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(255,255,255,.15);padding:.9rem 0;margin-top:1rem}
.thanks{min-height:60vh;display:grid;place-items:center;text-align:center}
@media (max-width:980px){
    .hero-grid,.grid-2,.cards,.footer-grid{grid-template-columns:1fr}
    .meta{display:none}
}

.hero{
    overflow: hidden;
}

section,.site-footer{
    overflow: hidden;
}

img{
    max-width: 100%;
}


.site-footer a{
    color: #fff;
}