/* ============================================
   PABLO MEJÍA ABOGADO — v2 PREMIUM 2026
   Palette: Black #0A0A0A · White #FAFAF8 · Accent #B8A080
   Fonts: DM Serif Display · DM Sans
   ============================================ */
:root {
  --black: #0A0A0A;
  --white: #FAFAF8;
  --g50: #F5F4F1;
  --g100: #ECEAE6;
  --g200: #D6D3CD;
  --g300: #C4C0B9;
  --g500: #6B6B6B;
  --g700: #3A3A3A;
  --accent: #B8A080;
  --accent-d: #9C8466;
  --accent-soft: rgba(184,160,128,.10);
  --serif: "DM Serif Display", Georgia, serif;
  --sans: "DM Sans", system-ui, sans-serif;
  --max: 1320px;
  --ease: cubic-bezier(.22,1,.36,1);
  --ease-out: cubic-bezier(0,.55,.45,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--white);color:var(--g700);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.ctr{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,4vw,56px)}

/* ---------- BTN ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 32px;font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;border:none;transition:all .35s var(--ease);position:relative;overflow:hidden}
.btn::before{content:'';position:absolute;inset:0;transform:translateY(101%);transition:transform .4s var(--ease)}
.btn::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);transition:none}
.btn:hover::before{transform:translateY(0)}
.btn:hover::after{left:120%;transition:left .6s var(--ease)}
.btn span{position:relative;z-index:1;display:inline-flex;align-items:center;gap:10px}
.btn .arr{transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(5px)}
.btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(0,0,0,.1)}

.btn-w{background:#fff;color:var(--black)}.btn-w::before{background:var(--accent)}.btn-w:hover{color:#fff}
.btn-b{background:var(--black);color:#fff}.btn-b::before{background:var(--accent)}.btn-b:hover{color:#fff}
.btn-o{background:transparent;border:1.5px solid var(--black);color:var(--black)}.btn-o::before{background:var(--black)}.btn-o:hover{color:#fff;border-color:var(--black)}
.btn-ow{background:transparent;border:1.5px solid rgba(255,255,255,.45);color:#fff}.btn-ow::before{background:#fff}.btn-ow:hover{color:var(--black)}
.btn-a{background:var(--accent);color:#fff}.btn-a::before{background:var(--black)}

/* ---------- NAV ---------- */
.topbar{background:var(--black);color:var(--g300);font-size:12px;padding:8px 0;letter-spacing:.04em}
.topbar .ctr{display:flex;justify-content:flex-end;gap:28px;flex-wrap:wrap}
.topbar a{color:var(--g300);display:inline-flex;align-items:center;gap:7px;transition:color .2s}
.topbar a:hover{color:var(--accent)}
.topbar svg{flex-shrink:0}

.nav-bar{position:sticky;top:0;z-index:50;background:rgba(250,250,248,.96);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:border-color .4s,box-shadow .4s}
.nav-bar.scrolled{border-color:var(--g100);box-shadow:0 1px 12px rgba(0,0,0,.04)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:76px;transition:height .35s var(--ease)}
.nav-bar.scrolled .nav-inner{height:62px}

.logo{display:flex;align-items:center;gap:14px}
.logo-mark{width:38px;height:44px;flex-shrink:0}
.logo-type{display:flex;flex-direction:column;line-height:1.15}
.logo-type .n1{font-family:var(--serif);font-size:17px;color:var(--black)}
.logo-type .n2{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--g500)}

.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{padding:8px 18px;font-size:13px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--g700);position:relative;transition:color .25s}
.nav-links a:hover{color:var(--accent)}
.nav-links a::after{content:'';position:absolute;bottom:4px;left:18px;right:18px;height:1.5px;background:var(--accent);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);transform-origin:left}
.nav-cta{margin-left:16px;padding:10px 24px!important;border:1.5px solid var(--black)!important;transition:all .3s var(--ease)!important}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--black)!important;color:#fff!important}

.hamburger{display:none;width:42px;height:42px;background:none;border:none;cursor:pointer;padding:0}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--black);margin:5px auto;transition:all .3s var(--ease)}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.mob-menu{position:fixed;inset:0;z-index:45;background:var(--black);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.mob-menu.open{opacity:1;pointer-events:auto}
.mob-menu a{color:#fff;font-family:var(--serif);font-size:28px;padding:10px 0;opacity:0;transform:translateY(16px);transition:opacity .4s var(--ease),transform .4s var(--ease),color .2s}
.mob-menu.open a{opacity:1;transform:translateY(0)}
.mob-menu a:hover{color:var(--accent)}

/* ---------- HERO ---------- */
.hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:flex-end;overflow:hidden;background:var(--black)}
.hero-img{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.08);transition:transform 12s linear}
.hero.in-view .hero-img{transform:scale(1)}
.hero-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,10,10,.35) 0%,rgba(10,10,10,.55) 40%,rgba(10,10,10,.88) 100%)}
.hero-content{position:relative;z-index:2;padding-bottom:clamp(80px,12vh,140px);width:100%}
.hero .eyebrow{display:inline-flex;align-items:center;gap:16px;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--accent);margin-bottom:28px}
.hero .eyebrow::before{content:'';width:48px;height:1px;background:var(--accent)}
.hero h1{font-family:var(--serif);font-size:clamp(44px,7vw,86px);line-height:1.04;color:#fff;font-weight:400;max-width:900px;letter-spacing:-.02em;text-shadow:0 2px 40px rgba(0,0,0,.4)}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero-sub{font-size:clamp(15px,1.3vw,18px);color:rgba(255,255,255,.78);max-width:540px;margin-top:28px;line-height:1.75;text-shadow:0 1px 12px rgba(0,0,0,.3)}
.hero-actions{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.35);display:flex;flex-direction:column;align-items:center;gap:8px;font-size:9px;letter-spacing:.35em;text-transform:uppercase;z-index:3}
.hero-scroll .line{width:1px;height:48px;background:linear-gradient(to bottom,var(--accent),transparent);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}

/* ---------- CRED BAR ---------- */
.cred{border-bottom:1px solid var(--g100);padding:52px 0}
.cred-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center}
.cred-item strong{display:block;font-family:var(--serif);font-size:clamp(36px,4.5vw,60px);color:var(--black);line-height:1}
.cred-item .suf{font-size:.55em;color:var(--accent)}
.cred-item span{display:block;margin-top:8px;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--g500)}

/* ---------- SECTIONS ---------- */
.sec{padding:clamp(80px,10vw,140px) 0;position:relative}
.sec.dark{background:var(--black);color:#fff}
.sec.alt{background:var(--g50)}
.eyebrow{font-size:11px;letter-spacing:.35em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:20px;display:inline-flex;align-items:center;gap:14px}
.eyebrow::before{content:'';width:40px;height:1px;background:var(--accent)}
.sec-title{font-family:var(--serif);font-size:clamp(32px,3.8vw,52px);font-weight:400;line-height:1.12;margin-bottom:24px;letter-spacing:-.01em}
.sec.dark .sec-title{color:#fff}
.sec-text{font-size:16px;line-height:1.85;color:var(--g500);max-width:600px}
.sec.dark .sec-text{color:rgba(255,255,255,.5)}

/* ---------- SPLIT LAYOUT ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,6vw,100px);align-items:center}
.split.reverse .split-img{order:-1}
.split-img{position:relative;overflow:hidden}
.split-img img,.split-img .img-ph{width:100%;aspect-ratio:4/5;object-fit:cover;display:block;transform:scale(1.04);transition:transform .8s var(--ease)}
.split-img.revealed img,.split-img.revealed .img-ph{transform:scale(1)}
.split-img .img-reveal{position:absolute;inset:0;background:var(--accent);transform-origin:left;transform:scaleX(1);z-index:2}
.split-img.revealed .img-reveal{animation:imgReveal .9s var(--ease-out) forwards}
@keyframes imgReveal{0%{transform:scaleX(1);transform-origin:left}50%{transform:scaleX(1);transform-origin:right}100%{transform:scaleX(0);transform-origin:right}}
.split-img .corner{position:absolute;width:70px;height:70px;z-index:3}
.split-img .corner.tl{top:-1px;left:-1px;border-left:2px solid var(--accent);border-top:2px solid var(--accent)}
.split-img .corner.br{bottom:-1px;right:-1px;border-right:2px solid var(--accent);border-bottom:2px solid var(--accent)}
.split-badge{position:absolute;bottom:0;right:0;background:var(--black);color:#fff;padding:24px 28px;z-index:4}
.split-badge strong{display:block;font-family:var(--serif);font-size:42px;line-height:1}
.split-badge span{font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--g300);display:block;margin-top:4px}

/* ---------- SERVICES GRID ---------- */
.srv-head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:64px;flex-wrap:wrap}
.srv-head .sec-text{margin-bottom:0}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.srv-card{position:relative;overflow:hidden;aspect-ratio:4/3;cursor:pointer;background:var(--g700)}
.srv-card img,.srv-card .img-ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),filter .5s}
.srv-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.85) 0%,rgba(10,10,10,.15) 60%);transition:background .5s var(--ease)}
.srv-card:hover img,.srv-card:hover .img-ph{transform:scale(1.08);filter:brightness(.75)}
.srv-card:hover::after{background:linear-gradient(to top,rgba(10,10,10,.9) 0%,rgba(10,10,10,.35) 60%)}
.srv-card-inner{position:absolute;bottom:0;left:0;right:0;padding:32px;z-index:2;transform:translateY(12px);transition:transform .5s var(--ease)}
.srv-card:hover .srv-card-inner{transform:translateY(0)}
.srv-num{font-family:var(--serif);font-size:14px;color:var(--accent);letter-spacing:.1em;margin-bottom:8px}
.srv-card h3{font-family:var(--serif);font-size:22px;font-weight:400;color:#fff;margin-bottom:6px;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.srv-card p{font-size:13px;color:rgba(255,255,255,.55);line-height:1.6;max-height:0;overflow:hidden;transition:max-height .5s var(--ease),opacity .4s;opacity:0}
.srv-card:hover p{max-height:100px;opacity:1}
.srv-card .srv-link{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-size:11px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);opacity:0;transform:translateY(8px);transition:all .4s var(--ease)}
.srv-card:hover .srv-link{opacity:1;transform:translateY(0)}
.srv-banner{grid-column:1/-1;padding:40px;background:var(--accent);color:var(--black);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.srv-banner h3{font-family:var(--serif);font-size:24px;font-weight:400}

/* ---------- CONTACT SECTION ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(40px,5vw,80px)}
.ci-row{display:flex;align-items:flex-start;gap:16px;padding:20px 0;border-top:1px solid var(--g100)}
.ci-icon{width:44px;height:44px;flex-shrink:0;background:var(--accent-soft);display:flex;align-items:center;justify-content:center}
.ci-row strong{display:block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--black);margin-bottom:2px}
.ci-row span{font-size:14px;color:var(--g500)}
.c-form{padding:48px;background:var(--g50)}
.c-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.c-form .field{margin-bottom:16px}
.c-form label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--g500);font-weight:600;margin-bottom:8px}
.c-form input,.c-form textarea{width:100%;padding:14px 16px;border:1px solid var(--g100);background:#fff;font-family:var(--sans);font-size:15px;color:var(--black);transition:border-color .3s,box-shadow .3s}
.c-form input:focus,.c-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.c-form textarea{min-height:120px;resize:vertical}

/* ---------- CTA BAND ---------- */
.cta-band{padding:80px 0;background:var(--black);color:#fff;text-align:center}
.cta-band h3{font-family:var(--serif);font-size:clamp(26px,3.2vw,44px);font-weight:400;margin-bottom:14px;max-width:780px;margin-left:auto;margin-right:auto}
.cta-band p{color:rgba(255,255,255,.45);margin-bottom:40px;font-size:16px}

/* ---------- FOOTER ---------- */
.footer{border-top:1px solid var(--g100);padding:72px 0 0;font-size:14px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;padding-bottom:56px}
.foot-grid h4{font-family:var(--serif);font-size:15px;color:var(--black);margin-bottom:20px;font-weight:400}
.foot-grid ul{list-style:none;padding:0;margin:0}
.foot-grid li{margin-bottom:10px}
.foot-grid a{color:var(--g500);transition:color .2s,padding-left .3s var(--ease)}
.foot-grid a:hover{color:var(--accent);padding-left:6px}
.foot-addr{color:var(--g500);font-size:13px;line-height:1.7;margin-bottom:14px}
.foot-addr strong{color:var(--black);display:block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:2px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding:20px 0;border-top:1px solid var(--g100);font-size:12px;color:var(--g500);letter-spacing:.06em;flex-wrap:wrap;gap:8px}

/* ---------- PAGE HERO ---------- */
.page-hero{position:relative;padding:160px 0 100px;background:var(--black);color:#fff;overflow:hidden}
.page-hero-img{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.25}
.page-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,10,10,.3),rgba(10,10,10,.5))}
.page-hero h1,.page-hero p{text-shadow:0 2px 20px rgba(0,0,0,.35)}
.page-hero .ctr{position:relative;z-index:2}
.page-hero .eyebrow::before{background:var(--accent)}
.page-hero h1{font-family:var(--serif);font-size:clamp(40px,5.5vw,64px);color:#fff;font-weight:400;margin-bottom:14px}
.page-hero p{font-size:17px;color:rgba(255,255,255,.6);max-width:600px}
.breadcrumbs{margin-top:20px;font-size:12px;color:rgba(255,255,255,.5);letter-spacing:.06em}
.breadcrumbs a{color:rgba(255,255,255,.7)}.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs .sep{margin:0 10px;opacity:.4}

/* ---------- SERVICE DETAIL ---------- */
.svc-detail{padding:100px 0}
.svc-layout{display:grid;grid-template-columns:1fr 340px;gap:60px;align-items:start}
.svc-main .hero-img-wrap{aspect-ratio:16/8;overflow:hidden;margin-bottom:40px;position:relative}
.svc-main .hero-img-wrap img,.svc-main .hero-img-wrap .img-ph{width:100%;height:100%;object-fit:cover}
.svc-main h2{font-family:var(--serif);font-size:32px;color:var(--black);font-weight:400;margin:32px 0 16px}
.svc-main p{font-size:16px;line-height:1.85;margin-bottom:16px;color:var(--g500)}
.svc-main h3{font-family:var(--serif);font-size:22px;color:var(--black);font-weight:400;margin:36px 0 20px}
.svc-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.svc-list li{padding:14px 16px 14px 44px;background:var(--g50);border-left:3px solid var(--accent);font-size:14px;position:relative;transition:all .25s var(--ease)}
.svc-list li::before{content:'';position:absolute;left:16px;top:50%;transform:translateY(-50%);width:10px;height:10px;border-radius:50%;background:var(--accent);opacity:.5}
.svc-list li:hover{background:#fff;box-shadow:0 2px 12px rgba(0,0,0,.05);transform:translateX(4px)}
.svc-list li:hover::before{opacity:1;transform:translateY(-50%) scale(1.3)}
.svc-cta{margin-top:48px;padding:32px;background:var(--g50);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.svc-cta h3{margin:0 0 6px;font-size:20px}.svc-cta p{margin:0;color:var(--g500)}

/* Sidebar */
.sidebar{position:sticky;top:90px}
.sb-block{border:1px solid var(--g100);padding:28px;margin-bottom:24px}
.sb-block h4{font-family:var(--serif);font-size:14px;color:var(--black);text-transform:uppercase;letter-spacing:.12em;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--g100);font-weight:400}
.sb-nav{list-style:none;padding:0;margin:0}
.sb-nav li{margin-bottom:2px}
.sb-nav a{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;color:var(--g700);font-size:13px;font-weight:500;transition:all .2s var(--ease)}
.sb-nav a:hover,.sb-nav a.active{background:var(--black);color:#fff;transform:translateX(4px)}
.sb-nav a{transition:all .25s var(--ease)}
.sb-nav a::after{content:'›';opacity:.4;font-size:16px}
.sb-nav a:hover::after,.sb-nav a.active::after{opacity:1}
.sb-cta{background:var(--black);color:#fff;padding:32px;position:relative;overflow:hidden}
.sb-cta::before{content:'';position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;background:rgba(184,160,128,.08)}
.sb-cta h4{color:#fff;border:none;padding:0;font-size:18px;letter-spacing:0;text-transform:none;margin-bottom:8px}
.sb-cta p{font-size:14px;color:rgba(255,255,255,.6);margin:0 0 20px}
.sb-cta .btn{width:100%;justify-content:center;background:var(--accent);color:#fff}

/* ---------- LEYES ---------- */
.leyes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.ley-card{border:1px solid var(--g100);padding:48px 36px;text-align:center;position:relative;transition:all .35s var(--ease);overflow:hidden}
.ley-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--black));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.ley-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,.08)}.ley-card:hover::before{transform:scaleX(1)}
.ley-icon{width:72px;height:72px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.ley-card h3{font-family:var(--serif);font-size:20px;font-weight:400;margin-bottom:10px;color:var(--black)}
.ley-card p{font-size:14px;color:var(--g500);margin-bottom:24px;min-height:40px}

/* ---------- OFFICES ---------- */
.offices-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.office-card{border:1px solid var(--g100);overflow:hidden;transition:box-shadow .3s}
.office-card:hover{box-shadow:0 12px 40px rgba(0,0,0,.06)}
.office-map{aspect-ratio:16/9;overflow:hidden;position:relative}
.office-map img,.office-map .img-ph{width:100%;height:100%;object-fit:cover}
.office-body{padding:32px}
.office-body h3{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.office-body .addr{font-size:15px;line-height:1.7;margin-bottom:18px;color:var(--g700)}
.office-body .phone{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:18px;color:var(--black)}

/* ---------- STATS ---------- */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;padding:60px 0;border-top:1px solid var(--g100);border-bottom:1px solid var(--g100)}
.stat{text-align:center}
.stat strong{display:block;font-family:var(--serif);font-size:52px;line-height:1;color:var(--black)}
.stat .suf{font-size:.55em;color:var(--accent)}
.stat span{display:block;margin-top:8px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--g500)}

/* ---------- FLOAT WA ---------- */
.float-wa{position:fixed;right:24px;bottom:24px;z-index:40;width:56px;height:56px;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;border-radius:50%;box-shadow:0 8px 24px rgba(37,211,102,.35);transition:transform .25s var(--ease)}
.float-wa:hover{transform:scale(1.12) rotate(-5deg)}
.float-wa::after{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid #25D366;animation:waPulse 2s infinite}
@keyframes waPulse{0%{transform:scale(.85);opacity:1}100%{transform:scale(1.5);opacity:0}}

/* ---------- EXTRAS PREMIUM ---------- */
.split-img{position:relative;overflow:hidden}
.split-img img{transition:transform 6s var(--ease)!important}
.split-img:hover img{transform:scale(1.03)!important}

/* Nav link magnetic hover */
.nav-links a{transition:color .25s,letter-spacing .4s var(--ease)}
.nav-links a:hover{letter-spacing:.1em}
.nav-cta{transition:all .35s var(--ease)!important}
.nav-cta:hover{transform:translateY(-2px)!important;box-shadow:0 6px 20px rgba(0,0,0,.12)!important}

/* Service card glow line */
.srv-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),#d4c3a8);z-index:3;transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.srv-card:hover::before{transform:scaleX(1)}

/* Eyebrow line animate */
.eyebrow::before{transition:width .6s var(--ease)}
.rv.in .eyebrow::before,.eyebrow:hover::before{width:56px}

/* Form field underline effect */
.c-form input,.c-form textarea{position:relative}
.c-form .field{position:relative}
.c-form .field::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:center;transition:transform .4s var(--ease)}
.c-form .field:focus-within::after{transform:scaleX(1)}

/* Footer link arrow on hover */
.foot-grid li{transition:transform .2s var(--ease)}
.foot-grid li:hover{transform:translateX(4px)}

/* Smooth scroll indicator fade */
.hero-scroll{animation:fadeInDelay 2s var(--ease) forwards;opacity:0}
@keyframes fadeInDelay{0%{opacity:0}70%{opacity:0}100%{opacity:1}}

/* Stat counter underline */
.cred-item::after{content:'';display:block;width:32px;height:2px;background:var(--accent);margin:16px auto 0;opacity:0;transform:scaleX(0);transition:all .5s var(--ease)}
.cred-item:hover::after{opacity:1;transform:scaleX(1)}

/* CTA band pulse subtle */
.cta-band{position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at center,rgba(184,160,128,.06) 0%,transparent 50%);animation:ctaGlow 6s ease-in-out infinite}
@keyframes ctaGlow{0%,100%{transform:translate(0,0)}50%{transform:translate(5%,5%)}}
.ci-icon{transition:background .3s var(--ease),transform .3s var(--ease)}
.ci-row:hover .ci-icon{background:var(--accent);transform:scale(1.08)}
.ci-row:hover .ci-icon svg{stroke:#fff!important}
.ley-card{transition:all .35s var(--ease),box-shadow .4s}
.ley-icon{transition:background .3s var(--ease),transform .4s var(--ease)}
.ley-card:hover .ley-icon{background:var(--accent);transform:scale(1.1) rotate(-5deg)}
.ley-card:hover .ley-icon svg{stroke:#fff!important}
.cred-item{transition:transform .3s var(--ease)}
.cred-item:hover{transform:translateY(-4px)}
.cred-item:hover strong{color:var(--accent)}
.cred-item strong{transition:color .3s var(--ease)}
.page-hero-img{transition:transform 12s linear}
.page-hero:hover .page-hero-img{transform:scale(1.03)}

/* ---------- REVEAL SYSTEM ---------- */
.rv{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv.in{opacity:1;transform:translateY(0)}
.rv-d1{transition-delay:.1s}.rv-d2{transition-delay:.2s}.rv-d3{transition-delay:.3s}.rv-d4{transition-delay:.4s}
.rv-left{transform:translateX(-30px)}.rv-left.in{transform:translateX(0)}
.rv-right{transform:translateX(30px)}.rv-right.in{transform:translateX(0)}
.rv-scale{transform:scale(.94)}.rv-scale.in{transform:scale(1)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1024px){
  .nav-links{display:none}.hamburger{display:block}
  .split{grid-template-columns:1fr;gap:48px}.split.reverse .split-img{order:0}
  .srv-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .cred-grid{grid-template-columns:1fr 1fr;gap:24px}
  .svc-layout{grid-template-columns:1fr}.sidebar{position:static}
  .leyes-grid,.offices-grid{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .srv-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .c-form{padding:24px}.c-form .row2{grid-template-columns:1fr}
  .svc-list{grid-template-columns:1fr}
  .srv-banner{flex-direction:column;text-align:center}
  .cta-band{padding:56px 0}
  .hero{min-height:600px}
}
