/* ============================================================
   BartuFinanzas — sitio público (look & feel de Regiones)
   Verde profundo + dorado + marfil · Playfair Display + Archivo
   ============================================================ */
:root{
  --bg:#0B1411; --bg2:#101D18; --panel:#16241E; --panel2:#1E3228;
  --ink:#F2EEE3; --ink-dim:#C7D6CB; --ink-faint:#8FA395;
  --gold:#D8B158; --gold-soft:#E7C97F; --gold-deep:#B8902F; --gold-bright:#F2E2B0;
  --green:#6FE0A0;
  --line:rgba(216,177,88,.20); --line-2:rgba(216,177,88,.40);
  --serif:"Playfair Display",Georgia,serif; --sans:"Archivo",system-ui,sans-serif;
  --r:6px; --r-lg:16px; --maxw:1200px; --ease:cubic-bezier(.22,.7,.22,1); --nav-h:70px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
::selection{background:var(--gold);color:#0B1411}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.65;font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative;min-height:100vh}
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:
  radial-gradient(1100px 620px at 80% -12%,rgba(216,177,88,.10),transparent 60%),
  radial-gradient(900px 560px at -8% 8%,rgba(216,177,88,.05),transparent 55%),
  radial-gradient(1200px 800px at 50% 120%,rgba(0,0,0,.35),transparent 60%),var(--bg)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.08;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
em{font-style:italic;color:var(--gold-soft)}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,52px)}
section{position:relative;padding:clamp(64px,9vw,120px) 0}
.tint{background:var(--bg2)}
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.eyebrow::before{content:"";width:26px;height:2px;border-radius:2px;background:var(--gold)}
.grad{background:linear-gradient(120deg,var(--gold-bright),var(--gold-deep));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;padding:14px 26px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:all .3s var(--ease);white-space:nowrap}
.btn-gold{background:linear-gradient(135deg,var(--gold-soft),var(--gold-deep));color:#0E3B2A}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 14px 34px -14px rgba(216,177,88,.7)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{background:rgba(216,177,88,.1);border-color:var(--gold);color:var(--gold-soft)}
.btn-lg{padding:17px 32px;font-size:14px}

/* ---- Nav ---- */
.nav{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px clamp(20px,5vw,52px);background:rgba(14,59,42,.66);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:.3s}
.nav.scrolled{background:rgba(14,59,42,.93);border-bottom-color:var(--line-2)}
.brand{display:flex;align-items:center;gap:11px;flex:none}
.brand-mark{display:block;height:40px;aspect-ratio:1.86;overflow:hidden;flex:none}
.brand-mark img{width:100%;height:auto;display:block;object-fit:cover;object-position:top center}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand .wm{font-family:var(--serif);font-weight:700;font-size:21px;letter-spacing:.01em;color:var(--ink)}
.brand-tag{font-family:var(--sans);font-size:9.5px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links>a,.nav-drop-btn{font-family:var(--sans);font-size:14px;font-weight:600;color:var(--ink-dim);padding:9px 13px;border-radius:8px;transition:.25s;background:none;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;line-height:1}
.nav-links>a:hover,.nav-links>a.active,.nav-drop-btn:hover,.nav-drop.active .nav-drop-btn{color:var(--gold-soft)}
/* desplegable Servicios */
.nav-drop{position:relative}
.nav-drop-btn svg{transition:transform .25s}
.nav-drop:hover .nav-drop-btn svg,.nav-drop.open .nav-drop-btn svg{transform:rotate(180deg)}
.nav-drop-menu{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);min-width:330px;background:rgba(14,59,42,.97);backdrop-filter:blur(14px);border:1px solid var(--line-2);border-radius:14px;padding:8px;box-shadow:0 30px 60px -30px rgba(0,0,0,.85);opacity:0;visibility:hidden;transition:.28s var(--ease);z-index:120}
.nav-drop:hover .nav-drop-menu,.nav-drop.open .nav-drop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-drop-menu a{display:block;padding:12px 14px;border-radius:10px;transition:.2s}
.nav-drop-menu a:hover{background:rgba(216,177,88,.1)}
.nav-drop-menu a b{display:block;font-family:var(--sans);font-size:14.5px;font-weight:700;color:var(--ink)}
.nav-drop-menu a:hover b{color:var(--gold-soft)}
.nav-drop-menu a span{display:block;font-size:12.5px;color:var(--ink-faint);margin-top:2px}
.nav-cta{display:flex;align-items:center;gap:10px;flex:none}
.nav-cta .access{font-size:13px;font-weight:600;color:var(--ink-dim)}
.nav-cta .access:hover{color:var(--gold-soft)}
.burger{display:none;width:42px;height:42px;border:1px solid var(--line-2);border-radius:8px;background:none;color:var(--gold-soft);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.burger span{display:block;width:20px;height:2px;background:currentColor;border-radius:2px;transition:.3s}

/* ---- Hero ---- */
.hero{padding:clamp(36px,5vw,70px) 0 clamp(40px,6vw,80px)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,4vw,56px);align-items:center}
.tag{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:700;color:var(--gold-soft);letter-spacing:.04em;margin-bottom:22px}
.tag .star{color:var(--gold)}
.hero h1{font-size:clamp(40px,6.4vw,76px);font-weight:600;letter-spacing:-.02em}
.hero h1 em{color:var(--gold-soft)}
.hero .lead{margin:24px 0 30px;font-size:clamp(16px,1.9vw,20px);color:var(--ink-dim);max-width:46ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-tabs{display:flex;gap:8px;margin-top:30px;flex-wrap:wrap}
.hero-tabs span{font-size:12px;font-weight:600;letter-spacing:.05em;color:var(--ink-dim);border:1px solid var(--line);border-radius:999px;padding:7px 16px}
.hero-tabs span b{color:var(--gold-soft);font-weight:700}
.hero-portrait{position:relative;margin:0}
.hero-portrait::before{content:"";position:absolute;inset:-6% -4% -8% -4%;z-index:0;background:radial-gradient(60% 60% at 55% 40%,rgba(216,177,88,.28),rgba(216,177,88,.05) 45%,transparent 72%);filter:blur(16px)}
.hero-portrait img{position:relative;z-index:1;width:100%;max-width:460px;display:block;margin-left:auto;aspect-ratio:4/5;object-fit:cover;object-position:top center;border-radius:14px;
  -webkit-mask-image:radial-gradient(118% 92% at 54% 38%,#000 42%,transparent 85%);mask-image:radial-gradient(118% 92% at 54% 38%,#000 42%,transparent 85%)}
/* portada: Bartu recortado, solo él sobre el fondo de la web (sin marco ni halo) */
.person-hero::before{display:none}
.person-hero img{aspect-ratio:1111/1788;object-fit:contain;object-position:bottom center;background:transparent;border:none;border-radius:0;box-shadow:none;-webkit-mask-image:none;mask-image:none}
/* portada con globo (imagen ya integrada sobre fondo verde) */
.globe-hero::before{background:radial-gradient(58% 58% at 50% 45%,rgba(216,177,88,.22),rgba(216,177,88,.04) 50%,transparent 74%)}
.globe-hero img{aspect-ratio:4/5;object-position:center;border:1px solid var(--line);box-shadow:0 40px 90px -50px rgba(0,0,0,.9);
  -webkit-mask-image:radial-gradient(125% 100% at 50% 50%,#000 60%,transparent 96%);mask-image:radial-gradient(125% 100% at 50% 50%,#000 60%,transparent 96%)}

/* ---- Stat strip ---- */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats .wrap{display:flex;flex-wrap:wrap;gap:30px;justify-content:space-between;padding-top:34px;padding-bottom:34px}
.stat .n{font-family:var(--serif);font-weight:600;font-size:clamp(30px,4vw,46px);color:var(--gold-soft);line-height:1}
.stat .l{font-size:13.5px;color:var(--ink-dim);margin-top:8px;letter-spacing:.02em}

/* ---- Section heads ---- */
.head{max-width:720px;margin-bottom:50px}
.head.center{margin-left:auto;margin-right:auto;text-align:center}
.head.center .eyebrow{justify-content:center}
.head h2{font-size:clamp(30px,5vw,54px);margin:16px 0 14px;font-weight:600}
.head h2 em{color:var(--gold-soft)}
.head p{color:var(--ink-dim);font-size:clamp(16px,2vw,18px)}
.head.center p{margin-left:auto;margin-right:auto;max-width:60ch}

/* ---- Services grid ---- */
.svcs{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{position:relative;border-radius:var(--r-lg);padding:30px;background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line-2);overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.card:hover{transform:translateY(-5px);box-shadow:0 30px 60px -40px rgba(0,0,0,.85)}
.card .ico{width:52px;height:52px;border-radius:13px;display:grid;place-items:center;margin-bottom:18px;background:linear-gradient(145deg,var(--gold-soft),var(--gold-deep));box-shadow:0 8px 20px -10px rgba(216,177,88,.6)}
.card .ico svg{width:24px;height:24px;stroke:#0B1411;fill:none;stroke-width:1.8}
.card h3{font-size:21px;margin-bottom:10px}
.card p{color:var(--ink-dim);font-size:14.5px}
.card .more{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-size:12.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gold-soft)}

/* ---- Global presence / regiones teaser ---- */
.globe{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.region{position:relative;display:block;overflow:hidden;border-radius:var(--r-lg);border:1px solid var(--line);aspect-ratio:3/2;transition:.4s var(--ease)}
.region:hover{transform:translateY(-4px);border-color:var(--gold)}
.region img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.region:hover img{transform:scale(1.07)}
.region span{position:absolute;inset:0;display:flex;align-items:flex-end;gap:9px;padding:14px;background:linear-gradient(180deg,transparent 45%,rgba(8,17,13,.9));font-family:var(--serif);font-weight:600;font-size:15px;color:var(--ink)}
.region img.flag{position:static;width:26px;height:auto;border-radius:2px;box-shadow:0 0 0 1px rgba(255,255,255,.2);flex:none}

/* ---- Método band ---- */
.metodo{background:linear-gradient(160deg,var(--panel),var(--bg2));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.metodo .wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center}
.metodo h2{font-size:clamp(28px,4.5vw,46px);margin:14px 0 16px}
.metodo p{color:var(--ink-dim);font-size:16px;margin-bottom:12px}

/* ---- CTA band ---- */
.cta{background:linear-gradient(135deg,var(--gold-deep),var(--gold-soft));color:#0E3B2A;text-align:center}
.cta h2{font-size:clamp(30px,5vw,54px);font-weight:600}
.cta p{font-size:18px;margin:16px auto 28px;max-width:54ch;color:#21331c}
.cta .btn-dark{background:#0B1411;color:var(--gold-soft);border:none}
.cta .btn-dark:hover{transform:translateY(-2px);box-shadow:0 14px 34px -14px rgba(0,0,0,.6)}

/* ---- Footer ---- */
.footer{background:#0A2419;border-top:1px solid var(--line);padding:clamp(50px,7vw,84px) 0 36px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1.2fr;gap:40px}
.foot-brand p{color:var(--ink-dim);font-size:14.5px;margin:16px 0 0;max-width:36ch}
.foot-col h5{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--gold);margin-bottom:16px}
.foot-col a{display:block;color:var(--ink-dim);font-size:14.5px;padding:6px 0;transition:.25s}
.foot-col a:hover{color:var(--gold-soft)}
.foot-col p{color:var(--ink-dim);font-size:14.5px;margin-bottom:6px}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:46px;padding-top:24px;border-top:1px solid var(--line);color:var(--ink-faint);font-size:13px}

/* ---- Reveal ---- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}.reveal[data-d="3"]{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* ---- page hero (interior) ---- */
.page-hero{padding:clamp(40px,6vw,80px) 0 clamp(20px,3vw,36px)}
.page-hero h1{font-size:clamp(36px,6vw,68px);font-weight:600}
.page-hero h1 em{color:var(--gold-soft)}
.page-hero p{color:var(--ink-dim);font-size:clamp(16px,2vw,19px);max-width:60ch;margin-top:18px}

/* ---- Responsive ---- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr} .hero-portrait{max-width:420px;margin:0 auto}
  .svcs{grid-template-columns:1fr 1fr} .globe{grid-template-columns:1fr 1fr}
  .metodo .wrap{grid-template-columns:1fr} .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:940px){
  .nav-links,.nav-cta .access{display:none} .burger{display:flex}
  .nav.open .nav-links{display:flex;position:absolute;top:100%;left:12px;right:12px;flex-direction:column;align-items:stretch;gap:2px;padding:14px;margin-top:8px;background:rgba(11,20,17,.98);border:1px solid var(--line-2);border-radius:var(--r-lg);box-shadow:0 30px 60px -30px rgba(0,0,0,.85)}
  .nav.open .nav-links>a,.nav.open .nav-drop-btn{width:100%;justify-content:flex-start;padding:12px 14px}
  .nav-drop{width:100%}
  .nav-drop-menu{position:static;transform:none;min-width:0;width:100%;box-shadow:none;background:rgba(255,255,255,.03);margin:2px 0 6px;opacity:1;visibility:visible;display:none;border-color:var(--line)}
  .nav-drop.open .nav-drop-menu{display:block;transform:none}
  .nav-drop:hover .nav-drop-menu{opacity:0;visibility:hidden} .nav-drop.open:hover .nav-drop-menu,.nav-drop.open .nav-drop-menu{opacity:1;visibility:visible}
}
@media(max-width:680px){
  .svcs{grid-template-columns:1fr} .globe{grid-template-columns:1fr 1fr} .foot-grid{grid-template-columns:1fr;gap:26px}
}

/* ---- Página Regiones (grid grande) ------------------------- */
.regions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.regions-grid .region{aspect-ratio:3/2}
.regions-grid .region span{font-size:17px}
@media(max-width:900px){.regions-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.regions-grid{grid-template-columns:1fr}}

/* ---- Toggle de idioma ES/EN -------------------------------- */
.lang-toggle{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;letter-spacing:.04em;color:var(--ink-faint)}
.lang-toggle a{color:var(--ink-faint);padding:2px 4px;border-radius:5px;transition:.2s}
.lang-toggle a.active{color:var(--gold-soft)}
.lang-toggle a:hover{color:var(--gold)}
.lang-toggle .sep{opacity:.5}
