/* =====================================================
   AGENCIA MARÍTIMA KASHI PORT S.A.S. — Hoja de estilos
   Sitio creado por LARM182 Soluciones
   ===================================================== */

:root{
  --navy-950:#040c1e;
  --navy-900:#0a1c3d;
  --navy-800:#14294f;
  --navy-700:#1e3a68;
  --gold-100:#fff6d9;
  --gold-200:#ffe9a0;
  --gold-400:#f0b93a;
  --gold-500:#d99a1f;
  --gold-700:#a66a15;
  --cream:#ffffff;
  --cream-2:#f4f6f9;
  --ink:#182238;
  --muted-dark:#5c6785;
  --muted-light:#aab6d4;
  --line-gold:rgba(240,185,58,0.4);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%;}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:'Work Sans',sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif; font-weight:600; letter-spacing:0.01em;}
h2{color:var(--navy-900);}
section h3, section h4{color:var(--navy-900);}
a{color:inherit;text-decoration:none;}
.mono{font-family:'IBM Plex Mono',monospace;}
.wrap{max-width:1200px;margin:0 auto;padding:0 40px;}
img{max-width:100%;}
@media(max-width:640px){ .wrap{padding:0 20px;} }

/* Las columnas de todos los grids pueden encoger sin desbordar */
.nosotros-grid > *, .cob-grid > *, .mv-grid > *, .pq-grid > *, .ct-grid > *,
.serv-row > *, .prin-layout > *, .hero-top > *, .ct-item > div{ min-width:0; }

/* Pantallas muy pequeñas (iPhone SE y similares) */
@media(max-width:400px){
  .wrap{padding:0 16px;}
  section{padding:56px 0;}
  .hero h1{font-size:2.35rem;}
  .hero .sub{font-size:1rem;}
  .hero-coord .tag{font-size:0.6rem;}
  .stat{padding:20px 16px;}
  .stat .n{font-size:1.35rem;}
  .stat .l{font-size:0.64rem;}
  .mv-card{padding:26px 20px;}
  .head-block h2{font-size:2rem;}
  .serv-row h3, .mv-card h3{font-size:1.6rem;}
  .quote p{font-size:1.2rem;}
  .prin-wheel-box{width:220px;height:220px;}
  .partners-row{gap:24px;}
  .brand-word .b1{font-size:1.1rem;}
}

/* Pantallas grandes: aprovechar el espacio */
@media(min-width:1600px){
  .wrap{max-width:1320px;}
  .hero{padding-top:170px;}
}
.tag{
  font-family:'IBM Plex Mono',monospace;
  font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gold-700); font-weight:500;
}
.tag.on-dark{color:var(--gold-400);}
.tag::before{content:'◆ ';}
.grid-bg{
  background-image:
    linear-gradient(rgba(240,185,58,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(240,185,58,0.06) 1px, transparent 1px);
  background-size:48px 48px;
}

/* ---------- IMAGE SLOT COMPONENT ---------- */
.img-slot{
  position:relative;
  overflow:hidden;
  border:1.5px solid var(--line-gold);
  border-radius:4px;
  box-shadow:0 14px 34px rgba(4,12,30,0.12);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;text-align:center;padding:24px;
  background:rgba(240,185,58,0.05);
}
.img-slot img.real-img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:5;
}
.img-slot .filename-hint{
  position:absolute; bottom:6px; right:8px; z-index:1;
  font-family:'IBM Plex Mono',monospace; font-size:0.62rem; letter-spacing:0.04em;
  color:rgba(207,154,62,0.55);
}
.img-slot.on-dark .filename-hint{ color:rgba(240,185,58,0.4); }
.img-slot.on-dark{ background:rgba(246,242,230,0.03); border-color:rgba(240,185,58,0.3); }
.img-slot svg{width:34px;height:34px;opacity:0.55;}
.img-slot .slot-title{font-family:'IBM Plex Mono',monospace;font-size:0.68rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold-700);font-weight:600;}
.img-slot.on-dark .slot-title{color:var(--gold-400);}
.img-slot .slot-desc{font-size:0.78rem;color:var(--muted-dark);max-width:240px;line-height:1.5;}
.img-slot.on-dark .slot-desc{color:var(--muted-light);}
.img-slot.fit{ padding:0; min-height:0; background:#fff; }
.img-slot.fit img.real-img{ position:relative; inset:auto; width:100%; height:auto; display:block; object-fit:contain; }
.img-slot.fit:has(img.real-img) svg,
.img-slot.fit:has(img.real-img) .slot-title,
.img-slot.fit:has(img.real-img) .slot-desc{ display:none; }
.slot-h-260{min-height:260px;}
.slot-h-360{min-height:360px;}
.slot-h-460{min-height:460px;}
.slot-h-full{min-height:100%;}

/* ---------- HEADER ---------- */
header{
  position:fixed;top:0;left:0;right:0;z-index:60;
  background:rgba(4,12,30,0.88);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(240,185,58,0.14);
}
.nav{max-width:1200px;margin:0 auto;padding:14px 40px;display:flex;align-items:center;justify-content:space-between;}
.brand{display:flex;align-items:center;gap:12px;}
.brand-word{line-height:1.05;}
.brand-word .b1{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:700;color:var(--cream);letter-spacing:0.05em;}
.brand-word .b2{font-family:'IBM Plex Mono',monospace;font-size:0.56rem;letter-spacing:0.2em;color:var(--gold-400);text-transform:uppercase;}
.nav-links{display:flex;gap:30px;font-size:0.84rem;font-weight:500;color:var(--muted-light);}
.nav-links a{position:relative;transition:color .2s;}
.nav-links a:hover{color:var(--gold-400);}
.nav-cta{
  background:linear-gradient(135deg,var(--gold-400),var(--gold-700));
  color:var(--navy-950);font-weight:700;font-size:0.78rem;
  padding:10px 20px;border-radius:2px;letter-spacing:0.03em;
}
.menu-btn{display:none;background:none;border:1px solid rgba(240,185,58,0.4);border-radius:2px;padding:8px 10px;cursor:pointer;line-height:0;}
.menu-btn svg{width:20px;height:20px;stroke:var(--gold-400);}
.nav-links a.m-contact{ display:none; }
@media(max-width:960px){
  .nav{padding:12px 20px;}
  .nav-cta{display:none;}
  .menu-btn{display:block;}
  .nav-links a.m-contact{ display:block; color:var(--gold-400); font-weight:600; }
  .nav-links{
    display:none;
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; gap:0;
    background:rgba(4,12,30,0.97);
    border-bottom:1px solid rgba(240,185,58,0.2);
  }
  .nav-links.open{display:flex;}
  .nav-links a{padding:15px 24px;border-top:1px solid rgba(240,185,58,0.1);color:var(--cream);}
}

/* ---------- HELM (LOGO WHEEL) ---------- */
.helm-wheel{ display:block; }
.wheel-rotor{ transform-origin:60px 60px; transition:transform .05s linear; }

/* ---------- WAYPOINT RAIL ---------- */
.rail{
  position:fixed; left:26px; top:50%; transform:translateY(-50%);
  z-index:40; display:flex; flex-direction:column; gap:30px;
}
.rail::before{
  content:''; position:absolute; left:5px; top:6px; bottom:6px; width:1px;
  background:linear-gradient(var(--line-gold), transparent);
}
.wp{ display:flex; align-items:center; gap:12px; cursor:pointer; }
.wp .dot{ width:11px;height:11px;border-radius:50%; border:1.5px solid var(--gold-500); background:var(--cream); flex:none; transition:all .25s; }
.wp.active .dot{ background:var(--gold-500); box-shadow:0 0 0 4px rgba(207,154,62,0.18); }
.wp .info{
  opacity:0; transform:translateX(-6px); transition:all .25s; white-space:nowrap;
  background:rgba(255,255,255,0.97);
  border:1px solid rgba(217,154,31,0.4);
  border-radius:3px;
  padding:6px 12px;
  box-shadow:0 4px 14px rgba(4,12,30,0.18);
}
.wp:hover .info, .wp.active .info{ opacity:1; transform:translateX(0); }
.wp .info .num{ font-family:'IBM Plex Mono',monospace; font-size:0.66rem; color:var(--gold-700); letter-spacing:0.08em;}
.wp .info .lbl{ font-size:0.72rem; font-weight:600; color:var(--ink); text-transform:uppercase; letter-spacing:0.05em;}
@media(max-width:1080px){ .rail{display:none;} }

/* ---------- HERO ---------- */
.hero{
  position:relative;
  padding:118px 0 0;
  min-height:100vh;
  min-height:100svh;
  display:flex;
  flex-direction:column;
  background:
    radial-gradient(ellipse 800px 420px at 85% -10%, rgba(240,185,58,0.10), transparent 60%),
    linear-gradient(180deg, var(--navy-950), var(--navy-900) 60%, var(--navy-800));
  color:var(--cream);
}
.hero > .wrap{ width:100%; flex:1 0 auto; display:flex; flex-direction:column; justify-content:center; }
.hero-top{ display:grid; grid-template-columns:1.05fr 0.95fr; align-items:center; gap:56px; }
.hero-text{ max-width:600px; }
.hero-frame{ position:relative; }
.hero-frame::before{
  content:''; position:absolute; top:22px; left:22px; right:-22px; bottom:-22px;
  border:1.5px solid rgba(240,185,58,0.55);
  border-radius:4px;
  z-index:0;
}
.hero-img-slot{
  position:relative; z-index:1;
  aspect-ratio:1226/864;
  border:1.5px solid var(--line-gold);
  border-radius:4px;
  overflow:hidden;
  box-shadow:0 22px 50px rgba(0,0,0,0.4);
  background:rgba(246,242,230,0.03);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:30px;
}
.hero-img-slot svg{width:38px;height:38px;opacity:0.55;}
.hero-img-slot img.real-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:5; }
.hero-img-slot .filename-hint{ position:absolute; bottom:6px; right:8px; z-index:1; font-family:'IBM Plex Mono',monospace; font-size:0.62rem; color:rgba(240,185,58,0.4); }
.hero-img-slot .slot-title{font-family:'IBM Plex Mono',monospace;font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold-400);font-weight:600;}
.hero-img-slot .slot-desc{font-size:0.8rem;color:var(--muted-light);max-width:260px;line-height:1.5;}
@media(max-width:820px){
  .hero{padding-top:110px;}
  .hero-top{grid-template-columns:1fr;gap:40px;}
  .hero-frame{margin-right:14px;}
  .hero-frame::before{ right:-14px; bottom:-14px; top:14px; left:14px; }
  .hero-divider{margin-top:44px;}
  .hero-divider svg{height:90px;}
  .btn-gold,.btn-outline{flex:1;text-align:center;min-width:200px;}
}
.hero-coord{ display:flex; gap:8px; align-items:center; margin-bottom:26px; }
.hero-coord .ln{ width:30px;height:1px;background:var(--gold-400); }
.hero h1{
  font-size:clamp(2.5rem,4.9vw,4.2rem); line-height:1.02; color:var(--cream);
  max-width:780px;
}
.hero h1 em{ color:var(--gold-400); font-style:italic; }
.hero .sub{
  margin-top:22px; font-size:1.05rem; color:var(--muted-light); max-width:480px; line-height:1.65;
}
.hero .sub b{color:var(--gold-200); font-weight:600;}
.hero-divider{
  position:relative; margin-top:auto; padding-top:26px; line-height:0;
}
.hero-divider svg{ width:100%; height:130px; display:block; margin-bottom:-1px; }
.hero-actions{display:flex;gap:16px;margin-top:32px;flex-wrap:wrap;}
.btn-gold{
  background:linear-gradient(135deg,var(--gold-400),var(--gold-700));
  color:var(--navy-950); font-weight:700; padding:15px 28px; border-radius:2px; font-size:0.86rem;
  letter-spacing:0.02em;
}
.btn-outline{ border:1px solid rgba(246,242,230,0.3); color:var(--cream); padding:15px 28px; border-radius:2px; font-size:0.86rem; font-weight:600; }




/* ---------- SECTION GENERIC ---------- */
section{padding:110px 0;scroll-margin-top:64px;}
/* Cada sección llena la pantalla al navegar: la siguiente no se asoma */
@media(min-width:960px){
  section:not(.hero){
    min-height:calc(100vh - 64px);
    min-height:calc(100svh - 64px);
    display:flex;
    align-items:center;
    padding:90px 0;
  }
  section:not(.hero) > .wrap{width:100%;}
}
@media(max-width:820px){
  section{padding:70px 0;}
  .slot-h-460{min-height:300px;}
  .slot-h-360{min-height:260px;}
  .stat .n{font-size:1.5rem;}
  .serv-row{padding:40px 0;}
}
section + section{ border-top:1.5px solid rgba(240,185,58,0.5); }
#nosotros{ border-top:none; }
.head-block{max-width:640px;margin-bottom:56px;}
.head-block h2{font-size:clamp(2.4rem,4.4vw,3.6rem);margin-top:14px;line-height:1.08;}
.head-block p{margin-top:16px;color:var(--muted-dark);font-size:1rem;line-height:1.65;}

/* Nosotros */
.nosotros-grid{display:grid;grid-template-columns:1fr 0.9fr;gap:64px;align-items:stretch;}

/* Panel azul curvo — Perfil de la empresa (estilo catálogo) */
.perfil-panel{
  position:relative;
  background:linear-gradient(160deg, var(--navy-800) 0%, var(--navy-900) 55%, var(--navy-950) 100%);
  border-radius:120px 6px 6px 120px;
  padding:54px 44px 54px 64px;
  color:var(--muted-light);
  overflow:hidden;
  border:1px solid rgba(240,185,58,0.25);
  border-left:3px solid var(--gold-400);
  box-shadow:0 24px 54px rgba(4,12,30,0.25);
}
.perfil-panel .tag{color:var(--gold-400);}
.perfil-panel h3{font-size:1.55rem;color:#fff !important;margin:12px 0 18px;}
.perfil-panel p{font-size:0.94rem;line-height:1.8;margin-bottom:16px;}
.perfil-panel p b{color:var(--gold-200);font-weight:600;}
.perfil-panel .compass-bg{
  position:absolute; right:-40px; top:-40px; width:190px; height:190px;
  opacity:0.1; pointer-events:none;
}
.perfil-panel .gold-rule{width:44px;height:2px;background:var(--gold-400);margin-bottom:18px;}
@media(max-width:760px){
  .perfil-panel{border-radius:60px 6px 6px 60px;padding:40px 26px 40px 38px;}
}

/* Foto panorámica bajo la sección quiénes somos */
.nosotros-banner{margin-top:56px;}
.nosotros-banner .img-slot{min-height:300px;}
@media(max-width:640px){ .nosotros-banner .img-slot{min-height:200px;} }

/* Banda de valores en el hero (portada del catálogo) */
.hero-values{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  margin-top:42px;position:relative;z-index:5;
  padding-top:24px;border-top:1px solid rgba(240,185,58,0.25);
}
.hv-item{display:flex;align-items:center;gap:13px;justify-content:center;}
.hv-item .hv-ring{
  width:46px;height:46px;flex:none;border-radius:50%;
  border:1.5px solid var(--gold-400);
  display:flex;align-items:center;justify-content:center;
  background:rgba(240,185,58,0.08);
}
.hv-item .hv-ring svg{width:21px;height:21px;}
.hv-item span{font-family:'IBM Plex Mono',monospace;font-size:0.68rem;letter-spacing:0.16em;color:#fff;text-transform:uppercase;}
@media(max-width:820px){ .hero-values{grid-template-columns:1fr 1fr;gap:20px;margin-top:44px;} .hv-item{justify-content:flex-start;} }

/* Portátiles de pantalla corta: hero compacto para que la ola siempre se vea */
@media(min-width:960px) and (max-height:820px){
  .hero{padding-top:88px;}
  .hero h1{font-size:clamp(2.2rem,3.9vw,3.3rem);}
  .hero .sub{margin-top:16px;font-size:0.98rem;}
  .hero-actions{margin-top:24px;}
  .hero-actions a{padding:12px 22px;}
  .hero-top{grid-template-columns:1.1fr 0.9fr;gap:44px;}
  .hero-values{margin-top:26px;padding-top:16px;}
  .hv-item .hv-ring{width:38px;height:38px;}
  .hv-item .hv-ring svg{width:17px;height:17px;}
  .hero-divider{padding-top:16px;}
  .hero-divider svg{height:100px;}
}
.nosotros-grid p.body-p{color:#454f6c;line-height:1.8;margin-bottom:16px;font-size:0.98rem;}
.nosotros-grid p.body-p b{color:var(--ink);}

.stat-row{display:grid;grid-template-columns:repeat(4,1fr);margin-top:70px;border:1.5px solid var(--gold-500);border-radius:3px;overflow:hidden;}
.stat{background:var(--cream);padding:26px 22px;border-left:1.5px solid var(--gold-500);}
.stat:first-child{border-left:none;}
.stat .n{font-family:'IBM Plex Mono',monospace;font-size:2rem;color:var(--navy-900);font-weight:600;}
.stat .l{font-size:0.72rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted-dark);margin-top:6px;font-weight:600;}
@media(max-width:760px){
  .nosotros-grid{grid-template-columns:1fr;}
  .stat-row{grid-template-columns:1fr 1fr;}
  .stat:nth-child(3){border-left:none;}
  .stat:nth-child(n+3){border-top:1.5px solid var(--gold-500);}
}

/* Cobertura */
.cobertura{background:var(--navy-950);color:var(--cream);}
.cob-grid{display:grid;grid-template-columns:0.8fr 1.2fr;gap:56px;align-items:center;}
.cob-grid p{color:var(--muted-light);margin-top:16px;line-height:1.7;}
.port-chip-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px;}
.port-chip{font-family:'IBM Plex Mono',monospace;font-size:0.72rem;padding:8px 14px;border:1px solid rgba(240,185,58,0.3);color:var(--gold-200);border-radius:2px;}
.port-chip.main{background:var(--gold-500);color:var(--navy-950);border-color:var(--gold-500);font-weight:600;}
@media(max-width:820px){ .cob-grid{grid-template-columns:1fr;} }

/* Mision Vision */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-top:50px;}
.mv-card{background:#fff;border:1px solid rgba(10,28,61,0.08);padding:38px;border-radius:4px;}
.mv-card .n{font-family:'IBM Plex Mono',monospace;color:var(--gold-700);font-size:0.75rem;letter-spacing:0.14em;}
.mv-card h3{font-size:2rem;margin:12px 0 16px;color:var(--navy-900);}
.mv-card p{color:var(--muted-dark);line-height:1.75;font-size:0.95rem;}
@media(max-width:760px){ .mv-grid{grid-template-columns:1fr;} }

/* Principios - radial wheel */
.principios{background:var(--navy-900);color:var(--cream);position:relative;overflow:hidden;}
.principios .wrap{position:relative;z-index:2;}
.prin-layout{display:grid;grid-template-columns:420px 1fr;gap:60px;align-items:center;margin-top:40px;}
.prin-wheel-box{position:relative;width:420px;height:420px;}
.prin-list{list-style:none;display:flex;flex-direction:column;gap:0;}
.prin-list li{display:flex;gap:18px;padding:20px 0;border-top:1px solid rgba(240,185,58,0.14);align-items:baseline;}
.prin-list li:first-child{border-top:none;}
.prin-list .idx{font-family:'IBM Plex Mono',monospace;color:var(--gold-500);font-size:0.85rem;min-width:26px;}
.prin-list .txt b{display:block;font-family:'Cormorant Garamond',serif;font-size:1.25rem;color:var(--gold-200);font-weight:600;}
.prin-list .txt span{font-size:0.85rem;color:var(--muted-light);}
@media(max-width:900px){ .prin-layout{grid-template-columns:1fr;} .prin-wheel-box{width:280px;height:280px;margin:0 auto;} }

/* Servicios */
.serv-row{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:56px 0;border-top:1px solid rgba(10,28,61,0.08);}
.serv-row:first-of-type{border-top:none;}
.serv-row.reverse .txt{order:2;}
.serv-row .n{font-family:'IBM Plex Mono',monospace;color:var(--gold-700);font-size:0.8rem;letter-spacing:0.1em;}
.serv-row h3{font-size:2.1rem;margin:10px 0 14px;color:var(--navy-900);}
.serv-row p{color:var(--muted-dark);line-height:1.75;font-size:0.96rem;}
@media(max-width:820px){ .serv-row{grid-template-columns:1fr;gap:26px;} .serv-row.reverse .txt{order:0;} }

.serv-compact{margin-top:20px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.sc-item{border:1px solid rgba(10,28,61,0.08);padding:22px;border-radius:4px;}
.sc-item svg{width:22px;height:22px;margin-bottom:12px;}
.sc-item h4{font-size:1.02rem;color:var(--navy-900);margin-bottom:6px;}
.sc-item p{font-size:0.84rem;color:var(--muted-dark);line-height:1.55;}
@media(max-width:760px){ .serv-compact{grid-template-columns:1fr 1fr;} }
@media(max-width:520px){ .serv-compact{grid-template-columns:1fr;} }

/* Por que */
.porque{background:var(--navy-950);color:var(--cream);}
.pq-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;}
.checklist{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:16px;}
.checklist li{display:flex;gap:14px;font-size:0.96rem;color:var(--muted-light);line-height:1.5;}
.checklist svg{width:18px;height:18px;flex:none;margin-top:3px;}
.quote{border-left:2px solid var(--gold-500);padding-left:24px;margin-top:36px;}
.quote p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.5rem;color:var(--cream);line-height:1.5;}
.quote span{display:block;margin-top:14px;font-family:'IBM Plex Mono',monospace;font-size:0.7rem;letter-spacing:0.1em;color:var(--gold-400);text-transform:uppercase;}
@media(max-width:820px){ .pq-grid{grid-template-columns:1fr;} }

/* Contacto */
.contacto{background:var(--cream-2);}
.ct-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;}
.ct-list{margin-top:30px;display:flex;flex-direction:column;gap:22px;}
.ct-item{display:flex;gap:16px;align-items:flex-start;}
.ct-item .ring{width:38px;height:38px;border:1px solid var(--gold-500);border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none;}
.ct-item svg{width:16px;height:16px;}
.ct-item h4{font-family:'IBM Plex Mono',monospace;font-size:0.68rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold-700);margin-bottom:4px;}
.ct-item p,.ct-item a{font-size:0.92rem;color:var(--ink);line-height:1.5;overflow-wrap:anywhere;}
.partners{margin-top:70px;padding-top:34px;border-top:1px solid rgba(10,28,61,0.1);}
.partners h4{text-align:center;font-family:'IBM Plex Mono',monospace;font-size:0.68rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted-dark);margin-bottom:26px;}
.partners-row{display:flex;justify-content:center;align-items:center;gap:28px;flex-wrap:wrap;}
.partner-logo{
  background:#fff;
  border:1px solid rgba(10,28,61,0.14);
  border-radius:6px;
  padding:14px 22px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(10,28,61,0.06);
  transition:transform .3s, box-shadow .3s, filter .3s;
  filter:grayscale(35%);
}
.partner-logo:hover{ transform:translateY(-4px); box-shadow:0 12px 26px rgba(10,28,61,0.12); filter:grayscale(0%); }
.partner-logo img{ height:52px; width:auto; max-width:220px; object-fit:contain; display:block; }
@media(max-width:640px){ .partner-logo img{ height:42px; max-width:160px; } .partners-row{ gap:16px; } }
.partner{display:flex;align-items:center;gap:9px;color:var(--navy-900);font-weight:700;font-size:0.82rem;}
.partner svg{width:22px;height:22px;}
@media(max-width:820px){ .ct-grid{grid-template-columns:1fr;} }




/* ---------- CAPA 3D ---------- */
.hero-top{ perspective:1400px; }
.hero-img-slot{ transform-style:preserve-3d; will-change:transform; }
.mv-card, .sc-item, .perfil-panel, .stat{ will-change:transform; }
.tilt-glare{
  position:absolute; inset:0; z-index:6; pointer-events:none; border-radius:inherit;
  background:radial-gradient(420px circle at var(--gx,50%) var(--gy,50%), rgba(255,246,217,0.22), transparent 62%);
  opacity:0; transition:opacity .35s;
}
.tilting .tilt-glare{ opacity:1; }
@media (prefers-reduced-motion: reduce){
  .tilt-glare{ display:none; }
}


/* ---------- PAQUETE PROFESIONAL ---------- */
::selection{ background:var(--gold-400); color:var(--navy-950); }
::-webkit-scrollbar{ width:11px; }
::-webkit-scrollbar-track{ background:var(--navy-950); }
::-webkit-scrollbar-thumb{ background:linear-gradient(var(--gold-500),var(--gold-700)); border-radius:6px; border:2px solid var(--navy-950); }

/* Preloader de marca */
#preloader{
  position:fixed; inset:0; z-index:9999; background:var(--navy-950);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px;
  transition:opacity .6s ease, visibility .6s;
}
#preloader.out{ opacity:0; visibility:hidden; }
#preloader svg{ width:64px; height:64px; animation:preSpin 2.4s linear infinite; }
#preloader .pre-brand{ font-family:'Cormorant Garamond',serif; font-size:1.5rem; font-weight:700; color:#fff; letter-spacing:0.35em; text-indent:0.35em; }
#preloader .pre-sub{ font-family:'IBM Plex Mono',monospace; font-size:0.6rem; letter-spacing:0.3em; color:var(--gold-400); text-transform:uppercase; }
@keyframes preSpin{ to{ transform:rotate(360deg); } }

/* Botón flotante de WhatsApp */
.wa-float{
  position:fixed; right:26px; bottom:26px; z-index:900;
  width:58px; height:58px; border-radius:50%;
  background:#25d366; display:flex; align-items:center; justify-content:center;
  box-shadow:0 10px 28px rgba(37,211,102,0.45);
  transition:transform .3s;
}
.wa-float:hover{ transform:translateY(-4px) scale(1.06); }
.wa-float svg{ width:30px; height:30px; fill:#fff; }
.wa-float::before{
  content:''; position:absolute; inset:-6px; border-radius:50%;
  border:2px solid rgba(37,211,102,0.55); animation:waPulse 2s ease-out infinite;
}
@keyframes waPulse{ 0%{ transform:scale(0.9); opacity:1; } 100%{ transform:scale(1.35); opacity:0; } }

/* Volver arriba */
.to-top{
  position:fixed; right:26px; bottom:98px; z-index:900;
  width:44px; height:44px; border-radius:50%;
  background:var(--navy-900); border:1.5px solid var(--gold-400);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transform:translateY(10px);
  transition:all .35s; cursor:pointer;
}
.to-top.show{ opacity:1; visibility:visible; transform:none; }
.to-top:hover{ background:var(--navy-800); transform:translateY(-3px); }
.to-top svg{ width:18px; height:18px; stroke:var(--gold-400); }
@media(max-width:640px){ .wa-float{ right:18px; bottom:18px; width:54px; height:54px; } .to-top{ right:20px; bottom:84px; } }

/* Footer corporativo */
.footer-pro{ background:var(--navy-950); color:var(--muted-light); padding:70px 0 0; border-top:2px solid rgba(240,185,58,0.45); }
.footer-grid{ display:grid; grid-template-columns:1.3fr 0.8fr 1fr; gap:56px; padding-bottom:52px; }
.footer-grid > div{ min-width:0; }
.footer-pro .f-item span, .footer-pro .f-item a{ overflow-wrap:anywhere; }
.footer-pro .f-brand{ display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.footer-pro .f-brand svg{ width:34px; height:34px; }
.footer-pro .f-brand .b1{ font-family:'Cormorant Garamond',serif; font-size:1.35rem; font-weight:700; color:#fff; letter-spacing:0.05em; }
.footer-pro .f-brand .b2{ font-family:'IBM Plex Mono',monospace; font-size:0.55rem; letter-spacing:0.3em; color:var(--gold-400); }
.footer-pro p{ font-size:0.88rem; line-height:1.75; max-width:340px; }
.footer-pro h5{ font-family:'IBM Plex Mono',monospace; font-size:0.68rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--gold-400); margin-bottom:18px; }
.footer-pro .f-nav a{ display:block; color:var(--muted-light); font-size:0.9rem; padding:5px 0; transition:color .25s, transform .25s; }
.footer-pro .f-nav a:hover{ color:var(--gold-200); transform:translateX(4px); }
.footer-pro .f-item{ display:flex; gap:10px; align-items:baseline; font-size:0.88rem; margin-bottom:10px; }
.footer-pro .f-item svg{ width:14px; height:14px; flex:none; transform:translateY(2px); }
.footer-pro .f-item a{ color:var(--muted-light); }
.footer-pro .f-item a:hover{ color:var(--gold-200); }
.footer-bottom{ border-top:1px solid rgba(240,185,58,0.18); padding:20px 0; font-family:'IBM Plex Mono',monospace; font-size:0.72rem; letter-spacing:0.04em; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.footer-bottom .gold{ color:var(--gold-400); }
@media(max-width:820px){ .footer-grid{ grid-template-columns:1fr; gap:38px; } .footer-bottom{ justify-content:center; text-align:center; } }

/* ---------- MOTION / MODERN LAYER ---------- */
/* Reveals al hacer scroll (solo si hay JS) */
.js .reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s cubic-bezier(.22,.61,.36,1), transform .8s cubic-bezier(.22,.61,.36,1); }
.js .reveal.in{ opacity:1; transform:none; }
.js .reveal.d1{ transition-delay:.1s; }
.js .reveal.d2{ transition-delay:.2s; }
.js .reveal.d3{ transition-delay:.3s; }

/* Entrada del hero */
.js .hero-text > *{ opacity:0; transform:translateY(24px); animation:heroIn .9s cubic-bezier(.22,.61,.36,1) forwards; }
.js .hero-text > *:nth-child(1){ animation-delay:.05s; }
.js .hero-text > *:nth-child(2){ animation-delay:.18s; }
.js .hero-text > *:nth-child(3){ animation-delay:.34s; }
.js .hero-text > *:nth-child(4){ animation-delay:.5s; }
.js .hero-frame{ opacity:0; transform:translateY(30px) scale(.97); animation:heroIn 1s .35s cubic-bezier(.22,.61,.36,1) forwards; }
@keyframes heroIn{ to{ opacity:1; transform:none; } }

/* Zoom sutil en imágenes */
.img-slot img.real-img, .hero-img-slot img.real-img{ transition:transform 1s cubic-bezier(.22,.61,.36,1); }
.img-slot:hover img.real-img{ transform:scale(1.045); }
.img-slot.fit:hover img.real-img{ transform:none; }
.img-slot, .mv-card, .sc-item{ transition:transform .45s cubic-bezier(.22,.61,.36,1), box-shadow .45s, border-color .45s; }
.mv-card:hover, .sc-item:hover{ box-shadow:0 18px 40px rgba(10,28,61,0.14); border-color:rgba(217,154,31,0.45); }

/* Botones: brillo dorado al pasar */
.btn-gold, .nav-cta{ position:relative; overflow:hidden; transition:transform .3s, box-shadow .3s; }
.btn-gold::after, .nav-cta::after{
  content:''; position:absolute; top:0; left:-80%; width:50%; height:100%;
  background:linear-gradient(105deg, transparent, rgba(255,246,217,0.55), transparent);
  transform:skewX(-20deg); transition:left .6s ease;
}
.btn-gold:hover::after, .nav-cta:hover::after{ left:130%; }
.btn-gold:hover, .nav-cta:hover{ transform:translateY(-2px); box-shadow:0 10px 26px rgba(240,185,58,0.35); }
.btn-outline{ transition:border-color .3s, background .3s, transform .3s; }
.btn-outline:hover{ border-color:var(--gold-400); background:rgba(240,185,58,0.08); transform:translateY(-2px); }

/* Chips de puertos */
.port-chip{ transition:transform .3s, border-color .3s, color .3s, background .3s; cursor:default; }
.port-chip:hover{ transform:translateY(-3px); border-color:var(--gold-400); color:var(--gold-100); }
.port-chip.main:hover{ background:var(--gold-400); }

/* Nav links: subrayado dorado animado */
.nav-links a::after{ content:''; position:absolute; left:0; bottom:-5px; width:100%; height:1.5px; background:var(--gold-400); transform:scaleX(0); transform-origin:left; transition:transform .3s ease; }
.nav-links a:hover::after{ transform:scaleX(1); }
.nav-links a.active{ color:var(--gold-400); }
.nav-links a.active::after{ transform:scaleX(1); }

/* Ola animada: capas que se desplazan */
.wave-drift{ animation:drift 14s linear infinite; }
.wave-drift-2{ animation:drift 9s linear infinite reverse; opacity:.5; }
@keyframes drift{ from{ transform:translateX(0); } to{ transform:translateX(-1200px); } }

/* Parallax suave del hero */
.js .hero-img-slot img.real-img{ will-change:transform; }

/* Header con sombra al hacer scroll */
header{ transition:box-shadow .35s, background .35s; }
header.scrolled{ background:rgba(4,12,30,0.96); box-shadow:0 8px 30px rgba(0,0,0,0.45); }

/* Timón: giro suave */
.wheel-rotor{ transition:transform .25s ease-out; }


/* Respeto a usuarios con movimiento reducido */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; }
  .js .reveal, .js .hero-text > *, .js .hero-frame{ opacity:1 !important; transform:none !important; }
}
