/* Start custom CSS */@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@700&family=Inter:wght@400;500;600;700&display=swap');

/* ── Tokens ── */
:root {
  --lila-50:#F5F0FA; --lila-100:#E8DDEF; --lila-200:#D4C0E3;
  --lila-300:#B898D4; --lila-400:#9B6FC4; --lila-500:#7E4DB3;
  --lila-600:#6A3D9A; --lila-700:#553180; --lila-800:#3E2360;
  --lila-900:#271540;
  --neutral-900:#1A1A2E; --neutral-700:#4A4A5A; --neutral-600:#5A5A6A;
  --neutral-500:#7A7A8A; --neutral-400:#9A9AAA; --neutral-300:#C8C8D4;
  --neutral-200:#DEDEE8; --neutral-100:#EDEDF2;
  --white-warm:#FAF8FC; --white-pure:#FFFFFF;
  --whatsapp:#25D366; --success:#2ECC71; --error:#E74C3C;
  --font-heading:'DM Sans','Inter',system-ui,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,sans-serif;
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px;
  --space-5:24px; --space-6:32px; --space-7:48px; --space-8:64px;
  --space-9:80px; --space-10:120px;
  --radius-sm:6px; --radius-md:8px; --radius-lg:12px; --radius-xl:16px; --radius-full:9999px;
  --shadow-sm:0 1px 4px rgba(30,30,46,.06);
  --shadow-md:0 4px 16px rgba(30,30,46,.08);
  --shadow-lg:0 8px 30px rgba(126,77,179,.12);
  --shadow-xl:0 16px 48px rgba(126,77,179,.18);
  --transition-fast:.18s ease;
  --transition-base:.28s ease;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
img,svg{display:block;max-width:100%}
button,input,textarea,select{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* ── Base ── */
body{
  font:400 17px/1.65 var(--font-body);
  color:var(--neutral-700);
  background-color:var(--white-warm);
  overflow-x:hidden;
  background-image:
    radial-gradient(ellipse at 20% 0%,rgba(126,77,179,.04) 0%,transparent 60%),
    radial-gradient(ellipse at 80% 100%,rgba(126,77,179,.03) 0%,transparent 50%);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--neutral-900);font-weight:700;-webkit-font-smoothing:antialiased}
h1{font-size:54px;line-height:1.08;letter-spacing:-.02em}
h2{font-size:44px;line-height:1.15;letter-spacing:-.01em}
h3{font-size:30px;line-height:1.2}
h4{font-size:22px;line-height:1.3}
h5{font-size:18px;line-height:1.35;font-weight:700}
p+p{margin-top:var(--space-4)}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-5)}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:var(--space-2);font:600 15px/1 var(--font-body);border-radius:var(--radius-md);cursor:pointer;border:none;transition:all .25s ease}
.btn-primary{background:var(--lila-500);color:#fff;padding:14px 32px}
.btn-primary:hover{background:var(--lila-600);transform:translateY(-2px);box-shadow:0 6px 20px rgba(126,77,179,.3)}
.btn-primary:active{transform:translateY(0)}
.btn-secondary{background:transparent;color:var(--lila-500);padding:14px 30px;border:2px solid var(--lila-300)}
.btn-secondary:hover{background:var(--lila-50);border-color:var(--lila-500)}

/* ── Badge ── */
.badge{display:inline-block;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--lila-500);margin-bottom:var(--space-4);padding:6px 14px;background:var(--lila-50);border-radius:var(--radius-full);border:1px solid var(--lila-200)}

/* ── Section shared ── */
.section{padding:var(--space-9) 0}
.section-alt{background:var(--lila-50)}
.section-header{text-align:center;max-width:700px;margin:0 auto var(--space-8)}
.section-header h2{margin-bottom:var(--space-4)}
.section-header p{font-size:18px;color:var(--neutral-500);line-height:1.7;margin:0}
.lila-text{color:var(--lila-600)}

/* ── Page Hero ── */
.page-hero{position:relative;min-height:70vh;display:flex;align-items:center;background:linear-gradient(135deg,var(--lila-900) 0%,#1e0f30 55%,#0e0820 100%);overflow:hidden;padding:var(--space-10) 0 var(--space-9)}
.ph-bg{position:absolute;inset:0;pointer-events:none}
.ph-glow{position:absolute;border-radius:50%;filter:blur(80px)}
.ph-glow-1{width:600px;height:600px;top:-150px;left:-100px;background:radial-gradient(circle,rgba(126,77,179,.25) 0%,transparent 70%)}
.ph-glow-2{width:400px;height:400px;bottom:-100px;right:10%;background:radial-gradient(circle,rgba(155,111,196,.15) 0%,transparent 70%)}
.ph-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px}
.ph-inner{position:relative;z-index:2;max-width:820px;padding-top:40px}
.page-hero h1{color:#fff;font-weight:700;margin-bottom:var(--space-6);-webkit-font-smoothing:antialiased}
.ph-accent{color:var(--lila-300)}
.ph-body{font-size:18px;line-height:1.7;color:rgba(255,255,255,.75);max-width:700px}
.ph-body strong{color:rgba(255,255,255,.95)}
.ph-ctas{display:flex;gap:var(--space-4);flex-wrap:wrap;margin-top:var(--space-7)}
.page-hero .btn-secondary{color:#fff;border-color:rgba(255,255,255,.35)}
.page-hero .btn-secondary:hover{background:rgba(255,255,255,.1);border-color:#fff}

/* ── Trust Strip ── */
.svc-strip{background:var(--lila-800);border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
.svc-strip-list{display:flex;align-items:center;justify-content:center;flex-wrap:nowrap;padding:var(--space-4) 0}
.svc-strip-list li{display:flex;align-items:center;gap:var(--space-2);font:500 14px/1 var(--font-body);color:rgba(255,255,255,.72);padding:var(--space-2) var(--space-6);border-right:1px solid rgba(255,255,255,.1);white-space:nowrap}
.svc-strip-list li:last-child{border-right:none}
.strip-diamond{color:var(--lila-400);font-size:10px;flex-shrink:0}

/* ── Service Tab Nav ── */
.svc-tab-nav{display:flex;align-items:center;gap:var(--space-2);border-bottom:2px solid var(--neutral-200);margin-bottom:var(--space-8);position:sticky;top:80px;background:var(--white-warm);z-index:50;padding:var(--space-3) 0 0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;transition:box-shadow .25s ease}
.svc-tab-nav.is-stuck{box-shadow:0 3px 12px rgba(30,30,46,.08)}
.svc-tab-nav::-webkit-scrollbar{display:none}
.svc-tab{font:600 14px/1 var(--font-body);color:var(--neutral-500);padding:var(--space-2) var(--space-4) var(--space-3);border-radius:var(--radius-sm) var(--radius-sm) 0 0;white-space:nowrap;position:relative;bottom:-2px;border-bottom:2px solid transparent;transition:color .2s ease,border-color .2s ease;text-decoration:none}
.svc-tab:hover{color:var(--lila-600)}
.svc-tab.active{color:var(--lila-600);border-bottom-color:var(--lila-500)}
.svc-tab::after{display:none !important}

/* ── Service Blocks ── */
.svc-blocks{display:flex;flex-direction:column;gap:var(--space-5)}
.svc-block{background:var(--white-pure);border:0.7px solid var(--lila-400);border-radius:var(--radius-xl);padding:var(--space-7) var(--space-8);position:relative;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s ease,box-shadow .3s ease}
.svc-block:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.svc-block-tinted{background:var(--lila-50);border-color:var(--lila-500)}
.svc-block-deco{position:absolute;right:var(--space-7);top:50%;transform:translateY(-50%);font:800 160px/1 var(--font-heading);color:var(--lila-100);pointer-events:none;user-select:none;opacity:.45}
.svc-block-tinted .svc-block-deco{color:var(--lila-200)}
.svc-block-top{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5)}
.svc-icon-ring{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--lila-50);border:1.5px solid var(--lila-200);color:var(--lila-500);flex-shrink:0;transition:background .3s ease,color .3s ease,border-color .3s ease}
.svc-block:hover .svc-icon-ring{background:var(--lila-500);color:#fff;border-color:var(--lila-500)}
.svc-category-tag{font:700 12px/1 var(--font-heading);letter-spacing:1.2px;text-transform:uppercase;color:var(--lila-500);background:var(--lila-50);border:1px solid var(--lila-200);padding:5px 12px;border-radius:var(--radius-full)}
.svc-block-tinted .svc-category-tag{background:var(--white-pure)}
.svc-block-content{position:relative;z-index:1}
.svc-block-content h3{font-size:32px;color:var(--neutral-900);margin-bottom:var(--space-4)}
.svc-lead{font-size:19px;line-height:1.65;color:var(--neutral-700);margin-bottom:var(--space-4)}
.svc-block-content p{font-size:17px;line-height:1.7;color:var(--neutral-600)}
.svc-list{margin:var(--space-4) 0;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3) var(--space-6)}
.svc-list li{display:flex;align-items:flex-start;gap:var(--space-2);font-size:16px;line-height:1.5;color:var(--neutral-700)}
.svc-list li::before{content:'';flex-shrink:0;margin-top:7px;width:8px;height:8px;border-radius:50%;background:var(--lila-400)}
.svc-list-ordered{counter-reset:svc-counter}
.svc-list-ordered li{counter-increment:svc-counter}
.svc-list-ordered li::before{content:counter(svc-counter);background:var(--lila-500);color:#fff;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font:700 11px/1 var(--font-body);margin-top:1px}
.svc-callout{font:600 18px/1.45 var(--font-body);color:var(--lila-700);padding:var(--space-4) var(--space-5);background:var(--lila-50);border-left:3px solid var(--lila-500);border-radius:0 var(--radius-md) var(--radius-md) 0;margin-top:var(--space-5)}
.svc-block-tinted .svc-callout{background:var(--white-pure)}
.svc-block-footer{position:relative;z-index:1;margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--neutral-200)}
.svc-block-tinted .svc-block-footer{border-top-color:var(--lila-200)}
.svc-cta-link{display:inline-flex;align-items:center;gap:var(--space-2);font:600 15px/1 var(--font-body);color:var(--lila-600);transition:color .2s ease,gap .25s ease}
.svc-cta-link span{transition:transform .25s ease}
.svc-cta-link:hover{color:var(--lila-800);gap:var(--space-3)}
.svc-cta-link:hover span{transform:translateX(4px)}

/* ── Additional Services ── */
.add-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5);margin-bottom:var(--space-8)}
.add-card{background:var(--white-pure);border:1px solid var(--neutral-100);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);box-shadow:var(--shadow-sm);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease}
.add-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--lila-200)}
.add-card-icon{width:48px;height:48px;border-radius:var(--radius-lg);background:var(--lila-50);border:1px solid var(--lila-100);display:flex;align-items:center;justify-content:center;color:var(--lila-500);flex-shrink:0;transition:background .3s ease,color .3s ease,border-color .3s ease}
.add-card:hover .add-card-icon{background:var(--lila-500);color:#fff;border-color:var(--lila-500)}
.add-card h4{font-size:19px;color:var(--neutral-900);line-height:1.2;margin:0}
.add-card p{font-size:15px;line-height:1.65;color:var(--neutral-500);margin:0;flex-grow:1}
.add-cta{text-align:center;padding-top:var(--space-4)}

/* ── Trust Pledge ── */
.pledge-section{background:var(--neutral-900);position:relative;overflow:hidden}
.pledge-section::before{content:'';position:absolute;top:-200px;right:-100px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(126,77,179,.12) 0%,transparent 65%);pointer-events:none}
.pledge-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-8);align-items:center}
.pledge-left h2{color:#fff;font-size:44px;line-height:1.1;margin-bottom:var(--space-5)}
.pledge-left .lila-text{color:var(--lila-300)}
.pledge-intro{font-size:17px;line-height:1.7;color:rgba(255,255,255,.6);margin-bottom:var(--space-6)}
.pledge-quote-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);padding:var(--space-6)}
.pledge-quote-card .quote-icon{color:var(--lila-400);margin-bottom:var(--space-3);opacity:.8}
.pledge-quote-card p{font-size:17px;line-height:1.65;color:rgba(255,255,255,.72);margin:0;font-style:italic}
.pledge-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);overflow:hidden}
.pledge-item{display:flex;align-items:flex-start;gap:var(--space-5);padding:var(--space-6)}
.pledge-item-icon{width:44px;height:44px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:rgba(126,77,179,.2);border:1px solid rgba(126,77,179,.3);color:var(--lila-300);transition:background .3s ease,color .3s ease}
.pledge-item:hover .pledge-item-icon{background:var(--lila-500);color:#fff}
.pledge-item h5{font-size:17px;color:#fff;margin-bottom:var(--space-2)}
.pledge-item p{font-size:15px;line-height:1.6;color:rgba(255,255,255,.55);margin:0}
.pledge-divider{height:1px;background:rgba(255,255,255,.08);margin:0 var(--space-6)}

/* ── FAQ ── */
.faq-list{max-width:860px;margin:0 auto;display:flex;flex-direction:column;width:100%;overflow:hidden}
.faq-item{border-bottom:1px solid var(--neutral-200)}
.faq-item:first-child{border-top:1px solid var(--neutral-200)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);width:100%;padding:var(--space-5) 0;background:none;border:none;cursor:pointer;text-align:left;overflow:hidden}
.faq-q span{font:600 18px/1.35 var(--font-body);color:var(--neutral-900);transition:color .2s ease;flex:1;text-transform:none;letter-spacing:normal;word-break:break-word;overflow-wrap:break-word;white-space:normal}
.faq-q:hover span{color:var(--lila-600)}
.faq-chevron{flex-shrink:0;color:var(--neutral-400);transition:transform .3s ease,color .3s ease}
.faq-item.open .faq-chevron{transform:rotate(180deg);color:var(--lila-500)}
.faq-a{padding:0 var(--space-7) var(--space-5) 0}
.faq-a p{font-size:16px;line-height:1.7;color:var(--neutral-600)}
.faq-a[hidden]{display:none}

/* ── Contact ── */
.conversion{background:linear-gradient(135deg,var(--lila-800),var(--lila-900),#1e0f30);padding:var(--space-10) 0}
.contact-box{display:flex;background:var(--white-pure);border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.25);max-width:1100px;margin:0 auto}
.contact-info{flex:0 0 40%;background:var(--lila-50);padding:var(--space-8);display:flex;flex-direction:column}
.contact-info h2{font-size:44px;color:var(--lila-900);margin-bottom:var(--space-4);line-height:1.1}
.contact-info p{font-size:16px;color:var(--neutral-600);line-height:1.6;margin-bottom:var(--space-7)}
.contact-details{display:flex;flex-direction:column;gap:var(--space-5);margin-top:auto}
.detail-item{display:flex;flex-direction:column;gap:4px}
.detail-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--lila-400)}
.detail-link,.detail-text{font-size:18px;font-weight:500;color:var(--lila-900);text-decoration:none}
.detail-link:hover{color:var(--lila-600)}
.map-wrapper{margin-top:var(--space-7);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--neutral-200);box-shadow:var(--shadow-sm);transition:transform .3s ease,box-shadow .3s ease}
.map-wrapper:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.map-wrapper iframe{display:block}
.contact-form-side{flex:1;padding:var(--space-8);background:var(--white-pure)}
.premium-form{display:flex;flex-direction:column;gap:var(--space-5)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}
.input-wrapper{position:relative;background:var(--white-pure)}
.input-wrapper input,.input-wrapper textarea,.input-wrapper select{width:100%;background:transparent;border:none;border-bottom:2px solid var(--neutral-200);padding:24px 0 8px;font-size:16px;font-family:var(--font-body);color:var(--neutral-900);transition:border-color .3s ease;border-radius:0;appearance:none;-webkit-appearance:none}
.input-wrapper input:focus,.input-wrapper textarea:focus,.input-wrapper select:focus{outline:none;border-bottom-color:var(--lila-500)}
.input-wrapper label{position:absolute;top:16px;left:0;font-size:16px;color:var(--neutral-500);pointer-events:none;transition:all .3s cubic-bezier(.34,1.56,.64,1);transform-origin:left top}
.input-wrapper input:focus ~ label,.input-wrapper input:not(:placeholder-shown) ~ label,.input-wrapper textarea:focus ~ label,.input-wrapper textarea:not(:placeholder-shown) ~ label,.input-wrapper select:focus ~ label,.input-wrapper select:valid ~ label{transform:translateY(-16px) scale(.75);color:var(--lila-500);font-weight:600}
.select-wrapper{position:relative}
.select-arrow{position:absolute;right:0;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--neutral-400);transition:transform .3s ease}
.input-wrapper select:focus ~ .select-arrow{transform:translateY(-50%) rotate(180deg);color:var(--lila-500)}
.btn-submit{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-3);background:var(--lila-600);color:#fff;border:none;padding:18px 32px;font-size:16px;font-weight:600;border-radius:var(--radius-full);cursor:pointer;transition:all .3s ease;margin-top:var(--space-4);align-self:flex-start}
.btn-submit:hover{background:var(--lila-700);transform:translateY(-2px);box-shadow:0 8px 24px rgba(106,61,154,.3)}
.btn-submit svg{transition:transform .3s ease}
.btn-submit:hover svg{transform:translateX(4px) translateY(-4px)}
.trust-micro-note{font-size:13px;color:var(--neutral-500);margin-top:var(--space-3);display:block}
#message{min-height:180px;resize:vertical}

/* ── Scroll Reveal ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease-out,transform .6s ease-out}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
@keyframes rippleAnim{to{transform:scale(4);opacity:0}}

/* ── Responsive ── */
@media(max-width:1024px){
  .pledge-layout{grid-template-columns:1fr;gap:var(--space-6)}
  .add-grid{grid-template-columns:repeat(2,1fr)}
  .svc-block-deco{font-size:120px;right:var(--space-5)}
}
@media(max-width:768px){
  h1{font-size:36px}h2{font-size:30px}h3{font-size:24px}
  body{font-size:16px}
  .page-hero{min-height:auto;padding:calc(var(--space-10) + 20px) 0 var(--space-7)}
  .ph-body{font-size:16px}
  .ph-ctas{flex-direction:column;align-items:flex-start}
  .ph-ctas .btn{width:100%;justify-content:center}
  .svc-strip-list{flex-wrap:wrap;justify-content:center}
  .svc-strip-list li{border-right:none;padding:var(--space-2) var(--space-4);font-size:13px}
  .svc-block{padding:var(--space-5)}
  .svc-block-deco{display:none}
  .svc-block-content h3{font-size:24px}
  .svc-lead{font-size:17px}
  .svc-list{grid-template-columns:1fr}
  .add-grid{grid-template-columns:1fr}
  .pledge-left h2{font-size:30px}
  .contact-box{flex-direction:column}
  .contact-info{padding:var(--space-6)}
  .contact-form-side{padding:var(--space-6)}
  .form-row{grid-template-columns:1fr;gap:var(--space-5)}
  .faq-q span{font-size:16px}
  .faq-a{padding-right:0}
  /* Nav mobile */
  .nav-links a:not(.btn){color:#fff !important}
  .nav-dropdown-trigger{color:#fff !important;text-transform:none !important}
}
@media(max-width:480px){
  h1{font-size:28px}
  .page-hero{padding-top:100px}
  .faq-a{padding-right:0}
}/* End custom CSS */