/* ============================================
   Velaris — shared stylesheet
   Edit here once; affects every page.
   ============================================ */

:root{
  --navy:#0E1B2A;
  --navy-2:#13263A;
  --slate:#475569;
  --slate-light:#64748B;
  --paper:#F8FAFC;
  --line:#E2E8F0;
  --accent:#14B8A6;
  --accent-deep:#0D9488;
  --display:'Fraunces',Georgia,serif;
  --body:'Archivo',system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--navy);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 40px}

/* ---------- BUTTONS ---------- */
.btn{display:inline-block;font-family:var(--body);font-weight:600;font-size:15px;padding:13px 26px;border-radius:4px;text-decoration:none;cursor:pointer;transition:all .2s;border:none}
.btn-primary{background:var(--accent-deep);color:#fff}
.btn-primary:hover{background:var(--accent);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--paper);border:1px solid rgba(248,250,252,.35)}
.btn-ghost:hover{border-color:var(--paper);background:rgba(248,250,252,.08)}
.btn-outline{background:transparent;color:var(--navy);border:1px solid var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}

/* ---------- NAV ---------- */
header.nav{position:sticky;top:0;z-index:50;background:rgba(248,250,252,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{font-family:var(--display);font-weight:600;font-size:23px;letter-spacing:.04em;color:var(--navy);text-decoration:none}
.logo span{color:var(--accent-deep)}
nav ul{display:flex;gap:34px;list-style:none;align-items:center}
nav a{text-decoration:none;color:var(--slate);font-size:15px;font-weight:500;transition:color .2s}
nav a:hover, nav a.active{color:var(--navy)}
nav a.active{font-weight:600}
.menu-btn{display:none;background:none;border:none;color:var(--navy);font-size:24px;cursor:pointer}

/* ---------- HERO ---------- */
.hero{background:var(--navy);color:var(--paper);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 500px at 78% -10%,rgba(20,184,166,.16),transparent 60%),linear-gradient(180deg,var(--navy),var(--navy-2))}
.hero::after{content:"";position:absolute;inset:0;opacity:.4;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:64px 64px;-webkit-mask-image:linear-gradient(180deg,#000,transparent 85%);mask-image:linear-gradient(180deg,#000,transparent 85%)}
.hero-inner{position:relative;z-index:2;padding:96px 0 104px;max-width:780px}
.hero-inner.compact{padding:72px 0 80px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:26px}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--accent)}
.hero h1{font-family:var(--display);font-weight:500;font-size:60px;line-height:1.06;letter-spacing:-.015em;margin-bottom:26px}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero p{font-size:19px;color:#B8C4D0;max-width:600px;margin-bottom:38px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}

/* ---------- TRUST STRIP ---------- */
.trust{background:var(--navy-2);border-top:1px solid rgba(255,255,255,.06);position:relative;z-index:2}
.trust .wrap{display:flex;align-items:center;justify-content:space-between;padding:22px 40px;flex-wrap:wrap;gap:16px}
.trust>.wrap>span{color:#7E8C9A;font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:600}
.trust .vals{display:flex;gap:42px;flex-wrap:wrap}
.trust .vals b{color:#D5DDE5;font-weight:600;font-size:14px}

/* ---------- SECTIONS ---------- */
section.block{padding:94px 0}
.sec-eyebrow{font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-deep);margin-bottom:16px}
.sec-title{font-family:var(--display);font-weight:500;font-size:40px;line-height:1.12;letter-spacing:-.01em;max-width:640px;margin-bottom:18px}
.sec-lead{font-size:18px;color:var(--slate);max-width:600px}

/* ---------- INTRO TWO-COL ---------- */
.intro{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.intro .big{font-family:var(--display);font-weight:400;font-size:29px;line-height:1.32;letter-spacing:-.01em}
.intro .big strong{font-weight:600;color:var(--accent-deep)}
.intro .body p{color:var(--slate);font-size:16.5px;margin-bottom:18px}

/* ---------- SERVICES GRID ---------- */
.services{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:50px;border-radius:8px;overflow:hidden}
.card{background:#fff;padding:38px 32px;transition:background .25s}
.card:hover{background:var(--paper)}
.card .num{font-family:var(--display);font-size:15px;color:var(--accent-deep);font-weight:600;margin-bottom:20px;display:block}
.card h3{font-family:var(--display);font-weight:500;font-size:21px;line-height:1.2;margin-bottom:12px}
.card p{color:var(--slate-light);font-size:15px}
.card.feat{background:var(--navy);color:var(--paper)}
.card.feat:hover{background:var(--navy-2)}
.card.feat h3{color:#fff}
.card.feat p{color:#A9B6C2}
.card.feat .num{color:var(--accent)}

/* ---------- SERVICES PAGE — DETAIL LIST ---------- */
.svc-list{display:flex;flex-direction:column;gap:0;margin-top:40px;border-top:1px solid var(--line)}
.svc-row{display:grid;grid-template-columns:160px 1fr;gap:48px;padding:48px 0;border-bottom:1px solid var(--line);align-items:start}
.svc-row .num{font-family:var(--display);font-size:46px;color:var(--accent-deep);font-weight:500;letter-spacing:-.02em}
.svc-row h3{font-family:var(--display);font-weight:500;font-size:28px;line-height:1.2;margin-bottom:14px;letter-spacing:-.01em}
.svc-row p{color:var(--slate);font-size:16.5px;margin-bottom:14px;max-width:720px}
.svc-row ul{list-style:none;margin-top:18px;display:grid;grid-template-columns:repeat(2,1fr);gap:10px 32px;max-width:720px}
.svc-row ul li{color:var(--slate);font-size:15px;padding-left:18px;position:relative}
.svc-row ul li::before{content:"";position:absolute;left:0;top:10px;width:8px;height:1px;background:var(--accent-deep)}

/* ---------- WHY ---------- */
.why{background:var(--paper)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:52px}
.why-item{border-top:2px solid var(--accent-deep);padding-top:24px}
.why-item h4{font-family:var(--display);font-weight:600;font-size:21px;margin-bottom:10px}
.why-item p{color:var(--slate);font-size:15.5px}

/* ---------- APPROACH BANNER ---------- */
.approach{background:var(--navy);color:var(--paper);position:relative;overflow:hidden}
.approach::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 400px at 12% 120%,rgba(20,184,166,.14),transparent 60%)}
.approach .wrap{position:relative;z-index:2;text-align:center;padding:86px 40px}
.approach .sec-eyebrow{color:var(--accent)}
.approach h2{font-family:var(--display);font-weight:500;font-size:37px;line-height:1.18;max-width:720px;margin:0 auto 40px;letter-spacing:-.01em}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:left}
.step{padding:26px 22px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:rgba(255,255,255,.02)}
.step .s-num{font-family:var(--display);color:var(--accent);font-size:14px;font-weight:600;letter-spacing:.1em;margin-bottom:14px}
.step h5{font-size:17px;font-weight:600;margin-bottom:8px;color:#fff}
.step p{color:#9DAAB6;font-size:14px;line-height:1.55}

/* ---------- APPROACH PAGE — DETAILED ---------- */
.approach-detail{background:#fff;padding:94px 0}
.approach-row{display:grid;grid-template-columns:200px 1fr;gap:64px;padding:48px 0;border-top:1px solid var(--line);align-items:start}
.approach-row:last-child{border-bottom:1px solid var(--line)}
.approach-row .lbl{font-family:var(--display);font-size:46px;color:var(--accent-deep);font-weight:500;letter-spacing:-.02em}
.approach-row h3{font-family:var(--display);font-weight:500;font-size:30px;line-height:1.18;margin-bottom:16px;letter-spacing:-.01em}
.approach-row p{color:var(--slate);font-size:16.5px;margin-bottom:14px;max-width:720px}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-top:48px;align-items:start}
.contact-info h4{font-family:var(--display);font-size:18px;font-weight:600;margin-bottom:8px}
.contact-info p, .contact-info a{color:var(--slate);font-size:16px;margin-bottom:24px;text-decoration:none;display:block}
.contact-info a:hover{color:var(--accent-deep)}
form.contact{display:flex;flex-direction:column;gap:16px}
form.contact label{font-size:13px;font-weight:600;color:var(--slate);letter-spacing:.04em;text-transform:uppercase;margin-bottom:-10px}
form.contact input, form.contact select, form.contact textarea{font-family:var(--body);font-size:15px;padding:12px 14px;border:1px solid var(--line);border-radius:4px;background:#fff;color:var(--navy);transition:border-color .2s}
form.contact input:focus, form.contact select:focus, form.contact textarea:focus{outline:none;border-color:var(--accent-deep)}
form.contact textarea{min-height:140px;resize:vertical;font-family:var(--body)}
form.contact button{margin-top:8px;align-self:flex-start}

/* ---------- CTA ---------- */
.cta{background:#fff;text-align:center}
.cta .wrap{padding:94px 40px}
.cta h2{font-family:var(--display);font-weight:500;font-size:44px;letter-spacing:-.01em;margin-bottom:18px}
.cta p{font-size:18px;color:var(--slate);max-width:520px;margin:0 auto 34px}

/* ---------- FOOTER ---------- */
footer{background:var(--navy);color:#8B98A5;padding:54px 0 30px}
.foot-top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:30px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-top .logo{color:#fff;margin-bottom:12px;display:inline-block}
.foot-brand p{font-size:14px;max-width:280px}
.foot-cols{display:flex;gap:60px;flex-wrap:wrap}
.foot-cols h6{color:#fff;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px;font-weight:600}
.foot-cols a{display:block;color:#8B98A5;text-decoration:none;font-size:14.5px;margin-bottom:10px;transition:color .2s}
.foot-cols a:hover{color:var(--accent)}
.foot-bottom{padding-top:24px;font-size:13px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- MOBILE ---------- */
@media(max-width:900px){
  .wrap{padding:0 22px}
  nav ul{display:none}
  .menu-btn{display:block}
  nav.open ul{display:flex;position:absolute;top:74px;left:0;right:0;background:var(--paper);flex-direction:column;padding:20px;gap:14px;border-bottom:1px solid var(--line)}
  .hero h1{font-size:40px}
  .hero-inner{padding:64px 0 72px}
  .intro,.grid,.why-grid,.steps,.contact-grid{grid-template-columns:1fr}
  .svc-row,.approach-row{grid-template-columns:1fr;gap:16px}
  .svc-row ul{grid-template-columns:1fr}
  .sec-title{font-size:29px}
  .cta h2{font-size:32px}
  .approach h2{font-size:28px}
  section.block{padding:64px 0}
}
