/* Fonts */
@font-face{
  font-family: "Made Avenue";
  src: url("assets/fonts/MADEAvenuePERSONALUSE-Regular.otf") format("opentype");
  font-display: swap;
}

@font-face{
  font-family: "Montserrat";
  src: url("assets/fonts/Montserrat-VariableFont_wght.ttf") format("truetype");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face{
  font-family: "Montserrat";
  src: url("assets/fonts/Montserrat-Italic-VariableFont_wght.ttf") format("truetype");
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}

/* Base */
:root{
  --bg:#000;
  --fg:#fff;
  --muted: rgba(255,255,255,.72);
  --hairline: rgba(255,255,255,.12);
  --max: 980px;
  --topbar-h: 88px;
  --sidebar-w: 160px;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }

body{
  margin:0;
  background:var(--bg);
  color:var(--fg);
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Topbar (centrada en el eje del contenido, no en toda la pantalla) */
.topbar{
  position: sticky;
  top: 0;
  z-index: 20;
  height: var(--topbar-h);
  border-bottom: 1px solid var(--hairline);
  background: rgba(0,0,0,.78);
  backdrop-filter: blur(10px);
}

.topbar-inner{
  height: 100%;
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
}

.topbar-left{
  display:flex;
  align-items:center;
  justify-content: center;   /* ← centrado horizontal */
  padding: 0;               /* ← quitamos el sesgo */
}

.tilaka{
  width: 98px;
  height: 98px;
  border-radius: 999px;
}

.topbar-center{
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 0 18px;
}

/* El eje real del contenido: mismo max-width que las secciones */
.topbar-content{
  width: 100%;
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 28px;
  display: flex;
  justify-content: center;
}

/* Lockup: centrado dentro del ancho del contenido (max 980) */
.brand-lockup{
  display:flex;
  align-items: baseline;
  justify-content: center;
  gap: 16px;
  text-transform: uppercase;

  text-shadow:
    0 1px 0 rgba(255,255,255,.12),
    0 10px 22px rgba(0,0,0,.55);
}

/* ORAYA = Made Avenue */
.brand-oraya{
  font-family: "Made Avenue", "Montserrat", system-ui, sans-serif;
  font-size: 38px;
  letter-spacing: .06em;
  opacity: .98;

  /* Metal azul más profundo (acero pulido) */
  background: linear-gradient(
    180deg,
    #f4f9ff 0%,
    #b9d2e6 18%,
    #6f97b8 42%,
    #9fc2dd 62%,
    #e9f3fb 82%,
    #ffffff 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;

  /* Volumen y profundidad */
  text-shadow:
    0 1px 0 rgba(255,255,255,.25),
    0 2px 4px rgba(0,0,0,.45),
    0 6px 12px rgba(0,0,0,.55),
    0 18px 36px rgba(0,0,0,.75);

  /* Aura metálica muy sutil */
  filter: drop-shadow(0 0 12px rgba(110,160,200,.18));
}

/* SYNTHETICS = Montserrat semibold */
.brand-synth{
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 22px;
  letter-spacing: .18em;
  opacity: .92;

  background: linear-gradient(
    180deg,
    #fffaf0 0%,
    #f2ede4 35%,
    #d8d1c7 55%,
    #f6f0e6 78%,
    #ffffff 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;

  text-shadow:
    0 1px 0 rgba(255,255,255,.18),
    0 2px 4px rgba(0,0,0,.35),
    0 10px 20px rgba(0,0,0,.55);
}

/* Layout */
.layout{
  display:grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  min-height: calc(100vh - var(--topbar-h));
}

.sidebar{
  position: sticky;
  top: var(--topbar-h);
  height: calc(100vh - var(--topbar-h));
  padding: 24px 18px;
  border-right: 1px solid var(--hairline);
}

.navlink{
  display:block;
  padding: 10px;
  margin: 2px 0;
  color: var(--muted);
  text-decoration:none;
  border-radius: 10px;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: .02em;
}

.navlink:hover{
  color: var(--fg);
  background: rgba(255,255,255,.06);
}

.navlink.active{
  color: var(--fg);
  background: rgba(255,255,255,.08);
}

.navlink.disabled{
  opacity: .35;
  cursor: default;
  pointer-events: none;
}

/* Content */
.content{
  padding: 36px 28px 80px;
}

.section{
  max-width: var(--max);
  margin: 0 auto;
  padding: 32px 0;
  border-bottom: 1px solid var(--hairline);
}

.section.slim{
  border-bottom:none;
}

.media{
  margin-bottom: 18px;
}

.hero-video{
  width:100%;
  border-radius:14px;
  background:#000;
}

.copy{
  padding: 6px 2px;
}

/* Eslogan de marca */
.tagline{
  font-size: 36px;
  font-style: italic;
  font-weight: 400;
  text-align: center;

  margin: 36px auto 48px;
  max-width: var(--max);
  line-height: 1.25;
  letter-spacing: .015em;

  /* Metal cálido suave (inspirado en SYNTHETICS) */
  background: linear-gradient(
    180deg,
    #fffaf0 0%,
    #f2ede4 40%,
    #d8d1c7 60%,
    #f6f0e6 82%,
    #ffffff 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;

  /* Brillo editorial, muy contenido */
  text-shadow:
    0 2px 4px rgba(0,0,0,.35),
    0 10px 24px rgba(0,0,0,.55);
}

/* Títulos de sección */
.h2{
  font-size: 22px;
  font-weight: 500;
  margin-bottom: 10px;
}

.text{
  font-size:15.5px;
  line-height:1.7;
  color:var(--muted);
  margin-bottom:14px;
}

.text strong{
  font-weight: 600;
  color: var(--fg);
}

.inline-brand{
  color:var(--fg);
  font-weight:500;
}

.mailto{
  color:var(--fg);
  text-decoration:none;
  border-bottom:1px solid rgba(255,255,255,.25);
}

.mailto:hover{
  border-bottom-color: rgba(255,255,255,.55);
}

/* PersonS 2-column block */
/* PersonS block: texto izquierda + vídeo derecha + cierre a doble columna */
.persons-grid{
  display: grid;
  grid-template-columns: 1fr 360px; /* texto | vídeo */
  gap: 34px 46px;
  align-items: start;
}

/* contenedor del vídeo */
.persons-media{
  margin: 0;
  margin-top: 42px; /* alinea el vídeo con el primer párrafo */
}

/* vídeo */
.persons-video{
  width: 100%;
  max-width: 360px;
  border-radius: 14px;
  background: #000;
  display: block;
  margin-left: auto;  /* lo apoya a la derecha */
  opacity: .94;       /* un pelín más ligero */
}

/* cierre ocupando las dos columnas */
.persons-foot{
  grid-column: 1 / -1;
  margin-top: -18px;
}



/* Responsive */
@media (max-width: 920px){
  :root{
    --topbar-h: 72px;
    --sidebar-w: 72px;
  }

  .layout{ grid-template-columns: 1fr; }

  .topbar-inner{
    grid-template-columns: var(--sidebar-w) 1fr;
  }

  .tilaka{
    width: 60px;
    height: 60px;
  }

  .brand-oraya{ font-size: 20px; }
  .brand-synth{ font-size: 14px; }

  .sidebar{
    position: relative;
    top: 0;
    height: auto;
    border-right:none;
    border-bottom:1px solid var(--hairline);
    display:flex;
    gap:8px;
    overflow-x:auto;
  }

  .content{ padding: 22px 16px 60px; }

  .persons-grid{
    grid-template-columns: 1fr;
  }
}

/* ===== PersonS page additions ===== */

.persons-hero-grid{
  display:grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 28px;
  align-items:start;
}

.badge{
  display:inline-block;
  padding:6px 10px;
  border:1px solid rgba(255,255,255,0.15);
  border-radius:999px;
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  opacity:0.9;
  margin-bottom:10px;
}

.lead{
  font-size:1.05rem;
  opacity:0.92;
  margin-top:10px;
  margin-bottom:14px;
  max-width:56ch;
}

.bullets{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.bullets li{
  padding:6px 10px;
  border:1px solid rgba(255,255,255,0.10);
  border-radius:999px;
  font-size:0.95rem;
  opacity:0.9;
}

.floating-media{
  border-radius:18px;
  padding:18px;
  background:rgba(255,255,255,0.02);
  border:1px solid rgba(255,255,255,0.08);
  box-shadow: 0 12px 30px rgba(0,0,0,0.35);
}

/* PersonS logo floating */
.persons-logo-wrap{
  display:flex;
  justify-content:center;
  align-items:flex-start;
  padding-top: 8px; /* opcional: 0–12px según gusto */
}

.persons-logo{
  max-width:360px;
  width:100%;
  height:auto;
  background:none;
  border:none;
  box-shadow:none;
  filter: drop-shadow(0 18px 40px rgba(0,0,0,0.55));
}

.cards{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:16px;
  margin-top:14px;
}

.card{
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.02);
  border-radius:16px;
  padding:14px 14px 12px;
}

.h3{
  margin:0 0 6px 0;
  font-size:0.98rem;
  font-weight:600;
  letter-spacing:0.02em;
  text-transform:lowercase;
}

.muted{
  opacity:0.78;
}

.spec-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:14px;
  margin-top:14px;
}

.spec{
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.02);
  border-radius:16px;
  padding:14px;
}

.spec-k{
  font-size:0.85rem;
  opacity:0.7;
  text-transform:lowercase;
  margin-bottom:6px;
}

.spec-v{
  font-size:1rem;
  opacity:0.92;
  line-height:1.45;
}

.blueprint-wrap{
  margin-top:16px;
  border-radius:18px;
  overflow:hidden;
}

.blueprint-img{
  width:100%;
  height:auto;
  display:block;
  /* esto ayuda a integrar el borde degradado en fondo oscuro */
  background: #000;
}

.disclaimer .cta{
  margin-top:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.02);
  border-radius:18px;
  padding:16px;
}

.cta-title{
  font-weight:600;
}

.cta-sub{
  opacity:0.78;
  margin-top:4px;
  font-size:0.95rem;
}

/* responsive */
@media (max-width: 920px){
  .persons-hero-grid{ grid-template-columns: 1fr; }
  .cards{ grid-template-columns: 1fr; }
  .spec-grid{ grid-template-columns: 1fr; }
  .disclaimer .cta{ flex-direction:column; align-items:flex-start; }
}

/* Proceso: imagen + texto (ajuste) */

.process-layout{
  display:grid;
  grid-template-columns: 1.35fr 0.65fr; /* más grande la imagen */
  gap:32px;
  align-items:center; /* mejor que center para textos largos */
  margin-top:22px;
}

.process-text{
  font-size:0.95rem;
  line-height:1.65;
  opacity:0.88;
  margin-top: 0px;
}

.process-text p{
  max-width:48ch;      /* algo más estrecho */
  margin-top:0;
  margin-bottom:14px;
}

/* Continuación ocupando las dos columnas */
.process-full{
  grid-column: 1 / -1;
  font-size:0.95rem;
  line-height:1.65;
  opacity:0.88;
  margin: 6px 0 0;
}

@media (max-width: 920px){
  .process-layout{ grid-template-columns: 1fr; }
  .process-full{ grid-column:auto; }
}

/* Ajuste fino Ayuda: alinear texto con imagen */
#persons .section .process-layout .process-text{
  margin-top: 38px;
}

/* Contact form */
.contact-form{
  margin-top: 18px;
  max-width: 620px;
}

.field{
  display:block;
  margin: 14px 0;
}

.field-k{
  display:block;
  font-size: 0.85rem;
  opacity: 0.7;
  text-transform: lowercase;
  margin-bottom: 8px;
}

.field-i, .field-t{
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.02);
  color: rgba(255,255,255,0.92);
  outline: none;
}

.field-i:focus, .field-t:focus{
  border-color: rgba(255,255,255,0.22);
}

.hp{ display:none; }

/* Botón ORAYA – forzar estilo en Safari */
button.btn,
input[type="submit"].btn {
  -webkit-appearance: none;
  appearance: none;

  border: 1px solid rgba(255,255,255,0.14);
  background-color: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.92);

  padding: 10px 16px;
  border-radius: 14px;
  cursor: pointer;
  font: inherit;

  box-shadow: none;
  outline: none;

  transition:
    border-color 160ms ease,
    background-color 160ms ease,
    transform 120ms ease;
}

button.btn:hover,
input[type="submit"].btn:hover {
  border-color: rgba(255,255,255,0.22);
  background-color: rgba(255,255,255,0.06);
}

button.btn:active,
input[type="submit"].btn:active {
  transform: translateY(1px);
}

button.btn:focus-visible,
input[type="submit"].btn:focus-visible {
  outline: 1px solid rgba(255,255,255,0.28);
  outline-offset: 2px;
}

/* ORAYA — Núcleo relacional: 2 columnas (chip izq + cards en columna dcha) */
.nucleo-2col{
  display:grid;
  grid-template-columns: minmax(240px, 280px) minmax(0, 1fr);
  gap: 34px 46px;
  align-items:start;
  margin-top: 18px;
}

.nucleo-chipwrap{
  margin: 0;
  margin-top: 0px; /* alinea con la primera card */
}

.nucleo-chip{
  width:100%;
  max-width: 280px;
  height:auto;
  border-radius: 14px; /* opcional, por si tu chip lo admite */
  opacity: .95;
  filter: drop-shadow(0 22px 50px rgba(0,0,0,.7));
}

.nucleo-cards{
  display:flex;
  flex-direction:column;
  gap:16px;
  margin-top: 32px;
}

/* ORAYA — Núcleo relacional: solo apilar en móvil real */
@media (max-width: 760px){
  .nucleo-2col{
    grid-template-columns: 1fr;
  }
  .nucleo-chip{
    max-width: 420px;
  }
}

/* ORAYA — Corporalidad sintética: texto izquierda + imagen derecha (más contenida) */
.process-layout.process-invert{
  align-items: start;
}

.process-layout.process-invert .process-media{
  display:flex;
  justify-content:flex-end;
}

.blueprint-img.blueprint-small{
  width: 100%;
  max-width: 280px;   /* “muchísimo” más contenida */
  height: auto;
  opacity: .90;
  filter: drop-shadow(0 18px 44px rgba(0,0,0,.65));
}

/* ORAYA — Corporalidad sintética: bajar bloque completo de texto */
.process-layout.process-invert .process-text{
  margin-top: 56px;
}

.process-layout.process-invert .process-text p{
  margin-bottom: 28px;
}

.process-layout.process-invert .process-text p:last-child{
  margin-bottom: 0;
}

/* ===== ORAYA: ajuste fino del logo respecto al texto ===== */
#oraya .persons-hero-grid{
  align-items: center;          /* referencia clara: logo centrado contra el bloque de texto */
}

#oraya .persons-logo-wrap{
  padding-top: 0;               /* anulamos el padding general si molesta */
  margin-top: 50px;             /* sube/baja aquí en px hasta clavarlo (p.ej. 12–30) */
}

/* Bloque legal – Protección de Datos */
.legal-block{
  margin-top: 28px;
  padding-top: 18px;
  border-top: 1px solid var(--hairline);

  font-size: 13px;          /* más pequeño que .text */
  line-height: 1.55;
  color: rgba(255,255,255,.62);
}

.legal-block p{
  margin-bottom: 10px;
}

.legal-block strong{
  font-weight: 500;
  color: rgba(255,255,255,.78);
}

/* ===== Language switcher (Topbar) ===== */

.topbar-content{
  position: relative; /* permite posicionar el selector sin afectar al centrado */
}

.lang-switch{
  position: absolute;
  right: 28px;              /* coincide con el padding de topbar-content */
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  gap: 10px;

  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.70);
}

.lang-switch a{
  color: rgba(255,255,255,.70);
  text-decoration: none;
  padding: 6px 8px;
  border-radius: 999px;
  border: 1px solid transparent;
}

.lang-switch a:hover{
  color: rgba(255,255,255,.92);
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.10);
}

.lang-switch a.active{
  color: rgba(255,255,255,.96);
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.14);
}

/* Ajuste móvil: que no invada el lockup */
@media (max-width: 920px){
  .lang-switch{
    right: 10px;
    font-size: 11px;
    letter-spacing: .10em;
    gap: 8px;
  }
  .lang-switch a{
    padding: 5px 7px;
  }
}
