:root{
  --navy:#0d3b66;
  --navy-deep:#082a4d;
  --blue:#2a7fc1;
  --sky:#5aa9e6;
  --red:#c0392b;
  --ink:#13202e;
  --ink-soft:#4a5a6a;
  --cream:#f4f8fc;
  --cream-2:#e7f0f9;
  --white:#ffffff;
  --line:rgba(13,59,102,.12);
  --shadow:0 18px 50px -18px rgba(13,59,102,.35);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;color:var(--ink);background:var(--cream);line-height:1.6;overflow-x:hidden}
h1,h2,h3{font-family:'Manrope',sans-serif;line-height:1.1;font-weight:800;letter-spacing:-.025em}
h4{font-family:'Manrope',sans-serif;font-weight:700;letter-spacing:-.01em}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.accent{color:var(--blue)}

/* ---------- Topbar ---------- */
.topbar{background:var(--navy-deep);color:#dceaf6;font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:42px;gap:16px}
.dot{width:7px;height:7px;border-radius:50%;background:#5ad17e;box-shadow:0 0 0 3px rgba(90,209,126,.25)}
.topbar .hours{display:flex;align-items:center;gap:7px}
.topbar .area{opacity:.75}
@media(max-width:680px){.topbar .area{display:none}}

/* ---------- Nav ---------- */
header.nav{position:sticky;top:0;z-index:50;background:var(--cream);box-shadow:0 1px 0 var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:84px}
.logo img{height:54px;width:auto;display:block}
nav.menu{display:flex;align-items:center;gap:28px}
nav.menu a{font-size:.92rem;font-weight:500;color:var(--ink-soft);transition:color .2s}
nav.menu a:hover,nav.menu a.active{color:var(--blue)}
.btn{display:inline-flex;align-items:center;gap:9px;background:var(--navy);color:#fff;padding:13px 22px;border-radius:999px;font-weight:600;font-size:.92rem;transition:transform .2s,box-shadow .2s;box-shadow:0 10px 24px -8px rgba(13,59,102,.6);cursor:pointer;border:none}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px -8px rgba(13,59,102,.7)}
.btn.ghost{background:transparent;color:var(--ink);box-shadow:none;border:1.5px solid var(--line)}
.btn.ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn.wa{background:#1ebe5d;box-shadow:0 10px 24px -8px rgba(30,190,93,.6)}
.btn.wa:hover{box-shadow:0 16px 30px -8px rgba(30,190,93,.7)}
.menu-btn{display:none;background:none;border:none;cursor:pointer;width:42px;height:42px}
.menu-btn span{display:block;width:24px;height:2px;background:var(--ink);margin:5px auto;transition:.3s}
@media(max-width:980px){
  nav.menu{position:fixed;inset:84px 0 auto 0;flex-direction:column;background:var(--cream);padding:24px;gap:18px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .35s;align-items:stretch}
  nav.menu.open{transform:translateY(0)}
  .menu-btn{display:block}.nav .cta-desk{display:none}
}

/* ---------- Hero ---------- */
.hero{position:relative;padding:74px 0 90px;overflow:hidden}
.hero::before{content:"";position:absolute;top:-180px;right:-160px;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(90,169,230,.30),transparent 65%);filter:blur(10px)}
.hero::after{content:"";position:absolute;bottom:-200px;left:-140px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(192,57,43,.12),transparent 68%)}
.hero-grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.pill{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);padding:8px 16px;border-radius:999px;font-size:.8rem;font-weight:600;color:var(--ink-soft);box-shadow:var(--shadow)}
.pill .dot{background:var(--blue);box-shadow:0 0 0 3px rgba(42,127,193,.2)}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.2rem);margin:22px 0 18px}
.hero p.lead{font-size:1.12rem;color:var(--ink-soft);max-width:480px;margin-bottom:30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-stats{display:flex;gap:34px;margin-top:42px;flex-wrap:wrap}
.hero-stats .num{font-family:'Manrope';font-size:2rem;font-weight:800;color:var(--navy)}
.hero-stats small{color:var(--ink-soft);font-size:.82rem}
.hero-card{position:relative;background:linear-gradient(160deg,var(--navy),var(--navy-deep));border-radius:28px;padding:36px;color:#eaf3fb;box-shadow:0 40px 80px -30px rgba(8,42,77,.7)}
.hero-card h3{font-size:1.5rem;color:#fff;margin-bottom:6px}
.hero-card .sub{font-size:.88rem;opacity:.7;margin-bottom:26px}
.call-row{display:flex;align-items:center;gap:16px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:18px 20px;margin-bottom:14px;transition:background .2s}
.call-row:hover{background:rgba(255,255,255,.12)}
.call-row .ic{width:46px;height:46px;border-radius:12px;background:var(--blue);display:grid;place-items:center;flex-shrink:0}
.call-row .ic svg{width:22px;height:22px}
.call-row .big{font-family:'Manrope';font-size:1.45rem;font-weight:700;color:#fff;line-height:1}
.call-row .lbl{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;opacity:.6}
.badge-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
.badge-row span{font-size:.74rem;background:rgba(90,169,230,.16);color:var(--sky);padding:6px 12px;border-radius:999px;font-weight:600}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr;gap:40px}.hero{padding:48px 0 64px}}
@media(max-width:560px){.hero-cta{flex-direction:column;align-items:stretch}.hero-cta .btn{justify-content:center}}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;padding:54px 0 46px;overflow:hidden;background:linear-gradient(160deg,var(--cream-2),var(--cream))}
.page-hero::before{content:"";position:absolute;top:-160px;right:-140px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(90,169,230,.28),transparent 66%);filter:blur(8px)}
.page-hero .wrap{position:relative}
.crumb{font-size:.82rem;color:var(--ink-soft);margin-bottom:16px}
.crumb a:hover{color:var(--blue)}
.crumb span{opacity:.5;margin:0 8px}
.page-hero h1{font-size:clamp(2rem,4.6vw,3.2rem);max-width:780px;margin-bottom:14px}
.page-hero p{color:var(--ink-soft);max-width:620px;font-size:1.05rem}

/* ---------- Brands marquee ---------- */
.brands{background:var(--navy-deep);padding:26px 0;overflow:hidden}
.brands .track{display:flex;gap:56px;align-items:center;animation:scroll 26s linear infinite;white-space:nowrap;width:max-content}
.brands .track span{font-family:'Manrope';font-size:1.5rem;font-weight:600;color:rgba(220,234,246,.55)}
@keyframes scroll{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.brands .track{animation:none}}

/* ---------- Sections ---------- */
section{padding:88px 0}
.eyebrow{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
.sec-title{font-size:clamp(2rem,4vw,2.9rem);max-width:680px}
.sec-head{margin-bottom:52px}
.sec-head p{color:var(--ink-soft);max-width:600px;margin-top:14px}

/* ---------- Service cards ---------- */
.services{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:34px 30px;transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden;display:flex;flex-direction:column}
.card::after{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--navy),var(--sky));transform:scaleX(0);transform-origin:left;transition:transform .35s}
.card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.card:hover::after{transform:scaleX(1)}
.card .ic{width:60px;height:60px;border-radius:16px;background:linear-gradient(150deg,rgba(13,59,102,.1),rgba(90,169,230,.14));display:grid;place-items:center;margin-bottom:22px}
.card .ic svg{width:30px;height:30px;stroke:var(--navy)}
.card h3{font-size:1.4rem;margin-bottom:10px}
.card p{color:var(--ink-soft);font-size:.94rem;margin-bottom:18px;flex-grow:1}
.card .more{font-weight:600;color:var(--blue);font-size:.9rem;display:inline-flex;gap:6px;align-items:center}
@media(max-width:760px){.services{grid-template-columns:1fr}}

/* ---------- Why / features ---------- */
.why{background:var(--white)}
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.feat{background:var(--cream);border-radius:18px;padding:28px 24px;text-align:center}
.feat .ic{width:54px;height:54px;margin:0 auto 16px;border-radius:14px;background:#fff;display:grid;place-items:center;box-shadow:var(--shadow)}
.feat .ic svg{width:26px;height:26px;stroke:var(--blue)}
.feat h4{font-family:'Manrope';font-size:1.12rem;margin-bottom:6px}
.feat p{font-size:.85rem;color:var(--ink-soft)}
@media(max-width:760px){.feat-grid{grid-template-columns:1fr 1fr}}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.step{position:relative;padding-top:18px}
.step .n{font-family:'Manrope';font-size:3.2rem;font-weight:700;color:rgba(13,59,102,.16);line-height:1}
.step h4{font-size:1.25rem;margin:8px 0}
.step p{color:var(--ink-soft);font-size:.92rem}
@media(max-width:760px){.steps{grid-template-columns:1fr}}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;border-radius:30px;padding:54px;display:flex;justify-content:space-between;align-items:center;gap:30px;box-shadow:0 30px 60px -24px rgba(13,59,102,.6);position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;top:-80px;right:-40px;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.1)}
.cta-band h2{font-size:2rem;color:#fff;position:relative}
.cta-band p{opacity:.92;margin-top:8px;position:relative}
.cta-band .cta-actions{display:flex;gap:12px;flex-wrap:wrap;position:relative}
.cta-band .btn{background:#fff;color:var(--navy)}
.cta-band .btn.wa{background:#1ebe5d;color:#fff}
@media(max-width:760px){.cta-band{flex-direction:column;text-align:center;padding:40px 28px}.cta-band .cta-actions{justify-content:center}}

/* ---------- FAQ ---------- */
.faq-item{background:#fff;border:1px solid var(--line);border-radius:16px;margin-bottom:14px;overflow:hidden}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:22px 26px;cursor:pointer;font-family:'Manrope';font-size:1.1rem;font-weight:700;letter-spacing:-.01em}
.faq-q .plus{width:28px;height:28px;flex-shrink:0;border-radius:50%;background:rgba(42,127,193,.12);display:grid;place-items:center;color:var(--blue);font-size:1.2rem;transition:transform .3s}
.faq-item.open .plus{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease;color:var(--ink-soft);font-size:.94rem}
.faq-a div{padding:0 26px 24px}
.faq-item.open .faq-a{max-height:600px}

/* ---------- Article / prose ---------- */
.article{background:#fff}
.prose{max-width:760px;margin:0 auto}
.prose .meta{font-size:.82rem;color:var(--ink-soft);margin-bottom:26px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.prose .meta .tag{background:var(--cream-2);color:var(--navy);padding:4px 12px;border-radius:999px;font-weight:600}
.prose h2{font-size:1.7rem;margin:38px 0 14px;color:var(--ink)}
.prose h3{font-size:1.3rem;margin:28px 0 10px}
.prose p{color:var(--ink-soft);margin-bottom:16px}
.prose ul,.prose ol{color:var(--ink-soft);margin:0 0 18px 22px}
.prose li{margin-bottom:9px}
.prose strong{color:var(--ink)}
.prose .lead-p{font-size:1.15rem;color:var(--ink);margin-bottom:24px}
.callout{background:var(--cream);border-left:4px solid var(--blue);border-radius:0 14px 14px 0;padding:20px 24px;margin:26px 0}
.callout strong{color:var(--navy)}
.code-table{width:100%;border-collapse:collapse;margin:22px 0;font-size:.92rem}
.code-table th,.code-table td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line)}
.code-table th{background:var(--cream-2);font-family:'Manrope';color:var(--navy)}
.code-table td:first-child{font-weight:700;color:var(--navy);white-space:nowrap}

/* ---------- Blog list cards ---------- */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-card{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.post-card .thumb{height:8px;background:linear-gradient(90deg,var(--navy),var(--sky))}
.post-card .body{padding:26px;display:flex;flex-direction:column;flex-grow:1}
.post-card .tag{align-self:flex-start;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);margin-bottom:12px}
.post-card h3{font-size:1.22rem;margin-bottom:10px;line-height:1.25}
.post-card p{color:var(--ink-soft);font-size:.92rem;flex-grow:1;margin-bottom:16px}
.post-card .more{font-weight:600;color:var(--blue);font-size:.9rem}
@media(max-width:880px){.posts{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.posts{grid-template-columns:1fr}}

/* ---------- Service detail two-column ---------- */
.svc-layout{display:grid;grid-template-columns:1fr 340px;gap:44px;align-items:start}
.svc-side{position:sticky;top:108px;background:linear-gradient(160deg,var(--navy),var(--navy-deep));border-radius:24px;padding:30px;color:#eaf3fb;box-shadow:0 30px 60px -28px rgba(8,42,77,.6)}
.svc-side h4{color:#fff;font-size:1.2rem;margin-bottom:6px}
.svc-side .sub{opacity:.7;font-size:.86rem;margin-bottom:20px}
.svc-side ul{list-style:none;margin:20px 0 0}
.svc-side li{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;margin-bottom:12px;opacity:.92}
.svc-side li svg{width:18px;height:18px;flex-shrink:0;margin-top:2px;stroke:var(--sky)}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 8px}
.chips span{background:#fff;border:1px solid var(--line);padding:8px 14px;border-radius:999px;font-size:.84rem;font-weight:600;color:var(--navy)}
@media(max-width:900px){.svc-layout{grid-template-columns:1fr}.svc-side{position:static}}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px;display:flex;gap:18px;align-items:flex-start}
.contact-card .ic{width:52px;height:52px;border-radius:14px;background:linear-gradient(150deg,rgba(13,59,102,.1),rgba(90,169,230,.14));display:grid;place-items:center;flex-shrink:0}
.contact-card .ic svg{width:24px;height:24px;stroke:var(--navy)}
.contact-card h4{font-size:1.1rem;margin-bottom:4px}
.contact-card p,.contact-card a{color:var(--ink-soft);font-size:.94rem}
.contact-card a:hover{color:var(--blue)}
.map-embed{margin-top:28px;border-radius:20px;overflow:hidden;border:1px solid var(--line);height:360px}
.map-embed iframe{width:100%;height:100%;border:0}
@media(max-width:680px){.contact-grid{grid-template-columns:1fr}}

/* ---------- Internal link grid ---------- */
.link-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.link-grid a{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px 22px;display:flex;justify-content:space-between;align-items:center;gap:12px;transition:border-color .2s,transform .2s}
.link-grid a:hover{border-color:var(--blue);transform:translateY(-3px)}
.link-grid a span:first-child{font-family:'Manrope';font-weight:700;color:var(--ink)}
.link-grid a span:last-child{color:var(--blue);font-size:1.2rem}
@media(max-width:680px){.link-grid{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:#dbe6f0;padding:64px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(219,230,240,.12)}
footer h5{font-family:'Plus Jakarta Sans';font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;opacity:.55;margin-bottom:18px}
footer .flist a,footer .flist p{display:block;color:rgba(219,230,240,.8);font-size:.92rem;margin-bottom:10px;transition:color .2s}
footer .flist a:hover{color:var(--sky)}
.foot-logo img{height:46px;margin-bottom:14px;filter:brightness(0) invert(1);opacity:.95}
.foot-desc{color:rgba(219,230,240,.6);font-size:.9rem;max-width:320px}
.copy{text-align:center;padding-top:26px;font-size:.82rem;opacity:.5}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr}}

/* ---------- FAB ---------- */
.fab-wrap{position:fixed;bottom:22px;right:22px;z-index:60;display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.fab{display:flex;align-items:center;gap:10px;color:#fff;padding:14px 20px;border-radius:999px;font-weight:600;box-shadow:0 14px 30px -8px rgba(13,59,102,.8)}
.fab.call{background:var(--navy);animation:pulse 2.4s infinite}
.fab.whatsapp{background:#1ebe5d;box-shadow:0 14px 30px -8px rgba(30,190,93,.8)}
.fab svg{width:20px;height:20px}
@keyframes pulse{0%,100%{box-shadow:0 14px 30px -8px rgba(13,59,102,.8)}50%{box-shadow:0 14px 40px -4px rgba(13,59,102,.95)}}
@media(prefers-reduced-motion:reduce){.fab.call{animation:none}}
@media(max-width:560px){.fab span.lbl{display:none}.fab{padding:15px}}

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

/* ---------- Focus visibility ---------- */
a:focus-visible,button:focus-visible,.btn:focus-visible{outline:3px solid var(--sky);outline-offset:3px;border-radius:6px}
