:root{
  /* Light theme (marca azul + amarillo) */
  --bg: #ffffff;
  --bg2:#f4fbff;          /* azul muy suave */
  --text:#0b1220;
  --muted:#556176;
  --card:#ffffff;
  --border:#dfe9f3;

  --accent:#2DA9FF;       /* azul claro marca */
  --accent2:#F6C343;      /* amarillo marca */
  --accent3:#0B6BFF;      /* azul más profundo para contraste */

  --shadow: 0 18px 45px rgba(11,18,32,.10);
  --radius: 18px;
  --radius2: 26px;
  --ease: cubic-bezier(.2,.8,.2,1);
}


[data-theme="dark"]{
  --bg:#0b1220;
  --bg2:#0f172a;
  --text:#eaf0ff;
  --muted:#aab3c7;
  --card:#0f172a;
  --border:#22304a;

  --accent:#38bdf8;
  --accent2:#a78bfa;
  --accent3:#4ade80;

  --shadow: 0 18px 60px rgba(0,0,0,.40);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  background:
  radial-gradient(1000px 520px at 12% -10%, color-mix(in oklab, var(--accent), transparent 80%), transparent 60%),
  radial-gradient(900px 500px at 88% 0%,  color-mix(in oklab, var(--accent2), transparent 85%), transparent 60%),
  var(--bg);
}

a{color:inherit}
code{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}

.container{width:min(1120px, 92%); margin-inline:auto}
.muted{color:var(--muted)}
.small{font-size:.92rem}
.hidden{display:none}

/* Barra de progreso */
.progress{
  position:fixed;
  top:0; left:0; right:0;
  height:3px;
  z-index:999;
  background: color-mix(in oklab, var(--bg), transparent 60%);
}
.progress__bar{
  height:100%;
  width:0%;
  background: linear-gradient(90deg, var(--accent), var(--accent2), var(--accent3));
  box-shadow: 0 0 18px color-mix(in oklab, var(--accent), transparent 60%);
}

/* Accesibilidad */
.skip{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip:focus{left:12px; top:12px; width:auto; height:auto; padding:10px 12px; background:var(--card); border:1px solid var(--border); border-radius:12px; z-index:999}

/* Header */
.header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(180%) blur(12px);
  background: color-mix(in oklab, var(--bg), transparent 10%);
  border-bottom:1px solid var(--border);
}
.header__inner{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:12px 0}

.brand{display:flex; align-items:center; gap:12px; min-width:240px}
.brand__mark{
  width:44px;
  height:44px;
  border-radius:14px;
  display:grid;
  place-items:center;
  overflow:hidden; /* importante para que el logo no se salga */
  border:1px solid color-mix(in oklab, var(--accent), var(--border) 60%);
  background: color-mix(in oklab, var(--bg2), transparent 20%);
}

.brand__mark img{
  width:100%;
  height:100%;
  object-fit:contain; /* mantiene proporción del logo */
  padding:2px;        /* aire alrededor, ajusta si lo quieres más grande */
}

.brand__name{font-weight:800}
.brand__tag{font-size:.9rem; color:var(--muted)}

.nav{display:flex; align-items:center; gap:12px}
.nav__toggle{
  display:none;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--card);
  cursor:pointer;
}
.nav__links{display:flex; align-items:center; gap:10px}
.nav__links a{padding:10px 10px; text-decoration:none; color:var(--muted); position:relative}
.nav__links a:hover{color:var(--text)}
.nav__links a::after{
  content:"";
  position:absolute;
  left:10px; right:10px; bottom:6px;
  height:2px; border-radius:99px;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .25s var(--ease);
  background: linear-gradient(90deg, var(--accent), var(--accent2));
}
.nav__links a:hover::after{transform:scaleX(1)}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--card);
  cursor:pointer;
  text-decoration:none;
  font-weight:700;
  transition: transform .18s var(--ease), box-shadow .18s var(--ease), border-color .18s var(--ease);
}
.btn:hover{transform: translateY(-1px); box-shadow: var(--shadow)}
.btn:active{transform: translateY(0px) scale(.99)}

.btn--primary{
  background: linear-gradient(135deg, var(--accent3), var(--accent));
  border-color: color-mix(in oklab, var(--accent2), var(--border) 55%);
  color: white;
  box-shadow:
    0 18px 40px color-mix(in oklab, var(--accent), transparent 75%),
    0 0 0 6px color-mix(in oklab, var(--accent2), transparent 88%);
}

.btn--primary:hover{
  box-shadow:
    0 24px 60px color-mix(in oklab, var(--accent3), transparent 72%),
    0 0 0 8px color-mix(in oklab, var(--accent2), transparent 85%);
}
.btn--ghost{background:transparent}

/* HERO más llamativo */
.hero{padding:74px 0 28px; position:relative}
.hero:not(.hero--photo) .hero__bg{
  position:absolute;
  inset:-180px -120px auto -120px;
  height:520px;
  background:
    radial-gradient(600px 220px at 20% 30%, color-mix(in oklab, var(--accent), transparent 70%), transparent 60%),
    radial-gradient(520px 240px at 70% 20%, color-mix(in oklab, var(--accent2), transparent 75%), transparent 60%),
    radial-gradient(520px 260px at 55% 85%, color-mix(in oklab, var(--accent3), transparent 78%), transparent 60%);
  filter: blur(18px);
  opacity:.95;
  pointer-events:none;
  animation: floatBg 10s var(--ease) infinite alternate;
}
@keyframes floatBg{
  from{ transform: translateY(-6px) }
  to{ transform: translateY(10px) }
}

.hero__inner{display:grid; grid-template-columns: 1.2fr .8fr; gap:28px; align-items:center; position:relative}
.pill{
  display:inline-flex; align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--bg2), transparent 30%);
  color:var(--muted);
  margin:0 0 12px;
}
.hero h1{
  font-size: clamp(2.05rem, 4.1vw, 3.35rem);
  line-height:1.03;
  margin:0 0 12px;
  letter-spacing:-.02em;
}
.hero h1 .grad{
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.hero__cta{display:flex; gap:12px; flex-wrap:wrap; margin:18px 0 18px}

.hero__meta{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.metaCard{
  padding:14px;
  border-radius: var(--radius);
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--card), transparent 0%);
  box-shadow: var(--shadow);
  transition: transform .22s var(--ease);
}
.metaCard:hover{transform: translateY(-2px)}
.metaCard__k{font-weight:800; font-size:.95rem}
.metaCard__v{color:var(--muted); margin-top:6px}

.hero__visual{display:flex; justify-content:flex-end}
.visualCard{
  width:min(360px, 100%);
  aspect-ratio: 4/3;
  border-radius: 30px;
  border:1px solid var(--border);
  background:
    radial-gradient(900px 380px at 20% 10%, color-mix(in oklab, var(--accent), transparent 70%), transparent 60%),
    linear-gradient(180deg, var(--bg2), var(--bg));
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
  transform-style:preserve-3d;
  transition: transform .25s var(--ease);
}
.visualCard::after{
  content:"";
  position:absolute;
  inset:-40px;
  background: repeating-linear-gradient(
    135deg,
    color-mix(in oklab, var(--text), transparent 92%),
    color-mix(in oklab, var(--text), transparent 92%) 10px,
    transparent 10px,
    transparent 22px
  );
  opacity:.35;
  pointer-events:none;
}
.visualCard__top{height:46px; border-bottom:1px solid var(--border)}
.visualCard__lines{padding:16px; display:grid; gap:10px; position:relative}
.visualCard__lines div{
  height:12px;
  border-radius:999px;
  background: color-mix(in oklab, var(--text), transparent 90%);
}
.visualCard__badge{
  position:absolute; right:16px; bottom:16px;
  width:58px; height:58px; border-radius:20px;
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--accent), transparent 70%),
    color-mix(in oklab, var(--accent2), transparent 78%));
  border:1px solid color-mix(in oklab, var(--accent), var(--border) 60%);
  display:grid; place-items:center;
  font-weight:900;
}

/* Secciones */
.section{padding:58px 0}
.section--alt{background:var(--bg2); border-block:1px solid var(--border)}
.section__head{display:flex; flex-direction:column; gap:10px; margin-bottom:18px}
.section__head h2{margin:0; font-size: clamp(1.45rem, 2.6vw, 2.1rem); letter-spacing:-.01em}

.grid2{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.card{
  padding:18px;
  border-radius: var(--radius2);
  border:1px solid var(--border);
  background:var(--card);
  box-shadow: var(--shadow);
  transition: transform .22s var(--ease), box-shadow .22s var(--ease);
}
.card:hover{transform: translateY(-2px); box-shadow: 0 22px 70px rgba(11,18,32,.12)}
.card h3{margin:0 0 8px}
.list{margin:0; padding-left:18px; color:var(--muted)}
.list li{margin:8px 0}

.toolbar{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; margin:14px 0 16px}
.input{
  width:min(420px, 100%);
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--text);
  outline:none;
  transition: border-color .18s var(--ease), box-shadow .18s var(--ease);
}
.input:focus{
  border-color: color-mix(in oklab, var(--accent), var(--border) 40%);
  box-shadow: 0 0 0 6px color-mix(in oklab, var(--accent), transparent 88%);
}
.label{display:grid; gap:8px; margin-bottom:12px}
textarea.input{resize:vertical}

.chips{display:flex; gap:8px; flex-wrap:wrap}
.chip{
  padding:10px 12px;
  border-radius:999px;
  border:1px solid var(--border);
  background:transparent;
  cursor:pointer;
  color:var(--muted);
  font-weight:800;
  transition: transform .18s var(--ease), background .18s var(--ease);
}
.chip:hover{transform: translateY(-1px)}
.chip.is-active{
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--accent), transparent 85%),
    color-mix(in oklab, var(--accent2), transparent 88%));
  border-color: color-mix(in oklab, var(--accent), var(--border) 60%);
  color:var(--text);
}

.cards{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px}
.pcard{
  border-radius: var(--radius2);
  border:1px solid var(--border);
  background:var(--card);
  box-shadow: var(--shadow);
  overflow:hidden;
  display:flex; flex-direction:column;
  transition: transform .22s var(--ease), box-shadow .22s var(--ease);
}
.pcard:hover{transform: translateY(-3px); box-shadow: 0 26px 80px rgba(11,18,32,.14)}
.pcard__media{
  aspect-ratio: 16/9;
  background:
    radial-gradient(850px 260px at 15% 15%, color-mix(in oklab, var(--accent), transparent 70%), transparent 60%),
    linear-gradient(180deg, var(--bg2), var(--bg));
  border-bottom:1px solid var(--border);
  position:relative;
}
.pcard__media img{width:100%; height:100%; object-fit:cover; display:block}
.pcard__badge{
  position:absolute; left:12px; top:12px;
  padding:8px 10px;
  border-radius:999px;
  background: color-mix(in oklab, var(--bg), transparent 10%);
  border:1px solid var(--border);
  color:var(--muted);
  font-weight:900;
  font-size:.88rem;
}
.pcard__body{padding:14px}
.pcard__title{font-weight:900; margin:0 0 6px}
.pcard__meta{color:var(--muted); font-size:.95rem; margin:0 0 12px}
.pcard__actions{margin-top:auto; padding:0 14px 14px; display:flex; gap:10px}

.accordion{display:grid; gap:10px}
.accItem{
  border-radius: var(--radius2);
  border:1px solid var(--border);
  background:var(--card);
  box-shadow: var(--shadow);
  overflow:hidden;
  transition: transform .22s var(--ease);
}
.accItem:hover{transform: translateY(-1px)}
.accBtn{
  width:100%;
  text-align:left;
  padding:14px 16px;
  border:0;
  background:transparent;
  color:var(--text);
  font-weight:900;
  cursor:pointer;
  display:flex; align-items:center; justify-content:space-between;
}
.accPanel{padding:0 16px 16px; color:var(--muted); display:none}
.accItem.is-open .accPanel{display:block}
.accChevron{color:var(--muted)}

.gallery{display:grid; grid-template-columns: repeat(4, 1fr); gap:10px}
.gitem{
  border-radius: 18px;
  border:1px solid var(--border);
  overflow:hidden;
  background:var(--card);
  box-shadow: var(--shadow);
  cursor:pointer;
  aspect-ratio: 1/1;
  transition: transform .22s var(--ease);
}
.gitem:hover{transform: translateY(-2px) scale(1.01)}
.gitem img{width:100%; height:100%; object-fit:cover; display:block}

.tableWrap{
  border-radius: var(--radius2);
  border:1px solid var(--border);
  overflow:hidden;
  background:var(--card);
  box-shadow: var(--shadow);
}
.table{width:100%; border-collapse:collapse}
.table th, .table td{padding:12px 12px; border-bottom:1px solid var(--border); vertical-align:top}
.table th{
  background: color-mix(in oklab, var(--bg2), transparent 10%);
  text-align:left; font-size:.95rem;
}
.table tr:last-child td{border-bottom:none}
.table tbody tr:hover td{
  background: color-mix(in oklab, var(--accent), transparent 93%);
}

.kv{display:grid; grid-template-columns: 140px 1fr; gap:10px 12px; align-items:start}
.kv__k{color:var(--muted); font-weight:900}
.kv__v a{color:var(--accent); text-decoration:none}
.kv__v a:hover{text-decoration:underline}

.footer{padding:22px 0; border-top:1px solid var(--border)}
.footer__inner{display:flex; justify-content:space-between; align-items:center; gap:12px}

/* Modal */
.modal{position:fixed; inset:0; display:none; z-index:100}
.modal.is-open{display:block}
.modal__backdrop{position:absolute; inset:0; background:rgba(0,0,0,.55)}
.modal__panel{
  position:relative;
  width:min(920px, 92%);
  margin: 6vh auto;
  background:var(--card);
  border:1px solid var(--border);
  border-radius: 24px;
  box-shadow: var(--shadow);
  padding:16px;
  animation: pop .2s var(--ease) both;
}
@keyframes pop{
  from{transform: translateY(10px) scale(.98); opacity:.6}
  to{transform: translateY(0) scale(1); opacity:1}
}
.modal__close{
  position:absolute; right:12px; top:12px;
  width:40px; height:40px;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--card);
  cursor:pointer;
}
.modal__panel img{max-width:100%; border-radius:18px; border:1px solid var(--border)}

/* Reveal animations */
.reveal{
  opacity:0;
  transform: translateY(12px);
  transition: opacity .55s var(--ease), transform .55s var(--ease);
}
.reveal.is-visible{
  opacity:1;
  transform: translateY(0);
}

/* Preferencias de movimiento reducido */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important}
  html{scroll-behavior:auto}
}

/* Responsive */
@media (max-width: 980px){
  .hero__inner{grid-template-columns:1fr}
  .hero__visual{justify-content:flex-start}
  .cards{grid-template-columns: 1fr 1fr}
  .gallery{grid-template-columns: 1fr 1fr 1fr}
}
@media (max-width: 720px){
  .nav__toggle{display:inline-flex}
  .nav__links{
    display:none;
    position:absolute;
    right:4%;
    top:64px;
    width:min(420px, 92%);
    flex-direction:column;
    align-items:stretch;
    gap:8px;
    padding:12px;
    border-radius:18px;
    border:1px solid var(--border);
    background:var(--card);
    box-shadow: var(--shadow);
  }
  .nav__links.is-open{display:flex}
  .cards{grid-template-columns: 1fr}
  .grid2{grid-template-columns: 1fr}
  .gallery{grid-template-columns: 1fr 1fr}
  .kv{grid-template-columns: 1fr}
}

/* Contacto: mejor uso de espacio */
.grid2--contact{
  grid-template-columns: .95fr 1.05fr;
  align-items: start;
}

/* Lista de contacto con íconos */
.contactList{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 12px;
}

.contactItem{
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 12px;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: color-mix(in oklab, var(--card), transparent 0%);
  box-shadow: var(--shadow);
  transition: transform .22s var(--ease), box-shadow .22s var(--ease);
}

.contactItem:hover{
  transform: translateY(-2px);
  box-shadow: 0 26px 80px rgba(11,18,32,.14);
}

/* Ícono base: usa variables por tipo */
.contactIcon{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  color: white;

  /* valores por defecto (por si falta alguna clase) */
  --iconA: var(--accent);
  --iconB: var(--accent2);

  background: linear-gradient(135deg, var(--iconA), var(--iconB));
  box-shadow: 0 18px 40px color-mix(in oklab, var(--iconA), transparent 82%);
}

.contactIcon svg{
  width: 22px;
  height: 22px;
}

/* Variantes por tipo */
.contactIcon--phone{
  --iconA: #0ea5e9;   /* azul */
  --iconB: #2563eb;
}

.contactIcon--email{
  --iconA: #a855f7;   /* morado */
  --iconB: #6366f1;
}

.contactIcon--location{
  --iconA: #ef4444;   /* rojo */
  --iconB: #b91c1c;
}

.contactIcon--whatsapp{
  --iconA: #22c55e;   /* verde WhatsApp */
  --iconB: #16a34a;
}


.contactLabel{
  font-weight: 900;
  letter-spacing: -.01em;
}

.contactValue{
  color: var(--muted);
  margin-top: 4px;
}

.contactValue a{
  color: var(--accent);
  text-decoration: none;
  font-weight: 800;
}
.contactValue a:hover{
  text-decoration: underline;
}

.contactActions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
}

/* Responsive */
@media (max-width: 720px){
  .grid2--contact{ grid-template-columns: 1fr; }
}


/* ===== HERO con imagen de fondo (mejor balance) ===== */
.hero--photo{
  position: relative;
  overflow: hidden;
  color: #fff;
}

.hero--photo .hero__bg{
  position:absolute;
  inset:0;
  height:100%;
  pointer-events:none;

  background: url("assets/hero/hero.jpg") center/cover no-repeat;
  transform: scale(1.02);
}

/* Overlay más CLARO + coherente con marca */
.hero--photo .hero__bg::after{
  content:"";
  position:absolute;
  inset:0;

  /* 1) Velo general suave para contraste (NO oscuro) */
  background:
    linear-gradient(90deg,
      rgba(10, 24, 46, .40) 0%,
      rgba(10, 24, 46, .18) 45%,
      rgba(10, 24, 46, .28) 100%),

    /* 2) Tintes marca (azul/amarillo) muy sutiles */
    radial-gradient(900px 420px at 18% 18%,
      color-mix(in oklab, var(--accent), transparent 78%), transparent 60%),
    radial-gradient(900px 420px at 82% 12%,
      color-mix(in oklab, var(--accent2), transparent 82%), transparent 62%),

    /* 3) Aclarado leve para que la foto se sienta viva */
    linear-gradient(180deg,
      rgba(255,255,255,.10) 0%,
      rgba(255,255,255,0) 35%,
      rgba(0,0,0,.08) 100%);
}

/* Una “caja” de lectura SOLO para la zona del texto */
.hero--photo .hero__copy{
  position: relative;
}
.hero--photo .hero__copy::before{
  content:"";
  position:absolute;
  inset:-14px -18px;
  border-radius: 28px;

  background: linear-gradient(135deg,
    rgba(10, 24, 46, .40),
    rgba(10, 24, 46, .18)
  );
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 22px 70px rgba(0,0,0,.22);
  backdrop-filter: blur(10px);
  z-index:-1;
}

/* Texto / pill */
.hero--photo .muted{ color: rgba(255,255,255,.86); }
.hero--photo h1{
  text-shadow: 0 10px 30px rgba(0,0,0,.28);
}

.hero--photo .pill{
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.22);
  color: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
}

/* Tarjetas del hero: glass más claro */
.hero--photo .metaCard{
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.20);
  box-shadow: 0 18px 55px rgba(0,0,0,.20);
  backdrop-filter: blur(12px);
}

/* Botón ghost sobre foto (más visible) */
.hero--photo .btn--ghost{
  border-color: rgba(255,255,255,.30);
  color: rgba(255,255,255,.94);
  background: rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
}

/* Visual card: que no se “pierda” */
.hero--photo .visualCard{
  border-color: rgba(255,255,255,.22);
  background:
    linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.06));
  box-shadow: 0 22px 70px rgba(0,0,0,.22);
}
.hero--photo{
  min-height: 70vh;   /* prueba 65vh - 80vh */
  display: flex;
  align-items: center;
}

/* ===== Sobre nosotros (layout + logo grande) ===== */
.aboutLayout{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 16px;
  align-items: start;
}

.aboutMain .section__head p{
  max-width: 72ch;
}

/* Chips de enfoque */
.aboutChips{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 10px 0 18px;
}

.aboutChip{
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--accent), transparent 92%),
    color-mix(in oklab, var(--accent2), transparent 93%)
  );
  color: var(--muted);
  font-weight: 850;
  font-size: .92rem;
}

/* Cards internas */
.aboutCards{
  display:grid;
  grid-template-columns: 1fr; /* por defecto en filas */
  gap: 16px;
}

.aboutList{
  margin: 12px 0 0;
  padding-left: 18px;
  color: var(--muted);
}
.aboutList li{ margin: 8px 0; }

.aboutSteps{
  margin: 12px 0 0;
  padding-left: 18px;
  color: var(--muted);
}
.aboutSteps li{ margin: 10px 0; }
.aboutSteps strong{ color: color-mix(in oklab, var(--text), transparent 10%); }

.aboutCta{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
}

/* Panel del logo */
.aboutBrand{
  border-radius: var(--radius2);
  border: 1px solid var(--border);
  background:
    radial-gradient(900px 420px at 20% 20%, color-mix(in oklab, var(--accent), transparent 80%), transparent 60%),
    radial-gradient(900px 420px at 85% 10%, color-mix(in oklab, var(--accent2), transparent 84%), transparent 62%),
    linear-gradient(180deg, var(--card), color-mix(in oklab, var(--bg2), transparent 20%));
  box-shadow: var(--shadow);
  overflow: hidden;
  position: relative;
  min-height: 100%;
}

.aboutBrandInner{
  padding: 22px;
  display:grid;
  gap: 14px;
  align-content: start;
  position: relative;
}

.aboutBrandGlow{
  position:absolute;
  inset: -60px;
  background:
    radial-gradient(500px 260px at 30% 20%, color-mix(in oklab, var(--accent), transparent 70%), transparent 60%),
    radial-gradient(520px 280px at 70% 15%, color-mix(in oklab, var(--accent2), transparent 78%), transparent 62%);
  filter: blur(18px);
  opacity: .9;
  pointer-events: none;
}

.aboutLogo{
  width: min(320px, 78%);
  height: auto;
  margin: 6px auto 0;
  display:block;
  position: relative;
  z-index: 1;

  /* “pop” elegante */
  filter: drop-shadow(0 18px 35px rgba(0,0,0,.12));
}

.aboutBrandText{
  margin: 0;
  color: var(--muted);
  text-align: center;
  position: relative;
  z-index: 1;
}

.aboutBrandBadges{
  display:flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  position: relative;
  z-index: 1;
}

/* Responsive */
@media (max-width: 980px){
  .aboutLayout{ grid-template-columns: 1fr; }
  .aboutCards{ grid-template-columns: 1fr; }
  .aboutBrand{ order: -1; } /* logo arriba en mobile */
}

/* =========================
   SERVICIOS (FIX FINAL)
   ========================= */

/* Si tu sección NO está dentro de .container, esto la centra igual */
#servicios .servicesShell{
  width: min(1120px, 92%);
  margin-inline: auto;
}

/* Barra de filtros (buscador + chips) */
.servicesControls{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  padding:12px;
  border-radius: var(--radius2);
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--card), transparent 0%);
  box-shadow: 0 14px 35px rgba(11,18,32,.08);
}

.servicesControls .input{
  flex: 1 1 280px;
  max-width: 420px;
  height: 44px;
  padding: 10px 12px;
  border-radius: 14px;
}

.servicesControls .chips{
  flex: 999 1 auto;
  justify-content:flex-start; /* clave: que no se vaya a la esquina */
  gap:8px;
}

/* Chips un poquito más finos */
.chip{
  padding:8px 10px;
  font-size:.90rem;
}

/* Layout: cards + panel (panel con ancho estable) */
.servicesLayout{
  margin-top:14px;
  display:grid;
  grid-template-columns: 1fr 420px; /* panel fijo y elegante */
  gap:16px;
  align-items:start;
}

/* Grid de tarjetas */
.servicesCards{
  display:grid;
  grid-template-columns: repeat(2, minmax(260px, 1fr));
  gap:12px;
}

/* Tarjeta */
.sCard{
  border-radius: 20px;
  padding:12px 14px;
  align-items:center;
  box-shadow: 0 14px 35px rgba(11,18,32,.08);
}

.sIcon{
  width:44px;
  height:44px;
  border-radius:16px;
  flex: 0 0 44px;
}

.sTitle{
  font-size: 1rem;
}

.sSub{
  font-size: .90rem;
  line-height: 1.25;

  /* evita que unas tarjetas queden gigantes */
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* Panel derecho */
.servicePanel{
  border-radius: 24px;
  position: sticky;
  top: 96px;
  background: linear-gradient(180deg,
    var(--card),
    color-mix(in oklab, var(--bg2), transparent 35%)
  );
  box-shadow: 0 18px 55px rgba(11,18,32,.10);
}

.panelTitle{ font-size: 1.15rem; }

/* Responsive */
@media (max-width: 980px){
  .servicesLayout{
    grid-template-columns: 1fr;
  }
  .servicePanel{
    position: static;
    top:auto;
    order:-1; /* panel arriba en móvil */
  }
  .servicesCards{
    grid-template-columns: 1fr;
  }
}

/* ==========================================
   PACK: Separación + armonía entre secciones
   Pegar al final del styles.css
   ========================================== */

:root{
  --shadowSoft: 0 12px 32px rgba(11,18,32,.08);
  --shadowElev: 0 26px 80px rgba(11,18,32,.12);
  --divider: color-mix(in oklab, var(--border), transparent 35%);
  --sectionPad: 70px;
}

/* Ritmo vertical general */
.section{
  padding: var(--sectionPad) 0;
  position: relative;
  isolation: isolate; /* permite overlays suaves sin afectar otros */
}

/* Separación ENTRE secciones: línea + glow suave */
.section + .section::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height:1px;
  background: linear-gradient(90deg, transparent, var(--divider), transparent);
}

.section + .section::after{
  content:"";
  position:absolute;
  left:0; right:0; top:-1px;
  height:34px;
  pointer-events:none;
  background:
    radial-gradient(900px 40px at 20% 0%,
      color-mix(in oklab, var(--accent), transparent 88%),
      transparent 70%),
    radial-gradient(900px 40px at 80% 0%,
      color-mix(in oklab, var(--accent2), transparent 90%),
      transparent 70%);
  opacity:.9;
}

/* Fondo suave por sección (no invade las secciones que ya son alt) */
.section:not(.section--alt){
  background:
    radial-gradient(900px 260px at 10% 10%,
      color-mix(in oklab, var(--accent), transparent 92%), transparent 60%),
    radial-gradient(900px 260px at 90% 0%,
      color-mix(in oklab, var(--accent2), transparent 94%), transparent 60%);
}

/* Mejora tu sección alt para que se vea como “banda” */
.section--alt{
  background:
    radial-gradient(1000px 320px at 15% 15%,
      color-mix(in oklab, var(--accent), transparent 90%), transparent 60%),
    radial-gradient(1000px 320px at 85% 10%,
      color-mix(in oklab, var(--accent2), transparent 92%), transparent 62%),
    var(--bg2);
  border-block: 1px solid var(--border);
}

/* Títulos con acento (subrayado de marca) */
.section__head h2{
  position: relative;
  display: inline-block;
  padding-bottom: 8px;
}

.section__head h2::after{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  width: 84px;
  height: 4px;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  box-shadow: 0 10px 24px color-mix(in oklab, var(--accent), transparent 82%);
}

/* Hacer que los párrafos de introducción no se vean “perdidos” */
.section__head p{
  max-width: 78ch;
  line-height: 1.55;
}

/* Tarjetas: menos planas, más “premium” */
.card,
.pcard,
.tableWrap,
.accItem,
.gitem,
.sCard,
.servicePanel,
.aboutBrand{
  background:
    linear-gradient(180deg,
      color-mix(in oklab, var(--card), transparent 0%),
      color-mix(in oklab, var(--bg2), transparent 68%));
  box-shadow: var(--shadowSoft);
}

.card:hover,
.pcard:hover,
.accItem:hover,
.gitem:hover,
.sCard:hover{
  box-shadow: var(--shadowElev);
}

/* Listas: más elegantes */
.list li,
.panelBullets li,
.aboutList li,
.aboutSteps li{
  padding-left: 4px;
}

/* Anclas: que el header sticky no tape el título al navegar */
section[id]{ scroll-margin-top: 92px; }
