
/* Fuentes: Poppins MUY fina + resto */
@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@200;400;600&family=Marcellus&family=Space+Grotesk:wght@400;600&family=Inter:wght@400;600&display=swap");

:root{
  --nude-soft: #f8eeee;      /* fondo general */
  --nude-card: #fdf7f7;      /* tarjetas */
  --gold: #661414;           /* color vino principal */
  --gold-soft: #8a3a3a;      /* variante suave */
  --text: #661414;           /* color de texto principal */
  --muted: #9b6b6b;          /* texto secundario */
  --glass: rgba(255,255,255,0.80);
  --shadow-strong: 0 30px 70px rgba(40,20,20,0.16);
  --transition: 220ms cubic-bezier(.2,.9,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial;
  background:var(--nude-soft);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none}
.hidden{display:none!important}

/* ===== PORTADA (FULLSCREEN) ===== */
.cover{
  position:fixed;inset:0;
  background:
    radial-gradient(circle at 10% 18%, #f7dede 0, #f7dede 30%, transparent 58%),
    radial-gradient(circle at 80% 86%, #f3d1d1 0, #f3d1d1 28%, transparent 60%),
    radial-gradient(circle at 75% 12%, #fbe6e6 0, #fbe6e6 20%, transparent 55%),
    var(--nude-soft);
  display:flex;align-items:center;justify-content:center;
  padding:0;
}
/* Marca de agua con V gigante */
.cover::after{
  content:"V";
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  font-family:"Poppins", sans-serif; /* fina y elegante */
  font-weight:200;                   /* muy ligera */
  font-size:50vw;                    /* ocupa toda la pantalla */
  color:#661414;                     /* tu tono vino */
  opacity:0.06;                      /* translúcida */
  pointer-events:none;               /* no molesta */
  z-index:0;                         /* detrás de todo */
}


.cover-inner{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:56px;
  gap:40px;
  flex-direction:column;
  text-align:center;
  background:transparent;
}

.cover-top{
  font-size:.78rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--muted);
}

/* NOMBRE súper fino solo con Poppins */
.cover-name{
  font-family: "Poppins","Space Grotesk",system-ui,sans-serif;
  font-weight:200;                     /* muy fina */
  font-size:clamp(3rem,8vw,4.6rem);
  letter-spacing:.4em;                 /* mucho espaciado estilo retro */
  text-transform:uppercase;
  color:var(--gold);
  line-height:1.1;
  margin-top:18px;
}

.cover-sub{
  margin-top:14px;
  font-size:.95rem;
  letter-spacing:.12em;
  color:var(--muted);
  text-transform:uppercase;
}

.cover-desc{
  max-width:720px;
  margin-top:22px;
  font-size:1rem;
  line-height:1.8;
  color:var(--text);
  background:var(--glass);
  padding:14px 18px;
  border-radius:10px;
  backdrop-filter: blur(6px);
  box-shadow:var(--shadow-strong);
  border: 1px solid rgba(184,121,59,0.08);
}

.cover-cta{ margin-top:26px; }

/* Botón principal (Perfil) */
.btn{
  display:inline-block;
  padding:12px 42px;
  border-radius:999px;
  border:2px solid rgba(0,0,0,0.06);
  background:#fff;            /* SIEMPRE blanco */
  color:var(--gold);          /* Texto vino/dorado */
  text-transform:uppercase;
  letter-spacing:.18em;
  cursor:pointer;
  box-shadow:0 14px 40px rgba(14,12,11,.08);
  transition:transform var(--transition),
             box-shadow var(--transition);
  font-weight:600;
  position:relative;
  overflow:hidden;            /* Necesario para animar el texto */
}

.btn:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 60px rgba(14,12,11,.12);
}
.btn-slide{
  display:inline-block;
  position:relative;
  transition:transform 0.4s ease;
}

/* Animación suave arriba → abajo → centro */
.btn:hover .btn-slide{
  animation:floatText 0.5s ease forwards;
}

@keyframes floatText {
  0%   { transform:translateY(0); }
  40%  { transform:translateY(-60%); }  /* sube dentro del globo */
  70%  { transform:translateY(60%); }   /* baja dentro del globo */
  100% { transform:translateY(0); }     /* vuelve al centro */
}



.cover-footer{
  margin-top:12px;
  font-size:.8rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
}

/* ===== INTERIOR (PERFIL) ===== */
.app{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  background:var(--nude-soft);
}

.app-header{
  width:100%;
  background:#f4dede;
  border-bottom:1px solid rgba(0,0,0,0.04);
  padding:44px 56px;
}
.app-header-inner{
  max-width:100%;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.app-header-title{
  font-family:"Space Grotesk",sans-serif;
  font-size:1.15rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:600;
}
.app-header-sub{
  font-size:.95rem;
  letter-spacing:.8em;
  text-transform:uppercase;
  color:var(--muted);
}

.container{
  width:100%;
  padding:5px 30px;
  box-sizing:border-box;
}
@media(max-width:960px){
  .container{
    grid-template-columns:1fr;
    padding:20px;
  }
}
/* === Barra horizontal + Banner === */
.side-banner-bar{
  width:100%;
  display:flex;
  align-items:center;
  gap:20px;
  padding:0 56px;       /* alineado con el resto del layout */
  margin:0;             /* sin margen adicional */
  box-sizing:border-box;
}

/* Icono + */
.side-toggle{
  cursor:pointer;
}

.side-toggle-icon{
  font-family:"Poppins", sans-serif;
  font-weight:200;
  font-size:3.3rem;
  color:var(--gold);
  opacity:0.7;
  transition:transform 0.3s ease, opacity 0.3s ease;
}

.side-toggle-icon:hover{
  transform:rotate(90deg);
  opacity:1;
}

/* Banner de iconos */
/* === Barra con banner y menú === */
.top-strip{
  position:relative;
  width:100%;
  height:70px;               /* alto de la barra */
  padding:0 56px;
  box-sizing:border-box;
  margin-bottom:18px;
  overflow:hidden;
}

/* Banner de bombillas de fondo */
.top-strip .icon-strip{
  position:absolute;
  inset:0;
  background-repeat:repeat-x;
  background-size:auto 100%;
  background-position:0 50%;

  /* Fondo con muchas V repetidas (SVG incrustado en una sola línea) */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='80'%3E%3Ctext x='0' y='60' font-size='60' font-family='Poppins' font-weight='200' fill='rgba(102,20,20,0.08)'%3E  V     V     V     V     V     V  %3C/text%3E%3C/svg%3E");

  animation: scrollIcons 18s linear infinite;
}

/* Contenedor del + y el menú, encima del banner */
.top-nav{
  position:relative;
  z-index:2;                 /* por encima de las bombillas */
  height:100%;
  display:flex;
  align-items:center;
  gap:16px;
}

/* Botón + */
.top-toggle{
  background:transparent;
  border:0;
  padding:0;
  margin:0;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}

.top-toggle-icon{
  font-family:"Poppins", sans-serif;
  font-weight:200;
  font-size:2.4rem;
  color:var(--gold);
  opacity:0.6;
  line-height:1;
  transition:transform 0.3s ease, opacity 0.3s ease;
}

/* Hover en toda la barra del menú (icono + zona de texto) */
.top-nav:hover .top-toggle-icon{
  transform:rotate(90deg);
  opacity:1;
}

/* Panel con los enlaces, horizontal, encima del banner version escritorio */
.top-panel{
  display:flex;
  align-items:center;
  gap:22px;
  margin-left:8px;

  opacity:0;
  pointer-events:none;
  transform:translateX(-6px);
  transition:opacity 0.25s ease, transform 0.25s ease;
}

/* Cuando pasas el cursor por la barra, se muestra el menú (solo escritorio) */
.top-nav:hover .top-panel{
  opacity:1;
  pointer-events:auto;
  transform:translateX(0);
}
@media (max-width: 768px) {

  .top-strip {
    position: relative;
    padding: 8px 16px;
  }

  /* Botón visible en móvil */
  .top-toggle {
    position: relative;
    z-index: 1001;
    font-size: 1.8rem;
  }

  /* Panel oculto por defecto en móvil */
  .top-panel {
    position: fixed;
    inset: 0;              /* top:0; right:0; bottom:0; left:0; */
    background: #111;      /* color de fondo del menú */
    display: flex;
    flex-direction: column;
    padding: 80px 24px 24px;
    gap: 16px;

    transform: translateX(100%);
    opacity: 0;
    pointer-events: none;
    transition: transform 0.3s ease, opacity 0.3s ease;
    z-index: 1000;
    margin-left: 0;        /* ya no hace falta el margen horizontal */
  }

  /* Cuando está abierto (clase is-open desde JS) */
  .top-panel.is-open {
    transform: translateX(0);
    opacity: 1;
    pointer-events: auto;
  }

  /* Enlaces ocupan todo el ancho y son fáciles de pulsar */
  .side-item {
    display: block;
    padding: 12px 0;
    font-size: 1.1rem;
  }

  /* En móvil ya no dependemos del :hover para mostrar el panel */
  .top-nav:hover .top-panel{
    /* vacío para que no afecte en táctiles */
  }
}


/* Animación del banner (bombillas moviéndose a la derecha) */
@keyframes scrollIcons{
  0%   { background-position:0 50%; }
  100% { background-position:260px 50%; }
}


/* ==== SIDEBAR CON BOTÓN + Y PANEL DESPLEGABLE ==== */

/* ===== SIDEBAR: + a la izquierda, títulos en fila a la derecha ===== */

/* Celda de la barra lateral en el grid */
.side{
  position:absolute;
  left:56px;             /* donde empieza el contenido visual */
  top:50%;               /* centrado vertical en el banner */
  transform:translateY(-50%);
  display:flex;
  align-items:center;
  gap:16px;
  color:var(--muted);
}

/* Icono + */
.side-toggle{
  cursor:pointer;
}

.side-toggle-icon{
  font-family:"Poppins", sans-serif;
  font-weight:200;
  font-size:2.4rem;
  color:var(--gold);
  opacity:0.6;
  line-height:1;
  transition:transform .3s ease, opacity .3s ease;
}
.side:hover .side-toggle-icon{
  transform:rotate(90deg);
  opacity:1;
}

.side-panel{
  max-width:0;              /* cerrado por defecto */
  overflow:hidden;
  opacity:0;
  transform:translateX(-6px);
  transition:
    max-width .25s ease,
    opacity .25s ease,
    transform .25s ease;
}

/* Al pasar el ratón por el área del menú (+ y zona alrededor) */
.side:hover .side-panel{
  max-width:700px;          /* ancho máximo del menú; el resto del banner se sigue viendo */
  opacity:1;
  transform:translateX(0);
}

/* Lista de secciones en una sola fila */
.side-list{
  display:flex;
  align-items:center;
  gap:22px;
  white-space:nowrap;       /* todo en una sola línea */
}

/* Items del menú */
.side-item{
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--muted);
  background:transparent;
  padding:0;
}

.side-label{
  display:inline-block;
}

/* Animación de texto */
@keyframes sweepDown {
  0%   { transform: translateY(0); }
  50%  { transform: translateY(40%); }
  100% { transform: translateY(0); }
}

.side-item:hover .side-label{
  animation:sweepDown 0.25s ease-out;
  color:var(--gold);
}

/* Activo */
.side-item.active .side-label{
  color:var(--gold);
  font-weight:600;
}

/* Espaciador opcional bajo el menú, si lo quieres */
.side-return{
  margin-top:8px;
  height:10px; /* ajustable */
}


.side-item:hover .side-label{
  animation: sweepDown 260ms ease-out;
}

/* Item activo: sin globo, solo texto destacado + subrayado */
.side-item.active{
  color:var(--gold);
  font-weight:600;
  background:transparent;
  padding-left:6px;
}
.side-item.active::after{
  background:linear-gradient(90deg,var(--gold), var(--gold-soft));
  transform:scaleX(1);
}

/* ===== Content ===== */
.content{
  display:flex;
  flex-direction:column;
  gap:22px;
  margin-top:-25px;   /* añade este margen si quieres bajar un poco el bloque */
}

.card{
  background:var(--nude-card);
  padding:22px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,0.04);
  box-shadow: 0 18px 45px rgba(14,12,11,0.04);
}

.profile-top{
  display:flex;
  gap:30px;
  align-items:flex-start;
  padding-bottom:6px;
  border-bottom:1px solid rgba(0,0,0,0.04);
}

.profile-meta{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:flex-start;
}
@media(max-width:960px){
  .profile-meta{ align-items:center; text-align:center; }
}

.profile-name{
  font-family: "Poppins", sans-serif;
  font-weight:100;                    /* súper fino como la portada */
  font-size:clamp(2rem, 2vw, 2rem); /* tamaño elegante adaptable */
  letter-spacing:.6em;               /* similar al de portada */
  text-transform:uppercase;
  color:var(--gold);                  /* mismo color que en la portada */
  line-height:1.1;
}

.profile-role{
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.9rem;
}

.section-title{
  font-family:"Space Grotesk",sans-serif;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:var(--gold);
  margin-bottom:10px;
  font-size:.95rem;
}
.text{
  color:var(--text);
  line-height:1.85;
  font-size:1rem;
}

.pill-row{ display:flex; flex-wrap:wrap; gap:10px; margin-top:10px; }
.pill{
  background:#fff7f0;
  padding:8px 12px;
  border-radius:999px;
  color:var(--text);
  border:1px solid rgba(0,0,0,0.04);
  font-size:.9rem;
}
.pill.highlight{
  background:var(--gold);
  color:#fff;
  border-color:var(--gold);
}

/* Ya no ocultamos secciones con JS, así que .section es neutro */
.section{
  opacity:1;
  transform:none;
}

/* Foto solo en "Quién soy" */
.sobre-img{
  width:360px;
  max-width:42%;
  min-width:220px;
  align-self:flex-start;
  border-radius:12px;
  overflow:hidden;
  box-shadow: 0 20px 50px rgba(14,12,11,0.06);
}
.sobre-img img{
  width:100%;
  height:auto;
  display:block;
}
@media(max-width:960px){
  .section-top{ flex-direction:column; align-items:center; }
  .sobre-img{ width:70%; max-width:420px; }
}


.footer{
  padding:18px 56px;
  display:flex;
  justify-content:space-between;
  gap:10px;
  color:var(--muted);
  background:transparent;
}
@media(max-width:760px){
  .footer{ flex-direction:column; align-items:flex-start; }
}

.muted{ color:var(--muted); }
.u-uppercase{ text-transform:uppercase; letter-spacing:.12em; font-weight:600; font-size:.85rem; }

/* Botón volver a portada arriba a la derecha */
.back-floating{
  position:absolute;
  top:120px;       /* ajusta si quieres más arriba/abajo */
  right:60px;      /* alineado visualmente con padding general */
  color:var(--gold);
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:600;
  z-index:5;
}

.back-floating:hover{
  color:var(--gold-soft);
}
/* Destello radial al cargar la portada */
.cover::before{
  content:"";
  position:fixed;
  inset:0;
  background:radial-gradient(circle, white 0%, transparent 60%);
  opacity:0;
  pointer-events:none;
  animation:radialFlash 1s ease-out forwards;
}

@keyframes radialFlash {
  0%   { opacity:0.9; transform:scale(1); }
  80%  { opacity:0.3; transform:scale(2); }
  100% { opacity:0; transform:scale(3); }
}
@media (max-width: 768px) {
  .cover::after{
    font-size: 120vw;   /* Mucho más grande para móviles */
    opacity: 0.08;      /* Un pelín más visible (opcional) */
  }
}
@media (max-width: 768px) {
  .back-floating {
    position: static;          /* deja de estar flotando */
    display: block;
    text-align: right;
    margin: 8px 16px 0 16px;   /* pequeño margen interior */
    z-index: 1;                /* ya no necesita estar por encima de todo */
  }

  .container {
    padding-top: 8px;          /* un poco de aire debajo de la barra */
  }
}
