/*
Theme Name: IMASS
Theme URI: https://imass.es/
Author: IMASS
Description: Tema WordPress a medida basado en la landing HTML de IMASS.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: imass
*/

/* ============================================================
   RESET & TOKENS
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --r:#c8102e; --r-dark:#a80e26;
  --r-light:rgba(200,16,46,0.08); --r-mid:rgba(200,16,46,0.15); --r-faint:rgba(200,16,46,0.04);
  --ink:#171614; --ink2:#2c2a28;
  --page:#f0eeea; --surface:#f5f3ef; --surface2:#edeae5; --surface3:#e5e2db;
  --off:#ffffff;
  --muted:#76726d; --muted2:#aeaaa4; --muted3:#cfccc6;
  --border:rgba(30,28,26,0.10); --border2:rgba(30,28,26,0.05);
  --green:#1a6b48; --green2:rgba(26,107,72,0.10);
  --amber:#b07c10; --amber2:rgba(176,124,16,0.10);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans','Helvetica Neue',Helvetica,Arial,sans-serif;
  --gutter:56px; --ease:cubic-bezier(0.22,1,0.36,1); --ease-fast:cubic-bezier(0.4,0,0.2,1);
}
html{scroll-behavior:smooth;}
body{background:var(--page);color:var(--ink);font-family:var(--sans);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;text-wrap:pretty;overflow-x:hidden;}

/* ============================================================
   UTILITIES
   ============================================================ */
.u-eyebrow{display:flex;align-items:center;gap:12px;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--r);margin-bottom:18px;}
.u-eyebrow-line{width:22px;height:1px;background:var(--r);flex-shrink:0;}
.serif{font-family:var(--serif);font-weight:400;}
.u-muted{color:var(--muted2);}
.cta-strip{display:flex;align-items:center;justify-content:space-between;padding:22px var(--gutter);border-top:1px solid var(--border);background:var(--surface2);gap:24px;}
.cta-strip-label{font-size:13px;color:var(--muted);}
.cta-strip-label strong{color:var(--ink);font-weight:500;}
.cta-strip-btns{display:flex;gap:10px;flex-shrink:0;}
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--r);color:#fff;font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;padding:14px 28px;border:none;cursor:pointer;transition:background 0.2s,transform 0.15s var(--ease);}
.btn-primary:hover{background:var(--r-dark);transform:translateY(-1px);}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--muted);font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:0.10em;text-transform:uppercase;padding-bottom:2px;border:none;border-bottom:1px solid var(--muted3);cursor:pointer;transition:color 0.2s,border-color 0.2s;}
.btn-ghost:hover{color:var(--ink);border-color:var(--ink);}
.btn-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--muted);font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:0.10em;text-transform:uppercase;padding:13px 24px;border:1px solid var(--border);cursor:pointer;transition:all 0.2s var(--ease-fast);}
.btn-outline:hover{border-color:var(--ink);color:var(--ink);}
.section-header{padding:64px var(--gutter) 48px;border-bottom:1px solid var(--border);display:flex;align-items:flex-end;justify-content:space-between;gap:48px;background:var(--off);}
.section-header-aside{max-width:260px;text-align:right;font-size:12px;color:var(--muted);line-height:1.75;flex-shrink:0;}
.grid-bg{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(var(--border2) 1px,transparent 1px),linear-gradient(90deg,var(--border2) 1px,transparent 1px);background-size:64px 64px;z-index:0;}
.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.dot-r{background:var(--r);animation:pulse 2.5s ease-in-out infinite;}
.dot-a{background:var(--amber);animation:pulse 2.8s ease-in-out infinite;}
.dot-g{background:var(--green);}
.dot-grey{background:var(--muted3);}
.phase-tag{display:inline-block;font-size:9px;letter-spacing:0.10em;text-transform:uppercase;padding:3px 9px;border:1px solid;}
.phase-interv{color:var(--amber);border-color:rgba(176,124,16,0.3);}
.phase-acuerdo{color:var(--r);border-color:rgba(200,16,46,0.3);}
.phase-reg{color:var(--green);border-color:rgba(26,107,72,0.3);}
.phase-diag{color:var(--muted);border-color:var(--border);}
.reveal{opacity:0;transform:translateY(16px);transition:opacity 0.65s var(--ease),transform 0.65s var(--ease);}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-d1{transition-delay:0.07s;} .reveal-d2{transition-delay:0.14s;} .reveal-d3{transition-delay:0.21s;} .reveal-d4{transition-delay:0.28s;} .reveal-d5{transition-delay:0.35s;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.25;}}
@keyframes ticker{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
@keyframes fade-up{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0.2;}}

/* ============================================================
   NAV
   ============================================================ */
.main-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--gutter);
  height:64px;
  background:rgba(255,255,255,0.98);
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 16px rgba(0,0,0,0.05);
  backdrop-filter:blur(12px);
  transition:box-shadow 0.35s var(--ease);
}
.main-nav.scrolled{
  box-shadow:0 2px 20px rgba(0,0,0,0.08);
}
.nav-left{display:flex;align-items:center;gap:0;}
.nav-logo{display:flex;align-items:center;gap:0;text-decoration:none;}
.nav-logo svg{height:28px;width:auto;}
.nav-divider{width:1px;height:28px;background:var(--border);margin:0 20px;}
.nav-tagline{font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);}
.nav-links{display:flex;align-items:center;gap:2px;}
.nav-link{font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted);cursor:pointer;border:none;background:transparent;font-family:var(--sans);padding:8px 14px;position:relative;transition:color 0.2s;font-weight:500;}
.nav-link::after{content:'';position:absolute;bottom:4px;left:14px;right:14px;height:1px;background:var(--r);transform:scaleX(0);transform-origin:left;transition:transform 0.25s var(--ease);}
.nav-link:hover{color:var(--ink);}
.nav-link:hover::after{transform:scaleX(1);}
.nav-actions{display:flex;align-items:center;gap:10px;}
.nav-tel{font-size:12px;letter-spacing:0.04em;color:var(--ink);border:1px solid var(--border);padding:8px 16px;cursor:pointer;transition:border-color 0.2s;background:transparent;font-family:var(--sans);font-weight:500;}
.nav-tel:hover{border-color:var(--r);color:var(--r);}
.nav-cta{background:var(--r);color:#fff;font-size:11px;letter-spacing:0.10em;text-transform:uppercase;padding:9px 20px;cursor:pointer;border:none;font-family:var(--sans);font-weight:500;transition:background 0.2s;}
.nav-cta:hover{background:var(--r-dark);}

/* Red top line */
.nav-top-line{position:fixed;top:0;left:0;right:0;height:2px;background:var(--r);z-index:101;}

/* ============================================================
   HERO — CINEMA EDITORIAL
   ============================================================ */
.hero-wrap{position:relative;overflow:hidden;padding-top:64px;background:#0a0908;color:#fff;height:100vh;height:100dvh;display:flex;flex-direction:column;}
.hero-stage{position:relative;width:100%;flex:1 1 auto;min-height:0;overflow:hidden;isolation:isolate;cursor:none;}
.hero-video-bg{position:absolute;top:-25%;left:-10%;width:175%;min-width:175%;height:150%;min-height:150%;object-fit:cover;object-position:left center;z-index:0;will-change:transform;animation:heroKenBurns 28s ease-in-out infinite alternate;transform-origin:50% 50%;filter:saturate(0.92) contrast(1.05);}
@keyframes heroKenBurns{from{transform:scale(1.02) translate(0,0);}to{transform:scale(1.10) translate(-1.5%,-1%);}}
.hero-shade{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(10,9,8,0.55) 0%,rgba(10,9,8,0.20) 30%,rgba(10,9,8,0.45) 70%,rgba(10,9,8,0.92) 100%);pointer-events:none;}
.hero-vignette{position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(ellipse at center,transparent 40%,rgba(10,9,8,0.55) 100%);}
.hero-grain{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:0.08;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");}
.hero-scanline{position:absolute;inset:0;z-index:2;pointer-events:none;background:repeating-linear-gradient(0deg,rgba(255,255,255,0.012) 0 1px,transparent 1px 3px);mix-blend-mode:overlay;}

/* Frame slate (top corner) */
.hero-slate{position:absolute;top:24px;left:var(--gutter);z-index:5;display:flex;align-items:center;gap:10px;font-size:9px;letter-spacing:0.24em;text-transform:uppercase;color:rgba(255,255,255,0.45);font-family:var(--sans);}
.hero-slate-dot{width:6px;height:6px;border-radius:50%;background:var(--r);box-shadow:0 0 0 0 rgba(200,16,46,0.6);animation:liveBeacon 2s ease-out infinite;}
@keyframes liveBeacon{0%{box-shadow:0 0 0 0 rgba(200,16,46,0.55);}80%{box-shadow:0 0 0 10px rgba(200,16,46,0);}100%{box-shadow:0 0 0 0 rgba(200,16,46,0);}}
.hero-slate-id{color:rgba(255,255,255,0.6);}

/* Cardinal corner marks */
.hero-corner{position:absolute;width:30px;height:30px;z-index:5;pointer-events:none;border-color:rgba(255,255,255,0.35);border-style:solid;border-width:0;}
.hero-corner.tl{top:20px;left:calc(var(--gutter) - 14px);border-top-width:1px;border-left-width:1px;}
.hero-corner.tr{top:20px;right:calc(var(--gutter) - 14px);border-top-width:1px;border-right-width:1px;}
.hero-corner.bl{bottom:20px;left:calc(var(--gutter) - 14px);border-bottom-width:1px;border-left-width:1px;}
.hero-corner.br{bottom:20px;right:calc(var(--gutter) - 14px);border-bottom-width:1px;border-right-width:1px;}

/* Content */
.hero-content{position:relative;z-index:4;display:flex;flex-direction:column;justify-content:flex-end;height:100%;padding:72px var(--gutter) 64px;will-change:transform;}
.hero-h1-cinema{font-family:var(--serif);font-weight:300;font-size:clamp(52px,7.8vw,124px);line-height:0.94;letter-spacing:-0.022em;color:#fff;margin-bottom:28px;max-width:1100px;}
.hero-h1-cinema .h-line{display:block;overflow:hidden;}
.hero-h1-cinema .h-line span{display:inline-block;transform:translateY(110%);opacity:0;animation:heroLineRise 1.1s var(--ease) forwards;}
.hero-h1-cinema .h-line.l1 span{animation-delay:0.18s;}
.hero-h1-cinema .h-line.l2 span{animation-delay:0.34s;color:rgba(255,255,255,0.48);font-style:italic;}
.hero-h1-cinema .h-line.l3 span{animation-delay:0.50s;position:relative;}
.hero-h1-cinema .h-line.l3 span::after{content:'';position:absolute;left:0;right:0;bottom:0.08em;height:6px;background:var(--r);transform:scaleX(0);transform-origin:left;animation:heroUnderline 1.2s var(--ease) 1.4s forwards;}
@keyframes heroLineRise{to{transform:translateY(0);opacity:1;}}
@keyframes heroUnderline{to{transform:scaleX(1);}}

.hero-sub-cinema{font-size:14px;line-height:1.7;color:rgba(255,255,255,0.74);max-width:520px;margin-bottom:34px;opacity:0;animation:heroFadeUp 0.9s var(--ease) 1.0s forwards;}
@keyframes heroFadeUp{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}

.hero-ctas-cinema{display:flex;align-items:center;gap:26px;opacity:0;animation:heroFadeUp 0.9s var(--ease) 1.18s forwards;}
.btn-cine-primary{position:relative;display:inline-flex;align-items:center;gap:14px;background:var(--r);color:#fff;font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;padding:16px 28px;border:none;cursor:none;transition:background 0.25s var(--ease),box-shadow 0.3s var(--ease);overflow:hidden;will-change:transform;}
.btn-cine-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent);transform:translateX(-100%);transition:transform 0.6s var(--ease);}
.btn-cine-primary:hover{background:var(--r-dark);box-shadow:0 12px 38px rgba(200,16,46,0.45);}
.btn-cine-primary:hover::before{transform:translateX(100%);}
.btn-cine-primary svg{width:16px;height:10px;stroke:#fff;fill:none;stroke-width:1.5;transition:transform 0.3s var(--ease);}
.btn-cine-primary:hover svg{transform:translateX(5px);}
.btn-cine-ghost{display:inline-flex;align-items:center;gap:12px;background:transparent;color:#fff;font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;padding:16px 0;border:none;cursor:none;position:relative;will-change:transform;}
.btn-cine-ghost::after{content:'';position:absolute;left:0;right:0;bottom:8px;height:1px;background:rgba(255,255,255,0.4);transition:background 0.25s,right 0.3s var(--ease);}
.btn-cine-ghost:hover::after{background:#fff;right:-8px;}
.btn-cine-ghost .play-ico{width:22px;height:22px;border:1px solid rgba(255,255,255,0.45);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color 0.25s,background 0.25s;}
.btn-cine-ghost:hover .play-ico{border-color:#fff;background:rgba(255,255,255,0.08);}
.btn-cine-ghost .play-ico::before{content:'';width:0;height:0;border-left:5px solid #fff;border-top:3.5px solid transparent;border-bottom:3.5px solid transparent;margin-left:2px;}

/* Scroll indicator (bottom-right of stage) */
.hero-scroll-ind{position:absolute;right:var(--gutter);bottom:18px;z-index:5;display:inline-flex;align-items:center;gap:10px;font-size:9px;letter-spacing:0.24em;text-transform:uppercase;color:rgba(255,255,255,0.45);font-family:var(--sans);}
.hero-scroll-ind-line{width:42px;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.7),transparent);background-size:200% 100%;animation:scrollShimmer 2.4s linear infinite;}
@keyframes scrollShimmer{from{background-position:0% 0;}to{background-position:-200% 0;}}

/* Custom cursor inside hero */
.hero-cursor{position:fixed;top:0;left:0;width:18px;height:18px;border:1.5px solid var(--r);border-radius:50%;pointer-events:none;z-index:200;transform:translate(-50%,-50%) scale(1);mix-blend-mode:difference;transition:width 0.25s var(--ease),height 0.25s var(--ease),border-color 0.25s,opacity 0.2s;opacity:0;will-change:transform;}
.hero-cursor.active{opacity:1;}
.hero-cursor.hover{width:60px;height:60px;border-color:#fff;background:rgba(255,255,255,0.06);}
.hero-cursor-dot{position:fixed;top:0;left:0;width:5px;height:5px;background:var(--r);border-radius:50%;pointer-events:none;z-index:201;transform:translate(-50%,-50%);opacity:0;transition:opacity 0.2s,transform 0.08s linear;will-change:transform;}
.hero-cursor-dot.active{opacity:1;}

/* Stats — glass dark */
.hero-bottom{flex-shrink:0;display:grid;grid-template-columns:repeat(4,1fr);background:rgba(10,9,8,0.78);backdrop-filter:blur(18px) saturate(1.1);-webkit-backdrop-filter:blur(18px) saturate(1.1);border-top:1px solid rgba(255,255,255,0.08);position:relative;z-index:6;}
.hero-stat{padding:18px 28px;border-right:1px solid rgba(255,255,255,0.07);transition:background 0.3s var(--ease);position:relative;overflow:hidden;}
.hero-stat:last-child{border-right:none;}
.hero-stat::before{content:'';position:absolute;left:0;top:0;width:0;height:1px;background:var(--r);transition:width 0.5s var(--ease);}
.hero-stat:hover{background:rgba(255,255,255,0.03);}
.hero-stat:hover::before{width:100%;}
.hero-stat-n{font-family:var(--serif);font-size:30px;font-weight:300;color:#fff;display:flex;align-items:baseline;gap:3px;line-height:1;}
.hero-stat-n .count{display:inline-block;}
.hero-stat-n sup{font-size:13px;color:var(--r);font-family:var(--sans);font-weight:500;}
.hero-stat-l{font-size:9.5px;letter-spacing:0.10em;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-top:6px;line-height:1.45;}

/* Certif strip — dark */
.hero-certif{flex-shrink:0;padding:18px var(--gutter);background:#0a0908;border-top:1px solid rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:nowrap;position:relative;z-index:6;}
.certif-item{display:flex;align-items:center;gap:14px;flex:1;min-width:0;transition:transform 0.3s var(--ease);}
.certif-item:hover{transform:translateY(-1px);}
.certif-mark{width:40px;height:40px;border:1px solid rgba(255,255,255,0.18);background:rgba(255,255,255,0.02);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color 0.25s var(--ease),background 0.25s var(--ease);position:relative;}
.certif-mark::after{content:'';position:absolute;inset:-1px;border:1px solid var(--r);opacity:0;transform:scale(1.15);transition:opacity 0.3s var(--ease),transform 0.3s var(--ease);}
.certif-item:hover .certif-mark{border-color:rgba(200,16,46,0.55);background:rgba(200,16,46,0.06);}
.certif-item:hover .certif-mark::after{opacity:1;transform:scale(1);}
.certif-mark svg{width:17px;height:17px;stroke:rgba(255,255,255,0.85);fill:none;stroke-width:1.4;transition:stroke 0.25s;}
.certif-item:hover .certif-mark svg{stroke:var(--r);}
.certif-text{display:flex;flex-direction:column;gap:3px;min-width:0;}
.certif-text-title{font-size:12px;color:#fff;font-weight:500;letter-spacing:0.04em;line-height:1.2;font-family:var(--sans);}
.certif-text-sub{font-size:10px;color:rgba(255,255,255,0.55);letter-spacing:0.06em;line-height:1.3;text-transform:uppercase;}
.certif-sep{width:1px;height:38px;background:linear-gradient(180deg,transparent,rgba(255,255,255,0.18) 50%,transparent);flex-shrink:0;}

@media (max-width:760px){
  .hero-wrap{height:100vh;height:100dvh;}
  .hero-stage{cursor:auto;}
  .hero-cursor,.hero-cursor-dot{display:none;}
  .hero-content{padding:64px 24px 56px;}
  .hero-h1-cinema{font-size:clamp(38px,10vw,68px);margin-bottom:20px;}
  .hero-sub-cinema{font-size:13px;margin-bottom:24px;}
  .hero-bottom{grid-template-columns:repeat(2,1fr);}
  .hero-stat{padding:14px 18px;}
  .hero-stat-n{font-size:24px;}
  .hero-stat:nth-child(2n){border-right:none;}
  .hero-stat:nth-child(-n+2){border-bottom:1px solid rgba(255,255,255,0.07);}
  .hero-corner{display:none;}
  .hero-meta-line{font-size:9px;bottom:14px;}
  .hero-live{top:18px;font-size:9px;}
  .hero-certif{gap:14px 18px;padding:14px 24px;flex-wrap:wrap;justify-content:flex-start;}
  .hero-certif .certif-sep{display:none;}
  .certif-item{flex:1 1 calc(50% - 18px);min-width:140px;}
  .certif-mark{width:32px;height:32px;}
  .certif-mark svg{width:14px;height:14px;}
  .certif-text-title{font-size:11px;}
  .certif-text-sub{font-size:9px;}
}
@media (max-height:680px){
  .hero-certif{padding:12px var(--gutter);}
  .certif-mark{width:34px;height:34px;}
  .certif-mark svg{width:15px;height:15px;}
  .certif-text-title{font-size:11px;}
  .certif-text-sub{font-size:9.5px;}
  .hero-h1-cinema{font-size:clamp(40px,5.6vw,72px);margin-bottom:18px;}
  .hero-sub-cinema{margin-bottom:22px;font-size:13px;}
  .hero-content{padding:60px var(--gutter) 56px;}
  .hero-stat{padding:12px 22px;}
  .hero-stat-n{font-size:24px;}
  .hero-certif{padding:9px var(--gutter);}
}

/* Intro band */
.intro-band{background:var(--r);padding:14px var(--gutter);display:flex;align-items:center;justify-content:space-between;}
.intro-text{font-size:12px;letter-spacing:0.08em;text-transform:uppercase;color:rgba(255,255,255,0.92);}
.intro-cta{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:#fff;background:transparent;border:1px solid rgba(255,255,255,0.4);padding:8px 18px;cursor:pointer;font-family:var(--sans);transition:border-color 0.2s,background 0.2s;}
.intro-cta:hover{border-color:#fff;background:rgba(255,255,255,0.1);}

/* ============================================================
   SECTION 2 — SERVICIOS
   ============================================================ */
.services-section{position:relative;}
.aud-tabs{display:flex;background:var(--off);border-bottom:1px solid var(--border);}
.aud-tab{flex:1;padding:20px var(--gutter);cursor:pointer;border:none;background:var(--off);color:var(--muted);font-family:var(--sans);text-align:left;border-right:1px solid var(--border);border-bottom:2px solid transparent;transition:all 0.22s;display:flex;align-items:center;gap:16px;}
.aud-tab:last-child{border-right:none;}
.aud-tab:hover{background:var(--surface);}
.aud-tab.active{border-bottom-color:var(--r);background:var(--surface);}
.aud-tab-icon{width:36px;height:36px;border:1px solid var(--border);background:var(--surface2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color 0.22s;}
.aud-tab-icon svg{width:16px;height:16px;stroke:var(--muted);fill:none;stroke-width:1.5;transition:stroke 0.22s;}
.aud-tab.active .aud-tab-icon{border-color:rgba(200,16,46,0.3);}
.aud-tab.active .aud-tab-icon svg{stroke:var(--r);}
.aud-tab-title{font-size:14px;color:var(--ink);display:block;margin-bottom:3px;font-weight:500;}
.aud-tab-sub{font-size:10px;letter-spacing:0.03em;color:var(--muted);}
.aud-caret{margin-left:auto;font-size:20px;color:var(--muted3);transition:color 0.22s;line-height:1;}
.aud-tab.active .aud-caret{color:var(--r);}
.panel{display:none;}
.panel.active{display:block;animation:fade-up 0.3s var(--ease);}

/* Inversor layout */
.inv-layout{display:grid;grid-template-columns:300px 1fr;min-height:520px;}
.inv-nav{border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--surface);}
.inv-nav-item{padding:22px 26px;border:none;border-bottom:1px solid var(--border);border-left:2px solid transparent;cursor:pointer;transition:background 0.2s;display:flex;align-items:flex-start;gap:14px;background:transparent;width:100%;text-align:left;font-family:var(--sans);outline:none;}
.inv-nav-item:hover{background:var(--surface2);}
.inv-nav-item.active{background:var(--off);border-left-color:var(--r);}
.inv-num{font-size:11px;color:var(--r);letter-spacing:0.10em;margin-top:2px;min-width:20px;font-weight:500;}
.inv-nav-title{font-size:13px;color:var(--ink);margin-bottom:4px;font-weight:500;}
.inv-nav-sub{font-size:11px;color:var(--muted);line-height:1.5;}
.inv-detail{padding:52px var(--gutter);background:var(--off);}
.inv-detail-tag{font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--r);border:1px solid rgba(200,16,46,0.3);display:inline-block;padding:4px 12px;margin-bottom:24px;}
.inv-detail-bignum{font-family:var(--serif);font-size:80px;color:rgba(200,16,46,0.06);line-height:1;margin-bottom:-22px;user-select:none;}
.inv-detail-title{font-family:var(--serif);font-size:34px;font-weight:400;color:var(--ink);margin-bottom:14px;line-height:1.15;}
.inv-detail-desc{font-size:13px;color:var(--muted);line-height:1.9;margin-bottom:32px;max-width:500px;}
.inv-features{display:flex;flex-direction:column;gap:8px;margin-bottom:36px;}
.inv-feature{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;background:var(--surface);border:1px solid var(--border);transition:border-color 0.2s;}
.inv-feature:hover{border-color:var(--muted3);}
.inv-feat-dot{width:5px;height:5px;background:var(--r);margin-top:7px;flex-shrink:0;}
.inv-feat-text{font-size:12px;color:var(--muted);line-height:1.65;}
.inv-feat-text strong{color:var(--ink);font-weight:500;}

/* Particular layout */
.par-layout{display:grid;grid-template-columns:1fr 1fr;background:var(--off);}
.par-card{padding:40px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer;transition:background 0.22s;position:relative;overflow:hidden;}
.par-card:nth-child(2n){border-right:none;}
.par-card:nth-child(3),.par-card:nth-child(4){border-bottom:none;}
.par-card:hover{background:var(--surface);}
.par-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--r);transform:scaleX(0);transform-origin:left;transition:transform 0.3s var(--ease);}
.par-card:hover::after{transform:scaleX(1);}
.par-card-icon{width:40px;height:40px;border:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:border-color 0.22s;}
.par-card:hover .par-card-icon{border-color:rgba(200,16,46,0.3);}
.par-card-icon svg{width:18px;height:18px;stroke:var(--muted);fill:none;stroke-width:1.5;transition:stroke 0.22s;}
.par-card:hover .par-card-icon svg{stroke:var(--r);}
.par-q{font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--r);margin-bottom:10px;}
.par-card-title{font-size:17px;color:var(--ink);margin-bottom:12px;font-weight:500;line-height:1.3;}
.par-card-desc{font-size:12px;color:var(--muted);line-height:1.8;}
.par-card-link{display:flex;align-items:center;gap:8px;margin-top:20px;font-size:10px;letter-spacing:0.10em;text-transform:uppercase;color:var(--muted3);transition:color 0.2s;}
.par-card:hover .par-card-link{color:var(--r);}

/* ============================================================
   SECTION 3 — MÉTODO
   ============================================================ */
.method-section{position:relative;}
.step-selector{display:flex;border-bottom:1px solid var(--border);background:var(--off);}
.step-btn{flex:1;padding:0;border:none;background:transparent;cursor:pointer;font-family:var(--sans);border-right:1px solid var(--border);border-bottom:2px solid transparent;transition:background 0.2s,border-bottom-color 0.2s;position:relative;overflow:hidden;}
.step-btn:last-child{border-right:none;}
.step-btn:hover{background:var(--surface);}
.step-btn.active{border-bottom-color:var(--r);background:var(--surface);}
.step-btn-inner{padding:22px 24px;display:flex;align-items:center;gap:14px;}
.step-circle{width:36px;height:36px;border:1px solid var(--border);background:var(--surface2);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:11px;color:var(--muted);letter-spacing:0.05em;transition:all 0.25s;font-weight:500;}
.step-btn.active .step-circle{background:var(--r);border-color:var(--r);color:#fff;}
.step-btn-num{font-size:9px;letter-spacing:0.18em;color:var(--muted);margin-bottom:3px;text-transform:uppercase;}
.step-btn.active .step-btn-num{color:var(--r);}
.step-btn-label{font-size:13px;color:var(--ink);font-weight:500;line-height:1.2;text-align:left;}
.step-progress{position:absolute;bottom:0;left:0;height:2px;background:var(--r);width:0;}

.step-content{display:grid;grid-template-columns:1fr 340px;min-height:440px;}
.step-detail{padding:56px var(--gutter);background:var(--off);border-right:1px solid var(--border);}
.step-tag{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--r);border:1px solid rgba(200,16,46,0.3);display:inline-block;padding:4px 12px;margin-bottom:24px;}
.step-big-num{font-family:var(--serif);font-size:100px;color:rgba(200,16,46,0.05);line-height:1;margin-bottom:-24px;user-select:none;}
.step-title{font-family:var(--serif);font-size:36px;font-weight:400;color:var(--ink);line-height:1.12;margin-bottom:18px;}
.step-desc{font-size:13px;color:var(--muted);line-height:1.9;margin-bottom:36px;max-width:520px;}
.step-features{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:36px;}
.step-feat{background:var(--surface);border:1px solid var(--border);padding:16px;transition:border-color 0.2s;}
.step-feat:hover{border-color:var(--muted3);}
.step-feat-label{font-size:9px;letter-spacing:0.08em;text-transform:uppercase;color:var(--r);margin-bottom:7px;}
.step-feat-val{font-size:14px;color:var(--ink);font-weight:500;}
.step-feat-sub{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.5;}
.step-nav-btns{display:flex;align-items:center;gap:14px;}
.step-nav-btn{padding:12px 22px;font-size:11px;letter-spacing:0.10em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);font-weight:500;transition:all 0.2s;border:none;}
.step-nav-prev{background:transparent;color:var(--muted);border:1px solid var(--border);}
.step-nav-prev:hover:not(:disabled){border-color:var(--ink);color:var(--ink);}
.step-nav-prev:disabled{opacity:0.3;cursor:not-allowed;}
.step-nav-next{background:var(--r);color:#fff;}
.step-nav-next:hover{background:var(--r-dark);}

.step-sidebar{background:var(--surface);display:flex;flex-direction:column;}
.sidebar-header{padding:24px 28px;border-bottom:1px solid var(--border);}
.sidebar-label{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted2);}
.timeline{flex:1;padding:12px 0;}
.tl-item{display:flex;gap:0;position:relative;cursor:pointer;transition:background 0.2s;}
.tl-item:hover{background:var(--surface2);}
.tl-item.active{background:var(--off);}
.tl-spine{width:56px;display:flex;flex-direction:column;align-items:center;padding-top:20px;flex-shrink:0;}
.tl-dot{width:10px;height:10px;border-radius:50%;border:1px solid var(--border);background:var(--surface);flex-shrink:0;transition:all 0.25s;z-index:1;}
.tl-item.active .tl-dot{background:var(--r);border-color:var(--r);}
.tl-item.done .tl-dot{background:var(--green);border-color:var(--green);}
.tl-line{width:1px;flex:1;background:var(--border);margin-top:4px;}
.tl-item:last-child .tl-line{display:none;}
.tl-body{padding:16px 24px 20px 0;flex:1;}
.tl-step-num{font-size:9px;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted2);margin-bottom:5px;}
.tl-item.active .tl-step-num{color:var(--r);}
.tl-step-title{font-size:13px;color:var(--muted);font-weight:500;margin-bottom:4px;transition:color 0.2s;}
.tl-item.active .tl-step-title,.tl-item:hover .tl-step-title{color:var(--ink);}
.tl-step-sub{font-size:11px;color:var(--muted2);line-height:1.5;}
.tl-item.active .tl-step-sub{color:var(--muted);}
.tl-badge{display:inline-block;font-size:9px;letter-spacing:0.10em;text-transform:uppercase;padding:2px 8px;border:1px solid;margin-top:6px;}
.badge-active{color:var(--r);border-color:rgba(200,16,46,0.3);}
.badge-done{color:var(--green);border-color:rgba(26,107,72,0.3);}
.badge-pending{color:var(--muted2);border-color:var(--border);}
.sidebar-footer{padding:20px 28px;border-top:1px solid var(--border);}
.sidebar-stat{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border2);}
.sidebar-stat:last-child{border-bottom:none;}
.sidebar-stat-label{font-size:10px;color:var(--muted);}
.sidebar-stat-val{font-size:13px;color:var(--ink);font-weight:500;}

.diferencial{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--border);}
.dif-cell{padding:32px 36px;border-right:1px solid var(--border);display:flex;gap:16px;align-items:flex-start;transition:background 0.2s;background:var(--off);}
.dif-cell:last-child{border-right:none;}
.dif-cell:hover{background:var(--surface);}
.dif-icon{width:40px;height:40px;border:1px solid var(--border);background:var(--surface2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color 0.2s;}
.dif-cell:hover .dif-icon{border-color:rgba(200,16,46,0.3);}
.dif-icon svg{width:17px;height:17px;stroke:var(--muted);fill:none;stroke-width:1.5;transition:stroke 0.2s;}
.dif-cell:hover .dif-icon svg{stroke:var(--r);}
.dif-title{font-size:13px;color:var(--ink);font-weight:500;margin-bottom:7px;}
.dif-desc{font-size:11px;color:var(--muted);line-height:1.7;}

/* ============================================================
   SECTION 4 — IMASS PRO
   ============================================================ */
.pro-section{position:relative;}
.pro-header{position:relative;z-index:1;padding:64px var(--gutter) 48px;background:var(--off);border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:flex-end;}
.pro-pill{display:inline-flex;align-items:center;gap:9px;background:var(--r-light);border:1px solid rgba(200,16,46,0.2);padding:7px 16px;margin-top:18px;}
.pro-pill-dot{width:6px;height:6px;background:var(--r);border-radius:50%;animation:blink 1.8s ease-in-out infinite;}
.pro-pill-text{font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--r);}

.pro-layout{display:grid;grid-template-columns:200px 1fr 268px;border-bottom:1px solid var(--border);}
.pro-nav{border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--surface);}
.pro-nav-header{padding:16px 20px;border-bottom:1px solid var(--border);background:var(--surface2);}
.pro-nav-logo{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center;gap:8px;font-weight:600;}
.pro-nav-logo-dot{width:7px;height:7px;background:var(--r);}
.pro-nav-sub{font-size:9px;color:var(--muted2);margin-top:3px;}
.pro-nav-items{flex:1;padding:10px 0;}
.pro-nav-item{display:flex;align-items:center;gap:10px;padding:10px 18px;cursor:pointer;transition:background 0.18s;border-left:2px solid transparent;font-size:11px;color:var(--muted);letter-spacing:0.02em;border-top:none;border-right:none;border-bottom:none;background:transparent;font-family:var(--sans);width:100%;text-align:left;font-weight:500;}
.pro-nav-item:hover{background:var(--surface2);color:var(--ink);}
.pro-nav-item.active{background:var(--off);border-left-color:var(--r);color:var(--ink);}
.pro-nav-item svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.5;flex-shrink:0;}
.pro-nav-badge{margin-left:auto;background:var(--r);color:#fff;font-size:9px;padding:1px 6px;border-radius:2px;}
.pro-nav-footer{padding:14px 18px;border-top:1px solid var(--border);background:var(--surface2);}
.pro-nav-user{font-size:10px;color:var(--muted2);}
.pro-nav-user strong{display:block;color:var(--muted);font-weight:500;margin-bottom:2px;font-size:11px;}

.pro-center{display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--off);}
.pro-center-bar{padding:13px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--surface2);}
.pro-center-title{font-size:11px;letter-spacing:0.10em;text-transform:uppercase;color:var(--muted);font-weight:500;}
.pro-filter-row{display:flex;gap:5px;}
.pro-filter{font-size:9px;letter-spacing:0.10em;text-transform:uppercase;padding:4px 10px;border:1px solid var(--border);color:var(--muted2);cursor:pointer;transition:all 0.18s;background:var(--off);font-family:var(--sans);font-weight:500;}
.pro-filter:hover{border-color:var(--muted2);color:var(--muted);}
.pro-filter.active{border-color:var(--r);color:var(--r);background:var(--r-light);}
.pro-stats-mini{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--border);}
.pro-stat-mini{padding:13px 20px;border-right:1px solid var(--border);}
.pro-stat-mini:last-child{border-right:none;}
.pro-stat-n{font-family:var(--serif);font-size:24px;color:var(--ink);}
.pro-stat-n sup{font-size:12px;color:var(--green);font-family:var(--sans);font-weight:500;}
.pro-stat-l{font-size:9px;letter-spacing:0.07em;text-transform:uppercase;color:var(--muted2);margin-top:3px;}
.pro-table-head{display:grid;grid-template-columns:20px 1fr 110px 56px 28px;padding:9px 20px;border-bottom:1px solid var(--border);background:var(--surface);gap:10px;}
.pro-th{font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted2);font-weight:500;}
.pro-row{display:grid;grid-template-columns:20px 1fr 110px 56px 28px;padding:12px 20px;border-bottom:1px solid var(--border);cursor:pointer;transition:background 0.18s;align-items:center;gap:10px;}
.pro-row:hover{background:var(--surface);}
.pro-row.selected{background:var(--r-faint);}
.pro-row:last-child{border-bottom:none;}
.pro-status-dot{width:7px;height:7px;border-radius:50%;}
.prd-r{background:var(--r);animation:blink 2s ease-in-out infinite;}
.prd-a{background:var(--amber);animation:blink 2.5s ease-in-out infinite;}
.prd-g{background:var(--green);}
.pro-asset-name{font-size:12px;color:var(--ink);font-weight:500;}
.pro-asset-city{font-size:10px;color:var(--muted);margin-top:2px;}
.pro-phase-tag{font-size:8px;letter-spacing:0.06em;text-transform:uppercase;padding:3px 7px;border:1px solid;white-space:nowrap;display:inline-block;}
.tag-r{color:var(--r);border-color:rgba(200,16,46,0.3);}
.tag-a{color:var(--amber);border-color:rgba(176,124,16,0.3);}
.tag-g{color:var(--green);border-color:rgba(26,107,72,0.3);}
.tag-grey{color:var(--muted2);border-color:var(--border);}
.pro-days{font-size:11px;color:var(--muted);}
.pro-arr{font-size:14px;color:var(--muted3);text-align:right;}
.pro-row:hover .pro-arr{color:var(--r);}

.pro-right{display:flex;flex-direction:column;background:var(--surface);}
.pro-right-header{padding:13px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--surface2);}
.pro-right-label{font-size:9px;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted2);}
.pro-detail-body{padding:18px;flex:1;display:flex;flex-direction:column;gap:14px;}
.pro-detail-ref{font-size:9px;letter-spacing:0.14em;text-transform:uppercase;color:var(--r);margin-bottom:5px;}
.pro-detail-addr{font-size:13px;color:var(--ink);font-weight:600;line-height:1.3;margin-bottom:3px;}
.pro-detail-city{font-size:11px;color:var(--muted);}
.pro-detail-top{padding-bottom:14px;border-bottom:1px solid var(--border);}
.pro-detail-section{display:flex;flex-direction:column;gap:6px;}
.pro-detail-section-label{font-size:9px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted2);margin-bottom:4px;}
.pro-detail-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border2);}
.pro-detail-row:last-child{border-bottom:none;}
.pro-detail-key{font-size:11px;color:var(--muted);}
.pro-detail-val{font-size:11px;color:var(--ink);font-weight:500;text-align:right;}
.ptl-item{display:flex;gap:10px;align-items:flex-start;padding:7px 0;}
.ptl-item:not(:last-child){border-bottom:1px solid var(--border2);}
.ptl-dot{width:6px;height:6px;border-radius:50%;margin-top:4px;flex-shrink:0;}
.ptl-dot-done{background:var(--green);}
.ptl-dot-active{background:var(--r);animation:blink 2s ease-in-out infinite;}
.ptl-dot-pending{background:var(--muted3);}
.ptl-text{font-size:10px;color:var(--muted);line-height:1.5;}
.ptl-text strong{color:var(--ink);display:block;font-weight:500;margin-bottom:1px;}
.pro-right-cta{margin:0 18px 18px;background:var(--r);color:#fff;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;padding:11px;text-align:center;cursor:pointer;border:none;font-family:var(--sans);font-weight:500;transition:background 0.2s;}
.pro-right-cta:hover{background:var(--r-dark);}

.pro-features{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--border);}
.pro-feat{padding:28px 30px;border-right:1px solid var(--border);transition:background 0.2s;background:var(--off);}
.pro-feat:last-child{border-right:none;}
.pro-feat:hover{background:var(--surface);}
.pro-feat-num{font-family:var(--serif);font-size:30px;color:var(--r);margin-bottom:10px;opacity:0.45;}
.pro-feat-title{font-size:13px;color:var(--ink);font-weight:500;margin-bottom:7px;}
.pro-feat-desc{font-size:11px;color:var(--muted);line-height:1.65;}

/* ============================================================
   SECTION 5 — CASOS
   ============================================================ */
.casos-section{position:relative;}
.casos-header{position:relative;z-index:1;padding:64px var(--gutter) 48px;background:var(--off);border-bottom:1px solid var(--border);display:flex;align-items:flex-end;justify-content:space-between;gap:48px;}
.casos-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:14px;flex-shrink:0;}
.casos-header-right p{font-size:12px;color:var(--muted);line-height:1.75;text-align:right;max-width:240px;}
.filter-row{display:flex;gap:5px;}
.cat-btn{font-size:9px;letter-spacing:0.12em;text-transform:uppercase;padding:5px 12px;border:1px solid var(--border);color:var(--muted2);cursor:pointer;background:var(--off);font-family:var(--sans);transition:all 0.18s;font-weight:500;}
.cat-btn:hover{border-color:var(--muted2);color:var(--muted);}
.cat-btn.active{border-color:var(--r);color:var(--r);background:var(--r-light);}

.featured{display:grid;grid-template-columns:1fr 380px;border-bottom:1px solid var(--border);min-height:340px;cursor:pointer;transition:background 0.22s;}
.featured:hover .feat-left{background:var(--surface);}
.feat-left{padding:48px var(--gutter);background:var(--off);border-right:1px solid var(--border);display:flex;flex-direction:column;justify-content:space-between;transition:background 0.22s;}
.feat-badge-resolved{display:inline-flex;align-items:center;gap:9px;background:var(--green2);border:1px solid rgba(26,107,72,0.3);padding:5px 14px;margin-bottom:28px;}
.feat-badge-text{font-size:9px;letter-spacing:0.16em;text-transform:uppercase;color:var(--green);}
.feat-badge-dot{width:5px;height:5px;background:var(--green);border-radius:50%;}
.feat-ref{font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted2);margin-bottom:10px;}
.feat-title{font-family:var(--serif);font-size:28px;font-weight:400;color:var(--ink);line-height:1.2;margin-bottom:14px;}
.feat-desc{font-size:13px;color:var(--muted);line-height:1.85;max-width:500px;margin-bottom:28px;}
.feat-tags{display:flex;gap:7px;flex-wrap:wrap;}
.feat-tag{font-size:9px;letter-spacing:0.10em;text-transform:uppercase;padding:4px 10px;border:1px solid var(--border);color:var(--muted2);background:var(--surface);}
.feat-right{padding:36px 32px;background:var(--surface);display:flex;flex-direction:column;}
.feat-metric{padding:18px 0;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.feat-metric:first-child{padding-top:0;}
.feat-metric:last-child{border-bottom:none;padding-bottom:0;}
.feat-metric-label{font-size:10px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted2);}
.feat-metric-val{font-family:var(--serif);font-size:24px;color:var(--ink);}
.feat-metric-val sup{font-size:12px;color:var(--r);font-family:var(--sans);}
.feat-metric-val.green{color:var(--green);}
.feat-outcome{margin-top:auto;padding-top:20px;border-top:1px solid var(--border);}
.feat-outcome-label{font-size:9px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted2);margin-bottom:7px;}
.feat-outcome-text{font-size:12px;color:var(--muted);line-height:1.65;}
.feat-outcome-text strong{color:var(--ink);font-weight:500;}

.case-grid{display:grid;grid-template-columns:repeat(3,1fr);}
.case-card{padding:32px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer;transition:background 0.2s;position:relative;overflow:hidden;background:var(--off);}
.case-card:nth-child(3n){border-right:none;}
.case-card:hover{background:var(--surface);}
.case-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform 0.3s var(--ease);}
.case-card:hover::before{transform:scaleX(1);}
.case-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px;}
.case-resolved{background:var(--green2);border:1px solid rgba(26,107,72,0.25);padding:3px 10px;font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--green);}
.case-ref{font-size:9px;letter-spacing:0.10em;text-transform:uppercase;color:var(--muted2);}
.case-title{font-size:15px;color:var(--ink);font-weight:500;line-height:1.3;margin-bottom:8px;}
.case-desc{font-size:11px;color:var(--muted);line-height:1.7;margin-bottom:20px;}
.case-metrics{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:16px;}
.case-metric{background:var(--off);padding:10px 12px;}
.case-metric-l{font-size:9px;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted2);margin-bottom:3px;}
.case-metric-v{font-size:14px;color:var(--ink);font-weight:500;}
.case-metric-v.g{color:var(--green);}
.case-footer{display:flex;align-items:center;justify-content:space-between;}
.case-type{font-size:9px;letter-spacing:0.10em;text-transform:uppercase;padding:3px 8px;border:1px solid var(--border);color:var(--muted2);background:var(--surface);}
.case-arrow{font-size:14px;color:var(--muted3);transition:color 0.18s;}
.case-card:hover .case-arrow{color:var(--r);}

.quote-strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:grid;grid-template-columns:3px 1fr;background:var(--surface);}
.quote-accent{background:var(--r);}
.quote-body{padding:40px var(--gutter);display:flex;align-items:center;gap:52px;}
.quote-mark{font-family:var(--serif);font-size:72px;color:var(--r);line-height:0.6;margin-top:18px;flex-shrink:0;opacity:0.2;}
.quote-text{font-family:var(--serif);font-size:19px;color:var(--ink);line-height:1.6;margin-bottom:14px;font-weight:400;font-style:italic;}
.quote-text em{font-style:normal;color:var(--muted);}
.quote-attr{font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted2);}
.quote-attr strong{color:var(--muted);font-weight:500;}

.stats-band{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--border);}
.stat-cell{padding:30px 36px;border-right:1px solid var(--border);background:var(--off);}
.stat-cell:last-child{border-right:none;}
.stat-n{font-family:var(--serif);font-size:38px;color:var(--ink);}
.stat-n sup{font-size:17px;color:var(--r);font-family:var(--sans);font-weight:500;}
.stat-n.g sup{color:var(--green);}
.stat-l{font-size:10px;letter-spacing:0.07em;text-transform:uppercase;color:var(--muted2);margin-top:6px;line-height:1.5;}

/* ============================================================
   SECTION 6 — CONTACTO + FOOTER
   ============================================================ */
.morador-band{border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;}
.morador-left{padding:36px var(--gutter);border-right:1px solid var(--border);background:var(--surface);}
.morador-eyebrow{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--r);margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.morador-eyebrow-line{width:18px;height:1px;background:var(--r);}
.morador-title{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--ink);margin-bottom:10px;line-height:1.3;}
.morador-desc{font-size:12px;color:var(--muted);line-height:1.8;}
.morador-right{padding:36px var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:24px;background:var(--surface2);}
.morador-right p{font-size:12px;color:var(--muted);line-height:1.75;max-width:310px;}

.contact-wrap{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--border);}
.contact-left{padding:64px var(--gutter);background:var(--off);border-right:1px solid var(--border);}
.contact-title{font-family:var(--serif);font-size:42px;font-weight:400;color:var(--ink);line-height:1.06;margin-bottom:16px;}
.contact-title em{font-style:normal;color:var(--muted2);}
.contact-sub{font-size:13px;color:var(--muted);line-height:1.85;margin-bottom:44px;max-width:380px;}
.channel{display:flex;align-items:center;gap:18px;padding:20px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:opacity 0.2s;}
.channel:first-of-type{padding-top:0;}
.channel:last-of-type{border-bottom:none;padding-bottom:0;}
.channel:hover{opacity:0.75;}
.channel-icon{width:42px;height:42px;border:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color 0.2s;}
.channel:hover .channel-icon{border-color:rgba(200,16,46,0.3);}
.channel-icon svg{width:17px;height:17px;stroke:var(--muted);fill:none;stroke-width:1.5;transition:stroke 0.2s;}
.channel:hover .channel-icon svg{stroke:var(--r);}
.channel-label{font-size:10px;letter-spacing:0.10em;text-transform:uppercase;color:var(--muted2);margin-bottom:4px;}
.channel-val{font-size:15px;color:var(--ink);font-weight:500;}
.channel-sub{font-size:11px;color:var(--muted);margin-top:2px;}
.channel-arrow{margin-left:auto;font-size:16px;color:var(--muted3);transition:color 0.2s;}
.channel:hover .channel-arrow{color:var(--r);}

.contact-right{padding:64px var(--gutter);background:var(--surface);}
.form-header{margin-bottom:28px;}
.form-title{font-size:16px;color:var(--ink);font-weight:500;margin-bottom:6px;}
.form-sub{font-size:12px;color:var(--muted);}
.form-group{margin-bottom:13px;}
.form-label{display:block;font-size:9px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted2);margin-bottom:7px;}
.form-input,.form-select,.form-textarea{width:100%;background:var(--off);border:1px solid var(--border);color:var(--ink);padding:12px 14px;font-size:13px;font-family:var(--sans);outline:none;transition:border-color 0.2s;appearance:none;-webkit-appearance:none;}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--muted2);}
.form-input::placeholder,.form-textarea::placeholder{color:var(--muted2);}
.form-select{color:var(--muted);cursor:pointer;}
.form-textarea{resize:none;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.form-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:18px;gap:16px;}
.form-legal{font-size:10px;color:var(--muted2);line-height:1.6;max-width:200px;}
.form-submit{display:inline-flex;align-items:center;gap:10px;background:var(--r);color:#fff;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;padding:14px 28px;cursor:pointer;border:none;font-family:var(--sans);font-weight:500;transition:background 0.2s;white-space:nowrap;}
.form-submit:hover{background:var(--r-dark);}
.form-success{display:none;text-align:center;padding:60px 20px;}
.form-success-icon{width:52px;height:52px;background:var(--green2);border:1px solid rgba(26,107,72,0.3);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;}
.form-success-icon svg{width:22px;height:22px;stroke:var(--green);fill:none;stroke-width:2;}
.form-success-title{font-family:var(--serif);font-size:22px;color:var(--ink);margin-bottom:10px;}
.form-success-sub{font-size:13px;color:var(--muted);line-height:1.75;}

footer{border-top:1px solid var(--border);}
.footer-main{display:grid;grid-template-columns:280px 1fr 1fr 1fr;border-bottom:1px solid var(--border);}
.footer-brand{padding:40px var(--gutter);border-right:1px solid var(--border);background:var(--surface2);}
.footer-logo{display:flex;align-items:center;gap:0;margin-bottom:8px;}
.footer-logo svg{height:32px;width:auto;}
.footer-tagline{font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted2);margin-bottom:22px;}
.footer-brand-desc{font-size:11px;color:var(--muted);line-height:1.75;margin-bottom:22px;}
.footer-brand-cif{font-size:10px;color:var(--muted2);line-height:1.65;}
.footer-col{padding:40px 32px;border-right:1px solid var(--border);background:var(--surface);}
.footer-col:last-child{border-right:none;}
.footer-col-title{font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted2);margin-bottom:18px;}
.footer-link{display:block;font-size:12px;color:var(--muted);margin-bottom:10px;cursor:pointer;transition:color 0.18s;background:none;border:none;font-family:var(--sans);padding:0;text-align:left;}
.footer-link:hover{color:var(--ink);}
.footer-link:last-child{margin-bottom:0;}
.footer-link-red{color:var(--r);}
.footer-link-red:hover{color:var(--r-dark);}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding:18px var(--gutter);background:var(--surface3);}
.footer-legal-links{display:flex;gap:20px;}
.footer-legal-link{font-size:10px;color:var(--muted2);cursor:pointer;letter-spacing:0.04em;transition:color 0.18s;background:none;border:none;font-family:var(--sans);}
.footer-legal-link:hover{color:var(--muted);}
.footer-copy{font-size:10px;color:var(--muted2);letter-spacing:0.04em;}

/* ============================================================
   TWEAKS PANEL
   ============================================================ */
#tweaks-panel{position:fixed;bottom:24px;right:24px;width:260px;background:var(--off);border:1px solid var(--border);box-shadow:0 8px 32px rgba(0,0,0,0.12);z-index:200;display:none;flex-direction:column;overflow:hidden;}
#tweaks-panel.open{display:flex;}
.tweaks-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface2);}
.tweaks-title{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);font-weight:500;}
.tweaks-close{background:none;border:none;cursor:pointer;font-size:16px;color:var(--muted);line-height:1;padding:0;}
.tweaks-body{padding:16px;display:flex;flex-direction:column;gap:14px;}
.tweak-group label{display:block;font-size:9px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted2);margin-bottom:8px;}
.tweak-options{display:flex;gap:6px;flex-wrap:wrap;}
.tweak-opt{font-size:10px;padding:5px 10px;border:1px solid var(--border);cursor:pointer;background:var(--off);color:var(--muted);font-family:var(--sans);transition:all 0.18s;font-weight:500;}
.tweak-opt:hover{border-color:var(--muted2);color:var(--ink);}
.tweak-opt.active{border-color:var(--r);color:var(--r);background:var(--r-light);}
.tweak-color-row{display:flex;gap:8px;align-items:center;}
.tweak-swatch{width:24px;height:24px;border:2px solid transparent;cursor:pointer;transition:all 0.18s;flex-shrink:0;}
.tweak-swatch.active{border-color:var(--ink);}
body.admin-bar .main-nav,
body.admin-bar .nav-top-line { top: 32px; }
body.admin-bar .hero-wrap,
body.admin-bar .inner-page { padding-top: 96px; }
@media (max-width: 782px) {
  body.admin-bar .main-nav,
  body.admin-bar .nav-top-line { top: 46px; }
  body.admin-bar .hero-wrap,
  body.admin-bar .inner-page { padding-top: 150px; }
}
.wp-fallback { min-height: 70vh; padding: 120px var(--gutter) 80px; background: var(--page); }
.wp-fallback .entry-title { font-family: var(--serif); font-size: clamp(36px, 5vw, 72px); line-height: 1; margin-bottom: 24px; }
.screen-reader-text { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ============================================================
   INNER PAGES
   ============================================================ */
.nav-link,.nav-tel,.nav-cta,.footer-link,.footer-legal-link,.btn-primary,.btn-outline,.btn-ghost{text-decoration:none;}
.nav-link{display:inline-flex;align-items:center;}
.nav-link.active{color:var(--ink);}
.nav-link.active::after{transform:scaleX(1);}
.inner-page{padding-top:64px;background:var(--page);overflow:hidden;}
.inner-hero{position:relative;min-height:620px;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,0.95fr);align-items:stretch;border-bottom:1px solid var(--border);isolation:isolate;}
.inner-hero-dark{background:#0a0908;color:#fff;}
.inner-hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:saturate(0.86) contrast(1.04) brightness(0.62);}
.inner-hero.has-video::before{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(90deg,rgba(10,9,8,0.86) 0%,rgba(10,9,8,0.56) 44%,rgba(10,9,8,0.76) 100%),linear-gradient(180deg,rgba(10,9,8,0.35),rgba(10,9,8,0.78));}
.inner-hero.has-video .inner-hero-copy,.inner-hero.has-video .inner-hero-panel{z-index:2;}
.inner-hero-dark .grid-bg,.method-hero .grid-bg,.cases-hero .grid-bg{opacity:0.18;background-image:linear-gradient(rgba(255,255,255,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.05) 1px,transparent 1px);}
.inner-hero::after{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 70% 20%,rgba(200,16,46,0.16),transparent 34%),linear-gradient(180deg,rgba(10,9,8,0.08),rgba(10,9,8,0.22));z-index:0;}
.inner-hero-copy{position:relative;z-index:1;padding:92px var(--gutter) 78px;display:flex;flex-direction:column;justify-content:flex-end;max-width:820px;min-width:0;}
.inner-hero-title{font-size:clamp(52px,6.8vw,104px);line-height:0.96;letter-spacing:-0.015em;margin:0 0 26px;color:inherit;font-weight:300;text-wrap:balance;}
.inner-hero-text{font-size:15px;line-height:1.8;color:rgba(255,255,255,0.72);max-width:580px;margin:0 0 34px;}
.inner-hero-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.inner-outline-light{color:rgba(255,255,255,0.72);border-color:rgba(255,255,255,0.24);}
.inner-outline-light:hover{color:#fff;border-color:#fff;}
.inner-hero-panel{position:relative;z-index:1;padding:92px var(--gutter) 78px;display:flex;align-items:flex-end;border-left:1px solid rgba(255,255,255,0.08);min-width:0;}
.metric-board{width:100%;display:grid;grid-template-columns:1fr 1fr;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.03);backdrop-filter:blur(10px);}
.metric-board div{min-height:145px;padding:28px;border-right:1px solid rgba(255,255,255,0.08);border-bottom:1px solid rgba(255,255,255,0.08);display:flex;flex-direction:column;justify-content:space-between;}
.metric-board div:nth-child(2n){border-right:none;}
.metric-board div:nth-last-child(-n+2){border-bottom:none;}
.metric-board span{font-family:var(--serif);font-size:36px;line-height:1;color:#fff;font-weight:300;}
.metric-board small{font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.52);line-height:1.5;}
.inner-band{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px var(--gutter);background:var(--r);color:#fff;overflow:auto;}
.inner-band span{font-size:10px;letter-spacing:0.16em;text-transform:uppercase;white-space:nowrap;font-weight:500;}
.page-section{position:relative;background:var(--off);}
.page-section-title{font-size:clamp(32px,3.2vw,50px);line-height:1.06;color:var(--ink);font-weight:400;}
.service-matrix{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--border);}
.service-tile{min-height:360px;padding:34px 30px;background:var(--surface);border-right:1px solid var(--border);color:var(--ink);text-decoration:none;display:flex;flex-direction:column;transition:background 0.25s var(--ease),transform 0.25s var(--ease);}
.service-tile:last-child{border-right:none;}
.service-tile:hover{background:var(--off);transform:translateY(-2px);}
.tile-num{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--r);margin-bottom:74px;}
.service-tile h3{font-family:var(--serif);font-size:30px;font-weight:400;line-height:1.05;margin:0 0 18px;color:var(--ink);}
.service-tile p{font-size:13px;line-height:1.8;color:var(--muted);margin:0 0 28px;}
.tile-link{margin-top:auto;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--r);font-weight:500;}
.service-detail-section{display:grid;grid-template-columns:170px minmax(0,1fr) minmax(320px,0.8fr);gap:52px;padding:86px var(--gutter);background:var(--off);border-bottom:1px solid var(--border);align-items:start;}
.service-detail-section.invert{background:var(--surface2);}
.service-detail-index{font-family:var(--serif);font-size:72px;line-height:0.9;color:var(--muted3);font-weight:300;}
.service-detail-copy h2{font-size:clamp(34px,4vw,62px);line-height:1;color:var(--ink);font-weight:300;margin:0 0 24px;}
.service-detail-copy p{font-size:14px;line-height:1.9;color:var(--muted);max-width:680px;}
.service-detail-list{border-top:1px solid var(--border);}
.service-detail-list div{padding:22px 0;border-bottom:1px solid var(--border);}
.service-detail-list strong{display:block;font-size:13px;color:var(--ink);font-weight:500;margin-bottom:7px;}
.service-detail-list span{display:block;font-size:12px;line-height:1.7;color:var(--muted);}
.audience-strip{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:40px;align-items:end;padding:70px var(--gutter);background:#0a0908;color:#fff;border-bottom:1px solid rgba(255,255,255,0.1);}
.audience-copy h2{font-size:clamp(34px,4vw,62px);line-height:1;color:#fff;font-weight:300;margin:0 0 20px;max-width:760px;}
.audience-copy p{max-width:620px;color:rgba(255,255,255,0.68);font-size:14px;line-height:1.85;}
.audience-actions{display:flex;gap:18px;align-items:center;white-space:nowrap;}
.audience-actions .btn-ghost{color:rgba(255,255,255,0.76);border-color:rgba(255,255,255,0.3);}
.audience-actions .btn-ghost:hover{color:#fff;border-color:#fff;}

.method-hero{background:var(--off);color:var(--ink);}
.method-hero::after{background:radial-gradient(ellipse at 80% 20%,rgba(200,16,46,0.10),transparent 36%);}
.method-hero .inner-hero-text{color:var(--muted);}
.method-hero-system{position:relative;z-index:1;margin:92px var(--gutter) 78px 0;align-self:end;border:1px solid var(--border);background:var(--surface);padding:26px;}
.system-line{display:flex;align-items:center;gap:12px;padding:20px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--ink);}
.system-line:last-child{border-bottom:none;}
.method-flow{background:var(--surface);padding:78px var(--gutter);border-bottom:1px solid var(--border);}
.method-flow-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:42px;}
.method-steps{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--border);background:var(--off);}
.method-card{padding:32px 26px;border-right:1px solid var(--border);min-height:430px;}
.method-card:last-child{border-right:none;}
.method-num{font-size:10px;letter-spacing:0.18em;color:var(--r);text-transform:uppercase;}
.method-card h3{font-family:var(--serif);font-size:29px;font-weight:400;line-height:1.05;margin:74px 0 18px;}
.method-card p{font-size:13px;line-height:1.75;color:var(--muted);margin-bottom:24px;}
.method-card ul{list-style:none;margin:0;padding:0;}
.method-card li{position:relative;padding-left:16px;margin-bottom:10px;font-size:11px;color:var(--muted);line-height:1.55;}
.method-card li::before{content:'';position:absolute;left:0;top:0.72em;width:5px;height:5px;background:var(--r);}
.method-principles{display:grid;grid-template-columns:minmax(0,0.9fr) minmax(0,1.1fr);background:var(--off);border-bottom:1px solid var(--border);}
.principle-large{padding:82px var(--gutter);border-right:1px solid var(--border);}
.principle-large h2{font-size:clamp(38px,4.5vw,70px);line-height:1;font-weight:300;margin:0 0 24px;}
.principle-large p{font-size:14px;line-height:1.9;color:var(--muted);max-width:560px;}
.principle-list{display:grid;grid-template-columns:1fr 1fr;}
.principle-item{padding:42px 36px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);min-height:220px;}
.principle-item:nth-child(2n){border-right:none;}
.principle-item:nth-last-child(-n+2){border-bottom:none;}
.principle-item span{font-size:10px;letter-spacing:0.18em;color:var(--r);}
.principle-item strong{display:block;font-family:var(--serif);font-size:28px;font-weight:400;margin:42px 0 12px;}
.principle-item p{font-size:12px;line-height:1.75;color:var(--muted);}
.method-dashboard{display:grid;grid-template-columns:minmax(0,0.82fr) minmax(420px,1fr);gap:46px;padding:78px var(--gutter);background:#0a0908;color:#fff;border-bottom:1px solid rgba(255,255,255,0.1);}
.dashboard-copy h2{font-size:clamp(36px,4vw,62px);line-height:1;font-weight:300;margin:0 0 22px;color:#fff;}
.dashboard-copy p{max-width:520px;color:rgba(255,255,255,0.66);line-height:1.85;}
.dashboard-mini{border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.03);}
.dash-row{display:grid;grid-template-columns:90px 1fr 90px;gap:18px;align-items:center;padding:22px 24px;border-bottom:1px solid rgba(255,255,255,0.08);}
.dash-row:last-child{border-bottom:none;}
.dash-row span{font-size:10px;letter-spacing:0.14em;color:var(--r);font-weight:500;}
.dash-row strong{font-size:13px;color:#fff;font-weight:500;}
.dash-row em{font-style:normal;text-align:right;font-size:11px;color:rgba(255,255,255,0.52);}
.dash-row.active{background:rgba(200,16,46,0.10);}
.dash-row.done span{color:var(--green);}

.cases-hero{background:#0a0908;color:#fff;}
.cases-hero .inner-hero-text{color:rgba(255,255,255,0.7);}
.case-hero-stats{position:relative;z-index:1;align-self:end;margin:92px var(--gutter) 78px 0;border-top:1px solid rgba(255,255,255,0.18);}
.case-hero-stats div{display:flex;justify-content:space-between;align-items:baseline;gap:28px;padding:28px 0;border-bottom:1px solid rgba(255,255,255,0.14);}
.case-hero-stats span{font-family:var(--serif);font-size:42px;color:#fff;font-weight:300;}
.case-hero-stats small{font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.5);text-align:right;}
.case-filter-panel{display:flex;align-items:end;justify-content:space-between;gap:32px;padding:54px var(--gutter);background:var(--off);border-bottom:1px solid var(--border);}
.case-filter-copy h2{font-size:clamp(30px,3vw,46px);line-height:1.05;font-weight:400;margin:0;}
.case-page-filters{display:flex;gap:8px;flex-wrap:wrap;}
.case-page-filter{border:1px solid var(--border);background:var(--surface);color:var(--muted);font-family:var(--sans);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;padding:12px 18px;cursor:pointer;transition:all 0.2s;}
.case-page-filter:hover,.case-page-filter.active{border-color:var(--r);color:var(--r);background:var(--r-light);}
.case-portfolio{display:grid;grid-template-columns:repeat(3,1fr);background:var(--surface);border-bottom:1px solid var(--border);}
.portfolio-case{min-height:430px;padding:34px 30px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface);transition:opacity 0.2s,transform 0.2s,background 0.2s;}
.portfolio-case:nth-child(3n){border-right:none;}
.portfolio-case:hover{background:var(--off);}
.portfolio-case.is-hidden{display:none;}
.portfolio-case-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:76px;}
.portfolio-case-meta span{font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);padding:4px 8px;background:var(--off);}
.portfolio-case h3{font-family:var(--serif);font-size:34px;line-height:1.03;font-weight:400;margin:0 0 18px;color:var(--ink);}
.portfolio-case p{font-size:13px;line-height:1.8;color:var(--muted);margin:0 0 28px;}
.portfolio-metrics{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--border);margin-top:auto;}
.portfolio-metrics div{padding-top:18px;}
.portfolio-metrics strong{display:block;font-family:var(--serif);font-size:28px;font-weight:400;color:var(--ink);line-height:1;}
.portfolio-metrics span{display:block;margin-top:7px;font-size:10px;letter-spacing:0.10em;text-transform:uppercase;color:var(--muted2);}
.case-feature{display:grid;grid-template-columns:1fr minmax(320px,0.75fr) auto;gap:40px;align-items:end;padding:74px var(--gutter);background:var(--off);border-bottom:1px solid var(--border);}
.case-feature h2{font-size:clamp(36px,4vw,62px);line-height:1;font-weight:300;margin:0;}
.case-feature p{font-size:14px;line-height:1.85;color:var(--muted);margin:0;}

@media (max-width:1100px){
  .inner-hero,.service-detail-section,.method-principles,.method-dashboard,.case-feature{grid-template-columns:minmax(0,1fr);}
  .inner-hero-panel,.method-hero-system,.case-hero-stats{margin:0;padding:0 var(--gutter) 68px;border-left:none;}
  .service-matrix,.method-steps,.case-portfolio{grid-template-columns:repeat(2,1fr);}
  .service-tile:nth-child(2n),.portfolio-case:nth-child(2n){border-right:none;}
  .portfolio-case:nth-child(3n){border-right:1px solid var(--border);}
  .method-card:nth-child(2n){border-right:none;}
  .method-card{border-bottom:1px solid var(--border);}
}
@media (max-width:760px){
  :root{--gutter:24px;}
  .main-nav{height:auto;min-height:64px;padding:0 20px;flex-wrap:wrap;align-content:center;}
  .nav-left{height:62px;}
  .nav-logo span{font-size:24px!important;}
  .nav-divider,.nav-tagline{display:none;}
  .nav-links{order:3;display:flex;width:100%;overflow-x:auto;gap:4px;border-top:1px solid var(--border);padding:6px 0 8px;}
  .nav-link{padding:8px 12px;white-space:nowrap;}
  .nav-actions{display:none;}
  .inner-page,.hero-wrap{padding-top:104px;}
  .inner-hero{min-height:auto;}
  .inner-hero-copy{width:100%;max-width:100%;padding:74px var(--gutter) 56px;}
  .inner-hero-title{font-size:clamp(38px,11vw,48px);text-wrap:normal;white-space:normal;}
  .inner-hero-text{font-size:14px;}
  .metric-board,.service-matrix,.method-steps,.principle-list,.case-portfolio,.footer-main{grid-template-columns:1fr;}
  .metric-board div,.service-tile,.method-card,.portfolio-case,.footer-brand,.footer-col{border-right:none;}
  .service-detail-section,.method-flow,.principle-large,.method-dashboard,.case-filter-panel,.case-feature,.audience-strip{padding-left:var(--gutter);padding-right:var(--gutter);}
  .service-detail-section{grid-template-columns:1fr;gap:24px;padding-top:56px;padding-bottom:56px;}
  .service-detail-index{font-size:48px;}
  .audience-strip,.case-filter-panel{grid-template-columns:1fr;align-items:start;}
  .audience-actions,.cta-strip,.footer-bottom{flex-direction:column;align-items:flex-start;}
  .case-feature{grid-template-columns:1fr;}
  .footer-legal-links{flex-direction:column;gap:8px;}
}
@media (max-width:520px){
  .inner-hero-title,.inner-hero-text{max-width:342px;}
  .metric-board{max-width:342px;}
}

/* ============================================================
   RESPONSIVE HARDENING
   ============================================================ */
img,video,svg{max-width:100%;}
a,button,input,select,textarea{min-width:0;}
.main-nav,.hero-wrap,.inner-page,section,footer{max-width:100vw;}

@media (max-width:1280px){
  :root{--gutter:44px;}
  .main-nav{padding:0 var(--gutter);}
  .nav-divider{margin:0 14px;}
  .nav-link{padding:8px 11px;}
  .nav-tel{padding:8px 13px;}
  .nav-cta{padding:9px 16px;}
  .pro-layout{grid-template-columns:180px minmax(0,1fr) 248px;}
  .pro-table-head,.pro-row{grid-template-columns:18px minmax(0,1fr) 96px 44px 22px;}
  .featured{grid-template-columns:minmax(0,1fr) 340px;}
  .footer-main{grid-template-columns:260px repeat(3,minmax(0,1fr));}
}

@media (max-width:1080px){
  :root{--gutter:36px;}
  .nav-tagline,.nav-divider{display:none;}
  .section-header,.casos-header{gap:28px;}
  .aud-tab{padding:18px var(--gutter);}
  .aud-tab-sub{display:none;}
  .step-content{grid-template-columns:minmax(0,1fr);}
  .step-detail{border-right:none;border-bottom:1px solid var(--border);}
  .step-sidebar{display:grid;grid-template-columns:minmax(0,1fr) 280px;}
  .sidebar-header{grid-column:1/-1;}
  .sidebar-footer{border-top:none;border-left:1px solid var(--border);}
  .diferencial,.case-grid,.stats-band{grid-template-columns:repeat(2,1fr);}
  .dif-cell:nth-child(2n),.case-card:nth-child(2n),.stat-cell:nth-child(2n){border-right:none;}
  .dif-cell:nth-child(3),.stat-cell:nth-child(3){border-top:1px solid var(--border);}
  .case-card:nth-child(3n){border-right:1px solid var(--border);}
  .pro-header{grid-template-columns:minmax(0,1fr);gap:26px;}
  .pro-layout{grid-template-columns:minmax(0,1fr);border-bottom:none;}
  .pro-nav{border-right:none;border-bottom:1px solid var(--border);}
  .pro-nav-items{display:grid;grid-template-columns:repeat(3,1fr);padding:0;}
  .pro-nav-item{border-left:none;border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:13px 16px;}
  .pro-nav-item:nth-child(3n){border-right:none;}
  .pro-nav-item.active{border-left:none;box-shadow:inset 0 2px 0 var(--r);}
  .pro-center{border-right:none;border-bottom:1px solid var(--border);}
  .pro-right{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,0.45fr);}
  .pro-right-header{grid-column:1/-1;}
  .pro-right-cta{align-self:end;}
  .pro-features{grid-template-columns:repeat(2,1fr);}
  .pro-feat:nth-child(2n){border-right:none;}
  .featured{grid-template-columns:minmax(0,1fr);}
  .feat-left{border-right:none;border-bottom:1px solid var(--border);}
  .quote-body{gap:28px;}
  .morador-band,.contact-wrap{grid-template-columns:minmax(0,1fr);}
  .morador-left,.contact-left{border-right:none;border-bottom:1px solid var(--border);}
  .morador-right{justify-content:flex-start;}
  .footer-main{grid-template-columns:repeat(2,minmax(0,1fr));}
  .footer-brand{grid-column:1/-1;border-right:none;border-bottom:1px solid var(--border);}
}

@media (max-width:900px){
  .section-header,.casos-header{flex-direction:column;align-items:flex-start;padding-top:52px;padding-bottom:38px;}
  .section-header-aside,.casos-header-right,.casos-header-right p{text-align:left;align-items:flex-start;max-width:620px;}
  .inner-band{flex-wrap:wrap;overflow:visible;gap:12px 24px;}
  .inner-band span{white-space:normal;}
  .filter-row,.case-page-filters,.pro-filter-row{overflow-x:auto;max-width:100%;padding-bottom:3px;}
  .cat-btn,.case-page-filter,.pro-filter{white-space:nowrap;}
  .aud-tabs{display:grid;grid-template-columns:1fr 1fr;}
  .aud-tab{min-width:0;padding:18px 24px;}
  .inv-layout{grid-template-columns:minmax(0,1fr);min-height:0;}
  .inv-nav{flex-direction:row;overflow-x:auto;border-right:none;border-bottom:1px solid var(--border);}
  .inv-nav-item{min-width:235px;border-left:none;border-right:1px solid var(--border);}
  .inv-nav-item.active{border-left:none;box-shadow:inset 0 2px 0 var(--r);}
  .inv-detail{padding:44px var(--gutter);}
  .par-layout{grid-template-columns:minmax(0,1fr);}
  .par-card,.par-card:nth-child(2n),.par-card:nth-child(3),.par-card:nth-child(4){border-right:none;border-bottom:1px solid var(--border);}
  .par-card:last-child{border-bottom:none;}
  .step-selector{display:grid;grid-template-columns:repeat(4,minmax(178px,1fr));overflow-x:auto;}
  .step-btn{min-width:178px;}
  .step-btn-inner{padding:18px 20px;}
  .step-sidebar{grid-template-columns:minmax(0,1fr);}
  .sidebar-footer{border-left:none;border-top:1px solid var(--border);}
  .pro-right{display:flex;}
  .case-filter-panel{align-items:flex-start;flex-direction:column;}
  .case-feature{align-items:start;}
  .hero-certif{flex-wrap:wrap;}
  .hero-certif .certif-sep{display:none;}
  .certif-item{flex:1 1 calc(50% - 18px);min-width:220px;}
}

@media (max-width:760px){
  :root{--gutter:24px;}
  body{font-size:13px;}
  .main-nav{gap:0;padding:0 18px;}
  .nav-left{width:auto;min-width:0;}
  .nav-links{-webkit-overflow-scrolling:touch;scrollbar-width:none;}
  .nav-links::-webkit-scrollbar,.inv-nav::-webkit-scrollbar,.step-selector::-webkit-scrollbar,.filter-row::-webkit-scrollbar,.case-page-filters::-webkit-scrollbar,.pro-filter-row::-webkit-scrollbar{display:none;}
  .nav-link{flex:0 0 auto;}
  .hero-wrap{height:auto;min-height:100dvh;}
  .hero-stage{min-height:calc(100dvh - 104px);cursor:auto;}
  .hero-video-bg{top:-14%;left:-14%;width:128%;min-width:128%;height:128%;min-height:128%;object-position:center center;}
  .hero-content{padding:56px var(--gutter) 48px;}
  .hero-slate{left:var(--gutter);top:18px;}
  .hero-scroll-ind{display:none;}
  .hero-h1-cinema{letter-spacing:0;}
  .hero-ctas-cinema{flex-wrap:wrap;gap:14px;}
  .btn-cine-primary,.btn-cine-ghost{cursor:pointer;}
  .hero-bottom{grid-template-columns:repeat(2,minmax(0,1fr));}
  .hero-certif{padding:16px var(--gutter);}
  .certif-item{min-width:0;flex:1 1 calc(50% - 12px);}
  .intro-band{flex-direction:column;align-items:flex-start;gap:12px;padding:16px var(--gutter);}
  .intro-text{line-height:1.55;}
  .intro-cta{width:100%;text-align:center;}
  .section-header,.pro-header,.casos-header{padding:46px var(--gutter) 34px;}
  .u-eyebrow{letter-spacing:0.16em;line-height:1.4;}
  .cta-strip{padding:22px var(--gutter);}
  .cta-strip-btns{width:100%;flex-wrap:wrap;}
  .cta-strip-btns .btn-primary,.cta-strip-btns .btn-outline{justify-content:center;flex:1 1 220px;}
  .aud-tabs{grid-template-columns:minmax(0,1fr);}
  .aud-tab{border-right:none;border-bottom:1px solid var(--border);}
  .aud-tab-icon{width:34px;height:34px;}
  .inv-detail-title,.step-title{font-size:30px;}
  .inv-detail-bignum{font-size:62px;}
  .inv-feature{padding:13px 14px;}
  .step-detail{padding:44px var(--gutter);}
  .step-big-num{font-size:70px;}
  .step-features{grid-template-columns:minmax(0,1fr);}
  .step-nav-btns{width:100%;align-items:stretch;}
  .step-nav-btn{flex:1;min-width:0;padding:12px 14px;}
  .diferencial,.case-grid,.stats-band,.pro-features{grid-template-columns:minmax(0,1fr);}
  .dif-cell,.dif-cell:nth-child(2n),.case-card,.case-card:nth-child(2n),.case-card:nth-child(3n),.stat-cell,.pro-feat,.pro-feat:nth-child(2n){border-right:none;}
  .dif-cell,.stat-cell,.pro-feat{border-bottom:1px solid var(--border);}
  .dif-cell:last-child,.stat-cell:last-child,.pro-feat:last-child{border-bottom:none;}
  .pro-nav-header,.pro-nav-footer{display:none;}
  .pro-nav-items{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .pro-nav-item{flex:0 0 auto;min-width:132px;border-right:1px solid var(--border);}
  .pro-center-bar{align-items:flex-start;flex-direction:column;gap:10px;}
  .pro-filter-row{width:100%;}
  .pro-stats-mini{grid-template-columns:minmax(0,1fr);}
  .pro-stat-mini{border-right:none;border-bottom:1px solid var(--border);}
  .pro-stat-mini:last-child{border-bottom:none;}
  .pro-table-head,.pro-row{grid-template-columns:14px minmax(0,1fr) minmax(84px,max-content) 22px;padding-left:16px;padding-right:16px;}
  .pro-table-head .pro-th:nth-child(4),.pro-row .pro-days{display:none;}
  .pro-asset-name,.pro-asset-city{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
  .pro-detail-body{padding:18px var(--gutter);}
  .pro-right-cta{margin:0 var(--gutter) 22px;}
  .featured{min-height:0;}
  .feat-left{padding:38px var(--gutter);}
  .feat-title{font-size:25px;}
  .feat-right{padding:30px var(--gutter);}
  .quote-body{padding:34px var(--gutter);align-items:flex-start;}
  .quote-mark{font-size:54px;margin-top:10px;}
  .quote-text{font-size:17px;}
  .morador-left,.morador-right,.contact-left,.contact-right{padding:44px var(--gutter);}
  .morador-right{flex-direction:column;align-items:flex-start;}
  .contact-title{font-size:36px;}
  .form-row{grid-template-columns:minmax(0,1fr);}
  .form-bottom{flex-direction:column;align-items:flex-start;}
  .form-legal{max-width:none;}
  .form-submit{width:100%;justify-content:center;}
  .channel{gap:14px;}
  .channel-icon{width:38px;height:38px;}
  .channel-val{font-size:14px;overflow-wrap:anywhere;}
  .footer-main{grid-template-columns:minmax(0,1fr);}
  .footer-brand,.footer-col{padding:34px var(--gutter);border-right:none;border-bottom:1px solid var(--border);}
  .footer-col:last-child{border-bottom:none;}
  .footer-bottom{padding:20px var(--gutter);gap:14px;}
  .inner-hero-panel,.method-hero-system,.case-hero-stats{padding:0 var(--gutter) 52px;}
  .metric-board div{min-height:118px;padding:22px;}
  .service-tile{min-height:0;padding:30px var(--gutter);}
  .tile-num,.method-card h3,.principle-item strong,.portfolio-case-meta{margin-bottom:28px;}
  .method-flow{padding-top:56px;padding-bottom:56px;}
  .method-flow-head{align-items:flex-start;flex-direction:column;gap:14px;}
  .method-card{min-height:0;padding:30px var(--gutter);}
  .principle-item{min-height:0;padding:34px var(--gutter);}
  .dashboard-mini{min-width:0;}
  .dash-row{grid-template-columns:minmax(0,1fr);gap:6px;}
  .dash-row em{text-align:left;}
  .case-portfolio{grid-template-columns:minmax(0,1fr);}
  .portfolio-case{min-height:0;padding:32px var(--gutter);}
  .portfolio-case h3{font-size:29px;}
}

@media (max-width:560px){
  .btn-primary,.btn-outline,.btn-ghost,.btn-cine-primary,.btn-cine-ghost,.form-submit{letter-spacing:0.08em;}
  .hero-stage{min-height:620px;}
  .hero-content{padding-bottom:42px;}
  .hero-h1-cinema{font-size:clamp(39px,13vw,52px);line-height:0.98;}
  .hero-sub-cinema{max-width:340px;}
  .hero-ctas-cinema{align-items:stretch;flex-direction:column;max-width:320px;}
  .btn-cine-primary,.btn-cine-ghost{justify-content:center;width:100%;}
  .hero-bottom{grid-template-columns:minmax(0,1fr);}
  .hero-stat,.hero-stat:nth-child(2n),.hero-stat:nth-child(-n+2){border-right:none;border-bottom:1px solid rgba(255,255,255,0.07);}
  .hero-stat:last-child{border-bottom:none;}
  .certif-item{flex-basis:100%;}
  .section-header,.pro-header,.casos-header{padding-top:40px;}
  .aud-tab{padding:16px var(--gutter);}
  .inv-nav-item{min-width:215px;padding:18px 20px;}
  .inv-detail,.step-detail{padding-top:38px;padding-bottom:38px;}
  .par-card{padding:32px var(--gutter);}
  .step-selector{grid-template-columns:repeat(4,minmax(152px,1fr));}
  .step-btn{min-width:152px;}
  .step-btn-inner{padding:16px 14px;gap:10px;}
  .step-circle{width:32px;height:32px;}
  .step-btn-label{font-size:12px;}
  .step-nav-btns{flex-direction:column;}
  .pro-table-head{display:none;}
  .pro-row{grid-template-columns:12px minmax(0,1fr) 20px;gap:9px;}
  .pro-row .pro-phase-tag{grid-column:2/3;justify-self:start;margin-top:5px;}
  .pro-row .pro-arr{grid-column:3;grid-row:1/3;align-self:center;}
  .pro-stats-mini{grid-template-columns:repeat(3,minmax(0,1fr));}
  .pro-stat-mini{border-bottom:none;border-right:1px solid var(--border);padding:12px 10px;}
  .pro-stat-mini:last-child{border-right:none;}
  .pro-stat-n{font-size:22px;}
  .feat-metric{align-items:flex-start;flex-direction:column;gap:6px;}
  .quote-body{display:block;}
  .quote-mark{margin-bottom:12px;}
  .stats-band .stat-cell{padding:26px var(--gutter);}
  .contact-title{font-size:32px;}
  .channel{align-items:flex-start;}
  .channel-arrow{display:none;}
  .footer-copy{line-height:1.6;}
  .inner-page,.hero-wrap{padding-top:104px;}
  .inner-hero-copy{padding-top:58px;}
  .inner-hero-actions,.audience-actions{width:100%;align-items:stretch;flex-direction:column;}
  .inner-hero-actions .btn-primary,.inner-hero-actions .btn-outline,.audience-actions .btn-primary,.audience-actions .btn-ghost{justify-content:center;width:100%;}
  .metric-board{grid-template-columns:minmax(0,1fr);max-width:none;}
  .metric-board div,.metric-board div:nth-child(2n),.metric-board div:nth-last-child(-n+2){border-right:none;border-bottom:1px solid rgba(255,255,255,0.08);}
  .metric-board div:last-child{border-bottom:none;}
  .inner-band{gap:24px;}
  .service-detail-copy h2,.audience-copy h2,.dashboard-copy h2,.case-feature h2{font-size:34px;}
  .principle-large{padding-top:56px;padding-bottom:56px;}
  .portfolio-metrics{grid-template-columns:minmax(0,1fr);gap:14px;}
  .case-hero-stats div{align-items:flex-start;flex-direction:column;gap:7px;}
  .case-hero-stats small{text-align:left;}
}

@media (max-width:380px){
  :root{--gutter:18px;}
  .main-nav{padding:0 10px;}
  .nav-logo span{font-size:22px!important;}
  .nav-links{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;overflow:visible;}
  .nav-link{justify-content:center;font-size:8.5px;letter-spacing:0.01em;padding:8px 0;}
  .hero-h1-cinema{font-size:40px;}
  .hero-sub-cinema{font-size:12px;}
  .hero-stage{min-height:590px;}
  .btn-primary,.btn-outline,.btn-cine-primary,.form-submit{padding-left:18px;padding-right:18px;}
  .pro-stats-mini{grid-template-columns:minmax(0,1fr);}
  .pro-stat-mini{border-right:none;border-bottom:1px solid var(--border);padding:12px var(--gutter);}
  .pro-stat-mini:last-child{border-bottom:none;}
  .case-card,.portfolio-case{padding-left:var(--gutter);padding-right:var(--gutter);}
  .case-metrics{grid-template-columns:minmax(0,1fr);}
  .footer-legal-links{width:100%;}
}

@media (min-width:761px){
  .hero-wrap{height:100vh;height:100dvh;min-height:620px;}
  .hero-stage{min-height:0;}
  .hero-content{justify-content:center;padding:clamp(28px,4vh,66px) var(--gutter) clamp(22px,3.4vh,56px);}
  .hero-h1-cinema{font-size:clamp(58px,min(6.45vw,13vh),118px);line-height:0.95;margin-bottom:clamp(14px,2.4vh,28px);max-width:min(980px,62vw);}
  .hero-sub-cinema{font-size:clamp(12px,1.45vh,14px);line-height:1.68;margin-bottom:clamp(16px,2.8vh,34px);max-width:min(560px,36vw);}
  .hero-ctas-cinema{gap:clamp(16px,2.4vw,26px);}
  .btn-cine-primary{padding:clamp(13px,1.9vh,16px) clamp(22px,2.2vw,28px);}
  .btn-cine-ghost{padding:clamp(13px,1.9vh,16px) 0;}
  .hero-stat{padding:clamp(11px,1.9vh,18px) clamp(20px,2vw,28px);}
  .hero-stat-n{font-size:clamp(23px,3.25vh,30px);}
  .hero-stat-l{font-size:clamp(8.5px,1.02vh,9.5px);}
  .hero-certif{padding:clamp(11px,1.9vh,18px) var(--gutter);}
  .certif-mark{width:clamp(34px,4.4vh,40px);height:clamp(34px,4.4vh,40px);}
  .certif-text-title{font-size:clamp(11px,1.32vh,12px);}
  .certif-text-sub{font-size:clamp(9px,1.08vh,10px);}
  .intro-band{padding:clamp(10px,1.55vh,14px) var(--gutter);}
  .intro-text,.intro-cta{font-size:clamp(10px,1.22vh,12px);}
}

@media (min-width:761px) and (max-height:760px){
  .hero-wrap{min-height:0;}
  .hero-content{padding-top:24px;padding-bottom:22px;}
  .hero-h1-cinema{font-size:clamp(48px,min(5.4vw,12vh),82px);margin-bottom:14px;max-width:760px;}
  .hero-sub-cinema{max-width:520px;margin-bottom:16px;}
  .hero-stat{padding:10px 22px;}
  .hero-certif{padding:10px var(--gutter);}
  .intro-band{padding:9px var(--gutter);}
}

@media (min-width:761px) and (max-height:620px){
  .hero-h1-cinema{font-size:clamp(42px,min(4.8vw,10.5vh),64px);}
  .hero-sub-cinema{font-size:12px;line-height:1.55;margin-bottom:12px;}
  .btn-cine-primary{padding:12px 22px;}
  .hero-stat-n{font-size:22px;}
  .hero-stat-l,.certif-text-sub{font-size:8.5px;}
  .certif-mark{width:32px;height:32px;}
}
