:root{
  --azul:#0B1F3A;
  --verde:#7BAE3F;
  --musgo:#5A6B47;
  --ocre:#C98A2E;
  --mostaza:#D9A441;
  --crema:#F9F6EF;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--crema);
  color:var(--azul);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Fraunces',serif;font-weight:600;line-height:1.1}
a{color:inherit;text-decoration:none}

/* ROTATE OVERLAY */
#rotate-overlay{
  position:fixed;inset:0;background:var(--azul);z-index:9999;
  display:none;align-items:center;justify-content:center;flex-direction:column;
  color:var(--crema);text-align:center;padding:40px;gap:24px;
}
#rotate-overlay svg{width:80px;height:80px;stroke:var(--mostaza);fill:none;stroke-width:1.5;animation:rotatePhone 2s ease-in-out infinite}
@keyframes rotatePhone{0%,100%{transform:rotate(0deg)}50%{transform:rotate(90deg)}}
#rotate-overlay h2{font-size:28px;color:var(--mostaza)}
#rotate-overlay p{opacity:.8;max-width:320px}
@media (orientation:portrait){
  #rotate-overlay{display:flex}
  body{overflow:hidden}
}

/* SIDEBAR */
nav.sidebar{
  position:fixed;left:0;top:0;bottom:0;width:80px;
  background:rgba(11,31,58,.92);
  backdrop-filter:blur(16px) saturate(1.2);
  -webkit-backdrop-filter:blur(16px) saturate(1.2);
  border-right:1px solid rgba(217,164,65,.15);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;
  z-index:1000;
}
nav.sidebar .logo{
  position:absolute;top:24px;width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--ocre),var(--mostaza));
  display:grid;place-items:center;font-family:'Fraunces';font-weight:700;color:var(--azul);font-size:18px;
}
nav.sidebar a{
  width:48px;height:48px;display:grid;place-items:center;border-radius:14px;
  color:var(--crema);opacity:.7;transition:all .3s cubic-bezier(.2,.8,.2,1);position:relative;
}
nav.sidebar a svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
nav.sidebar a:hover{opacity:1;background:rgba(249,246,239,.08);transform:translateX(2px)}
nav.sidebar a.active{opacity:1;color:var(--mostaza);background:rgba(217,164,65,.14);box-shadow:inset 0 0 0 1px rgba(217,164,65,.35)}
nav.sidebar a.active::after{content:'';position:absolute;left:-16px;top:50%;transform:translateY(-50%);width:3px;height:24px;background:var(--mostaza);border-radius:2px}

main{margin-left:80px;width:calc(100% - 80px)}

/* INICIO */
#inicio{height:100vh;position:relative;overflow:hidden;background:var(--azul)}
.slider{height:100%;display:flex;transition:transform .9s cubic-bezier(.77,0,.175,1)}
.slide{min-width:100%;height:100%;position:relative;display:grid;place-items:center;color:var(--crema);overflow:hidden}
.slide-bg{position:absolute;inset:0;z-index:0}
.slide-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 30%,rgba(11,31,58,.4) 100%)}

/* CONTENIDO BASE */
.slide-content{
  position:relative;
  z-index:2;
  padding:0 8vw;
  max-width:1200px;
  width:100%;
  display:flex;
  align-items:center;
  gap:clamp(40px,6vw,80px);
}

/* TEXTOS */
.slide-text{flex:1}
.slide-content h1{
  font-size:clamp(48px,7vw,96px);
  font-weight:700;
  letter-spacing:-.02em;
  margin-bottom:16px;
  line-height:.95;
}
.slide-content .subtitle{
  font-size:clamp(16px,1.8vw,22px);
  opacity:.85;
  font-weight:300;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.slide-content h2{
  font-size:clamp(38px,6vw,84px);
  font-weight:400;
  line-height:1.15;
  max-width:900px;
  margin:0 auto;
}
.slide-content h2 em{font-style:italic;color:var(--mostaza)}
.slide-content .meta{margin-top:24px;font-size:15px;opacity:.7;letter-spacing:.1em;text-transform:uppercase}

/* IMAGEN */
.slide-media{
  flex:0 0 44%;
  max-width:540px;
}
.slide-media img{
  width:100%;
  height:auto;
  display:block;
  border-radius:16px;
  box-shadow:0 24px 60px rgba(0,0,0,.35);
}

/* LAYOUTS */
.slide.layout-left .slide-content{flex-direction:row;text-align:left}
.slide.layout-right .slide-content{flex-direction:row-reverse;text-align:left}

/* SIN IMAGEN - CENTRADO (tu estilo original) */
.slide.layout-center .slide-content{
  display:block;
  text-align:center;
  max-width:1100px;
}
.slide.layout-center .slide-content h1{
  font-size:clamp(56px,9vw,120px);
}
.slide.layout-center .slide-text{
  margin:0 auto;
}

/* DOTS */
.slide-dots{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;gap:12px;z-index:3}
.dot{width:32px;height:3px;background:rgba(249,246,239,.3);border-radius:2px;cursor:pointer;transition:.4s}
.dot.active{background:var(--mostaza);width:48px}

/* RESPONSIVE */
@media (max-width:900px){
  .slide-content,
  .slide.layout-left .slide-content,
  .slide.layout-right .slide-content{
    flex-direction:column !important;
    text-align:center !important;
    gap:32px;
  }
  .slide-media{flex:none;width:100%;max-width:380px}
  .slide-content h1{font-size:clamp(40px,10vw,64px)}
}

/* ===== QUIEN SOY - versión texto primero ===== */
#quien.quien-text-first {
  padding: 72px 0;
  background: #fff;
  position: relative;
}

/* container centrado */
#quien.quien-text-first .container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
}

/* 1. Avatar estático arriba */
.quien-galeria-secundaria {
  position: sticky;
  top: 100px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: stretch;
}

/* foto estática exactamente del mismo ancho que la galería */
.foto-estatica {
  width: 100%;
  max-width: 280px;
  aspect-ratio: 4/5;
  border-radius: 12px;
  overflow: hidden;
  background: #F9F6EF;
  border: 1px solid #E8DCC8;
}
.foto-estatica img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.foto-estatica.placeholder {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  color: #8A7B65;
  font-size: 13px;
  font-weight: 600;
}
.avatar-static {
  width: 96px;
  height: 96px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid #F9F6EF;
}
.avatar-static.placeholder {
  display: grid;
  place-items: center;
  background: #F9F6EF;
  color: #8A7B65;
  font-size: 12px;
  font-weight: 600;
}

/* 2. Layout principal */
.quien-layout {
  display: grid;
  grid-template-columns: 1.7fr 0.8fr;
  gap: 56px;
  align-items: start;
}
.quien-texto h2 {
  font-family: 'Fraunces', serif;
  font-size: clamp(28px, 3.5vw, 40px);
  color: #0B1F3A;
  margin: 0 0 20px;
  line-height: 1.2;
}
.texto-body {
  font-size: 17px;
  line-height: 1.75;
  color: #333;
  max-width: 65ch;
}
.texto-body p { margin: 0 0 1.1em; }

/* 3. Galería secundaria compacta */
.quien-galeria-secundaria {
  position: sticky;
  top: 100px;
}
.mini-carousel,
.mini-unica {
  aspect-ratio: 1/1;
  width: 100%;
  max-width: 280px;
  border-radius: 12px;
  overflow: hidden;
  background: #F9F6EF;
  border: 1px solid #E8DCC8;
}
.mini-carousel img,
.mini-unica img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .92;
  transition: opacity .3s;
}
.mini-carousel:hover img { opacity: 1; }

.carousel-track {
  position: relative;
  width: 100%;
  height: 100%;
}
.carousel-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .4s ease;
}
.carousel-slide.is-active { opacity: 1; }

.mini-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-top: 8px;
  max-width: 280px;
}
.mini-nav button {
  background: none;
  border: 1px solid #E8DCC8;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  cursor: pointer;
  color: #5A6B47;
  font-size: 16px;
  line-height: 1;
}
.mini-nav button:hover { background: #F9F6EF; }
.mini-dots { display: flex; gap: 5px; }
.mini-dots button {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  border: none;
  background: #D9D0BE;
  padding: 0;
  cursor: pointer;
  transition: .2s;
}
.mini-dots button.is-active {
  background: #D9A441;
  width: 18px;
  border-radius: 3px;
}
.galeria-nota {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #8A7B65;
  margin-top: 8px;
  text-align: center;
  max-width: 280px;
}

/* Responsive */
@media (max-width: 900px) {
  #quien.quien-text-first { padding: 56px 0; }
  .quien-layout {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .quien-galeria-secundaria {
    position: static;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .mini-carousel,
  .mini-unica,
  .mini-nav,
  .galeria-nota {
    max-width: 340px;
    width: 100%;
  }
}

/* PORTAFOLIO */
#portafolio{min-height:100vh;padding:8vh 0 6vh;background:linear-gradient(to bottom,var(--crema) 0%,#f0ebe0 100%);position:relative}
.portafolio-head{padding:0 5vw 3vh;max-width:1400px;margin:0 auto}
.portafolio-head h2{font-size:clamp(36px,4.5vw,64px);margin-bottom:16px}
.pills{display:flex;gap:10px;flex-wrap:wrap}
.pill{padding:9px 20px;border-radius:999px;font-size:14px;font-weight:500;letter-spacing:.01em;border:1px solid rgba(11,31,58,.15);background:transparent;color:var(--azul);cursor:pointer;transition:all .25s;white-space:nowrap}
.pill:hover{border-color:var(--mostaza);background:rgba(217,164,65,.08)}
.pill.active{background:var(--azul);color:var(--crema);border-color:var(--azul);box-shadow:0 4px 12px rgba(11,31,58,.15)}
.carousel-wrap{position:relative;padding:0 5vw}
.carousel{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;gap:2.5vw;padding:2vh 0 4vh;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}
.carousel::-webkit-scrollbar{height:8px}
.carousel::-webkit-scrollbar-track{background:rgba(11,31,58,.06);border-radius:4px;margin:0 5vw}
.carousel::-webkit-scrollbar-thumb{background:var(--mostaza);border-radius:4px}
.obra{min-width:84%;max-width:1100px;scroll-snap-align:center;display:flex;flex-direction:row;height:65vh;background:#fff;border-radius:28px;overflow:hidden;box-shadow:0 24px 60px rgba(11,31,58,.12);border:1px solid rgba(11,31,58,.06);flex-shrink:0}
.obra-visual{flex:0 0 60%;position:relative;background:var(--azul);overflow:hidden}
.art-bg{position:absolute;inset:0}
.art-noise{position:absolute;inset:0;opacity:.15;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.art-circle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:38%;aspect-ratio:1;border-radius:50%;border:2px solid rgba(249,246,239,.7);box-shadow:0 0 0 12px rgba(249,246,239,.08),0 0 0 24px rgba(249,246,239,.04),inset 0 0 40px rgba(0,0,0,.15)}
.art-circle::before,.art-circle::after{content:'';position:absolute;border-radius:50%;border:1px solid rgba(249,246,239,.4)}
.art-circle::before{inset:-18%;} .art-circle::after{inset:-36%;}
.obra-info{flex:0 0 40%;padding:4vh 3vw;display:flex;flex-direction:column;justify-content:center;min-width:0}
.obra-tag{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--mostaza);font-weight:600;margin-bottom:12px}
.obra-info h3{font-size:clamp(28px,3vw,44px);margin-bottom:10px;color:var(--azul)}
.obra-info .tecnica{font-size:14px;color:var(--musgo);margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid rgba(11,31,58,.1);font-weight:500}
.obra-info .desc{font-size:15px;line-height:1.7;color:rgba(11,31,58,.8)}
.carousel-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.95);border:1px solid rgba(11,31,58,.1);display:grid;place-items:center;cursor:pointer;z-index:5;box-shadow:0 8px 20px rgba(11,31,58,.15);transition:.2s;color:var(--azul)}
.carousel-nav:hover{background:var(--azul);color:var(--crema)}
.carousel-nav.prev{left:1.5vw} .carousel-nav.next{right:1.5vw}
.carousel-nav svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2}
.obra-visual{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:16px;background:#0B1F3A}
.obra-visual img{width:100%;height:100%;object-fit:cover;display:block}
.obra-visual.art-bg{position:absolute;inset:0}
/* Contenedor del carrusel */
.carousel-wrap{position:relative}
.carousel{
  display:flex;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  gap:30px;
  padding:20px 8vw;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.carousel::-webkit-scrollbar{display:none}
.obra{flex:0 0 100%;scroll-snap-align:start;max-width:720px}

/* Visual con fondo para resaltar */
.obra-visual{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  border-radius:20px;
  background:#0B1F3A;
  display:grid;
  place-items:center;
  padding:24px; /* ← espacio para el fondo */
  cursor:zoom-in;
}
.obra-visual .art-bg{position:absolute;inset:0;z-index:0}
.obra-visual .art-noise{position:absolute;inset:0;z-index:1;opacity:.15;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E")}
.obra-visual img{
  position:relative;
  z-index:2;
  max-width:88%;
  max-height:88%;
  width:auto;
  height:auto;
  object-fit:contain;
  border-radius:12px;
  box-shadow:0 12px 32px rgba(0,0,0,.35);
  transition:transform .3s;
}
.obra-visual:hover img{transform:scale(1.02)}
.obra-visual .art-circle{
  position:absolute;
  width:60%;
  height:60%;
  border:2px solid rgba(249,246,239,.2);
  border-radius:50%;
  z-index:1;
  pointer-events:none;
}
.obra-general .obra-visual{
  padding:32px;
  background:var(--azul);
}
.obra-general .obra-info h3{
  font-size:clamp(28px,3.5vw,44px);
  color:var(--mostaza);
}
.obra-general .obra-tag{
  background:var(--mostaza);
  color:var(--azul);
  padding:4px 10px;
  border-radius:20px;
  font-weight:600;
  font-size:11px;
  letter-spacing:.1em;
}

/* Info */
.obra-info{padding:20px 8px 0}

/* CONTACTO */
#contacto{min-height:75vh;display:flex;align-items:center;background:var(--azul);color:var(--crema);position:relative;overflow:hidden}
#contacto::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,var(--mostaza) 0%,transparent 70%);opacity:.12;top:-200px;right:-200px}
.contacto-wrap{width:100%;max-width:1100px;margin:0 auto;padding:0 5vw;display:flex;flex-direction:row;gap:6vw;align-items:center}
.contacto-info{flex:0 0 55%}
.contacto-info h2{font-size:clamp(36px,4.5vw,64px);color:var(--crema);margin-bottom:20px}
.contacto-info p{font-size:17px;line-height:1.7;opacity:.85;margin-bottom:28px;max-width:480px}
.contacto-links{display:flex;flex-direction:column;gap:14px}
.contacto-link{display:flex;align-items:center;gap:14px;font-size:16px;transition:.2s}
.contacto-link:hover{color:var(--mostaza);transform:translateX(4px)}
.contacto-link svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.75}
.contacto-cta{flex:0 0 45%;background:linear-gradient(135deg,rgba(249,246,239,.08),rgba(249,246,239,.03));border:1px solid rgba(249,246,239,.12);border-radius:24px;padding:40px;backdrop-filter:blur(10px)}
.contacto-cta h3{font-family:'Fraunces';font-size:24px;margin-bottom:12px;color:var(--mostaza)}
.contacto-cta p{opacity:.8;font-size:14px;line-height:1.6}

/* RESPONSIVE HORIZONTAL */
@media (max-height:600px){
  .obra{height:70vh}
  .quien-wrap{padding:0 4vw}
  .foto-circular{width:240px}
}
/* ===== FORMULARIO CONTACTO - Susana Larraín ===== */
.sl-form{
  display:grid;
  gap:22px;
  max-width:520px;
  margin-top:28px;
}
.sl-field{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.sl-field label{
  font-family:'Fraunces',serif;
  font-size:15px;
  letter-spacing:.02em;
  color:var(--crema);
  opacity:.9;
}
.sl-form input,
.sl-form textarea{
  width:100%;
  padding:14px 18px;
  background:rgba(249,246,239,.06);
  border:1px solid rgba(249,246,239,.18);
  border-radius:14px;
  color:var(--crema);
  font-family:'Inter',sans-serif;
  font-size:15px;
  line-height:1.5;
  transition:.25s ease;
  backdrop-filter:blur(4px);
}
.sl-form input::placeholder,
.sl-form textarea::placeholder{
  color:rgba(249,246,239,.45);
}
.sl-form input:focus,
.sl-form textarea:focus{
  outline:none;
  border-color:var(--mostaza);
  background:rgba(249,246,239,.1);
  box-shadow:0 0 0 3px rgba(217,164,65,.18);
}
.sl-form textarea{
  resize:vertical;
  min-height:110px;
}
.sl-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:var(--mostaza);
  color:var(--azul);
  padding:14px 28px;
  border-radius:999px;
  font-weight:500;
  font-size:15px;
  border:none;
  cursor:pointer;
  transition:.25s ease;
  justify-self:start;
  margin-top:4px;
}
.sl-btn:hover{
  background:var(--ocre);
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(0,0,0,.25);
}
.sl-btn:active{transform:translateY(0)}

/* En móvil horizontal se mantiene lado a lado */
@media (max-width:900px){
  .sl-form{gap:18px}
  .sl-form input,.sl-form textarea{padding:12px 16px}
}