/* ============================================================
   AVIL — SHARED DESIGN SYSTEM
   Used by every page. Maps to the WordPress theme stylesheet.
   ============================================================ */
:root{
  --bg:        #FBFAF8;
  --bg-warm:   #F4F1EC;
  --white:     #FFFFFF;
  --ink:       #161B26;
  --slate:     #4F5D75;
  --slate-2:   #6B7890;
  --orange:    #F37505;
  --orange-d:  #D9650A;
  --mist:      #EEF0F4;

  --glass:        rgba(255,255,255,0.55);
  --glass-brd:    rgba(255,255,255,0.75);
  --glass-shadow: 0 30px 70px -28px rgba(22,27,38,0.28);
  --glass-shadow-lg: 0 50px 120px -40px rgba(22,27,38,0.40);

  --r-sm: 14px;
  --r-md: 22px;
  --r-lg: 32px;
  --r-xl: 44px;

  --ease: cubic-bezier(.22,1,.36,1);
  --ease-soft: cubic-bezier(.4,0,.2,1);

  --container: 1240px;
  --pad: clamp(20px, 5vw, 64px);
  --section-y: clamp(90px, 13vw, 170px);

  --font-body: "Montserrat", -apple-system, BlinkMacSystemFont, sans-serif;
  --font-display: "Fraunces", Georgia, serif;
}

/* ---------- RESET ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-smooth [data-lenis-prevent]{ overscroll-behavior:contain; }
.lenis.lenis-stopped{ overflow:hidden; }
body{ font-family:var(--font-body); background:var(--bg); color:var(--ink); font-weight:300; line-height:1.6; overflow-x:hidden; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
::selection{ background:var(--orange); color:#fff; }

body::before{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(60% 50% at 80% -5%, rgba(243,117,5,0.10), transparent 60%),
    radial-gradient(50% 45% at -5% 15%, rgba(79,93,117,0.10), transparent 60%),
    radial-gradient(40% 40% at 50% 110%, rgba(243,117,5,0.06), transparent 60%);
}
body::after{
  content:""; position:fixed; inset:0; z-index:-1; opacity:.4; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
}

/* ---------- LAYOUT HELPERS ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--pad); }
.eyebrow{ display:inline-flex; align-items:center; gap:.6em; font-size:.72rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--orange); }
.eyebrow::before{ content:""; width:26px; height:1.5px; background:var(--orange); display:inline-block; }
.section-head{ max-width:680px; margin-bottom:clamp(40px,6vw,72px); }
.section-head h2{ font-family:var(--font-display); font-weight:500; font-size:clamp(2rem,4.6vw,3.4rem); line-height:1.05; letter-spacing:-.02em; margin:.5em 0 .35em; }
.section-head p{ font-size:clamp(1rem,1.4vw,1.15rem); color:var(--slate); max-width:54ch; }
.accent{ color:var(--orange); }
.serif-it{ font-family:var(--font-display); font-style:italic; font-weight:400; }

/* ---------- BUTTONS ---------- */
.btn{ position:relative; display:inline-flex; align-items:center; gap:.6em; padding:1.05em 1.7em; border-radius:100px; font-size:.95rem; font-weight:600; letter-spacing:.01em; transition:transform .5s var(--ease), box-shadow .5s var(--ease), background .35s; will-change:transform; }
.btn .ico{ transition:transform .45s var(--ease); }
.btn:hover .ico{ transform:translateX(4px); }
.btn-primary{ background:var(--orange); color:#fff; box-shadow:0 16px 34px -12px rgba(243,117,5,.6); overflow:hidden; }
.btn-primary:hover{ box-shadow:0 22px 46px -12px rgba(243,117,5,.7); }
.btn-primary::after{ content:""; position:absolute; top:0; left:-130%; width:55%; height:100%; background:linear-gradient(120deg,transparent,rgba(255,255,255,.4),transparent); transform:skewX(-20deg); transition:left .65s var(--ease); pointer-events:none; }
.btn-primary:hover::after{ left:150%; }
.btn-ghost{ background:rgba(79,93,117,.07); color:var(--ink); border:1px solid rgba(79,93,117,.16); }
.btn-ghost:hover{ background:rgba(79,93,117,.12); }
.btn-light{ background:#fff; color:var(--ink); box-shadow:var(--glass-shadow); }

/* ---------- SCROLL PROGRESS ---------- */
.scroll-bar{ position:fixed; top:0; left:0; height:3px; width:0%; z-index:200; background:linear-gradient(90deg,var(--orange),var(--orange-d)); }

/* ---------- FINANCIAL TICKER ---------- */
:root{ --ticker-h:34px; }
.ticker{ position:fixed; top:0; left:0; right:0; height:var(--ticker-h); z-index:96; background:var(--ink); color:rgba(255,255,255,.92); display:flex; align-items:center; overflow:hidden; transition:transform .45s var(--ease); }
.ticker.hide{ transform:translateY(-100%); }
.ticker-mask{ width:100%; overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent); mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent); }
.ticker-track{ display:flex; gap:26px; width:max-content; white-space:nowrap; will-change:transform; align-items:center; padding-left:20px; }
.tk{ display:inline-flex; align-items:center; gap:.45em; font-size:.76rem; font-weight:500; }
.tk-l{ color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:.06em; font-size:.68rem; }
.tk-v{ font-weight:600; }
.tk .up{ color:#4ade80; } .tk .down{ color:#f87171; }
.tk-sep{ color:rgba(255,255,255,.18); }
.ticker-tag{ flex-shrink:0; background:var(--orange); color:#fff; font-size:.64rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:0 12px; height:100%; display:flex; align-items:center; z-index:1; }

/* ---------- PAGE TRANSITION CURTAIN ---------- */
.page-curtain{ position:fixed; inset:0; z-index:300; background:linear-gradient(150deg,var(--slate),var(--ink)); display:grid; place-items:center; pointer-events:none; }
.page-curtain .pc-mark{ display:flex; flex-direction:column; align-items:center; gap:16px; }
.page-curtain img{ height:52px; width:auto; opacity:.96; }
.page-curtain .pc-bar{ width:0; height:2px; background:var(--orange); border-radius:2px; }

/* ---------- NAV ---------- */
.nav{ position:fixed; top:var(--ticker-h); left:0; right:0; z-index:100; display:flex; align-items:center; justify-content:space-between; padding:18px var(--pad); transition:padding .4s var(--ease), background .4s, box-shadow .4s, backdrop-filter .4s, top .45s var(--ease); }
.nav.scrolled{ top:0; padding:11px var(--pad); background:rgba(251,250,248,.72); backdrop-filter:blur(18px) saturate(1.4); -webkit-backdrop-filter:blur(18px) saturate(1.4); box-shadow:0 1px 0 rgba(79,93,117,.10); }
.brand{ display:flex; align-items:center; gap:.55em; font-weight:800; font-size:1.35rem; letter-spacing:-.02em; }
.brand .dot{ width:11px; height:11px; border-radius:50%; background:var(--orange); box-shadow:0 0 0 4px rgba(243,117,5,.18); }
.nav-links{ display:flex; align-items:center; gap:2.1rem; }
.nav-links > a, .nav-dd-trigger{ position:relative; font-size:.92rem; font-weight:500; color:var(--slate); transition:color .3s; cursor:pointer; }
.nav-links > a::after, .nav-dd-trigger::after{ content:""; position:absolute; left:0; bottom:-6px; height:2px; width:100%; background:var(--orange); transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease); }
.nav-links > a:hover, .nav-dd-trigger:hover{ color:var(--ink); }
.nav-links > a:hover::after, .nav-dd:hover .nav-dd-trigger::after{ transform:scaleX(1); }
.nav-links > a.active{ color:var(--ink); }
.nav-links > a.active::after{ transform:scaleX(1); }

/* dropdown */
.nav-dd{ position:relative; }
.nav-dd-menu{ position:absolute; top:150%; left:50%; transform:translateX(-50%) translateY(8px); background:rgba(255,255,255,.85); backdrop-filter:blur(20px) saturate(1.4); -webkit-backdrop-filter:blur(20px) saturate(1.4); border:1px solid rgba(255,255,255,.7); border-radius:18px; padding:10px; min-width:230px; opacity:0; visibility:hidden; transition:.3s var(--ease); box-shadow:var(--glass-shadow); }
.nav-dd:hover .nav-dd-menu{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.nav-dd-menu a{ display:block; padding:11px 14px; border-radius:11px; font-size:.9rem; font-weight:500; color:var(--slate); transition:.25s; }
.nav-dd-menu a:hover{ background:rgba(243,117,5,.08); color:var(--orange); transform:translateX(3px); }
.nav-cta{ display:flex; align-items:center; gap:1rem; }
.burger{ display:none; flex-direction:column; gap:5px; padding:8px; }
.burger span{ width:24px; height:2px; background:var(--ink); border-radius:2px; transition:.3s; }

/* ---------- HERO (home) ---------- */
.hero{ position:relative; padding:clamp(130px,17vw,180px) 0 clamp(70px,9vw,110px); }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,70px); align-items:center; }
.hero-eyebrow{ opacity:0; }
.hero h1{ font-family:var(--font-display); font-weight:500; font-size:clamp(2.7rem,6.4vw,5.1rem); line-height:.99; letter-spacing:-.025em; margin:.35em 0 .55em; }
.hero h1 .line{ display:block; overflow:hidden; }
.hero h1 .line > span{ display:block; transform:translateY(110%); }
.hero-sub{ font-size:clamp(1.05rem,1.5vw,1.25rem); color:var(--slate); max-width:30ch; margin-bottom:2.2em; opacity:0; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:1rem; opacity:0; }
.hero-note{ margin-top:1.7em; font-size:.85rem; color:var(--slate-2); display:flex; align-items:center; gap:.55em; opacity:0; }
.hero-note .check{ width:18px;height:18px;border-radius:50%;background:rgba(243,117,5,.14);color:var(--orange); display:grid;place-items:center;font-size:.7rem;font-weight:700; }

.hero-visual{ position:relative; height:clamp(360px,46vw,540px); perspective:1400px; }
.orb{ position:absolute; border-radius:50%; filter:blur(8px); pointer-events:none; }
.orb.o1{ width:240px;height:240px; background:radial-gradient(circle at 35% 35%,rgba(243,117,5,.55),rgba(243,117,5,0) 70%); top:-30px; right:0; }
.orb.o2{ width:180px;height:180px; background:radial-gradient(circle at 35% 35%,rgba(79,93,117,.5),rgba(79,93,117,0) 70%); bottom:10px; left:-10px; }

.glass-card{ position:absolute; background:var(--glass); border:1px solid var(--glass-brd); border-radius:var(--r-lg); backdrop-filter:blur(26px) saturate(1.5); -webkit-backdrop-filter:blur(26px) saturate(1.5); box-shadow:var(--glass-shadow-lg); }
.dash{ inset:6% 4% 6% 6%; padding:26px; display:flex; flex-direction:column; gap:18px; opacity:0; }
.dash-top{ display:flex; align-items:center; justify-content:space-between; }
.dash-top .t-label{ font-size:.72rem; text-transform:uppercase; letter-spacing:.14em; color:var(--slate-2); font-weight:600; }
.dash-top .t-pill{ font-size:.7rem; font-weight:600; color:var(--orange); background:rgba(243,117,5,.12); padding:.4em .8em; border-radius:100px; }
.dash-balance{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.8rem,3.4vw,2.6rem); letter-spacing:-.02em; }
.dash-balance small{ font-family:var(--font-body); font-size:.9rem; color:var(--slate); font-weight:500; }
.bars{ display:flex; align-items:flex-end; gap:10px; height:120px; margin-top:auto; }
.bar{ flex:1; border-radius:8px 8px 4px 4px; background:linear-gradient(var(--slate),rgba(79,93,117,.35)); height:20%; transition:height 1.1s var(--ease); }
.bar.hot{ background:linear-gradient(var(--orange),rgba(243,117,5,.4)); }
.dash-foot{ display:flex; gap:8px; }
.dash-foot .row{ height:9px; border-radius:6px; background:rgba(79,93,117,.16); }
.dash-foot .row:nth-child(1){ width:38%; } .dash-foot .row:nth-child(2){ width:24%; } .dash-foot .row:nth-child(3){ width:18%; }

.chip{ position:absolute; display:flex; align-items:center; gap:.6em; padding:.8em 1.1em; border-radius:100px; background:var(--glass); border:1px solid var(--glass-brd); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); box-shadow:var(--glass-shadow); font-size:.82rem; font-weight:600; opacity:0; }
.chip .ic{ width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:.7rem;color:#fff; }
.chip.c1{ top:2%; right:-2%; } .chip.c1 .ic{ background:var(--orange); }
.chip.c2{ bottom:6%; right:8%; } .chip.c2 .ic{ background:var(--slate); }

/* enriched hero dashboard */
.dash{ gap:13px; }
.live-dot{ width:7px; height:7px; border-radius:50%; background:#2faa5a; display:inline-block; margin-right:5px; vertical-align:middle; animation:livePulse 1.8s infinite; }
@keyframes livePulse{ 0%{ box-shadow:0 0 0 0 rgba(47,170,90,.5); } 70%{ box-shadow:0 0 0 6px rgba(47,170,90,0); } 100%{ box-shadow:0 0 0 0 rgba(47,170,90,0); } }
.dash-balance-row{ display:flex; align-items:flex-start; justify-content:space-between; gap:10px; }
.dash-sub{ font-size:.72rem; color:var(--slate-2); margin-top:.25em; }
.trend-chip{ flex-shrink:0; font-size:.74rem; font-weight:700; color:#2faa5a; background:rgba(47,170,90,.12); padding:.4em .7em; border-radius:100px; }
.dash-chart{ flex:1; min-height:72px; }
.dash-chart svg{ width:100%; height:100%; display:block; overflow:visible; }
.chart-dot{ filter:drop-shadow(0 0 5px rgba(243,117,5,.7)); }
.dash-grid{ display:flex; align-items:center; gap:18px; }
.donut-wrap{ display:flex; flex-direction:column; align-items:center; gap:4px; flex-shrink:0; }
.donut{ position:relative; width:56px; height:56px; }
.donut svg{ width:100%; height:100%; }
.donut-val{ position:absolute; inset:0; display:grid; place-items:center; font-size:.74rem; font-weight:700; color:var(--ink); }
.donut-cap{ font-size:.6rem; color:var(--slate-2); text-transform:uppercase; letter-spacing:.07em; }
.mini-kpis{ display:flex; gap:20px; flex:1; }
.kpi{ display:flex; flex-direction:column; gap:2px; }
.kpi-l{ font-size:.64rem; color:var(--slate-2); text-transform:uppercase; letter-spacing:.08em; }
.kpi-v{ font-family:var(--font-display); font-size:1.05rem; font-weight:500; color:var(--ink); letter-spacing:-.01em; }

/* ============================================================
   FLOATING DATA WIDGETS (over images) + pillar mini-viz
   ============================================================ */
.media-stack{ position:relative; }
.fwidget{ position:absolute; z-index:3; display:flex; align-items:center; gap:.55em; padding:.7em .95em; border-radius:14px;
  background:var(--glass); border:1px solid var(--glass-brd); backdrop-filter:blur(18px) saturate(1.4); -webkit-backdrop-filter:blur(18px) saturate(1.4);
  box-shadow:var(--glass-shadow); font-size:.8rem; font-weight:600; color:var(--ink); opacity:0; }
.fwidget .w-dot{ width:8px; height:8px; border-radius:50%; background:#2faa5a; animation:livePulse 1.8s infinite; flex-shrink:0; }
.fwidget .w-ic{ width:22px; height:22px; border-radius:50%; display:grid; place-items:center; color:#fff; font-size:.7rem; background:#2faa5a; flex-shrink:0; }
.fwidget.fw-tl{ top:7%; left:-7%; } .fwidget.fw-br{ bottom:9%; right:-6%; }
.w-bars{ display:flex; align-items:flex-end; gap:3px; height:24px; }
.w-bars i{ width:5px; border-radius:2px; background:var(--orange); height:25%; display:block; }
.w-col{ display:flex; flex-direction:column; line-height:1.05; gap:1px; }
.w-num{ font-family:var(--font-display); font-weight:500; font-size:1.15rem; color:var(--ink); }
.w-cap{ font-size:.6rem; color:var(--slate-2); text-transform:uppercase; letter-spacing:.06em; font-weight:600; }

/* pillar mini-viz */
.pcard-widget{ margin-top:18px; padding-top:16px; border-top:1px solid rgba(79,93,117,.1); }
.pw-bars{ display:flex; align-items:flex-end; gap:6px; height:38px; }
.pw-bars i{ flex:1; border-radius:3px; background:linear-gradient(var(--orange),rgba(243,117,5,.4)); height:20%; }
.pw-spark{ width:100%; height:40px; }
.pw-spark svg{ width:100%; height:100%; overflow:visible; }
.pw-chips{ display:flex; gap:7px; flex-wrap:wrap; }
.pw-chip{ font-size:.64rem; font-weight:700; padding:.4em .75em; border-radius:100px; background:rgba(79,93,117,.08); color:var(--slate-2); display:inline-flex; align-items:center; gap:.4em; transition:background .4s, color .4s; }
.pw-chip.on{ background:rgba(243,117,5,.12); color:var(--orange); }
.pw-chip .c{ width:15px; height:15px; border-radius:50%; background:rgba(79,93,117,.25); display:grid; place-items:center; font-size:.58rem; color:#fff; line-height:1; transition:background .3s; }
.pw-chip.on .c{ background:var(--orange); }
.pw-chip.on .c::after{ content:'✓'; }
.pw-lbl{ font-size:.62rem; color:var(--slate-2); text-transform:uppercase; letter-spacing:.07em; font-weight:600; margin-bottom:8px; display:block; }

/* ---------- TRUST STATS ---------- */
.trust{ padding:clamp(30px,4vw,40px) 0; border-top:1px solid rgba(79,93,117,.10); border-bottom:1px solid rgba(79,93,117,.10); }
.trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat{ text-align:center; }
.stat .num{ font-family:var(--font-display); font-weight:500; font-size:clamp(2rem,3.6vw,3rem); letter-spacing:-.02em; line-height:1; }
.stat .lbl{ margin-top:.5em; font-size:.85rem; color:var(--slate); }

/* ---------- PILLARS / CARDS-3 ---------- */
.pillars{ padding:var(--section-y) 0 0; }
.cards-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.pcard{ position:relative; overflow:hidden; padding:36px 32px 34px; border-radius:var(--r-md); background:var(--white); border:1px solid rgba(79,93,117,.10); box-shadow:0 24px 50px -34px rgba(22,27,38,.3); transition:transform .6s var(--ease), box-shadow .6s var(--ease); }
.pcard .glow{ position:absolute; width:280px;height:280px; border-radius:50%; pointer-events:none; opacity:0; background:radial-gradient(circle,rgba(243,117,5,.18),transparent 65%); transform:translate(-50%,-50%); transition:opacity .4s; }
.pcard:hover{ transform:translateY(-7px); box-shadow:0 40px 80px -40px rgba(22,27,38,.4); }
.pcard:hover .glow{ opacity:1; }
.pcard .picon{ width:54px;height:54px;border-radius:16px; display:grid;place-items:center; margin-bottom:22px; background:rgba(243,117,5,.10); color:var(--orange); font-size:1.4rem; }
.pcard h3{ font-size:1.3rem; font-weight:700; letter-spacing:-.01em; margin-bottom:.5em; }
.pcard p{ color:var(--slate); font-size:.97rem; }
.pcard .tag{ display:inline-block; margin-top:18px; font-size:.68rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--orange); background:rgba(243,117,5,.09); padding:.45em .9em; border-radius:100px; }

/* ---------- SERVICES GRID (home) ---------- */
.services{ padding:var(--section-y) 0 0; }
.svc-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
.svc{ position:relative; overflow:hidden; display:flex; flex-direction:column; justify-content:space-between; min-height:300px; padding:34px; border-radius:var(--r-lg); background:linear-gradient(150deg,#fff,#fbfaf8); border:1px solid rgba(79,93,117,.10); box-shadow:0 24px 50px -36px rgba(22,27,38,.3); transition:transform .6s var(--ease), box-shadow .6s var(--ease); }
.svc::after{ content:""; position:absolute; right:-60px; top:-60px; width:200px; height:200px; border-radius:50%; background:radial-gradient(circle,rgba(243,117,5,.14),transparent 68%); opacity:0; transition:opacity .5s; }
.svc:hover{ transform:translateY(-7px); box-shadow:0 46px 90px -44px rgba(22,27,38,.42); }
.svc:hover::after{ opacity:1; }
.svc .svc-num{ font-family:var(--font-display); font-size:.95rem; color:var(--slate-2); }
.svc h3{ font-size:1.55rem; font-weight:700; letter-spacing:-.015em; margin:.7em 0 .4em; }
.svc p{ color:var(--slate); font-size:.97rem; max-width:36ch; }
.svc .more{ display:inline-flex; align-items:center; gap:.5em; margin-top:24px; font-weight:600; font-size:.9rem; color:var(--orange); }
.svc .more .ico{ transition:transform .45s var(--ease); }
.svc:hover .more .ico{ transform:translateX(5px); }

/* ---------- DIFFERENTIATORS ---------- */
.diff{ padding:var(--section-y) 0 0; }
.diff-wrap{ border-radius:var(--r-lg); overflow:hidden; border:1px solid rgba(79,93,117,.12); background:var(--white); box-shadow:var(--glass-shadow); }
.diff-row{ display:grid; grid-template-columns:1fr 1fr; }
.diff-head{ font-size:.72rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; }
.diff-cell{ padding:24px clamp(20px,3vw,36px); border-bottom:1px solid rgba(79,93,117,.10); display:flex; align-items:center; gap:.8em; font-size:1.02rem; }
.diff-row:last-child .diff-cell{ border-bottom:none; }
.diff-cell.old{ color:var(--slate); background:rgba(79,93,117,.03); }
.diff-cell.old .mk{ color:var(--slate-2); }
.diff-cell.avil{ position:relative; font-weight:500; }
.diff-cell.avil .mk{ color:var(--orange); font-weight:700; }
.diff-cell.head-old{ color:var(--slate); }
.diff-cell.head-avil{ color:var(--orange); }
.diff-cell.avil::before{ content:""; position:absolute; left:0; top:50%; width:3px; height:0; border-radius:3px; background:var(--orange); transform:translateY(-50%); transition:height .6s var(--ease); }
.diff-cell.avil.lit::before{ height:58%; }

/* ---------- TESTIMONIALS ---------- */
.tst{ padding:var(--section-y) 0 0; overflow:hidden; }
.marquee{ display:flex; gap:22px; width:max-content; will-change:transform; }
.marquee-mask{ -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.tcard{ width:380px; flex-shrink:0; padding:32px; border-radius:var(--r-md); background:var(--white); border:1px solid rgba(79,93,117,.10); box-shadow:0 24px 50px -36px rgba(22,27,38,.28); }
.tcard .quote{ font-size:1.02rem; color:var(--ink); line-height:1.6; margin-bottom:24px; }
.tcard .quote::before{ content:"\201C"; font-family:var(--font-display); font-size:2.4rem; color:var(--orange); line-height:0; vertical-align:-.35em; margin-right:.08em; }
.tperson{ display:flex; align-items:center; gap:14px; }
.tavatar{ width:48px;height:48px;border-radius:50%; display:grid;place-items:center; font-weight:700; color:#fff; font-size:1rem; flex-shrink:0; }
.tperson .pn{ font-weight:600; font-size:.95rem; }
.tperson .pr{ font-size:.82rem; color:var(--slate); }
.tperson .pm{ margin-left:auto; font-size:.72rem; font-weight:600; color:var(--orange); text-align:right; max-width:90px; }

/* ---------- BLOG ---------- */
.blog{ padding:var(--section-y) 0 0; }
.blog-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:clamp(36px,5vw,56px); }
.bcard{ display:flex; flex-direction:column; border-radius:var(--r-md); overflow:hidden; background:var(--white); border:1px solid rgba(79,93,117,.10); box-shadow:0 24px 50px -38px rgba(22,27,38,.28); transition:transform .55s var(--ease), box-shadow .55s var(--ease); }
.bcard:hover{ transform:translateY(-6px); box-shadow:0 42px 80px -44px rgba(22,27,38,.4); }
.bcard .bthumb{ height:170px; position:relative; overflow:hidden; background:linear-gradient(135deg,var(--slate),var(--ink)); }
.bcard .bthumb.t2{ background:linear-gradient(135deg,#5a6276,#2a3140); }
.bcard .bthumb.t3{ background:linear-gradient(135deg,var(--orange-d),#9c4a08); }
.bcard .bthumb img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.bcard:hover .bthumb img{ transform:scale(1.05); }
.bcard .bthumb::after{ content:""; position:absolute; inset:0; background:radial-gradient(70% 60% at 75% 20%,rgba(243,117,5,.4),transparent 60%); pointer-events:none; }
.bcard .bthumb .gl{ position:absolute; inset:0; opacity:.35; background-image:radial-gradient(rgba(255,255,255,.5) 1px,transparent 1px); background-size:18px 18px; }
.bbody{ padding:24px 24px 28px; display:flex; flex-direction:column; gap:12px; flex:1; }
.bmeta{ display:flex; align-items:center; gap:.7em; font-size:.74rem; color:var(--slate-2); }
.bcat{ font-weight:600; color:var(--orange); text-transform:uppercase; letter-spacing:.1em; }
.bcard h3{ font-size:1.18rem; font-weight:700; letter-spacing:-.01em; line-height:1.25; }
.bcard p{ font-size:.92rem; color:var(--slate); flex:1; }
.bcard .read{ font-size:.85rem; font-weight:600; color:var(--ink); display:inline-flex; gap:.5em; align-items:center; }
.bcard:hover .read{ color:var(--orange); }

/* ---------- CTA FINAL ---------- */
.cta{ padding:var(--section-y) 0; }
.cta-panel{ position:relative; overflow:hidden; border-radius:var(--r-xl); padding:clamp(40px,6vw,80px); background:linear-gradient(150deg,var(--slate),var(--ink)); color:#fff; box-shadow:var(--glass-shadow-lg); display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,64px); align-items:center; }
.cta-panel .corb{ position:absolute; border-radius:50%; pointer-events:none; }
.cta-panel .corb.a{ width:340px;height:340px; top:-120px; right:-60px; background:radial-gradient(circle,rgba(243,117,5,.5),transparent 65%); filter:blur(10px); }
.cta-panel .corb.b{ width:260px;height:260px; bottom:-120px; left:-40px; background:radial-gradient(circle,rgba(255,255,255,.16),transparent 65%); filter:blur(10px); }
.cta-copy{ position:relative; z-index:1; }
.cta-copy .eyebrow{ color:#fff; } .cta-copy .eyebrow::before{ background:var(--orange); }
.cta-copy h2{ font-family:var(--font-display); font-weight:500; font-size:clamp(2rem,4vw,3.1rem); line-height:1.04; letter-spacing:-.02em; margin:.5em 0 .4em; }
.cta-copy p{ color:rgba(255,255,255,.7); max-width:38ch; }
.cta-contact{ margin-top:1.8em; display:flex; flex-direction:column; gap:.6em; font-size:.9rem; color:rgba(255,255,255,.85); }
.cta-contact span{ display:flex; align-items:center; gap:.6em; }
.cta-form{ position:relative; z-index:1; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16); border-radius:var(--r-lg); padding:clamp(26px,3vw,38px); backdrop-filter:blur(22px); -webkit-backdrop-filter:blur(22px); }
.field{ position:relative; margin-bottom:26px; }
.field input, .field select, .field textarea{ width:100%; background:transparent; border:none; border-bottom:1px solid rgba(255,255,255,.22); padding:10px 2px; color:#fff; font-family:inherit; font-size:1rem; outline:none; resize:vertical; }
.field select option{ color:#16243a; }
.field label{ position:absolute; left:2px; top:10px; color:rgba(255,255,255,.55); font-size:1rem; pointer-events:none; transition:.35s var(--ease); }
.field input:focus ~ label, .field input:valid ~ label,
.field select:focus ~ label, .field select:valid ~ label,
.field textarea:focus ~ label, .field textarea:valid ~ label{ top:-14px; font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--orange); }
.field .ln{ position:absolute; left:0; bottom:0; height:2px; width:100%; background:var(--orange); transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease); }
.field input:focus ~ .ln, .field select:focus ~ .ln, .field textarea:focus ~ .ln{ transform:scaleX(1); }
.cta-form .btn{ width:100%; justify-content:center; margin-top:6px; }
.cta-form .consent{ margin-top:16px; font-size:.76rem; color:rgba(255,255,255,.55); text-align:center; }
.cta-form .consent a{ color:rgba(255,255,255,.8); text-decoration:underline; }

/* ---------- FOOTER ---------- */
.footer{ padding:clamp(56px,7vw,80px) 0 36px; border-top:1px solid rgba(79,93,117,.12); }
.foot-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:36px; }
.foot-brand .brand{ margin-bottom:14px; }
.foot-brand p{ color:var(--slate); font-size:.92rem; max-width:34ch; }
.foot-brand .fcontact{ margin-top:16px; font-size:.88rem; color:var(--slate); display:flex; flex-direction:column; gap:.4em; }
.fcol h4{ font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--slate-2); margin-bottom:16px; }
.fcol a{ display:block; font-size:.92rem; color:var(--slate); margin-bottom:11px; transition:color .3s, transform .3s; }
.fcol a:hover{ color:var(--orange); transform:translateX(3px); }
.foot-bottom{ margin-top:clamp(40px,5vw,60px); padding-top:24px; border-top:1px solid rgba(79,93,117,.12); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.82rem; color:var(--slate-2); }
.foot-bottom .socials{ display:flex; gap:12px; }
.foot-bottom .socials a{ width:38px; height:38px; border-radius:50%; border:1px solid rgba(79,93,117,.22); display:grid; place-items:center; color:var(--slate); transition:transform .3s var(--ease), background .3s, color .3s, border-color .3s; }
.foot-bottom .socials a:hover{ color:#fff; background:var(--orange); border-color:var(--orange); transform:translateY(-3px); }
.foot-bottom .socials svg{ width:17px; height:17px; }

/* ============================================================
   REFERENCE-INSPIRED ELEMENTS (team, outcomes, hero glass, divider)
   ============================================================ */

/* Hero glass 3D floating tiles + plate */
.glass-tile{ position:absolute; border-radius:18px; background:var(--glass); border:1px solid var(--glass-brd);
  backdrop-filter:blur(20px) saturate(1.4); -webkit-backdrop-filter:blur(20px) saturate(1.4); box-shadow:var(--glass-shadow);
  display:grid; place-items:center; opacity:0; z-index:2; }
.glass-tile .shape{ width:44%; height:44%; box-shadow:0 6px 14px -4px rgba(22,27,38,.3); }
.glass-tile.t-a{ width:76px; height:76px; top:-5%; left:-7%; }
.glass-tile.t-a .shape{ background:linear-gradient(135deg,var(--orange),#ffb56b); border-radius:50%; }
.glass-tile.t-b{ width:62px; height:62px; bottom:16%; left:-10%; }
.glass-tile.t-b .shape{ background:linear-gradient(135deg,var(--slate),#8a96ad); border-radius:8px; transform:rotate(45deg); }
.glass-tile.t-c{ width:54px; height:54px; top:8%; right:-4%; }
.glass-tile.t-c .shape{ background:linear-gradient(135deg,#f3a705,var(--orange)); border-radius:6px; }
.hero-plate{ position:absolute; bottom:0; left:50%; transform:translateX(-50%); width:82%; height:46px;
  border-radius:50%; background:radial-gradient(ellipse,rgba(243,117,5,.20),transparent 70%); filter:blur(9px); z-index:0; }

/* Animated word divider */
.word-divider{ padding:clamp(34px,5vw,64px) 0; overflow:hidden; border-top:1px solid rgba(79,93,117,.10); border-bottom:1px solid rgba(79,93,117,.10); }
.word-track{ display:flex; gap:42px; width:max-content; align-items:center; will-change:transform; }
.word-track span{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.8rem,4.2vw,3.1rem); letter-spacing:-.02em; color:var(--ink); white-space:nowrap; }
.word-track .muted{ color:transparent; -webkit-text-stroke:1.2px rgba(79,93,117,.45); }
.word-track .sep{ color:var(--orange); font-size:1.3rem; -webkit-text-stroke:0; }

/* Outcomes / conversion bar */
.outcomes{ padding:var(--section-y) 0 0; }
.outcomes-inner{ position:relative; overflow:hidden; background:linear-gradient(150deg,var(--slate),var(--ink)); border-radius:var(--r-xl); padding:clamp(32px,4vw,52px); display:grid; grid-template-columns:repeat(4,1fr); gap:28px; box-shadow:var(--glass-shadow-lg); }
.outcomes-inner::before{ content:""; position:absolute; width:300px; height:300px; top:-120px; right:-60px; border-radius:50%; background:radial-gradient(circle,rgba(243,117,5,.4),transparent 65%); filter:blur(10px); pointer-events:none; }
.outcome{ position:relative; z-index:1; display:flex; flex-direction:column; gap:.55em; color:#fff; }
.outcome .oi{ width:50px; height:50px; border-radius:14px; display:grid; place-items:center; background:rgba(243,117,5,.18); color:var(--orange); font-size:1.4rem; }
.outcome h4{ font-size:1.08rem; font-weight:700; }
.outcome p{ font-size:.86rem; color:rgba(255,255,255,.7); }

/* Meet the team */
.team-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.member{ background:var(--white); border:1px solid rgba(79,93,117,.10); border-radius:var(--r-md); overflow:hidden; box-shadow:0 24px 50px -38px rgba(22,27,38,.28); transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.member:hover{ transform:translateY(-7px); box-shadow:0 42px 84px -44px rgba(22,27,38,.42); }
.member .m-photo{ aspect-ratio:1/1; background:linear-gradient(150deg,var(--mist),#fff); position:relative; overflow:hidden; }
.member .m-photo img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.member:hover .m-photo img{ transform:scale(1.05); }
.member .m-photo .ph{ position:absolute; inset:0; display:grid; place-items:center; color:var(--slate-2); font-size:.74rem; text-align:center; padding:14px; }
.member .m-body{ padding:20px 22px 24px; }
.member h4{ font-size:1.1rem; font-weight:700; letter-spacing:-.01em; }
.member .m-role{ font-size:.8rem; color:var(--orange); font-weight:600; margin-top:.25em; }
.member .m-bio{ font-size:.86rem; color:var(--slate); margin-top:.7em; line-height:1.5; }

@media (max-width:980px){
  .outcomes-inner{ grid-template-columns:repeat(2,1fr); }
  .team-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:560px){ .outcomes-inner{ grid-template-columns:1fr; } }

/* single centered testimonial (service pages) */
.tst-single{ max-width:720px; margin-inline:auto; }
.tst-single .tcard{ width:100%; }
/* feature highlight list */
.feature-list{ list-style:none; display:grid; gap:16px; }
.feature-list li{ display:flex; gap:14px; align-items:flex-start; font-size:1.05rem; color:var(--ink); font-weight:300; }
.feature-list .ck{ flex-shrink:0; width:26px; height:26px; border-radius:50%; display:grid; place-items:center; background:rgba(243,117,5,.12); color:var(--orange); font-size:.8rem; font-weight:700; margin-top:.15em; }

/* ---------- INTERIOR PAGE HEADER (subpages) ---------- */
.page-hero{ position:relative; padding:clamp(130px,17vw,180px) 0 clamp(40px,6vw,70px); }
.page-hero.center{ text-align:center; }
.page-hero.center .eyebrow{ justify-content:center; }
.page-hero h1{ font-family:var(--font-display); font-weight:500; font-size:clamp(2.4rem,5.5vw,4.2rem); line-height:1.02; letter-spacing:-.025em; margin:.4em 0 .4em; }
.page-hero .lead{ font-size:clamp(1.05rem,1.5vw,1.25rem); color:var(--slate); max-width:54ch; }
.page-hero.center .lead{ margin-inline:auto; }
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,70px); align-items:center; }
.media-frame{ position:relative; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--glass-shadow-lg); background:linear-gradient(150deg,var(--mist),#fff); aspect-ratio:4/5; }
.media-frame.r-3-4{ aspect-ratio:3/4; } .media-frame.r-1-1{ aspect-ratio:1/1; } .media-frame.r-16-9{ aspect-ratio:16/9; }
.media-frame img{ width:100%; height:100%; object-fit:cover; }
.media-frame .ph{ position:absolute; inset:0; display:grid; place-items:center; color:var(--slate-2); font-size:.8rem; text-align:center; padding:20px; }

/* ---------- REVEAL ---------- */
.reveal{ opacity:0; transform:translateY(38px); }

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .hero-grid, .split{ grid-template-columns:1fr; }
  .hero-sub{ max-width:46ch; }
  .hero-visual{ height:420px; order:-1; }
  .cards-3{ grid-template-columns:1fr; }
  .trust-grid{ grid-template-columns:repeat(2,1fr); gap:34px 20px; }
  .cta-panel{ grid-template-columns:1fr; }
  .blog-grid{ grid-template-columns:1fr; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:30px; }
}
@media (max-width:680px){
  .nav-links{ display:none; position:absolute; top:100%; left:0; right:0; flex-direction:column; align-items:flex-start; gap:1rem; padding:22px var(--pad); background:rgba(251,250,248,.96); backdrop-filter:blur(18px); box-shadow:0 20px 40px -20px rgba(22,27,38,.3); }
  .nav-links.open{ display:flex; }
  .nav-dd-menu{ position:static; transform:none; opacity:1; visibility:visible; box-shadow:none; background:none; border:none; padding:6px 0 0 14px; min-width:0; }
  .burger{ display:flex; }
  .nav .nav-cta .btn-primary{ display:none; }
  .svc-grid{ grid-template-columns:1fr; }
  .diff-cell{ padding:18px; font-size:.92rem; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
  .hero h1{ font-size:clamp(2.6rem,11vw,3.4rem); }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition-duration:.01ms !important; }
  .reveal,.hero-eyebrow,.hero-sub,.hero-actions,.hero-note,.dash,.chip{ opacity:1 !important; transform:none !important; }
  .hero h1 .line > span{ transform:none !important; }
  html{ scroll-behavior:auto; }
}

/* ============================================================
   INTERIOR PAGE SECTIONS (service / nosotros / contacto)
   ============================================================ */
.section{ padding:var(--section-y) 0 0; }
.section.last{ padding-bottom:var(--section-y); }

/* service hero chip */
.hero-chip{ display:inline-flex; align-items:center; gap:.5em; margin-left:.6em; font-size:.68rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--orange); background:rgba(243,117,5,.1); padding:.4em .8em; border-radius:100px; vertical-align:middle; }

/* "para quién es" */
.aud-list{ list-style:none; display:grid; gap:18px; max-width:64ch; }
.aud-list li{ position:relative; padding-left:34px; font-size:clamp(1rem,1.5vw,1.15rem); font-weight:300; color:var(--ink); }
.aud-list li::before{ content:""; position:absolute; left:0; top:.45em; width:12px; height:12px; border:1.5px solid var(--orange); background:rgba(243,117,5,.12); transform:rotate(45deg); border-radius:2px; }

/* includes 2x2 */
.inc-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
.inc-card{ padding:32px; border-radius:var(--r-md); background:var(--white); border:1px solid rgba(79,93,117,.10); box-shadow:0 24px 50px -36px rgba(22,27,38,.28); transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.inc-card:hover{ transform:translateY(-5px); box-shadow:0 36px 70px -40px rgba(22,27,38,.38); }
.inc-card .picon{ width:50px;height:50px;border-radius:14px; display:grid;place-items:center; margin-bottom:20px; background:rgba(243,117,5,.10); color:var(--orange); font-size:1.3rem; }
.inc-card h3{ font-size:1.2rem; font-weight:700; letter-spacing:-.01em; margin-bottom:.45em; }
.inc-card p{ color:var(--slate); font-size:.96rem; }

/* timeline / steps */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative; }
.steps::before{ content:""; position:absolute; top:26px; left:8%; right:8%; height:2px; background:linear-gradient(90deg,rgba(79,93,117,.25),rgba(243,117,5,.7)); }
.step{ position:relative; text-align:center; }
.step .snum{ width:54px;height:54px;border-radius:50%; margin:0 auto 18px; display:grid;place-items:center; background:var(--white); border:1px solid rgba(79,93,117,.14); box-shadow:var(--glass-shadow); font-family:var(--font-display); font-size:1.2rem; color:var(--orange); position:relative; z-index:1; }
.step h4{ font-size:1.05rem; font-weight:700; margin-bottom:.4em; }
.step p{ font-size:.9rem; color:var(--slate); max-width:24ch; margin:0 auto; }

/* results / checks */
.checks{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px 32px; max-width:920px; }
.check-item{ display:flex; gap:14px; align-items:flex-start; font-size:1.05rem; color:var(--ink); font-weight:300; }
.check-item .ck{ flex-shrink:0; width:26px;height:26px;border-radius:50%; display:grid;place-items:center; background:rgba(243,117,5,.12); color:var(--orange); font-size:.8rem; font-weight:700; margin-top:.15em; }

/* pull quote (nosotros) */
.pullquote{ font-family:var(--font-display); font-weight:400; font-style:italic; font-size:clamp(1.5rem,3vw,2.3rem); line-height:1.3; letter-spacing:-.01em; text-align:center; max-width:20ch; margin:clamp(40px,6vw,70px) auto 0; color:var(--ink); }
.pullquote .accent{ color:var(--orange); }

/* chips row (sectores / especialidades) */
.chips-row{ display:flex; flex-wrap:wrap; gap:12px; }
.chip-pill{ padding:12px 20px; border-radius:100px; border:1px solid rgba(79,93,117,.18); background:rgba(79,93,117,.04); font-size:.95rem; font-weight:500; color:var(--slate); transition:.3s; }
.chip-pill:hover{ border-color:var(--orange); color:var(--orange); transform:scale(1.03); }
.chip-pill.filt{ cursor:pointer; }
.chip-pill.filt.active{ border-color:var(--orange); background:var(--orange); color:#fff; }

/* FAQ accordion */
.faq{ max-width:880px; margin-inline:auto; }
.faq-item{ border-bottom:1px solid rgba(79,93,117,.12); }
.faq-q{ width:100%; text-align:left; display:flex; justify-content:space-between; align-items:center; gap:20px; padding:24px 4px; font-size:1.05rem; font-weight:600; color:var(--ink); }
.faq-q .pm{ flex-shrink:0; width:26px; height:26px; position:relative; transition:transform .3s var(--ease); color:var(--orange); font-size:1.4rem; line-height:1; }
.faq-item.open .faq-q .pm{ transform:rotate(45deg); }
.faq-a{ height:0; overflow:hidden; }
.faq-a p{ padding:0 4px 24px; color:var(--slate); font-size:1rem; max-width:70ch; }

/* contact layout */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,48px); align-items:start; }
.contact-card{ padding:24px; border-radius:var(--r-md); background:var(--white); border:1px solid rgba(79,93,117,.10); box-shadow:0 24px 50px -38px rgba(22,27,38,.24); margin-bottom:16px; }
.contact-card h4{ font-size:1.05rem; font-weight:700; margin-bottom:.3em; display:flex; align-items:center; gap:.5em; }
.contact-card p{ color:var(--slate); font-size:.92rem; margin-bottom:.5em; }
.contact-card a.lnk{ font-weight:600; color:var(--orange); font-size:.9rem; }
.cta-form.form-light{ background:transparent; border:none; padding:0; backdrop-filter:none; -webkit-backdrop-filter:none; box-shadow:none; }
.form-light .field input, .form-light .field select, .form-light .field textarea{ color:var(--ink); border-bottom-color:rgba(79,93,117,.25); }
.form-light .field label{ color:var(--slate-2); }
.form-light .consent{ color:var(--slate-2); }
.form-light .consent a{ color:var(--slate); }
.form-panel{ padding:clamp(28px,4vw,40px); border-radius:var(--r-lg); background:var(--white); border:1px solid rgba(79,93,117,.10); box-shadow:var(--glass-shadow); }

/* legal / prose */
.prose{ max-width:760px; margin-inline:auto; }
.prose h2{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.4rem,2.6vw,2rem); margin:1.6em 0 .5em; letter-spacing:-.01em; }
.prose h3{ font-size:1.15rem; font-weight:700; margin:1.3em 0 .4em; }
.prose p, .prose li{ color:var(--slate); font-size:1.02rem; margin-bottom:.9em; }
.prose ul, .prose ol{ padding-left:1.3em; margin-bottom:1em; }
.prose a{ color:var(--orange); text-decoration:underline; }
.prose .updated{ font-size:.85rem; color:var(--slate-2); }

/* blog article: floating TOC, related, news feed */
.toc-float{ position:fixed; left:max(20px, calc((100vw - 740px) / 2 - 232px)); top:140px; width:212px; max-height:72vh; overflow-y:auto; z-index:40; transition:opacity .35s var(--ease), transform .35s var(--ease); }
.toc-float.toc-hide{ opacity:0; transform:translateX(-12px); pointer-events:none; }
.toc-float .toc-title{ font-size:.64rem; text-transform:uppercase; letter-spacing:.12em; color:var(--slate-2); font-weight:700; display:block; margin-bottom:12px; }
.toc-float ul{ list-style:none; display:flex; flex-direction:column; gap:1px; border-left:1px solid rgba(79,93,117,.16); }
.toc-float li a{ display:block; padding:6px 0 6px 14px; margin-left:-1px; border-left:2px solid transparent; font-size:.82rem; color:var(--slate); line-height:1.35; transition:.25s; }
.toc-float li a:hover{ color:var(--ink); }
.toc-float li a.active{ color:var(--orange); border-left-color:var(--orange); font-weight:600; }
@media (max-width:1240px){ .toc-float{ display:none; } }
.related .bcard .bthumb{ height:150px; }
.news-feed .news-list{ max-width:760px; margin-inline:auto; display:flex; flex-direction:column; }
.news-item{ display:flex; align-items:center; gap:14px; padding:16px 6px; border-bottom:1px solid rgba(79,93,117,.1); transition:padding .25s var(--ease); }
.news-item:last-child{ border-bottom:none; }
.news-item:hover{ padding-left:12px; }
.news-item .news-dot{ width:7px; height:7px; border-radius:50%; background:var(--orange); flex-shrink:0; }
.news-item .news-t{ flex:1; font-size:1rem; color:var(--ink); font-weight:500; line-height:1.4; }
.news-item:hover .news-t{ color:var(--orange); }
.news-item .news-d{ font-size:.78rem; color:var(--slate-2); white-space:nowrap; }
.news-loading{ color:var(--slate-2); font-size:.9rem; padding:10px 0; }
.news-src{ display:block; margin-top:16px; font-size:.76rem; color:var(--slate-2); }
.news-src a{ color:var(--orange); }

/* article (blog post) */
.article{ max-width:740px; margin-inline:auto; }
.article .a-meta{ display:flex; gap:.7em; align-items:center; font-size:.82rem; color:var(--slate-2); margin-bottom:1.2em; }
.article h1{ font-family:var(--font-display); font-weight:500; font-size:clamp(2rem,4.4vw,3rem); line-height:1.08; letter-spacing:-.02em; margin-bottom:.5em; }
.article .a-hero{ aspect-ratio:16/9; border-radius:var(--r-md); overflow:hidden; margin:clamp(24px,4vw,40px) 0; background:linear-gradient(135deg,var(--slate),var(--ink)); }
.article .a-hero img{ width:100%; height:100%; object-fit:cover; }
.article .a-body p, .article .a-body li{ font-size:1.08rem; line-height:1.75; color:#2a3242; margin-bottom:1.1em; }
.article .a-body h2{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.4rem,2.6vw,1.9rem); margin:1.6em 0 .5em; letter-spacing:-.01em; color:var(--ink); }
.article .a-body h3{ font-size:1.2rem; font-weight:700; margin:1.3em 0 .4em; color:var(--ink); }
.article .a-body ul, .article .a-body ol{ padding-left:1.3em; margin-bottom:1.2em; }
.article .a-body strong{ color:var(--ink); font-weight:600; }
.article .a-cta{ margin-top:2.5em; padding:32px; border-radius:var(--r-md); background:linear-gradient(150deg,var(--slate),var(--ink)); color:#fff; }
.article .a-cta h3{ font-family:var(--font-display); font-weight:500; font-size:1.5rem; margin-bottom:.4em; }
.article .a-cta p{ color:rgba(255,255,255,.75); margin-bottom:1.2em; }

@media (max-width:980px){
  .inc-grid, .checks, .contact-grid{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:repeat(2,1fr); gap:36px 20px; }
  .steps::before{ display:none; }
}
@media (max-width:680px){
  .steps{ grid-template-columns:1fr; }
}

/* ============================================================
   REAL IMAGES (logo + generated media)
   ============================================================ */
/* logo cropped from its square canvas (content is ~30% tall, centered) */
/* header = isotipo (símbolo solo), caja casi cuadrada */
.brand-logo-box{ display:block; width:48px; height:54px; overflow:hidden; position:relative; transition:.4s var(--ease); }
.brand-logo-box img{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); height:66px; width:auto; max-width:none; }
.nav.scrolled .brand-logo-box{ width:44px; height:48px; }
.nav.scrolled .brand-logo-box img{ height:58px; }
.foot-brand .brand-logo-box{ width:176px; height:88px; margin-bottom:14px; }
.foot-brand .brand-logo-box img{ height:188px; }
.hero-img-card{ padding:0 !important; overflow:hidden; }
.hero-img-card img{ width:100%; height:100%; object-fit:cover; display:block; }
.diff{ position:relative; }
.diff-bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.14; z-index:0; pointer-events:none; }
.diff > .container{ position:relative; z-index:1; }
.cta-orb-img{ position:absolute; width:46%; max-width:380px; top:-14%; right:-8%; z-index:0; pointer-events:none; mix-blend-mode:screen; opacity:.85; }
@media (max-width:680px){ .brand-logo-box{ width:46px; height:52px; } .brand-logo-box img{ height:64px; } }

/* ============================================================
   WHATSAPP (nav button + floating)
   ============================================================ */
.btn-wa{ gap:.55em; }
.btn-wa svg{ flex-shrink:0; }
.wa-float{ position:fixed; bottom:24px; right:24px; z-index:120; width:62px; height:62px; border-radius:50%;
  background:#25D366; color:#fff; display:grid; place-items:center; box-shadow:0 16px 34px -10px rgba(37,211,102,.6);
  transition:transform .4s var(--ease); }
.wa-float:hover{ transform:scale(1.08); }
.wa-float svg{ position:relative; z-index:1; }
.wa-float .wa-pulse{ position:absolute; inset:0; border-radius:50%; background:#25D366; z-index:0; animation:wapulse 2.4s ease-out infinite; }
@keyframes wapulse{ 0%{ transform:scale(1); opacity:.55; } 100%{ transform:scale(1.9); opacity:0; } }
@media (max-width:680px){ .wa-float{ width:56px; height:56px; bottom:18px; right:18px; } }

/* ============================================================
   CLIENT LOGOS STRIP
   ============================================================ */
.logos{ padding:clamp(40px,5vw,64px) 0; border-bottom:1px solid rgba(79,93,117,.10); overflow:hidden; }
.logos-label{ text-align:center; font-size:.78rem; color:var(--slate-2); text-transform:uppercase; letter-spacing:.16em; margin-bottom:30px; }
.logos-mask{ -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.logos-track{ display:flex; gap:64px; width:max-content; align-items:center; will-change:transform; }
.logos-track .logo-item{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.1rem,1.8vw,1.5rem); color:var(--slate-2); opacity:.7; white-space:nowrap; letter-spacing:-.01em; }

/* ============================================================
   PEOPLE BAND (human element)
   ============================================================ */
.people .split{ align-items:center; }
.people .media-frame{ aspect-ratio:16/10; }
.people-tags{ display:flex; flex-wrap:wrap; gap:10px; margin-top:24px; }
.people-tags .chip-pill{ font-size:.85rem; padding:9px 16px; }

/* ============================================================
   INDUSTRIES
   ============================================================ */
.ind-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.ind-card{ padding:28px 20px; border-radius:var(--r-md); background:var(--white); border:1px solid rgba(79,93,117,.10);
  text-align:center; transition:transform .45s var(--ease), box-shadow .45s var(--ease), border-color .45s; }
.ind-card:hover{ transform:translateY(-6px); border-color:rgba(243,117,5,.45); box-shadow:0 28px 56px -36px rgba(22,27,38,.34); }
.ind-card .ii{ width:52px; height:52px; margin:0 auto 14px; border-radius:14px; display:grid; place-items:center;
  background:rgba(243,117,5,.10); color:var(--orange); font-size:1.5rem; }
.ind-card h4{ font-size:1.02rem; font-weight:600; }
.ind-card p{ font-size:.84rem; color:var(--slate); margin-top:.3em; }

/* photo testimonial avatar */
.tavatar img{ width:100%; height:100%; object-fit:cover; border-radius:50%; }

@media (max-width:980px){ .ind-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:680px){ .logos-track{ gap:40px; } }

/* ============================================================
   WORDPRESS ADMIN BAR OFFSET (logged-in views only; visitors unaffected)
   ============================================================ */
.admin-bar .ticker{ top:32px; }
.admin-bar .nav:not(.scrolled){ top:calc(var(--ticker-h) + 32px); }
.admin-bar .nav.scrolled{ top:32px; }
.admin-bar .page-curtain{ top:32px; }
@media screen and (max-width:782px){
  .admin-bar .ticker{ top:46px; }
  .admin-bar .nav:not(.scrolled){ top:calc(var(--ticker-h) + 46px); }
  .admin-bar .nav.scrolled{ top:46px; }
  .admin-bar .page-curtain{ top:46px; }
}

/* ============================================================
   FLUENT FORMS — alineación con la marca (panel de Contacto)
   ============================================================ */
.form-panel .fluentform .ff-el-group{ margin-bottom:18px; }
.form-panel .fluentform label,
.form-panel .fluentform .ff-el-input--label label{ color:var(--slate-2); font-weight:600; font-size:.85rem; }
.form-panel .fluentform input[type=text],
.form-panel .fluentform input[type=email],
.form-panel .fluentform input[type=tel],
.form-panel .fluentform input[type=number],
.form-panel .fluentform select,
.form-panel .fluentform textarea{
  width:100%; border-radius:12px; border:1px solid rgba(79,93,117,.25);
  padding:12px 14px; font-family:var(--font-body); font-size:1rem; color:var(--ink);
  background:#fff; transition:border-color .3s, box-shadow .3s;
}
.form-panel .fluentform input:focus,
.form-panel .fluentform select:focus,
.form-panel .fluentform textarea:focus{
  outline:none; border-color:var(--orange); box-shadow:0 0 0 3px rgba(243,117,5,.14);
}
.form-panel .fluentform .ff-btn-submit,
.form-panel .fluentform button.ff-btn,
.form-panel .frm-fluent-form .ff-btn-submit,
.form-panel form[class*="ff-form"] .ff-btn-submit,
.form-panel form[class*="ff-form"] button[type=submit],
.form-panel .fluentform button[type=submit]{
  background:var(--orange) !important;
  background-color:var(--orange) !important;
  background-image:none !important;
  color:#fff !important;
  border:0 !important;
  border-radius:100px !important;
  padding:1em 1.8em !important;
  font-family:var(--font-body) !important;
  font-weight:600 !important;
  font-size:.95rem !important;
  cursor:pointer;
  box-shadow:0 16px 34px -12px rgba(243,117,5,.6) !important;
  transition:background .3s, transform .4s var(--ease);
}
.form-panel .fluentform .ff-btn-submit:hover,
.form-panel .fluentform button.ff-btn:hover,
.form-panel .frm-fluent-form .ff-btn-submit:hover,
.form-panel form[class*="ff-form"] .ff-btn-submit:hover,
.form-panel form[class*="ff-form"] button[type=submit]:hover,
.form-panel .fluentform button[type=submit]:hover{
  background:var(--orange-d) !important;
  background-color:var(--orange-d) !important;
  transform:translateY(-2px);
}
.form-panel .fluentform .ff-message-success{
  background:rgba(47,170,90,.1); color:#2faa5a; border:1px solid rgba(47,170,90,.25);
  border-radius:12px; padding:14px 16px; font-weight:500;
}

/* ============================================================
   LEAD MAGNET — guía gratis + captura de email
   ============================================================ */
.leadmag{ padding:var(--section-y) 0 0; position:relative; }
.leadmag .container.split{ align-items:center; gap:clamp(40px,6vw,80px); }

.leadmag-visual{ position:relative; perspective:1200px; }
.guide-card{ position:relative; aspect-ratio:3/4; max-width:380px; margin-inline:auto; }
.guide-cover{
  position:relative; width:100%; height:100%;
  border-radius:6px 14px 14px 6px;
  background:
    radial-gradient(80% 60% at 30% 20%, rgba(255,255,255,.22), transparent 70%),
    linear-gradient(165deg, var(--orange), var(--orange-d));
  color:#fff; padding:36px 30px; display:flex; flex-direction:column;
  box-shadow:
    0 30px 60px -22px rgba(243,117,5,.45),
    0 60px 120px -34px rgba(22,27,38,.45),
    inset 1px 0 0 rgba(255,255,255,.28);
  transform:rotate(-3deg);
  transition:transform .6s var(--ease);
}
.guide-card:hover .guide-cover{ transform:rotate(-1deg) translateY(-6px); }
.guide-badge{
  display:inline-block; font-size:.7rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.35);
  padding:.5em 1em; border-radius:100px; backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); align-self:flex-start;
}
.guide-cover h3{
  font-family:var(--font-display); font-weight:500; font-size:clamp(1.5rem,2.6vw,2rem);
  line-height:1.1; letter-spacing:-.015em; margin-top:.8em; margin-bottom:auto;
}
.guide-author{ font-size:.78rem; opacity:.85; margin-top:1.5em; }
.guide-fold{
  position:absolute; top:0; left:0; bottom:0; width:7px;
  background:linear-gradient(90deg, rgba(0,0,0,.32), transparent);
  border-radius:6px 0 0 6px;
}
.guide-shadow{
  position:absolute; left:6%; right:6%; bottom:-26px; height:32px;
  background:radial-gradient(ellipse, rgba(22,27,38,.34), transparent 70%);
  filter:blur(10px); z-index:-1;
}

.leadmag-copy h2{
  font-family:var(--font-display); font-weight:500;
  font-size:clamp(2rem,4.4vw,3rem); line-height:1.04; letter-spacing:-.02em;
  margin:.4em 0 .5em;
}
.leadmag-copy .lead{ color:var(--slate); font-size:1.08rem; max-width:42ch; }
.leadmag-bullets{
  list-style:none; display:grid; gap:12px; margin:1.6em 0 1.8em; max-width:42ch;
}
.leadmag-bullets li{ display:flex; gap:12px; align-items:flex-start; font-size:1rem; color:var(--ink); font-weight:300; }
.leadmag-bullets .ck{
  flex-shrink:0; width:24px; height:24px; border-radius:50%;
  background:rgba(243,117,5,.12); color:var(--orange);
  display:grid; place-items:center; font-size:.75rem; font-weight:700; margin-top:.15em;
}
.leadmag-form{ max-width:42ch; }
.leadmag-form .fluentform .ff-el-group{ margin-bottom:14px; }
.leadmag-form .fluentform input[type=email],
.leadmag-form .fluentform input[type=text]{
  width:100%; border-radius:100px; border:1px solid rgba(79,93,117,.25);
  padding:14px 22px; font-family:var(--font-body); font-size:1rem; color:var(--ink);
  background:#fff; transition:border-color .3s, box-shadow .3s;
}
.leadmag-form .fluentform input:focus{
  outline:none; border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(243,117,5,.14);
}
.leadmag-form .fluentform .ff-btn-submit,
.leadmag-form .fluentform button[type=submit]{
  background:var(--orange) !important; color:#fff !important; border:0 !important;
  border-radius:100px !important; padding:1em 1.8em !important;
  font-family:var(--font-body) !important; font-weight:600 !important; font-size:.95rem !important;
  box-shadow:0 16px 34px -12px rgba(243,117,5,.6) !important;
  transition:background .3s, transform .4s var(--ease);
}
.leadmag-form .fluentform .ff-btn-submit:hover,
.leadmag-form .fluentform button[type=submit]:hover{
  background:var(--orange-d) !important; transform:translateY(-2px);
}
.leadmag-trust{
  margin-top:14px; font-size:.85rem; color:var(--slate-2);
  display:flex; align-items:center; gap:.55em;
}
.check-mini{
  flex-shrink:0; width:22px; height:22px; border-radius:50%;
  background:rgba(243,117,5,.14); color:var(--orange);
  display:grid; place-items:center; font-size:.78rem;
}

@media (max-width:980px){
  .leadmag .container.split{ grid-template-columns:1fr; }
  .leadmag-visual{ order:-1; }
  .guide-card{ max-width:280px; }
}
