/* ============================================================
   A&A Legal Group — Sistema visual compartido
   Paleta, tipografía, componentes y layout
   ============================================================ */
:root{
  /* Color */
  --navy:#13223F; --navy-2:#1B2C4D; --navy-dark:#0C1526;
  --steel:#97A1BC; --mist:#C7CDD9; --mist-2:#E4E8F0;
  --bone:#F6F6F4; --paper:#FCFCFB; --white:#FFFFFF;
  --ink:#202A40; --muted:#586079;
  --gold:#C2A24C; --gold-deep:#A9892F; --gold-soft:#E7D7A4; --gold-text:#8A6A22;
  --emerald:#2F7E68;
  --line:#E2E5EC;
  /* Type */
  --display:'Cinzel',serif;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
  /* Shadow */
  --sh-sm:0 2px 8px rgba(19,34,63,.05);
  --sh-md:0 14px 38px rgba(19,34,63,.09);
  --sh-lg:0 30px 70px rgba(12,21,38,.16);
  --sh-xl:0 40px 110px rgba(12,21,38,.30);
  --r:14px; --r-sm:8px; --r-lg:22px;
  --maxw:1140px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bone);line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;color:var(--navy);line-height:1.12;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:2px}
.hero :focus-visible,.product :focus-visible,.cta-band :focus-visible,.sectors-right :focus-visible,.legal-hero :focus-visible,footer :focus-visible,.utility :focus-visible,.why-visual :focus-visible{outline-color:var(--gold-soft)}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* Eyebrow / kicker */
.eyebrow{font-family:var(--sans);font-size:11.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-text);font-weight:600;display:inline-flex;align-items:center;gap:11px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);display:inline-block}
.eyebrow.center{justify-content:center}
.eyebrow.on-dark{color:var(--gold-soft)}
.eyebrow.on-dark::before{background:var(--gold-soft)}

/* Gold rule under titles */
.gold-rule{display:block;width:54px;height:2px;background:var(--gold);border-radius:2px;margin:18px 0 0}
.gold-rule.center{margin:18px auto 0}

/* Section scaffold */
section{padding:104px 0;position:relative}
.section-head{max-width:680px;margin:0 auto 60px;text-align:center}
.section-head .eyebrow{margin-bottom:18px}
.section-head h2{font-size:clamp(32px,4vw,46px)}
.section-head p{color:var(--muted);font-size:17.5px;margin-top:18px;text-wrap:pretty}

/* Buttons */
.btn{position:relative;overflow:hidden;font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:.02em;padding:14px 26px;border-radius:4px;display:inline-flex;align-items:center;gap:9px;transition:.22s ease;cursor:pointer;border:1px solid transparent;line-height:1}
.btn svg{width:15px;height:15px}
/* gold/light shine sweep on hover */
.btn::after{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;background:linear-gradient(115deg,transparent 0%,rgba(255,255,255,.55) 50%,transparent 100%);transform:skewX(-22deg);transition:left .65s cubic-bezier(.22,.61,.36,1);pointer-events:none}
.btn:hover::after{left:150%}
.btn-ghost::after{background:linear-gradient(115deg,transparent,rgba(194,162,76,.35),transparent)}
.btn-primary{background:var(--gold);color:var(--navy);box-shadow:0 8px 22px rgba(194,162,76,.28)}
.btn-primary:hover{background:var(--gold-deep);color:var(--navy);transform:translateY(-2px);box-shadow:0 14px 30px rgba(169,137,47,.36)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-2);transform:translateY(-2px)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-outline:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-deep)}

/* ============ UTILITY BAR ============ */
.utility{background:var(--navy-dark);color:rgba(255,255,255,.72);font-size:12.5px}
.utility .wrap{display:flex;align-items:center;justify-content:space-between;height:38px}
.utility-left{display:flex;gap:26px}
.utility-left a{display:inline-flex;align-items:center;gap:8px;transition:.2s}
.utility-left a:hover{color:#fff}
.utility-left svg{width:13px;height:13px;opacity:.7}
.utility-right{display:flex;align-items:center;gap:18px}
.lang{display:inline-flex;align-items:center;gap:2px;font-weight:600;letter-spacing:.04em;border:1px solid rgba(151,161,188,.4);border-radius:30px;overflow:hidden}
.lang button{background:none;border:none;color:rgba(255,255,255,.6);font:inherit;font-weight:600;padding:4px 11px;cursor:pointer;transition:.18s}
.lang button.active{background:var(--gold);color:var(--navy)}
.utility-right .ig{display:inline-flex;align-items:center;gap:7px;transition:.2s}
.utility-right .ig:hover{color:#fff}
.utility-right svg{width:14px;height:14px}
@media(max-width:760px){.utility{font-size:12px}.utility-left{gap:16px}.utility-left .u-hide{display:none}.utility-left a{white-space:nowrap}}
@media(max-width:380px){.utility{font-size:11px}.utility .wrap{padding:0 16px}.utility-left{gap:12px}}

/* ============ HEADER ============ */
header{position:sticky;top:0;z-index:60;background:rgba(246,246,244,.86);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
header.scrolled{box-shadow:0 6px 26px rgba(19,34,63,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;height:104px;transition:height .25s}
header.scrolled .nav{height:84px}
.brand{display:flex;align-items:center}
.brand img{height:74px;width:auto;transition:height .25s}
header.scrolled .brand img{height:60px}
nav.main ul{display:flex;gap:34px;list-style:none;font-size:14px;font-weight:500;color:var(--navy)}
nav.main a{position:relative;padding:6px 0;transition:color .2s}
nav.main a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--gold);transition:width .25s}
nav.main a:hover{color:var(--gold-deep)}
nav.main a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:16px}
.menu-btn{display:none;background:none;border:1px solid var(--line);border-radius:6px;width:42px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.menu-btn svg{width:22px;height:22px;color:var(--navy)}
.nav-mobile-cta{display:none}
@media(max-width:980px){nav.main{position:fixed;top:0;right:0;bottom:auto;left:auto;height:100dvh;width:min(320px,82vw);background:var(--paper);flex-direction:column;padding:30px;transform:translateX(105%);transition:transform .3s;box-shadow:var(--sh-lg);z-index:70;overflow-y:auto}
  nav.main.open{transform:none}
  nav.main ul{flex-direction:column;gap:6px;font-size:16px;width:100%}
  nav.main a{display:block;padding:14px 4px;border-bottom:1px solid var(--line)}
  .menu-btn{display:flex}
  .nav-cta .btn{display:none}
  .nav-mobile-cta{display:block;margin-top:18px}
  .nav-mobile-cta a{border-bottom:none;padding:0}
  .nav-mobile-cta .btn{display:inline-flex;width:100%;justify-content:center}
}

/* ============ HERO CAROUSEL ============ */
.hero{background:linear-gradient(120deg,#13223F 0%,#22304d 100%);color:#fff;position:relative;overflow:hidden}
.hero-carousel{position:relative}
.slide{display:none;position:relative;min-height:600px}
.slide.active{display:block;animation:fade .7s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.slide-photo{position:absolute;inset:0;background-size:cover;background-position:center;background-color:#1b2a4a;overflow:hidden}
.slide.active .slide-photo{animation:kenburns 13s ease-out both}
@keyframes kenburns{from{transform:scale(1.02)}to{transform:scale(1.13)}}
.slide-photo::after{content:"";position:absolute;inset:0}
.slide-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;border:0}
.slide-photo.has-video{background-color:#0c1526}
.slide.active .slide-photo.has-video{animation:none}
.slide-photo.has-video::after{z-index:1}
.slide[data-side="right"] .slide-photo::after{background:linear-gradient(90deg,rgba(8,15,28,.92) 0%,rgba(8,15,28,.62) 38%,rgba(8,15,28,.28) 68%,rgba(8,15,28,.5) 100%)}
.slide[data-side="left"] .slide-photo::after{background:linear-gradient(270deg,rgba(8,15,28,.92) 0%,rgba(8,15,28,.62) 38%,rgba(8,15,28,.28) 68%,rgba(8,15,28,.5) 100%)}
.glass{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:min(500px,44%);background:linear-gradient(150deg,rgba(13,21,38,.92),rgba(27,38,61,.86));backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);border-top:2px solid var(--gold);border-radius:4px;padding:48px 44px;box-shadow:var(--sh-xl);color:#fff}
.slide[data-side="right"] .glass{left:max(28px,calc((100vw - var(--maxw))/2 + 28px))}
.slide[data-side="left"] .glass{right:max(28px,calc((100vw - var(--maxw))/2 + 28px))}
.glass .eyebrow{color:var(--gold-soft)}
.glass .eyebrow::before{background:var(--gold-soft)}
.glass h2{color:#fff;font-size:clamp(32px,3.4vw,46px);margin:20px 0 18px}
.glass h2 em{color:var(--steel);font-style:italic;font-weight:500}
.glass p{color:rgba(255,255,255,.82);font-size:17px;font-weight:300;margin-bottom:30px;max-width:430px;text-wrap:pretty}
.glass .actions{display:flex;gap:14px;flex-wrap:wrap}
/* LIGHT card variant (prueba) */
.glass.light{background:linear-gradient(158deg,#F5F6F9,#E6E9F1);border:1px solid rgba(19,34,63,.07);border-top:2px solid var(--gold);box-shadow:0 34px 80px rgba(8,15,28,.42);color:var(--ink)}
.glass.light .eyebrow{color:var(--gold-text)}
.glass.light .eyebrow::before{background:var(--gold)}
.glass.light h2{color:var(--navy)}
.glass.light h2 em{color:var(--steel)}
.glass.light p{color:var(--muted)}
.glass.light .btn-outline{color:var(--navy);border-color:rgba(19,34,63,.28)}
.glass.light .btn-outline:hover{background:rgba(19,34,63,.06);border-color:var(--navy)}
/* staggered entrance for active slide content */
.slide.active .glass>*,.slide.brand.active .brand-inner>*{animation:slideUp .6s ease both}
.slide.active .glass>*:nth-child(1),.slide.brand.active .brand-inner>*:nth-child(1){animation-delay:.12s}
.slide.active .glass>*:nth-child(2),.slide.brand.active .brand-inner>*:nth-child(2){animation-delay:.22s}
.slide.active .glass>*:nth-child(3),.slide.brand.active .brand-inner>*:nth-child(3){animation-delay:.32s}
.slide.active .glass>*:nth-child(4),.slide.brand.active .brand-inner>*:nth-child(4){animation-delay:.42s}
.slide.brand.active .brand-inner>*:nth-child(5){animation-delay:.5s}
.slide.brand.active .brand-inner>*:nth-child(6){animation-delay:.58s}
@keyframes slideUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* Animated logo (gold light-sweep + float) */
.logo-anim{position:relative;display:inline-block}
.logo-anim img{display:block;position:relative;z-index:1;animation:logoFloat 6.5s ease-in-out infinite}
.logo-anim::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(115deg,transparent 38%,rgba(231,215,164,.55) 46%,rgba(255,251,238,.95) 50%,rgba(231,215,164,.55) 54%,transparent 62%);background-size:300% 100%;background-repeat:no-repeat;-webkit-mask:var(--logo-mask) center/contain no-repeat;mask:var(--logo-mask) center/contain no-repeat;animation:logoGlint 5.5s ease-in-out infinite}
@keyframes logoGlint{0%{background-position:145% 0}24%{background-position:-45% 0}100%{background-position:-45% 0}}
@keyframes logoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* Brand slide (5th) */
.slide.brand{min-height:600px;display:none}
.slide.brand.active{display:flex;align-items:center;justify-content:center;text-align:center}
.slide.brand .brand-bg{position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 30%,#1d2f51 0%,#13223F 55%,#0c1526 100%)}
.brand-mono-wm{position:absolute;right:-6%;bottom:-22%;width:62%;opacity:.07;pointer-events:none}
.brand-mono-wm.left{left:-10%;right:auto;top:-26%;bottom:auto;transform:rotate(0)}
.brand-inner{position:relative;z-index:2;padding:60px 24px;max-width:760px}
.brand-inner .blogo{height:150px;filter:drop-shadow(0 18px 40px rgba(0,0,0,.4))}
.brand-inner .logo-anim{display:block;width:-moz-fit-content;width:fit-content;margin:0 auto 28px}
.brand-inner .eyebrow{justify-content:center;color:var(--gold-soft);margin-bottom:22px}
.brand-inner .eyebrow::before,.brand-inner .eyebrow::after{background:var(--gold-soft)}
.brand-inner h2{color:#fff;font-size:clamp(30px,3.4vw,44px);max-width:620px;margin:0 auto}
.brand-inner h2 em{color:var(--steel);font-style:italic;font-weight:500}
.brand-inner p{color:rgba(255,255,255,.78);font-size:18px;font-weight:300;max-width:540px;margin:20px auto 30px;text-wrap:pretty}
.brand-inner .gold-rule{margin:26px auto}
.brand-inner .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Carousel controls */
.dots{position:absolute;left:50%;transform:translateX(-50%);bottom:22px;display:flex;gap:9px;z-index:6}
.dots button{width:34px;height:4px;border:none;border-radius:2px;background:rgba(255,255,255,.45);cursor:pointer;padding:0;transition:width .3s;position:relative}
.dots button::before{content:"";position:absolute;top:-20px;left:-6px;right:-6px;height:44px}
.dots button.active{width:50px;background:rgba(255,255,255,.3)}
.dots button.active::after{content:"";position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:left;animation:dotFill 6.5s linear forwards;border-radius:2px}
@keyframes dotFill{to{transform:scaleX(1)}}
.c-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.28);color:#fff;width:48px;height:48px;border-radius:50%;font-size:22px;cursor:pointer;z-index:6;transition:.2s;display:flex;align-items:center;justify-content:center}
.c-arrow:hover{background:rgba(194,162,76,.9);border-color:var(--gold);color:var(--navy)}
.c-arrow.prev{left:20px}.c-arrow.next{right:20px}
@media(max-width:880px){
  .slide{min-height:0}
  .slide-photo{position:relative;width:100%;height:220px}
  .glass{position:relative;top:0;transform:none;width:auto;margin:-40px 16px 20px;left:auto!important;right:auto!important;padding:38px 30px}
  .c-arrow{display:none}
  .slide.brand .blogo{height:108px}
}

/* ============ TRUST STRIP ============ */
.trust{background:var(--paper);border-bottom:1px solid var(--line)}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);padding:46px 0}
.trust-item{text-align:center;padding:6px 20px;position:relative}
.trust-item+.trust-item::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);height:54px;width:1px;background:var(--line)}
.trust-item .num{font-family:var(--serif);font-size:52px;font-weight:700;color:var(--navy);line-height:1}
.trust-item .num em{color:var(--gold);font-style:normal}
.trust-item .lbl{font-size:12px;color:var(--muted);letter-spacing:.18em;text-transform:uppercase;margin-top:10px;font-weight:600}
@media(max-width:680px){.trust-grid{grid-template-columns:1fr;gap:30px}.trust-item+.trust-item::before{display:none}}

/* ============ SERVICES ============ */
.lines-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.line-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:38px 36px;transition:.28s;box-shadow:var(--sh-sm);position:relative;overflow:hidden}
.line-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .3s}
.line-card:hover{transform:translateY(-5px);box-shadow:var(--sh-md);border-color:var(--mist)}
.line-card:hover::before{transform:scaleY(1)}
.line-head{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.line-tag{flex:0 0 auto;width:56px;height:56px;border-radius:10px;background:linear-gradient(150deg,var(--navy),var(--navy-2));color:#fff;font-family:var(--display);font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;letter-spacing:.04em;box-shadow:var(--sh-sm)}
.line-head h3{font-size:24px}
.line-card>p{color:var(--muted);font-size:15px;margin-bottom:18px}
.line-includes{list-style:none;border-top:1px solid var(--line);padding-top:16px}
.line-includes li{font-size:14.5px;color:#3d4763;padding:7px 0 7px 22px;position:relative}
.line-includes li::before{content:"";position:absolute;left:0;top:14px;width:6px;height:6px;border-radius:50%;background:var(--emerald)}
@media(max-width:780px){.lines-grid{grid-template-columns:1fr}}

/* ============ PRODUCT: constituye empresa ============ */
.product{position:relative;overflow:hidden;color:#fff;background-image:linear-gradient(rgba(12,21,38,.82),rgba(12,21,38,.7)),url('assets/hero-globe.jpg');background-size:cover;background-position:center;background-attachment:fixed}
.product .section-head h2{color:#fff}
.product .section-head p{color:rgba(255,255,255,.8)}
.product .section-head .eyebrow{color:var(--gold-soft)}
.product .section-head .eyebrow::before{background:var(--gold-soft)}
.flow{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:stretch;gap:0;max-width:920px;margin:0 auto 38px}
.flow-card{background:rgba(255,255,255,.97);border-radius:var(--r);padding:38px 26px 30px;text-align:center;position:relative;box-shadow:var(--sh-lg);transition:transform .28s ease,box-shadow .28s ease}
.flow-card:hover{transform:translateY(-8px);box-shadow:0 26px 56px rgba(8,15,28,.45)}
.flow-card .step{position:absolute;top:-17px;left:50%;transform:translateX(-50%);width:34px;height:34px;border-radius:50%;background:var(--emerald);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:15px;border:3px solid #fff;font-family:var(--sans);transition:transform .28s ease,box-shadow .28s ease}
.flow-card:hover .step{transform:translateX(-50%) scale(1.1);box-shadow:0 0 0 5px rgba(47,126,104,.3)}
.flow-card .fico{width:50px;height:50px;margin:6px auto 16px;color:var(--navy)}
.flow-card .fico svg{width:100%;height:100%}
.flow-card h3{font-size:21px;margin-bottom:7px}
.flow-card p{color:var(--muted);font-size:14px}
.flow-sep{display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:24px;padding:0 14px}
.product-tags{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:32px}
.product-tags .tag{border:1px solid rgba(231,215,164,.45);color:var(--gold-soft);border-radius:30px;padding:9px 20px;font-size:13.5px;letter-spacing:.02em}
.product-cta{text-align:center}
.product-note{text-align:center;font-size:12.5px;color:rgba(255,255,255,.55);max-width:620px;margin:24px auto 0}
@media(max-width:780px){.product{background-attachment:scroll}.flow{grid-template-columns:1fr;gap:10px}.flow-sep{transform:rotate(90deg);padding:8px 0}}

/* ============ STRUCT ============ */
.struct-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.struct-points{list-style:none}
.struct-points li{padding:15px 0;border-bottom:1px solid var(--line);font-size:15px;color:#3d4763;display:flex;gap:14px}
.struct-points li:last-child{border-bottom:none}
.struct-points li b{color:var(--navy)}
.struct-points li .arr{color:var(--emerald);font-weight:700;flex:0 0 auto}
.struct-flow{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:30px;box-shadow:var(--sh-sm)}
.struct-photo{height:190px;border-radius:var(--r-sm);background-size:cover;background-position:center;margin-bottom:26px}
.struct-flow .eyebrow{margin-bottom:18px}
.struct-flow .step-row{display:flex;gap:16px;margin-bottom:20px}
.struct-flow .step-row:last-child{margin-bottom:0}
.struct-flow .num{flex:0 0 auto;width:34px;height:34px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;font-family:var(--sans)}
.struct-flow .num.gold{background:var(--gold);color:var(--navy)}
.struct-flow h4{font-family:var(--sans);font-size:15px;color:var(--navy);margin-bottom:3px}
.struct-flow p{font-size:13.5px;color:var(--muted)}
@media(max-width:780px){.struct-grid{grid-template-columns:1fr;gap:34px}}

/* ============ ABOUT / NOSOTROS ============ */
.about{background:var(--white);position:relative;overflow:hidden}
.about-wm{position:absolute;left:-7%;top:50%;transform:translateY(-50%);width:48%;opacity:.05;pointer-events:none}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
.about-grid h2{font-size:clamp(28px,3vw,40px)}
.mvv{display:flex;flex-direction:column;gap:22px;margin-top:28px}
.mvv-item{border-left:2px solid var(--emerald);padding-left:20px}
.mvv-item h4{font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-text);margin-bottom:6px;font-weight:600}
.mvv-item p{font-size:15px;color:#3d4763}
.about-logo{background:linear-gradient(160deg,#13223F,#1f3157);border-radius:var(--r-lg);min-height:420px;display:flex;align-items:center;justify-content:center;padding:60px;box-shadow:var(--sh-lg);position:relative;overflow:hidden}
.about-logo::before{content:"";position:absolute;inset:14px;border:1px solid rgba(231,215,164,.28);border-radius:16px;pointer-events:none}
.about-logo .logo-anim{width:74%;max-width:330px}
.about-logo .logo-anim img{width:100%;max-width:100%;max-height:none;filter:drop-shadow(0 20px 40px rgba(0,0,0,.4))}
@media(max-width:820px){.about-grid{grid-template-columns:1fr;gap:40px}.about-logo{min-height:320px}}

/* ============ WHY (two-column + animated emblem) ============ */
.why{background:var(--mist-2)}
.why-split{display:grid;grid-template-columns:.82fr 1.18fr;gap:60px;align-items:center}
.why-visual{background:linear-gradient(160deg,#13223F,#1f3157);border-radius:var(--r-lg);padding:54px 40px 48px;color:#fff;position:relative;overflow:hidden;box-shadow:var(--sh-lg);text-align:center}
.why-visual::before{content:"";position:absolute;inset:12px;border:1px solid rgba(231,215,164,.22);border-radius:16px;pointer-events:none}
.why-orbit{position:relative;width:190px;height:190px;margin:0 auto 28px;display:flex;align-items:center;justify-content:center}
.why-orbit .ring{position:absolute;border-radius:50%}
.why-orbit .r1{inset:0;border:1px dashed rgba(231,215,164,.4);animation:spin 28s linear infinite}
.why-orbit .r2{inset:24px;border:1px solid rgba(151,161,188,.32);animation:spin 19s linear infinite reverse}
.why-orbit .r1 .dot{position:absolute;top:-5px;left:50%;margin-left:-5px;width:10px;height:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 14px var(--gold)}
.why-orbit .why-mono{width:92px;position:relative;z-index:2;filter:drop-shadow(0 12px 26px rgba(0,0,0,.45))}
.why-visual .eyebrow{justify-content:center;color:var(--gold-soft)}
.why-visual .eyebrow::before{background:var(--gold-soft)}
.why-visual h2{color:#fff;font-size:32px;margin-top:14px}
.why-visual p{color:rgba(255,255,255,.74);font-size:14.5px;margin-top:14px;max-width:280px;margin-left:auto;margin-right:auto;text-wrap:pretty}
.why-list{display:flex;flex-direction:column}
.why-row{display:flex;gap:24px;padding:28px 6px;border-bottom:1px solid var(--line);align-items:flex-start;transition:padding .25s ease,background .25s ease;border-radius:8px}
.why-row:last-child{border-bottom:none}
.why-row:hover{padding-left:16px;background:rgba(255,255,255,.55)}
.why-row .n{flex:0 0 auto;width:52px;height:52px;border:1.5px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:17px;color:var(--gold-text);font-weight:700;transition:.25s}
.why-row:hover .n{background:var(--gold);color:#fff}
.why-row h3{font-size:23px;margin-bottom:7px}
.why-row p{font-size:15px;color:var(--muted);max-width:480px}
@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:880px){.why-split{grid-template-columns:1fr;gap:34px}.why-row{gap:18px}}

/* ============ SECTORS SPLIT ============ */
.sectors-section{padding:104px 0;background:var(--bone)}
.sectors-split{display:grid;grid-template-columns:42% 58%;max-width:var(--maxw);margin:0 auto;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg)}
.sectors-left{background:var(--mist-2);padding:66px 50px;display:flex;flex-direction:column;justify-content:center}
.sectors-left h2{font-size:36px}
.sectors-left .lead{color:var(--muted);font-size:16px;margin:20px 0 32px;max-width:430px}
.phil-card{background:#fff;border-radius:var(--r);padding:34px 32px;box-shadow:var(--sh-md);position:relative;border-top:2px solid var(--gold)}
.phil-card .q{font-family:var(--serif);font-size:20px;font-style:italic;color:var(--navy);line-height:1.45;margin-bottom:16px}
.phil-card .who{font-family:var(--sans);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600}
.sectors-right{background:var(--navy);padding:66px 52px;display:flex;flex-direction:column;justify-content:center}
.sectors-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.sector-tile{background:rgba(255,255,255,.04);border:1px solid rgba(151,161,188,.22);border-radius:var(--r-sm);padding:24px 14px;display:flex;flex-direction:column;align-items:center;gap:13px;text-align:center;transition:.22s}
.sector-tile:hover{border-color:var(--gold);background:rgba(194,162,76,.08);transform:translateY(-3px)}
.sector-tile svg{width:28px;height:28px;color:var(--steel);transition:.22s}
.sector-tile:hover svg{color:var(--gold-soft)}
.sector-tile span{font-size:13px;color:#E4E8F2;line-height:1.3}
.confidential{font-size:13px;color:rgba(255,255,255,.55);margin-top:28px;display:flex;gap:10px;align-items:flex-start}
.confidential svg{width:16px;height:16px;flex:0 0 auto;margin-top:2px;color:var(--steel)}
@media(max-width:880px){.sectors-split{grid-template-columns:1fr}.sectors-left,.sectors-right{padding:48px 28px}.sectors-grid{grid-template-columns:repeat(2,1fr)}}

/* ============ CTA BAND ============ */
.cta-band{background:linear-gradient(120deg,#13223F,#22304d);text-align:center;position:relative;overflow:hidden}
.cta-band .cta-wm{position:absolute;right:-4%;top:50%;transform:translateY(-50%);width:34%;opacity:.06;pointer-events:none}
.cta-band .wrap{position:relative;z-index:1}
.cta-band h2{color:#fff;font-size:clamp(30px,3.4vw,40px);margin-bottom:14px}
.cta-band p{color:rgba(255,255,255,.78);margin:0 auto 30px;max-width:520px;font-size:17px}

/* ============ CONTACT ============ */
.contact{background:var(--white)}
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px}
.contact h2{font-size:clamp(28px,3vw,40px)}
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:6px;font-family:var(--sans);font-size:15px;background:var(--paper);transition:.2s;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(194,162,76,.14);background:#fff}
.contact-info{background:var(--bone);border:1px solid var(--line);border-radius:var(--r);padding:40px 36px}
.info-row{display:flex;gap:16px;margin-bottom:26px;align-items:flex-start}
.info-row .ic{flex:0 0 auto;width:42px;height:42px;border-radius:10px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold-deep)}
.info-row .ic svg{width:19px;height:19px}
.info-row .lbl{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:3px}
.info-row .val{color:var(--navy);font-size:15px;line-height:1.5}
.map-embed{margin-top:8px;width:100%;height:200px;border:0;border-radius:var(--r-sm)}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:38px}}

/* ============ FOOTER ============ */
footer{background:var(--navy-dark);color:rgba(255,255,255,.66);padding:64px 0 28px;font-size:14px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:42px;margin-bottom:42px}
.foot-brand img{height:96px;margin-bottom:18px}
.foot-brand p{max-width:300px;line-height:1.65}
footer h4{font-family:var(--sans);color:#fff;font-size:12px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
footer ul{list-style:none}
footer li{margin-bottom:11px}
footer a{transition:.2s}
footer a:hover{color:var(--gold-soft)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12.5px;color:rgba(255,255,255,.46)}
.foot-bottom a:hover{color:var(--gold-soft)}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px}.foot-brand{grid-column:1/-1}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* ============ WHATSAPP FLOAT ============ */
.wa{position:fixed;right:24px;bottom:24px;background:#25D366;color:#fff;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px rgba(0,0,0,.28);z-index:80;transition:.2s}
.wa:hover{transform:scale(1.08)}
.wa svg{width:28px;height:28px}

/* ============ REVEAL ANIMATION ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.slide.active{animation:none}.slide.active .slide-photo{animation:none}.slide-video{display:none}.btn::after{display:none}.logo-anim,.logo-anim img,.logo-anim::after{animation:none}.dots button.active::after{animation:none;transform:scaleX(1)}.slide.active .glass>*,.slide.brand.active .brand-inner>*{animation:none}.hero-pano{transition:none}}

/* ============ LEGAL PAGES ============ */
.legal-hero{background:linear-gradient(120deg,#13223F,#22304d);color:#fff;position:relative;overflow:hidden;padding:120px 0 80px}
.legal-hero .lh-wm{position:absolute;right:-3%;top:50%;transform:translateY(-50%);width:30%;opacity:.07;pointer-events:none}
.legal-hero .wrap{position:relative;z-index:1;max-width:880px}
.legal-hero .eyebrow{color:var(--gold-soft);margin-bottom:20px}
.legal-hero .eyebrow::before{background:var(--gold-soft)}
.legal-hero h1{color:#fff;font-size:clamp(38px,5vw,58px)}
.legal-hero p{color:rgba(255,255,255,.78);font-size:18px;font-weight:300;margin-top:18px;max-width:600px}
.legal-meta{margin-top:26px;font-size:13px;color:var(--gold-soft);letter-spacing:.04em}
.legal-body{padding:80px 0 100px}
.legal-layout{display:grid;grid-template-columns:240px 1fr;gap:60px;max-width:1000px;margin:0 auto}
.toc{position:sticky;top:130px;align-self:start;font-size:14px}
.toc h4{font-family:var(--sans);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-weight:600}
.toc ul{list-style:none}
.toc li{margin-bottom:4px}
.toc a{display:block;padding:8px 14px;border-left:2px solid var(--line);color:var(--muted);transition:.2s;font-size:13.5px}
.toc a:hover,.toc a.active{border-color:var(--gold);color:var(--navy)}
.legal-content h2{font-size:26px;margin:48px 0 16px;padding-top:8px}
.legal-content h2:first-child{margin-top:0}
.legal-content h3{font-size:19px;margin:28px 0 10px;font-family:var(--sans);font-weight:700;color:var(--navy)}
.legal-content p{color:#3d4763;font-size:15.5px;margin-bottom:16px;text-wrap:pretty}
.legal-content ul,.legal-content ol{margin:0 0 18px 4px;padding-left:22px;color:#3d4763;font-size:15.5px}
.legal-content li{margin-bottom:9px;padding-left:6px}
.legal-content a{color:var(--gold-text);text-decoration:underline;text-underline-offset:2px}
.legal-content strong{color:var(--navy)}
.callout{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:var(--r-sm);padding:22px 26px;margin:24px 0}
.callout p{margin-bottom:0}
@media(max-width:820px){.legal-layout{grid-template-columns:1fr;gap:32px}.toc{position:static;display:none}}

/* ARCO rights cards */
.arco-rights{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin:8px 0 40px}
.arco-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;box-shadow:var(--sh-sm);transition:.25s;position:relative}
.arco-card:hover{box-shadow:var(--sh-md);transform:translateY(-4px)}
.arco-card .letter{font-family:var(--display);font-size:30px;font-weight:700;color:var(--gold);line-height:1}
.arco-card h3{font-family:var(--serif);font-weight:600;font-size:22px;margin:12px 0 8px}
.arco-card p{color:var(--muted);font-size:14.5px;margin:0}
@media(max-width:600px){.arco-rights{grid-template-columns:1fr}}

/* ARCO form */
.arco-form{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:44px 42px;box-shadow:var(--sh-md);max-width:760px;margin:0 auto}
.arco-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.arco-form .full{grid-column:1/-1}
.radio-set{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}
.radio-chip{border:1px solid var(--line);border-radius:8px;padding:12px 16px;font-size:14px;cursor:pointer;transition:.2s;display:flex;align-items:center;gap:10px;background:#fff}
.radio-chip:hover{border-color:var(--gold)}
.radio-chip input{accent-color:var(--gold-deep)}
.consent{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.5;color:var(--muted);cursor:pointer}
.consent input{margin-top:3px;width:16px;height:16px;flex:none;accent-color:var(--gold-deep);cursor:pointer}
@media(max-width:600px){.arco-form{padding:32px 24px}.arco-form .form-grid{grid-template-columns:1fr}}

/* page-top mini header used on legal pages reuses header styles */
