:root{
  --primary:#0F172A;--accent:#2563EB;--accent-2:#38BDF8;--secondary:#1E293B;
  --bg:#F8FAFC;--surface:#fff;--text:#0F172A;--muted:#475569;--border:#E2E8F0;
  --radius:16px;--radius-lg:24px;
  --grad:linear-gradient(135deg,#2563EB 0%,#38BDF8 100%);
  --grad-dark:linear-gradient(135deg,#0F172A 0%,#1E293B 60%,#1e3a8a 100%);
  --shadow-sm:0 2px 6px rgba(15,23,42,.06);
  --shadow:0 12px 32px rgba(15,23,42,.08);
  --shadow-lg:0 24px 60px rgba(15,23,42,.14);
  --shadow-glow:0 20px 50px -10px rgba(37,99,235,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;color:var(--primary);font-weight:700;line-height:1.15;letter-spacing:-.02em}
h1{font-size:clamp(2.5rem,5.5vw,4.75rem)}
h2{font-size:clamp(1.9rem,3.8vw,3rem);margin-bottom:1rem}
h3{font-size:1.4rem;margin-bottom:.5rem}
p{margin-bottom:1rem;color:var(--muted)}
a{color:var(--accent);text-decoration:none;transition:color .2s}
a:hover{color:#1d4ed8}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.wrap{max-width:820px;margin:0 auto;padding:0 1.5rem}

/* Header — glass */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.78);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid rgba(15,23,42,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1.05rem 0;gap:1rem}
.brand{font-family:'Playfair Display',serif;font-weight:700;font-size:1.45rem;color:var(--primary);display:flex;align-items:center;gap:.6rem}
.brand img{width:34px;height:34px;filter:drop-shadow(0 4px 10px rgba(37,99,235,.3))}
.nav ul{display:flex;gap:2rem;list-style:none;flex-wrap:wrap;align-items:center}
.nav a{color:var(--secondary);font-weight:500;font-size:.95rem;position:relative;padding:.3rem 0}
.nav a:hover{color:var(--accent)}
.nav a[aria-current="page"]:after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--grad);border-radius:2px}
.nav .cta{background:var(--primary);color:#fff!important;padding:.55rem 1.1rem;border-radius:999px;font-weight:600}
.nav .cta:hover{background:var(--accent);color:#fff!important}
.menu-btn{display:none;background:none;border:0;font-size:1.6rem;color:var(--primary);cursor:pointer}
@media(max-width:880px){
  .nav ul{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:1rem 1.5rem;gap:.5rem;border-bottom:1px solid var(--border);box-shadow:var(--shadow)}
  .nav ul.open{display:flex}
  .menu-btn{display:block}
}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.95rem 1.85rem;border-radius:999px;font-weight:600;font-size:.98rem;cursor:pointer;border:0;transition:transform .2s,box-shadow .2s,background .2s,color .2s;text-decoration:none;line-height:1}
.btn:hover{transform:translateY(-2px);text-decoration:none}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow-glow)}
.btn-primary:hover{color:#fff;box-shadow:0 28px 60px -10px rgba(37,99,235,.55)}
.btn-outline{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.4);backdrop-filter:blur(6px)}
.btn-outline:hover{background:#fff;color:var(--primary);border-color:#fff}
.btn-dark{background:var(--primary);color:#fff}
.btn-dark:hover{background:var(--accent);color:#fff}
.btn-ghost{background:#fff;color:var(--primary);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

/* Hero */
.hero{position:relative;color:#fff;padding:7rem 0 6rem;overflow:hidden;background:var(--grad-dark)}
.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 80% 20%,rgba(56,189,248,.35),transparent 60%),radial-gradient(50% 60% at 10% 90%,rgba(37,99,235,.4),transparent 60%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3.5rem;align-items:center;position:relative;z-index:1}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;gap:2.5rem}}
.hero .pill{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem 1rem;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);font-size:.8rem;color:#E2E8F0;text-transform:uppercase;letter-spacing:.12em;font-weight:600;margin-bottom:1.5rem}
.hero .pill .dot{width:8px;height:8px;border-radius:50%;background:#38BDF8;box-shadow:0 0 0 4px rgba(56,189,248,.25);animation:pulse 2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 10px rgba(56,189,248,0)}}
.hero h1{color:#fff;max-width:640px;background:linear-gradient(180deg,#fff 30%,#cbd5e1 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{color:#CBD5E1;font-size:1.2rem;max-width:560px;margin:1.5rem 0 2rem}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap}
.hero-meta{display:flex;gap:2rem;margin-top:2.5rem;flex-wrap:wrap;color:#CBD5E1;font-size:.92rem}
.hero-meta strong{color:#fff;font-family:'Playfair Display',serif;font-size:1.6rem;display:block;background:linear-gradient(135deg,#fff,#38BDF8);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-visual{position:relative;height:480px}
.hero-visual .ph{position:absolute;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.1)}
.hero-visual .ph img{width:100%;height:100%;object-fit:cover}
.hero-visual .ph1{top:0;left:0;width:78%;height:75%}
.hero-visual .ph2{bottom:0;right:0;width:55%;height:55%;border:4px solid rgba(15,23,42,.6)}
.hero-visual .badge{position:absolute;bottom:14%;left:-10px;background:#fff;color:var(--primary);padding:.85rem 1.1rem;border-radius:14px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.7rem;font-weight:600;font-size:.9rem;z-index:2}
.hero-visual .badge .ico{width:38px;height:38px;border-radius:10px;background:var(--grad);color:#fff;display:grid;place-items:center;font-size:1.1rem}
@media(max-width:920px){.hero-visual{height:380px}}

/* Trust strip */
.trust{background:#fff;border-bottom:1px solid var(--border)}
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;padding:1.5rem 0}
.trust-grid div{font-weight:600;color:var(--secondary);font-size:.92rem;display:flex;align-items:center;gap:.5rem}
.trust-grid .tick{width:22px;height:22px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-size:.7rem;flex-shrink:0}

/* Sections */
section{padding:6rem 0;position:relative}
.section-head{text-align:center;max-width:720px;margin:0 auto 3.5rem}
.section-head p{font-size:1.15rem}
.eyebrow{display:inline-block;color:var(--accent);font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.78rem;margin-bottom:1rem;padding:.35rem .9rem;background:rgba(37,99,235,.08);border-radius:999px}

/* Service cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.5rem}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:2rem;transition:transform .3s,box-shadow .3s,border-color .3s;display:flex;flex-direction:column;position:relative;overflow:hidden}
.card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card:hover:before{transform:scaleX(1)}
.card .num{font-family:'Playfair Display',serif;font-size:.85rem;color:var(--accent);font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.5rem}
.card .price{font-family:'Playfair Display',serif;font-size:2.4rem;font-weight:700;margin:.5rem 0 1rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.card .price small{font-size:.85rem;color:var(--muted);font-weight:400;font-family:'Inter',sans-serif;-webkit-text-fill-color:var(--muted)}
.card ul{list-style:none;margin:1rem 0;padding:0;flex:1}
.card ul li{padding:.45rem 0 .45rem 1.75rem;position:relative;color:var(--secondary);font-size:.95rem}
.card ul li:before{content:"";position:absolute;left:0;top:.85rem;width:14px;height:8px;border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(-45deg)}
.card .btn{margin-top:1.25rem;width:100%;justify-content:center}

/* Image-led service teaser */
.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
@media(max-width:820px){.media-grid{grid-template-columns:1fr}}
.media{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow)}
.media img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.media:hover img{transform:scale(1.06)}
.media .cap{position:absolute;inset:auto 0 0 0;padding:1.5rem;background:linear-gradient(180deg,transparent,rgba(15,23,42,.85));color:#fff}
.media .cap h3{color:#fff;font-size:1.25rem;margin-bottom:.25rem}
.media .cap span{color:#CBD5E1;font-size:.88rem}

.alt{background:#fff}

/* Split / about */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
@media(max-width:880px){.about-grid{grid-template-columns:1fr;gap:2.5rem}}
.about-visual{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.about-visual img{aspect-ratio:4/5;width:100%;object-fit:cover}
.about-visual .tag{position:absolute;left:1.25rem;bottom:1.25rem;background:rgba(15,23,42,.85);backdrop-filter:blur(10px);color:#fff;padding:.85rem 1.1rem;border-radius:12px;font-size:.88rem;border:1px solid rgba(255,255,255,.15)}
.about-visual .tag strong{color:#38BDF8;display:block;font-size:1.1rem;margin-bottom:.15rem;font-family:'Playfair Display',serif}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}
.stat{padding:1.35rem;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border)}
.stat strong{font-family:'Playfair Display',serif;color:var(--primary);font-size:1.8rem;display:block;margin-bottom:.15rem}
.stat span{color:var(--muted);font-size:.9rem}

/* Process / steps */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}
.step{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;position:relative}
.step .n{font-family:'Playfair Display',serif;font-size:2.5rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;margin-bottom:.75rem;font-weight:700}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2.5rem}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr}}
.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.25rem;box-shadow:var(--shadow-sm)}
form label{display:block;font-weight:600;margin:1rem 0 .4rem;color:var(--secondary);font-size:.92rem}
form input,form textarea{width:100%;padding:.95rem 1.1rem;border:1px solid var(--border);border-radius:12px;font:inherit;background:#fff;color:var(--text);transition:border-color .2s,box-shadow .2s}
form input:focus,form textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 4px rgba(37,99,235,.12)}
form textarea{min-height:140px;resize:vertical}
.contact-info{background:var(--grad-dark);color:#fff;padding:2.5rem;border-radius:var(--radius-lg);position:relative;overflow:hidden}
.contact-info:before{content:"";position:absolute;top:-50%;right:-30%;width:400px;height:400px;background:radial-gradient(circle,rgba(56,189,248,.25),transparent 70%)}
.contact-info>*{position:relative;z-index:1}
.contact-info h3{color:#fff}
.contact-info p{color:#CBD5E1}
.contact-info a{color:#fff;font-weight:500}
.contact-info a:hover{color:#38BDF8}
.contact-info dl{margin-top:1.5rem}
.contact-info dt{font-weight:600;color:#94A3B8;margin-top:1.1rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.12em}
.contact-info dd{margin:.3rem 0 0;color:#fff;font-size:1rem}

/* FAQ */
.faq details{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem 1.4rem;margin-bottom:.75rem;transition:box-shadow .2s,border-color .2s}
.faq details:hover{border-color:rgba(37,99,235,.4)}
.faq summary{cursor:pointer;font-weight:600;color:var(--primary);font-size:1.05rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-size:1.6rem;line-height:1;font-weight:300;transition:transform .2s}
.faq details[open] summary::after{content:"−"}
.faq details[open]{box-shadow:var(--shadow);border-color:var(--accent)}
.faq details p{margin-top:.85rem;color:var(--muted)}

/* Legal */
.legal{padding:5rem 0;background:#fff}
.legal h1{margin-bottom:.5rem}
.legal .updated{color:var(--muted);margin-bottom:2rem;font-size:.95rem}
.legal h2{font-size:1.65rem;margin:2.5rem 0 .85rem;color:var(--primary)}
.legal h3{font-size:1.2rem;margin:1.5rem 0 .5rem}
.legal p,.legal li{color:#334155;font-size:1.02rem;line-height:1.8}
.legal ul,.legal ol{margin:0 0 1rem 1.25rem}
.legal li{margin-bottom:.45rem}

/* Page hero */
.page-hero{background:var(--grad-dark);color:#fff;padding:5rem 0 4rem;position:relative;overflow:hidden}
.page-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(50% 80% at 90% 0%,rgba(56,189,248,.3),transparent 60%)}
.page-hero>div{position:relative;z-index:1}
.page-hero h1{color:#fff}
.page-hero p{color:#CBD5E1;font-size:1.2rem;max-width:680px;margin-top:1rem}
.breadcrumbs{color:#94A3B8;font-size:.85rem;margin-bottom:1rem;letter-spacing:.05em}
.breadcrumbs a{color:#94A3B8}
.breadcrumbs a:hover{color:#fff}

/* CTA band */
.cta-band{background:var(--grad-dark);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-band:before{content:"";position:absolute;inset:0;background:radial-gradient(60% 70% at 50% 100%,rgba(37,99,235,.45),transparent 60%)}
.cta-band>div{position:relative;z-index:1}
.cta-band h2{color:#fff}
.cta-band p{color:#CBD5E1;font-size:1.15rem;margin-bottom:2rem;max-width:620px;margin-left:auto;margin-right:auto}

/* Footer */
footer{background:#0A1020;color:#94A3B8;padding:4rem 0 1.5rem;font-size:.95rem;position:relative;border-top:1px solid #1E293B}
footer h4{color:#fff;font-family:'Inter',sans-serif;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1.25rem;font-weight:700}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.3fr;gap:2.5rem}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-brand{font-family:'Playfair Display',serif;color:#fff;font-size:1.5rem;display:flex;align-items:center;gap:.6rem;margin-bottom:1rem}
.foot-brand img{width:30px;height:30px}
footer ul{list-style:none}
footer li{margin-bottom:.5rem}
footer a{color:#94A3B8}
footer a:hover{color:#38BDF8;text-decoration:none}
.foot-contact{font-style:normal;line-height:1.85}
.foot-contact strong{color:#fff;display:block;margin-bottom:.4rem;font-weight:600}
.foot-bottom{border-top:1px solid #1E293B;margin-top:3rem;padding-top:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.85rem;color:#64748B}

/* 404 */
.notfound{padding:8rem 0;text-align:center;background:var(--grad-dark);color:#fff;min-height:80vh;display:flex;align-items:center;justify-content:center}
.notfound h1{font-size:clamp(5rem,15vw,10rem);background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;margin-bottom:1rem}
.notfound h2{color:#fff}
.notfound p{color:#CBD5E1;font-size:1.1rem;max-width:480px;margin:1rem auto 2rem}

.success{display:none;background:#DCFCE7;color:#166534;padding:1rem 1.25rem;border-radius:12px;margin-top:1.25rem;border:1px solid #86EFAC;font-weight:500}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}
