/* ===========================================================
   ISW TALLER · LANDING PAGE
   Industrial · Sharp edges · #1A2744 corporate · Document accents
   =========================================================== */

:root{
  --c-bg:#F5F6F8;
  --c-bg-alt:#EDEFF3;
  --c-dark:#1A2744;
  --c-dark-2:#0F1A30;
  --c-ink:#101626;
  --c-mute:#5A6477;
  --c-line:#D6D9E0;
  --c-line-2:#E5E7EC;

  --c-ot:#FD7E14;
  --c-pre:#3498DB;
  --c-pro:#27AE60;
  --c-fac:#E74C3C;

  --f-display:'Archivo', system-ui, -apple-system, sans-serif;
  --f-narrow:'Archivo Narrow', 'Archivo', system-ui, sans-serif;
  --f-mono:'JetBrains Mono', ui-monospace, monospace;

  --max:1320px;
  --pad:clamp(1.25rem, 4vw, 4rem);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--f-display);
  background:var(--c-bg);
  color:var(--c-ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none}

/* ===========================================================
   TOPBAR
   =========================================================== */
.topbar{
  background:var(--c-dark-2);
  color:#A8B2C7;
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar__inner{
  max-width:var(--max);
  margin:0 auto;
  padding:.5rem var(--pad);
  display:flex;
  align-items:center;
  gap:1.5rem;
  flex-wrap:wrap;
}
.topbar__pill{
  background:var(--c-ot);
  color:#fff;
  padding:.2rem .55rem;
  font-weight:700;
  letter-spacing:.1em;
}
.topbar__txt{flex:1;min-width:200px}
.topbar__status{display:flex;align-items:center;gap:.5rem;color:#7AE2A0}
.topbar__status i{
  width:8px;height:8px;border-radius:50%;
  background:#2ECC71;box-shadow:0 0 0 3px rgba(46,204,113,.18);
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 3px rgba(46,204,113,.18)}
  50%{box-shadow:0 0 0 6px rgba(46,204,113,.05)}
}

/* ===========================================================
   NAV
   =========================================================== */
.nav{
  position:sticky;top:0;z-index:50;
  background:var(--c-dark);
  color:#fff;
  border-bottom:3px solid var(--c-ot);
}
.nav__inner{
  max-width:var(--max);
  margin:0 auto;
  padding:1rem var(--pad);
  display:flex;
  align-items:center;
  gap:2rem;
}
.logo{
  display:flex;
  align-items:center;
  gap:.65rem;
  color:#fff;
}
.logo__mark{
  display:flex;
  width:40px;height:40px;
  color:#fff;
}
.logo__text{
  font-family:var(--f-display);
  font-weight:900;
  font-size:1.15rem;
  letter-spacing:.02em;
  line-height:1;
  display:flex;flex-direction:column;
}
.logo__text strong{font-size:1.25rem;letter-spacing:.06em}
.logo__text span{
  font-family:var(--f-narrow);
  font-weight:500;
  font-size:.78rem;
  letter-spacing:.4em;
  color:var(--c-ot);
  margin-top:2px;
}
.logo--light .logo__text strong{color:#fff}
.logo--light .logo__text span{color:var(--c-ot)}

.nav__links{
  display:flex;
  gap:2rem;
  margin-left:auto;
  font-family:var(--f-narrow);
  font-weight:500;
  font-size:.95rem;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.nav__links a{
  color:#C4CCDC;
  position:relative;
  padding:.25rem 0;
  transition:color .2s;
}
.nav__links a:hover{color:#fff}
.nav__links a::after{
  content:'';
  position:absolute;left:0;bottom:-4px;
  width:0;height:2px;background:var(--c-ot);
  transition:width .25s;
}
.nav__links a:hover::after{width:100%}

.nav__cta{display:flex;gap:.5rem}

/* ===========================================================
   BUTTONS
   =========================================================== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.4rem;
  padding:.7rem 1.2rem;
  font-family:var(--f-narrow);
  font-weight:600;
  font-size:.9rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  border-radius:0;
  border:2px solid transparent;
  transition:all .2s;
  white-space:nowrap;
}
.btn--lg{padding:1rem 1.6rem;font-size:.95rem}
.btn--block{width:100%}
.btn--primary{
  background:var(--c-ot);
  color:#fff;
  border-color:var(--c-ot);
}
.btn--primary:hover{
  background:#E66E03;
  border-color:#E66E03;
  transform:translate(-2px,-2px);
  box-shadow:4px 4px 0 var(--c-dark);
}
.btn--ghost{
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.25);
}
.btn--ghost:hover{
  border-color:#fff;
  background:rgba(255,255,255,.05);
}
.btn--outline{
  background:transparent;
  color:var(--c-dark);
  border-color:var(--c-dark);
}
.btn--outline:hover{
  background:var(--c-dark);
  color:#fff;
}

/* ===========================================================
   HERO
   =========================================================== */
.hero{
  position:relative;
  background:var(--c-dark);
  color:#fff;
  overflow:hidden;
  padding:4rem 0 0;
}
.hero__grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(ellipse at 70% 30%, black 30%, transparent 75%);
  pointer-events:none;
}
.hero__inner{
  position:relative;
  max-width:var(--max);
  margin:0 auto;
  padding:2rem var(--pad) 5rem;
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:3rem;
  align-items:center;
}
.hero__tag{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  padding:.45rem .85rem;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.12em;
  color:#C4CCDC;
  margin-bottom:1.5rem;
}
.hero__tag .dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--c-ot);
  box-shadow:0 0 12px var(--c-ot);
}
.hero__title{
  font-family:var(--f-display);
  font-weight:900;
  font-size:clamp(2rem, 4.6vw, 3.8rem);
  line-height:1.02;
  letter-spacing:-.02em;
  margin-bottom:1.5rem;
}
.hero__title-accent{
  display:inline-block;
  background:linear-gradient(180deg, transparent 60%, var(--c-ot) 60%);
  padding:0 .15em;
}
.hero__sub{
  font-size:1.1rem;
  line-height:1.6;
  color:#C4CCDC;
  max-width:540px;
  margin-bottom:2rem;
}
.hero__sub strong{color:#fff}
.hero__sub em{
  color:var(--c-ot);
  font-style:normal;
  font-weight:600;
}
.hero__ctas{
  display:flex;
  gap:.75rem;
  margin-bottom:3rem;
  flex-wrap:wrap;
}
.hero__ctas .btn--outline{
  color:#fff;
  border-color:rgba(255,255,255,.4);
}
.hero__ctas .btn--outline:hover{
  background:#fff;color:var(--c-dark);border-color:#fff;
}

.hero__stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:1.5rem;
}
.stat{
  border-right:1px solid rgba(255,255,255,.08);
  padding-right:1rem;
}
.stat:last-child{border-right:none}
.stat b{
  display:block;
  font-family:var(--f-display);
  font-weight:800;
  font-size:1.6rem;
  color:#fff;
  letter-spacing:-.01em;
}
.stat span{
  font-family:var(--f-mono);
  font-size:10px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:#8B95AB;
}

/* HERO SCREEN */
.hero__right{
  position:relative;
}
.screen{
  background:#fff;
  box-shadow:
    0 30px 60px -15px rgba(0,0,0,.5),
    0 0 0 1px rgba(255,255,255,.05);
  transform:perspective(1500px) rotateY(-6deg) rotateX(2deg);
  transition:transform .5s;
}
.screen:hover{transform:perspective(1500px) rotateY(-3deg) rotateX(1deg)}
.screen__bar{
  background:#E1E4EC;
  padding:.5rem .8rem;
  display:flex;
  align-items:center;
  gap:.4rem;
  border-bottom:1px solid #C9CFDA;
}
.screen__dot{
  width:11px;height:11px;border-radius:50%;
  background:#C9CFDA;
}
.screen__dot:nth-child(1){background:#FF5F57}
.screen__dot:nth-child(2){background:#FFBD2E}
.screen__dot:nth-child(3){background:#28C940}
.screen__url{
  margin-left:1rem;
  font-family:var(--f-mono);
  font-size:11px;
  color:#5A6477;
  background:#fff;
  padding:.2rem .6rem;
  flex:1;
  letter-spacing:.05em;
}
.screen__img{
  width:100%;
  display:block;
}

.screen-floating{
  position:absolute;
  bottom:-2.5rem;
  left:-2.5rem;
  width:42%;
  background:#fff;
  border:1px solid var(--c-line);
  box-shadow:0 25px 50px -10px rgba(0,0,0,.45);
  transform:rotate(-3deg);
  transition:transform .4s;
}
.screen-floating:hover{transform:rotate(0deg)}

/* MARQUEE */
.hero__marquee{
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
  padding:1rem 0;
  background:rgba(0,0,0,.15);
  overflow:hidden;
  position:relative;
}
.marquee__track{
  display:flex;
  gap:3rem;
  white-space:nowrap;
  font-family:var(--f-narrow);
  font-weight:600;
  letter-spacing:.3em;
  font-size:.85rem;
  color:#7B859B;
  animation:marquee 35s linear infinite;
  width:max-content;
}
.marquee__track span:nth-child(odd){color:#C4CCDC}
@keyframes marquee{
  to{transform:translateX(-50%)}
}

/* ===========================================================
   SECTIONS
   =========================================================== */
.section{
  padding:6rem 0;
  position:relative;
}
.section__head{
  max-width:var(--max);
  margin:0 auto 3.5rem;
  padding:0 var(--pad);
}
.section__head--center{text-align:center}
.section__num{
  display:inline-block;
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.2em;
  color:var(--c-mute);
  padding:.3rem .6rem;
  border:1px solid var(--c-line);
  background:#fff;
  margin-bottom:1.25rem;
}
.section__num--light{
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.15);
  color:#C4CCDC;
}
.section__title{
  font-family:var(--f-display);
  font-weight:900;
  font-size:clamp(1.8rem, 3.5vw, 3rem);
  line-height:1.05;
  letter-spacing:-.02em;
  color:var(--c-dark);
  max-width:780px;
  margin-bottom:1.25rem;
}
.section__head--center .section__title{margin-left:auto;margin-right:auto}
.section__title--light{color:#fff}
.section__lead{
  font-size:1.15rem;
  line-height:1.65;
  color:var(--c-mute);
  max-width:680px;
}
.section__head--center .section__lead{margin-left:auto;margin-right:auto}
.section__lead--light{color:#C4CCDC}

/* ===========================================================
   CRM SECTION (DARK)
   =========================================================== */
.section--dark{
  background:#fff;
}
.crm-grid{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  gap:1rem;
}
.crm-card{
  background:#fff;
  border:1px solid var(--c-line);
  padding:1.5rem;
  display:flex;
  flex-direction:column;
  transition:all .3s;
  position:relative;
  overflow:hidden;
}
.crm-card::before{
  content:'';
  position:absolute;left:0;top:0;
  width:4px;height:0;
  background:var(--c-ot);
  transition:height .3s;
}
.crm-card:hover{
  border-color:var(--c-dark);
  box-shadow:8px 8px 0 var(--c-ot);
  transform:translate(-4px,-4px);
}
.crm-card:hover::before{height:100%}

.crm-card--big{
  grid-column:span 3;
  grid-row:1;
  background:var(--c-dark);
  color:#fff;
  border-color:var(--c-dark);
  display:grid;
  grid-template-columns:1fr 2fr;
  gap:2rem;
  padding:2.5rem;
  align-items:center;
}
.crm-card--big::before{background:#fff}
.crm-card--big:hover{box-shadow:8px 8px 0 var(--c-ot)}

.crm-card__hd{margin-bottom:.75rem}
.crm-card h3{
  font-size:1.5rem;
  font-weight:800;
  letter-spacing:-.01em;
  margin-top:.5rem;
}
.crm-card--big h3{font-size:2rem}
.crm-card p{
  color:var(--c-mute);
  font-size:.95rem;
  line-height:1.55;
  margin-bottom:1rem;
}
.crm-card--big p{color:#A8B2C7;font-size:1.05rem}

.crm-card__media{
  margin-top:auto;
  border:1px solid var(--c-line);
  background:var(--c-bg-alt);
  overflow:hidden;
  aspect-ratio:16/9;
}
.crm-card--big .crm-card__media{
  aspect-ratio:auto;
  border:1px solid rgba(255,255,255,.1);
  align-self:stretch;
  display:flex;
  align-items:center;
  background:#0F1A30;
}
.crm-card__media img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:top center;
  transition:transform .5s;
}
.crm-card:hover .crm-card__media img{transform:scale(1.03)}

.badge{
  display:inline-block;
  font-family:var(--f-mono);
  font-size:10px;
  letter-spacing:.15em;
  padding:.25rem .5rem;
  font-weight:700;
}
.badge--blue{background:#E3F0FB;color:#1B6CB5}
.badge--orange{background:#FFE9D5;color:#B85800}
.badge--green{background:#D9F2E1;color:#177A3F}
.badge--purple{background:#EAE2F5;color:#6B3FA0}
.badge--white{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.2)}

/* ===========================================================
   CIRCUITS SECTION
   =========================================================== */
.section--circuits{
  background:var(--c-bg-alt);
  position:relative;
}
.section--circuits::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(26,39,68,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(26,39,68,.025) 1px, transparent 1px);
  background-size:30px 30px;
  pointer-events:none;
}
.circuits{
  position:relative;
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem;
}
.circuit:nth-child(5){grid-column:span 2}
.circuit{
  background:#fff;
  padding:2rem;
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:1.5rem;
  align-items:start;
  border-left:6px solid var(--c);
  position:relative;
  transition:all .3s;
}
.circuit:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 40px -10px rgba(26,39,68,.15);
}
.circuit__num{
  font-family:var(--f-mono);
  font-size:2.5rem;
  font-weight:700;
  color:var(--c);
  line-height:1;
  letter-spacing:-.05em;
}
.circuit__body h3{
  font-size:1.4rem;
  font-weight:800;
  letter-spacing:-.01em;
  margin-bottom:.5rem;
  color:var(--c-dark);
}
.circuit__body p{
  color:var(--c-mute);
  font-size:.95rem;
  line-height:1.55;
  margin-bottom:1rem;
}
.circuit__body ul{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:.4rem;
}
.circuit__body li{
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.04em;
  background:var(--c-bg-alt);
  padding:.3rem .6rem;
  color:var(--c-dark);
}
.circuit__icon{
  font-size:2rem;
  color:var(--c);
  opacity:.4;
}

.chain{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:.5rem;
  margin-top:1rem;
}
.chain__pill{
  font-family:var(--f-narrow);
  font-weight:700;
  letter-spacing:.1em;
  background:var(--p);
  color:#fff;
  padding:.4rem .8rem;
  font-size:.9rem;
}
.chain__arrow{
  color:var(--c-mute);
  font-weight:700;
}

.circuits__shot{
  max-width:var(--max);
  margin:3rem auto 0;
  padding:0 var(--pad);
  position:relative;
}
.circuits__shot img{
  width:100%;
  border:1px solid var(--c-line);
  box-shadow:0 30px 60px -20px rgba(26,39,68,.3);
}

/* ===========================================================
   SPLIT SECTION
   =========================================================== */
.section--split{background:#fff}
.split{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:4rem;
  align-items:center;
}
.split--rev{grid-template-columns:1.1fr 1fr}
.split--rev .split__txt{order:2}
.split--rev .split__media{order:1}

.features{
  margin-top:2rem;
  display:flex;
  flex-direction:column;
  gap:1.5rem;
}
.feat{
  display:flex;
  gap:1rem;
  align-items:flex-start;
}
.feat__bul{
  font-size:1.5rem;
  color:var(--c-ot);
  line-height:1;
  flex-shrink:0;
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  background:#FFF1E5;
  border:1px solid #FFD9B8;
}
.feat h4{
  font-size:1.05rem;
  font-weight:700;
  margin-bottom:.25rem;
  color:var(--c-dark);
}
.feat p{
  color:var(--c-mute);
  font-size:.9rem;
  line-height:1.55;
}

.split__media{
  position:relative;
  min-height:400px;
}
.split__shot{
  border:1px solid var(--c-line);
  background:#fff;
  box-shadow:0 25px 50px -15px rgba(26,39,68,.25);
}
.split__shot--1{
  position:relative;
  z-index:1;
}
.split__shot--2{
  position:absolute;
  bottom:-3rem;right:-2rem;
  width:50%;
  z-index:2;
  box-shadow:0 30px 60px -15px rgba(26,39,68,.4);
}
.split__shot img{width:100%;display:block}

/* ===========================================================
   OPERARIO SECTION
   =========================================================== */
.section--operario{
  background:var(--c-dark);
  color:#fff;
  position:relative;
  overflow:hidden;
}
.operario__bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(253,126,20,.15) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(52,152,219,.1) 0%, transparent 50%);
  pointer-events:none;
}
.operario__grid{
  position:relative;
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2rem;
}
.operario__card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.1);
  padding:2rem;
  display:flex;
  flex-direction:column;
  gap:1.5rem;
  transition:all .3s;
}
.operario__card:hover{
  background:rgba(255,255,255,.06);
  border-color:var(--c-ot);
}
.operario__shot{
  border:1px solid rgba(255,255,255,.1);
  background:#0a1322;
  overflow:hidden;
}
.operario__shot img{width:100%}
.operario__txt h3{
  font-size:1.4rem;
  font-weight:800;
  margin:.5rem 0 .5rem;
  letter-spacing:-.01em;
}
.operario__txt p{
  color:#A8B2C7;
  font-size:.95rem;
  line-height:1.6;
}

.ops-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-top:1rem;
}
.opsbtn{
  font-family:var(--f-narrow);
  font-weight:700;
  font-size:.85rem;
  letter-spacing:.08em;
  padding:.55rem .9rem;
  background:rgba(255,255,255,.05);
  color:var(--data-c, #fff);
  border:1px solid var(--data-c);
}
.opsbtn[data-c="#27AE60"]{color:#27AE60;border-color:#27AE60}
.opsbtn[data-c="#F39C12"]{color:#F39C12;border-color:#F39C12}
.opsbtn[data-c="#3498DB"]{color:#3498DB;border-color:#3498DB}
.opsbtn[data-c="#E74C3C"]{color:#E74C3C;border-color:#E74C3C}

/* ===========================================================
   CONFIG SECTION
   =========================================================== */
.section--config{background:var(--c-bg)}
.taxgrid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.75rem;
  margin-top:2rem;
}
.tax{
  background:#fff;
  border:1px solid var(--c-line);
  padding:1rem;
  text-align:center;
  transition:all .2s;
}
.tax:hover{border-color:var(--c-dark);transform:translateY(-2px)}
.tax__code{
  display:block;
  font-family:var(--f-display);
  font-weight:900;
  font-size:1.5rem;
  color:var(--c-dark);
  letter-spacing:-.01em;
}
.tax__zone{
  display:block;
  font-family:var(--f-mono);
  font-size:10px;
  letter-spacing:.1em;
  color:var(--c-mute);
  text-transform:uppercase;
  margin-top:.25rem;
}
.config__items{
  margin-top:2rem;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.5rem;
}
.config__items > div{
  font-family:var(--f-narrow);
  font-size:.95rem;
  color:var(--c-dark);
  padding:.4rem 0;
  border-bottom:1px dashed var(--c-line);
}

/* ===========================================================
   GALLERY MASONRY
   =========================================================== */
.section--gallery{background:#fff}
.masonry{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  column-count:4;
  column-gap:1rem;
}
.masonry__item{
  break-inside:avoid;
  margin-bottom:1rem;
  cursor:zoom-in;
  position:relative;
  overflow:hidden;
  border:1px solid var(--c-line);
  transition:all .3s;
  background:#fff;
}
.masonry__item:hover{
  border-color:var(--c-dark);
  box-shadow:0 15px 30px -10px rgba(26,39,68,.3);
  transform:translateY(-2px);
}
.masonry__item img{
  width:100%;
  display:block;
  transition:transform .4s;
}
.masonry__item:hover img{transform:scale(1.04)}
.masonry__item::after{
  content:'⤢';
  position:absolute;
  top:.5rem;right:.5rem;
  background:var(--c-dark);
  color:#fff;
  width:32px;height:32px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1rem;
  opacity:0;
  transition:opacity .3s;
}
.masonry__item:hover::after{opacity:1}

/* ===========================================================
   LIGHTBOX
   =========================================================== */
.lightbox{
  position:fixed;inset:0;
  background:rgba(15,26,48,.96);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:1000;
  padding:2rem;
}
.lightbox.active{display:flex}
.lightbox__fig{
  max-width:90vw;
  max-height:90vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:1rem;
}
.lightbox__fig img{
  max-height:80vh;
  max-width:100%;
  border:1px solid rgba(255,255,255,.15);
}
.lightbox__fig figcaption{
  font-family:var(--f-mono);
  font-size:12px;
  letter-spacing:.1em;
  color:#C4CCDC;
  text-transform:uppercase;
}
.lightbox__close,
.lightbox__prev,
.lightbox__next{
  position:absolute;
  background:rgba(255,255,255,.1);
  color:#fff;
  width:50px;height:50px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.5rem;
  border:1px solid rgba(255,255,255,.2);
  transition:all .2s;
}
.lightbox__close:hover,
.lightbox__prev:hover,
.lightbox__next:hover{
  background:var(--c-ot);
  border-color:var(--c-ot);
}
.lightbox__close{top:1.5rem;right:1.5rem;font-size:2rem}
.lightbox__prev{left:1.5rem;top:50%;transform:translateY(-50%);font-size:2rem}
.lightbox__next{right:1.5rem;top:50%;transform:translateY(-50%);font-size:2rem}

/* ===========================================================
   CTA FINAL
   =========================================================== */
.cta{
  background:var(--c-dark);
  color:#fff;
  padding:5rem 0;
  position:relative;
  overflow:hidden;
}
.cta::before{
  content:'';
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 50%, rgba(253,126,20,.18) 0%, transparent 50%);
  pointer-events:none;
}
.cta__inner{
  position:relative;
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
}
.cta__txt h2{
  font-family:var(--f-display);
  font-weight:900;
  font-size:clamp(1.6rem, 3vw, 2.6rem);
  line-height:1.05;
  letter-spacing:-.02em;
  margin:1rem 0 1.5rem;
}
.cta__big{
  display:inline-block;
  color:var(--c-ot);
  font-size:1.3em;
  font-weight:900;
  position:relative;
}
.cta__big::after{
  content:'';
  position:absolute;
  left:0;bottom:.05em;
  width:100%;height:.18em;
  background:var(--c-ot);
  opacity:.25;
  z-index:-1;
}
.cta__txt p{
  color:#C4CCDC;
  font-size:1.05rem;
  line-height:1.6;
}

.cta__form{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  padding:2.5rem;
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.cta__form label{
  display:flex;
  flex-direction:column;
  gap:.4rem;
}
.cta__form span{
  font-family:var(--f-mono);
  font-size:10px;
  letter-spacing:.15em;
  color:#8B95AB;
  text-transform:uppercase;
}
.cta__form input,
.cta__form select{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.15);
  color:#fff;
  padding:.85rem 1rem;
  font-family:var(--f-display);
  font-size:.95rem;
  transition:border .2s;
}
.cta__form input:focus,
.cta__form select:focus{
  outline:none;
  border-color:var(--c-ot);
  background:rgba(255,255,255,.08);
}
.cta__form input::placeholder{color:#5A6477}
.cta__form select{cursor:pointer}
.cta__form select option{background:var(--c-dark);color:#fff}
.cta__legal{
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.05em;
  color:#8B95AB;
  text-align:center;
}
.cta__legal a{color:var(--c-ot);text-decoration:underline}

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{
  background:var(--c-dark-2);
  color:#A8B2C7;
  padding:4rem 0 0;
  border-top:3px solid var(--c-ot);
}
.footer__top{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad) 3rem;
  display:grid;
  grid-template-columns:1.7fr .8fr .8fr .8fr 1.2fr;
  gap:2rem;
}
.footer__brand p{
  font-size:.9rem;
  line-height:1.6;
  margin:1rem 0;
  color:#8B95AB;
}
.footer__brand strong{color:#C4CCDC}
.footer__compl{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-top:1rem;
}
.footer__compl span{
  font-family:var(--f-mono);
  font-size:10px;
  letter-spacing:.1em;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  padding:.3rem .55rem;
  color:#C4CCDC;
  text-transform:uppercase;
}
.footer__col h5{
  font-family:var(--f-narrow);
  font-size:.8rem;
  letter-spacing:.15em;
  color:#fff;
  text-transform:uppercase;
  margin-bottom:1rem;
}
.footer__col a{
  display:block;
  padding:.3rem 0;
  font-size:.9rem;
  color:#8B95AB;
  transition:color .2s;
}
.footer__col a:hover{color:var(--c-ot)}

.footer__newsletter h5{
  font-family:var(--f-narrow);
  font-size:.8rem;
  letter-spacing:.15em;
  color:#fff;
  text-transform:uppercase;
  margin-bottom:1rem;
}
.footer__newsletter p{
  font-size:.85rem;
  margin-bottom:1rem;
  color:#8B95AB;
  line-height:1.5;
}
.footer__newsletter form{
  display:flex;
  border:1px solid rgba(255,255,255,.15);
}
.footer__newsletter input{
  flex:1;
  background:transparent;
  border:none;
  padding:.7rem .8rem;
  color:#fff;
  font-family:var(--f-display);
  font-size:.9rem;
}
.footer__newsletter input:focus{outline:none;background:rgba(255,255,255,.04)}
.footer__newsletter input::placeholder{color:#5A6477}
.footer__newsletter button{
  background:var(--c-ot);
  color:#fff;
  padding:.7rem 1rem;
  font-size:1.1rem;
  font-weight:700;
  transition:background .2s;
}
.footer__newsletter button:hover{background:#E66E03}

.footer__bottom{
  border-top:1px solid rgba(255,255,255,.06);
  padding:1.25rem var(--pad);
  max-width:var(--max);
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:1rem;
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.08em;
  color:#5A6477;
  text-transform:uppercase;
}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width: 1100px){
  .hero__inner{grid-template-columns:1fr;gap:3rem}
  .hero__right{margin-top:1rem}
  .crm-grid{grid-template-columns:1fr 1fr}
  .crm-card--big{grid-column:span 2;grid-template-columns:1fr}
  .circuits{grid-template-columns:1fr}
  .circuit:nth-child(5){grid-column:span 1}
  .split,.split--rev{grid-template-columns:1fr;gap:2.5rem}
  .split--rev .split__txt{order:1}
  .split--rev .split__media{order:2}
  .operario__grid{grid-template-columns:1fr}
  .cta__inner{grid-template-columns:1fr;gap:2rem}
  .footer__top{grid-template-columns:1fr 1fr}
  .masonry{column-count:3}
}
@media (max-width: 760px){
  .nav__links{display:none}
  .topbar__inner{font-size:10px;gap:.75rem}
  .topbar__txt{display:none}
  .hero__title{font-size:2.2rem}
  .hero__stats{grid-template-columns:1fr 1fr;gap:.5rem}
  .stat{padding:.5rem 0;border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
  .crm-grid{grid-template-columns:1fr}
  .crm-card--big{grid-column:span 1}
  .masonry{column-count:2}
  .footer__top{grid-template-columns:1fr;gap:2rem}
  .config__items{grid-template-columns:1fr}
  .nav__cta .btn--ghost{display:none}
  .screen-floating{left:0;width:50%}
}
@media (max-width: 480px){
  .masonry{column-count:1}
  .hero__title{font-size:1.8rem}
  .section{padding:4rem 0}
  .taxgrid{grid-template-columns:1fr}
}

/* ===========================================================
   VERIFACTI FLOW (circuito 5)
   =========================================================== */
.verifacti-flow{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:.5rem;
  margin:1rem 0;
  padding:.85rem;
  background:#FCEDEB;
  border:1px solid #F5C6C0;
}
.vf__node{
  font-family:var(--f-narrow);
  font-weight:700;
  letter-spacing:.08em;
  font-size:.78rem;
  background:#fff;
  color:var(--c-dark);
  padding:.4rem .65rem;
  border:1px solid var(--c-line);
}
.vf__node--mid{ background:var(--c-fac); color:#fff; border-color:var(--c-fac); }
.vf__node--end{ background:var(--c-dark); color:#fff; border-color:var(--c-dark); }
.vf__arrow{
  font-family:var(--f-mono);
  font-size:10px;
  letter-spacing:.05em;
  color:var(--c-mute);
  font-weight:600;
}

/* ===========================================================
   PRICING SECTION
   =========================================================== */
.section--pricing{ background:#fff; }
.pricing{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.5rem;
}
.price-card{
  background:#fff;
  border:1px solid var(--c-line);
  padding:2.5rem;
  display:flex;
  flex-direction:column;
  position:relative;
  transition:all .3s;
}
.price-card--main{
  background:var(--c-dark);
  color:#fff;
  border-color:var(--c-dark);
  box-shadow:8px 8px 0 var(--c-ot);
}
.price-card:hover{ transform:translateY(-4px); }
.price-card--main:hover{ box-shadow:12px 12px 0 var(--c-ot); }
.price-card--addon:hover{ border-color:var(--c-dark); box-shadow:8px 8px 0 var(--c-line); }

.price-card__tag{
  display:inline-block;
  font-family:var(--f-mono);
  font-size:10px;
  letter-spacing:.15em;
  background:var(--c-ot);
  color:#fff;
  padding:.3rem .55rem;
  font-weight:700;
}
.price-card__tag--alt{ background:var(--c-bg-alt); color:var(--c-dark); border:1px solid var(--c-line); }
.price-card__hd{ margin-bottom:1.5rem; }
.price-card h3{
  font-family:var(--f-display);
  font-weight:900;
  font-size:1.6rem;
  letter-spacing:-.01em;
  margin-top:.75rem;
}
.price-card__sub{
  font-size:.85rem;
  margin-top:.25rem;
  color:var(--c-mute);
  font-family:var(--f-mono);
  letter-spacing:.05em;
  text-transform:uppercase;
}
.price-card--main .price-card__sub{ color:#A8B2C7; }

.price-card__amount{
  display:flex;
  align-items:baseline;
  gap:.25rem;
  margin-bottom:1.5rem;
  padding-bottom:1.5rem;
  border-bottom:1px solid rgba(255,255,255,.1);
  font-family:var(--f-display);
}
.price-card--addon .price-card__amount{ border-color:var(--c-line); }
.price-card__plus{ font-size:2rem; font-weight:700; color:var(--c-ot); margin-right:.25rem; }
.price-card__num{ font-size:4.5rem; font-weight:900; letter-spacing:-.04em; line-height:1; }
.price-card--main .price-card__num{ color:#fff; }
.price-card__cur{ font-size:2rem; font-weight:700; color:var(--c-ot); margin-left:.1rem; }
.price-card__per{
  font-family:var(--f-mono);
  font-size:.8rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-left:.5rem;
  color:var(--c-mute);
}
.price-card--main .price-card__per{ color:#A8B2C7; }

.price-card__list{ list-style:none; margin-bottom:2rem; flex:1; }
.price-card__list li{
  display:flex;
  gap:.6rem;
  align-items:baseline;
  padding:.4rem 0;
  font-size:.95rem;
  border-bottom:1px dashed rgba(255,255,255,.08);
}
.price-card--addon .price-card__list li{ border-color:var(--c-line-2); }
.price-card__list b{ color:var(--c-ot); font-weight:700; flex-shrink:0; width:14px; }
.price-card--main .price-card__list strong{ color:var(--c-ot); }

.price-card__example{
  background:#FFF6EC;
  border:1px solid #FFD9B8;
  padding:1rem;
  margin-bottom:1.25rem;
}
.price-card__example > span{
  display:block;
  font-family:var(--f-mono);
  font-size:10px;
  letter-spacing:.12em;
  color:var(--c-mute);
  margin-bottom:.5rem;
  text-transform:uppercase;
}
.price-formula{
  display:flex;
  align-items:baseline;
  gap:.4rem;
  flex-wrap:wrap;
  font-family:var(--f-display);
  font-weight:700;
  color:var(--c-dark);
}
.price-formula small{
  font-family:var(--f-mono);
  font-size:9px;
  font-weight:400;
  color:var(--c-mute);
  letter-spacing:.05em;
}
.price-formula__op{ color:var(--c-mute); font-weight:400; }
.price-formula strong{ font-size:1.25rem; color:var(--c-ot); margin-left:.25rem; }

/* ===========================================================
   KIT DIGITAL
   =========================================================== */
.kitdigital{
  max-width:var(--max);
  margin:4rem auto 0;
  padding:0 var(--pad);
}
.kitdigital__inner{
  background:linear-gradient(135deg, #1A2744 0%, #0F1A30 100%);
  color:#fff;
  padding:3rem;
  display:grid;
  grid-template-columns:1.6fr 1fr;
  gap:3rem;
  align-items:center;
  position:relative;
  overflow:hidden;
  border-left:6px solid #FFD200;
}
.kitdigital__inner::before{
  content:'';
  position:absolute;
  top:-50%;right:-10%;
  width:500px;height:500px;
  background:radial-gradient(circle, rgba(255,210,0,.12) 0%, transparent 65%);
  pointer-events:none;
}
.kit__badge{
  display:inline-block;
  background:#FFD200;
  color:#1A2744;
  font-family:var(--f-mono);
  font-size:11px;
  font-weight:700;
  letter-spacing:.15em;
  padding:.35rem .65rem;
  margin-bottom:1.25rem;
}
.kitdigital__left h3{
  font-family:var(--f-display);
  font-weight:900;
  font-size:clamp(1.5rem, 2.6vw, 2.2rem);
  line-height:1.1;
  margin-bottom:1rem;
  letter-spacing:-.02em;
}
.kit__big{ display:inline-block; color:#FFD200; position:relative; }
.kit__big::after{
  content:'';
  position:absolute;
  left:0;bottom:.05em;
  width:100%;height:.18em;
  background:#FFD200;
  opacity:.25;
  z-index:-1;
}
.kitdigital__left p{
  color:#C4CCDC;
  font-size:1rem;
  line-height:1.65;
  margin-bottom:1.5rem;
}
.kitdigital__left p strong{ color:#fff; }

.kit__flow{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:.5rem;
  margin-bottom:1.75rem;
}
.kit__step{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  padding:.85rem;
}
.kit__step span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:24px;height:24px;
  background:#FFD200;
  color:#1A2744;
  font-family:var(--f-mono);
  font-weight:700;
  font-size:12px;
  margin-bottom:.5rem;
}
.kit__step b{ display:block; font-size:.9rem; font-weight:700; margin-bottom:.15rem; color:#fff; }
.kit__step small{
  font-family:var(--f-mono);
  font-size:10px;
  letter-spacing:.05em;
  color:#8B95AB;
  line-height:1.4;
}
.kitdigital__left .btn--outline{ color:#FFD200; border-color:#FFD200; }
.kitdigital__left .btn--outline:hover{ background:#FFD200; color:#1A2744; }

.kitdigital__right{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:1.25rem;
}
.kit__seal{
  width:180px;height:180px;
  background:#FFD200;
  color:#1A2744;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  font-family:var(--f-display);
  font-weight:900;
  text-align:center;
  border:6px solid #1A2744;
  outline:2px solid #FFD200;
  outline-offset:0;
}
.kit__seal-top{ font-size:.85rem; letter-spacing:.18em; margin-bottom:.25rem; }
.kit__seal-mid{ font-size:5rem; line-height:1; letter-spacing:-.05em; }
.kit__seal-bot{
  font-family:var(--f-mono);
  font-size:9px;
  font-weight:700;
  letter-spacing:.15em;
  margin-top:.25rem;
}
.kit__bullets{ list-style:none; width:100%; }
.kit__bullets li{
  font-size:.85rem;
  color:#C4CCDC;
  padding:.35rem 0;
  border-bottom:1px dashed rgba(255,255,255,.08);
}
.kit__bullets li:last-child{ border:none; }

@media (max-width: 1100px){
  .pricing{ grid-template-columns:1fr; }
  .kitdigital__inner{ grid-template-columns:1fr; padding:2rem; }
  .kit__flow{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 480px){
  .kit__flow{ grid-template-columns:1fr; }
  .price-card__num{ font-size:3.5rem; }
  .price-card{ padding:1.75rem; }
}

/* ===========================================================
   DOSSIER PDF SECTION
   =========================================================== */
.section--dossier{
  background:var(--c-dark);
  color:#fff;
  padding:5rem 0;
  position:relative;
  overflow:hidden;
}
.section--dossier::before{
  content:'';
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 80% 20%, rgba(253,126,20,.12) 0%, transparent 50%),
    radial-gradient(circle at 10% 80%, rgba(52,152,219,.08) 0%, transparent 50%);
  pointer-events:none;
}
.dossier__inner{
  position:relative;
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:4rem;
  align-items:center;
}
.dossier__left h2{
  font-family:var(--f-display);
  font-weight:900;
  font-size:clamp(1.8rem, 3.5vw, 2.8rem);
  line-height:1.05;
  letter-spacing:-.02em;
  margin:1rem 0 1.25rem;
}
.dossier__left p{
  color:#C4CCDC;
  font-size:1.05rem;
  line-height:1.65;
  margin-bottom:1.5rem;
  max-width:520px;
}
.dossier__meta{
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
  margin-bottom:2rem;
  padding:1rem 0;
  border-top:1px solid rgba(255,255,255,.1);
  border-bottom:1px solid rgba(255,255,255,.1);
}
.dossier__meta span{
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:#8B95AB;
}
.dossier__meta b{
  color:var(--c-ot);
  font-family:var(--f-display);
  font-size:1rem;
  font-weight:800;
  margin-right:.25rem;
}
.dossier__cta{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
}
.dossier__cta .btn--outline{
  color:#fff;
  border-color:rgba(255,255,255,.4);
}
.dossier__cta .btn--outline:hover{
  background:#fff;color:var(--c-dark);border-color:#fff;
}

/* Cover mock-up del PDF */
.dossier__right{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  perspective:1200px;
}
.dossier__cover{
  position:relative;
  width:100%;
  max-width:380px;
  aspect-ratio:1/1.414;
  background:linear-gradient(155deg, #0F1A30 0%, #1A2744 60%, #0F1A30 100%);
  box-shadow:
    -25px 25px 60px -10px rgba(0,0,0,.6),
    0 0 0 1px rgba(255,255,255,.05);
  transform:rotateY(-12deg) rotateX(4deg);
  transition:transform .6s;
  display:flex;
  flex-direction:column;
  padding:2.5rem 2rem;
  overflow:hidden;
  border-left:4px solid var(--c-ot);
}
.dossier__cover:hover{transform:rotateY(-6deg) rotateX(2deg)}
.dossier__cover-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:24px 24px;
  pointer-events:none;
}
.dossier__cover-shine{
  position:absolute;
  top:-50%;left:-50%;
  width:200%;height:200%;
  background:linear-gradient(135deg, transparent 40%, rgba(255,255,255,.04) 50%, transparent 60%);
  pointer-events:none;
}
.dossier__cover-content{
  position:relative;
  display:flex;
  flex-direction:column;
  height:100%;
  z-index:2;
}
.dossier__brand{
  font-family:var(--f-narrow);
  font-weight:700;
  font-size:.7rem;
  letter-spacing:.4em;
  color:var(--c-ot);
  margin-bottom:auto;
  padding-bottom:1rem;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.dossier__cover h3{
  font-family:var(--f-display);
  font-weight:900;
  font-size:1.5rem;
  line-height:1.15;
  letter-spacing:-.01em;
  color:#fff;
  margin:1.5rem 0 1rem;
}
.dossier__cover-content p{
  font-family:var(--f-narrow);
  color:#A8B2C7;
  font-size:.85rem;
  line-height:1.5;
  margin:0 0 1.5rem;
}
.dossier__cover-footer{
  display:flex;
  flex-direction:column;
  gap:.25rem;
  padding-top:1rem;
  border-top:1px solid rgba(255,255,255,.1);
}
.dossier__cover-footer span{
  font-family:var(--f-mono);
  font-size:9px;
  letter-spacing:.15em;
  color:#5A6477;
}
.dossier__pages{
  position:absolute;
  bottom:1rem;right:1rem;
  width:90%;height:90%;
  background:#fff;
  z-index:-1;
  transform:translate(8px, 8px);
  opacity:.05;
}
.dossier__pages::before,
.dossier__pages::after{
  content:'';
  position:absolute;
  inset:0;
  background:#fff;
  transform:translate(4px, 4px);
}

@media (max-width: 1100px){
  .dossier__inner{grid-template-columns:1fr;gap:3rem}
  .dossier__cover{transform:rotateY(0) rotateX(0);max-width:320px}
}
@media (max-width: 480px){
  .dossier__cta{flex-direction:column;align-items:stretch}
  .dossier__cta .btn{justify-content:center}
}

/* ===========================================================
   ISW MOBILE SECTION
   =========================================================== */
.section--mobile{
  background:#0F1A30;
  color:#fff;
  position:relative;
  overflow:hidden;
}
.mobile__bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 80% 20%, rgba(253,126,20,.12) 0%, transparent 55%),
    radial-gradient(ellipse at 10% 80%, rgba(39,174,96,.08) 0%, transparent 55%);
  pointer-events:none;
}
.section--mobile .section__title{ color:#fff; }
.section--mobile .section__lead{ color:#C4CCDC; }
.section--mobile .section__lead strong{ color:#fff; }

.mobile__grid{
  position:relative;
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:4rem;
  align-items:center;
}

/* Phones layout */
.mobile__phones{
  position:relative;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:.75rem;
  align-items:end;
}
.phone{
  position:relative;
  background:#000;
  border:3px solid #1A2744;
  border-radius:24px;
  padding:6px;
  box-shadow:0 25px 50px -12px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.05);
  overflow:hidden;
  transition:transform .4s, box-shadow .4s;
}
.phone:hover{
  transform:translateY(-6px);
  box-shadow:0 35px 60px -12px rgba(253,126,20,.25), 0 0 0 1px rgba(253,126,20,.3);
}
.phone__notch{
  position:absolute;
  top:8px;left:50%;
  transform:translateX(-50%);
  width:60px;height:6px;
  background:#1A2744;
  border-radius:0 0 6px 6px;
  z-index:5;
}
.phone img{
  width:100%;
  display:block;
  border-radius:18px;
}
.phone--1{ transform:rotate(-3deg) translateY(20px); }
.phone--2{ transform:rotate(-1deg) translateY(-10px); }
.phone--3{ transform:rotate(1deg)  translateY(-20px); }
.phone--4{ transform:rotate(3deg)  translateY(0); }
.phone--1:hover{ transform:rotate(-3deg) translateY(14px); }
.phone--2:hover{ transform:rotate(-1deg) translateY(-16px); }
.phone--3:hover{ transform:rotate(1deg)  translateY(-26px); }
.phone--4:hover{ transform:rotate(3deg)  translateY(-6px); }

.mobile__features{
  display:flex;
  flex-direction:column;
  gap:1.4rem;
}
.mfeat{
  display:flex;
  gap:1rem;
  align-items:flex-start;
  border-bottom:1px dashed rgba(255,255,255,.08);
  padding-bottom:1.2rem;
}
.mfeat:last-child{ border-bottom:none; padding-bottom:0; }
.mfeat__icon{
  width:42px;height:42px;
  background:rgba(253,126,20,.12);
  border:1px solid rgba(253,126,20,.4);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.2rem;
  color:var(--c-ot);
  flex-shrink:0;
}
.mfeat h4{
  font-size:1rem;
  font-weight:700;
  margin-bottom:.25rem;
  color:#fff;
}
.mfeat p{
  font-size:.9rem;
  line-height:1.5;
  color:#A8B2C7;
}

.mobile__compat{
  position:relative;
  max-width:var(--max);
  margin:3rem auto 0;
  padding:1.5rem var(--pad);
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  align-items:center;
  gap:1.5rem;
  flex-wrap:wrap;
}
.mobile__compat > span{
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.2em;
  color:var(--c-ot);
  font-weight:700;
}
.mobile__compat-list{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
}
.mobile__compat-list span{
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.08em;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  padding:.4rem .65rem;
  color:#C4CCDC;
  text-transform:uppercase;
}

@media (max-width: 1100px){
  .mobile__grid{ grid-template-columns:1fr; gap:3rem; }
  .mobile__phones{ max-width:520px; margin:0 auto; }
}
@media (max-width: 600px){
  .mobile__phones{ grid-template-columns:1fr 1fr; gap:1rem; }
  .phone{ transform:none !important; }
  .phone:hover{ transform:translateY(-4px) !important; }
}

/* ===========================================================
   MOBILE - QR DOWNLOAD BLOCK
   =========================================================== */
.mobile__qr{
  position:relative;
  max-width:var(--max);
  margin:4rem auto 0;
  padding:0 var(--pad);
}
.mobile__qr-inner{
  background:linear-gradient(135deg, rgba(253,126,20,.12) 0%, rgba(253,126,20,.04) 100%);
  border:1px solid rgba(253,126,20,.3);
  border-left:6px solid var(--c-ot);
  padding:2.5rem;
  display:grid;
  grid-template-columns:1.5fr 1fr;
  gap:2.5rem;
  align-items:center;
}
.mobile__qr-tag{
  display:inline-block;
  background:var(--c-ot);
  color:#fff;
  font-family:var(--f-mono);
  font-size:11px;
  font-weight:700;
  letter-spacing:.18em;
  padding:.35rem .65rem;
  margin-bottom:1.25rem;
}
.mobile__qr-text h3{
  font-family:var(--f-display);
  font-weight:900;
  font-size:clamp(1.4rem,2.4vw,2rem);
  line-height:1.1;
  letter-spacing:-.02em;
  margin-bottom:1rem;
  color:#fff;
}
.mobile__qr-text h3 span{ color:var(--c-ot); }
.mobile__qr-text p{
  color:#C4CCDC;
  font-size:.95rem;
  line-height:1.6;
  margin-bottom:1.5rem;
}
.mobile__qr-text p strong{ color:#fff; }

.mobile__qr-url{
  background:rgba(0,0,0,.3);
  border:1px solid rgba(255,255,255,.1);
  padding:.85rem 1rem;
  display:flex;
  flex-direction:column;
  gap:.4rem;
}
.mobile__qr-url > span{
  font-family:var(--f-mono);
  font-size:9px;
  letter-spacing:.18em;
  color:var(--c-ot);
  font-weight:700;
}
.mobile__qr-url code{
  font-family:var(--f-mono);
  font-size:.78rem;
  color:#C4CCDC;
  word-break:break-all;
  letter-spacing:.02em;
}
.mobile__qr-link{
  font-family:var(--f-narrow);
  font-weight:600;
  font-size:.85rem;
  letter-spacing:.06em;
  color:var(--c-ot);
  text-transform:uppercase;
  margin-top:.25rem;
  align-self:flex-start;
}
.mobile__qr-link:hover{ color:#fff; text-decoration:underline; }

.mobile__qr-img{
  position:relative;
  background:#fff;
  padding:1.25rem;
  width:100%;
  max-width:280px;
  margin:0 auto;
  box-shadow:0 30px 60px -15px rgba(0,0,0,.6);
  transition:transform .3s;
}
.mobile__qr-img:hover{ transform:scale(1.04); }
.mobile__qr-img img{
  width:100%;
  display:block;
}
.mobile__qr-corners span{
  position:absolute;
  width:18px;height:18px;
  border:3px solid var(--c-ot);
}
.mobile__qr-corners span:nth-child(1){ top:-3px;    left:-3px;    border-right:none; border-bottom:none; }
.mobile__qr-corners span:nth-child(2){ top:-3px;    right:-3px;   border-left:none;  border-bottom:none; }
.mobile__qr-corners span:nth-child(3){ bottom:-3px; left:-3px;    border-right:none; border-top:none; }
.mobile__qr-corners span:nth-child(4){ bottom:-3px; right:-3px;   border-left:none;  border-top:none; }

@media (max-width: 900px){
  .mobile__qr-inner{ grid-template-columns:1fr; gap:2rem; padding:2rem; }
  .mobile__qr-img{ order:-1; max-width:220px; }
}

/* ===========================================================
   FOOTER · CONTACTO DIRECTO (reemplaza newsletter)
   =========================================================== */
.footer__contact-link{
  display:flex;
  align-items:center;
  gap:.6rem;
  padding:.6rem .8rem;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  font-family:var(--f-mono);
  font-size:.8rem;
  letter-spacing:.04em;
  color:#C4CCDC;
  margin-bottom:.5rem;
  transition:all .2s;
}
.footer__contact-link:hover{
  border-color:var(--c-ot);
  color:#fff;
  background:rgba(253,126,20,.08);
}
.footer__contact-link span{
  color:var(--c-ot);
  font-size:1rem;
  flex-shrink:0;
}
