/*
Theme Name: Joyadise
Theme URI: https://joyadise.com
Author: Joyadise · José Félix Pérez Correa
Description: Tema cinematográfico de alto valor para la productora Joyadise. CPT Proyectos con pestañas, galerías privadas vía Google Drive (proxy), periódico de novedades, formulario de contacto y hero con cámaras 360 y grano de película.
Version: 1.0.0
Text Domain: joyadise
*/

:root{
  --carbon:#0A0908; --humo:#15110D;
  --oro:#C9A45C; --oro-claro:#E8CD96; --oro-dim:#8C7040;
  --marfil:#EFE9DD; --gris:#8B8579;
  --linea:rgba(201,164,92,.18);
  --ease:cubic-bezier(.22,1,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--carbon);color:var(--marfil);font-family:'Archivo',sans-serif;font-weight:300;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:var(--oro);color:var(--carbon)}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
.serif{font-family:'Italiana',serif;font-weight:400}

/* ---- Película: grano + viñeta + flicker ---- */
#grain{position:fixed;inset:0;z-index:90;pointer-events:none;opacity:.16;mix-blend-mode:overlay}
#vignette{position:fixed;inset:0;z-index:89;pointer-events:none;background:radial-gradient(ellipse at center, transparent 58%, rgba(0,0,0,.5) 100%)}
.flicker{animation:flick 5.2s steps(1) infinite}
@keyframes flick{0%,93%,100%{opacity:1}94%{opacity:.93}95%{opacity:1}97%{opacity:.96}}

/* ---- Nav ---- */
nav.joya{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:24px 5vw;mix-blend-mode:difference}
nav.joya .mark img{height:30px;width:auto;display:block}
nav.joya ul{display:flex;gap:40px;list-style:none}
nav.joya ul a{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:#fff;opacity:.75;transition:opacity .3s}
nav.joya ul a:hover{opacity:1}
@media(max-width:820px){nav.joya ul{display:none}}

/* ---- Hero ---- */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;text-align:center;padding:0 5vw;overflow:hidden;background:var(--carbon)}
.hero-cams{position:absolute;inset:0;z-index:0}
.hero-cams .cam{position:absolute;inset:-6%;background-position:center;background-size:cover;opacity:0;transform:scale(1.06) rotate(.001deg);transition:opacity 2.2s var(--ease);filter:brightness(.5) saturate(.9)}
.hero-cams .cam.on{opacity:.55;animation:orbit 14s linear forwards}
@keyframes orbit{
  0%{transform:scale(1.14) translateX(-3.5%) }
  100%{transform:scale(1.14) translateX(3.5%)}
}
.hero::after{content:'';position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse 75% 60% at 50% 50%, rgba(10,9,8,.25), rgba(10,9,8,.92) 78%)}
.hero-inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}
.hero-logo{width:min(860px,86vw);height:auto;filter:drop-shadow(0 8px 60px rgba(201,164,92,.22))}
.hero .tag{margin-top:5vh;font-size:12px;letter-spacing:.46em;text-transform:uppercase;color:var(--gris)}
.hero .tag b{color:var(--oro);font-weight:500}
.scroll-hint{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--gris);display:flex;flex-direction:column;align-items:center;gap:12px}
.scroll-hint::after{content:'';width:1px;height:42px;background:linear-gradient(to bottom,var(--oro),transparent);animation:drop 2.4s var(--ease) infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}55%{transform:scaleY(1);transform-origin:top}56%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---- Secciones ---- */
section{padding:13vh 5vw;position:relative}
.eyebrow{font-size:11px;letter-spacing:.42em;text-transform:uppercase;color:var(--oro);display:flex;align-items:center;gap:18px;margin-bottom:46px}
.eyebrow::after{content:'';height:1px;flex:0 0 64px;background:linear-gradient(to right,var(--oro),transparent)}
.center .eyebrow{justify-content:center}

/* Manifiesto */
.manifiesto{max-width:1100px;margin:0 auto}
.manifiesto .frase{font-family:'Italiana',serif;font-size:clamp(30px,4.4vw,58px);line-height:1.32}
.manifiesto .frase em{font-style:normal;color:var(--oro)}
.manifiesto .meta{display:flex;gap:8vw;margin-top:9vh;flex-wrap:wrap}
.manifiesto .meta div{max-width:300px}
.manifiesto .meta h4{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--oro);margin-bottom:14px;font-weight:500}
.manifiesto .meta p{font-size:15px;line-height:1.8;color:var(--gris)}

/* Proyectos */
.proyectos{background:var(--humo);border-top:1px solid var(--linea);border-bottom:1px solid var(--linea)}
.film{border-bottom:1px solid var(--linea);padding:6.5vh 0;display:grid;grid-template-columns:90px 1fr auto;gap:4vw;align-items:baseline;position:relative}
.film:first-of-type{border-top:1px solid var(--linea)}
.film .num{font-size:12px;letter-spacing:.3em;color:var(--gris);transition:color .4s}
.film h3{font-family:'Italiana',serif;font-size:clamp(32px,5.2vw,76px);letter-spacing:.04em;line-height:1.05;transition:transform .55s var(--ease),color .4s}
.film .dir{font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--gris);white-space:nowrap;transition:color .4s;text-align:right}
.film .estado{display:block;margin-top:8px;font-size:10px;letter-spacing:.22em;color:var(--oro-dim)}
.film:hover h3{transform:translateX(2.5vw);color:var(--oro-claro)}
.film:hover .num,.film:hover .dir{color:var(--oro)}
.film .desc{grid-column:2/4;font-size:15px;color:var(--gris);line-height:1.8;max-width:640px;max-height:0;overflow:hidden;opacity:0;transition:max-height .6s var(--ease),opacity .5s,margin .5s}
.film:hover .desc{max-height:160px;opacity:1;margin-top:18px}
.film.roadmap h3{color:var(--oro-dim)}
.film.roadmap:hover h3{color:var(--oro)}
.badge-2027{display:inline-block;margin-left:18px;padding:6px 14px;border:1px solid var(--oro);font-size:11px;letter-spacing:.3em;color:var(--oro);vertical-align:middle}
@media(max-width:760px){.film{grid-template-columns:1fr;gap:10px}.film .desc{grid-column:1}.film .dir{text-align:left}}

/* Galería home */
.galeria-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;max-width:1400px;margin:0 auto}
.gal-card{position:relative;border:1px solid var(--linea);background:var(--humo);overflow:hidden;aspect-ratio:4/3;cursor:pointer}
.gal-card img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease),filter .6s;filter:grayscale(.25) brightness(.85)}
.gal-card:hover img{transform:scale(1.05);filter:none}
.gal-card .gal-info{position:absolute;inset:auto 0 0 0;padding:22px;background:linear-gradient(to top,rgba(10,9,8,.92),transparent)}
.gal-card .gal-info small{display:block;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--oro)}
.gal-card .gal-info strong{font-family:'Italiana',serif;font-size:20px;font-weight:400;letter-spacing:.05em}
.gal-lock{position:absolute;top:18px;right:18px;font-size:10px;letter-spacing:.24em;color:var(--oro);border:1px solid var(--linea);padding:6px 12px;background:rgba(10,9,8,.55);backdrop-filter:blur(4px)}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(5,4,3,.94);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:90vw;max-height:84vh;border:1px solid var(--linea)}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:30px;color:var(--oro);background:none;border:none;cursor:pointer;padding:20px}
.lightbox .lb-prev{left:2vw}.lightbox .lb-next{right:2vw}
.lightbox .lb-close{position:absolute;top:24px;right:24px;font-size:22px;color:var(--marfil);background:none;border:1px solid var(--linea);width:48px;height:48px;cursor:pointer}
.lightbox img{-webkit-user-drag:none;user-select:none}

/* Periódico */
.periodico-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:30px;max-width:1400px;margin:0 auto}
.noticia{border:1px solid var(--linea);background:var(--humo);padding:36px;display:flex;flex-direction:column;gap:16px;transition:border-color .4s,transform .5s var(--ease)}
.noticia:hover{border-color:var(--oro);transform:translateY(-6px)}
.noticia time{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--oro)}
.noticia h3{font-family:'Italiana',serif;font-size:26px;font-weight:400;line-height:1.25;letter-spacing:.03em}
.noticia p{font-size:14px;line-height:1.8;color:var(--gris)}
.noticia .leer{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--oro);margin-top:auto}

/* CEO */
.ceo-grid{display:grid;grid-template-columns:1fr 1fr;gap:5vw;max-width:1280px;margin:0 auto;align-items:center}
@media(max-width:880px){.ceo-grid{grid-template-columns:1fr}}
.ceo-photo{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:3/4;background:var(--humo);border:1px solid var(--linea)}
.ceo-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s var(--ease),filter .8s}
.ceo-photo:hover img{transform:scale(1.04);filter:brightness(1.08)}
.ceo-photo .overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:34px;background:linear-gradient(to top,rgba(10,9,8,.85),transparent 45%)}
.ceo-photo .overlay span{font-size:11px;letter-spacing:.36em;text-transform:uppercase;color:var(--oro)}
.ceo-photo .overlay strong{font-family:'Italiana',serif;font-size:26px;font-weight:400;letter-spacing:.06em;margin-top:8px}
.ceo-photo .pulse{position:absolute;top:28px;right:28px;width:54px;height:54px;border:1px solid var(--oro);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--oro);animation:pulse 2.6s ease-in-out infinite;background:rgba(10,9,8,.4);backdrop-filter:blur(4px)}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(201,164,92,.35)}50%{box-shadow:0 0 0 14px rgba(201,164,92,0)}}
.ceo-copy h2{font-family:'Italiana',serif;font-size:clamp(40px,5vw,68px);line-height:1.1;letter-spacing:.04em;margin-bottom:28px}
.ceo-copy h2 span{color:var(--oro)}
.ceo-copy p{font-size:16px;line-height:1.9;color:var(--gris);max-width:480px;margin-bottom:22px}

/* Botones */
.btn{display:inline-flex;align-items:center;gap:16px;margin-top:14px;padding:18px 34px;border:1px solid var(--oro);color:var(--oro);font-size:12px;letter-spacing:.32em;text-transform:uppercase;background:transparent;cursor:pointer;font-family:'Archivo',sans-serif;position:relative;overflow:hidden;transition:color .45s var(--ease)}
.btn::before{content:'';position:absolute;inset:0;background:var(--oro);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.btn:hover::before{transform:scaleX(1)}
.btn:hover{color:var(--carbon)}
.btn span{position:relative;z-index:1}

/* Modal CEO */
.modal{position:fixed;inset:0;z-index:200;background:rgba(10,9,8,.55);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .5s var(--ease)}
.modal.open{opacity:1;pointer-events:auto}
.modal-card{width:min(1080px,92vw);max-height:88vh;overflow-y:auto;background:var(--humo);border:1px solid var(--linea);display:grid;grid-template-columns:42% 1fr;transform:translateY(38px);transition:transform .6s var(--ease)}
.modal.open .modal-card{transform:translateY(0)}
.modal-card .photo{position:relative;min-height:420px}
.modal-card .photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.modal-body{padding:clamp(32px,5vw,64px);position:relative}
.modal-body h3{font-family:'Italiana',serif;font-size:clamp(32px,3.6vw,48px);letter-spacing:.04em;line-height:1.12;margin-bottom:6px}
.modal-body .role{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--oro);margin-bottom:30px}
.modal-body p{font-size:15px;line-height:1.9;color:var(--gris);margin-bottom:18px}
.facts{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin:34px 0 8px;border-top:1px solid var(--linea);padding-top:30px}
.facts h5{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--oro);margin-bottom:8px;font-weight:500}
.facts p{font-size:14px;color:var(--marfil);margin:0}
.modal-close{position:absolute;top:22px;right:22px;width:44px;height:44px;border:1px solid var(--linea);background:transparent;color:var(--marfil);font-size:17px;cursor:pointer;transition:all .3s}
.modal-close:hover{border-color:var(--oro);color:var(--oro);transform:rotate(90deg)}
@media(max-width:760px){.modal-card{grid-template-columns:1fr}.modal-card .photo{min-height:320px}}

/* Contacto / formulario */
.contacto{text-align:center;padding-bottom:8vh}
.contacto h2{font-family:'Italiana',serif;font-size:clamp(44px,7vw,100px);letter-spacing:.06em;line-height:1.08;margin-bottom:6vh}
.contacto h2 span{color:var(--oro)}
.form-contacto{max-width:680px;margin:0 auto;text-align:left;display:grid;gap:22px}
.form-contacto .fila{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:640px){.form-contacto .fila{grid-template-columns:1fr}}
.form-contacto label{display:block;font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--oro);margin-bottom:10px}
.form-contacto input,.form-contacto textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--linea);color:var(--marfil);font-family:'Archivo',sans-serif;font-size:16px;padding:12px 2px;transition:border-color .3s}
.form-contacto input:focus,.form-contacto textarea:focus{outline:none;border-color:var(--oro)}
.form-contacto textarea{min-height:120px;resize:vertical}
.form-contacto .btn{justify-self:center;margin-top:10px}
.form-ok{border:1px solid var(--oro);color:var(--oro);padding:18px 26px;font-size:13px;letter-spacing:.14em;max-width:680px;margin:0 auto 34px}
.joya-hp{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}
.email-grande{display:inline-block;margin-top:7vh;font-family:'Italiana',serif;font-size:clamp(22px,3.4vw,40px);letter-spacing:.06em;border-bottom:1px solid var(--linea);padding-bottom:8px;transition:color .4s,border-color .4s}
.email-grande:hover{color:var(--oro);border-color:var(--oro)}

/* Footer */
footer.joya{border-top:1px solid var(--linea);padding:34px 5vw;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gris)}
footer.joya img{height:26px;width:auto}

/* ---- Single proyecto: pestañas ---- */
.proy-hero{min-height:62vh;display:flex;flex-direction:column;justify-content:flex-end;padding:18vh 5vw 7vh;position:relative;background:var(--humo);overflow:hidden}
.proy-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.3;filter:grayscale(.3)}
.proy-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--carbon),transparent 70%)}
.proy-hero h1{position:relative;z-index:2;font-family:'Italiana',serif;font-size:clamp(44px,8vw,110px);letter-spacing:.04em;line-height:1.04}
.proy-hero .ficha-mini{position:relative;z-index:2;margin-top:24px;display:flex;gap:34px;flex-wrap:wrap;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gris)}
.proy-hero .ficha-mini b{color:var(--oro);font-weight:500}
.tabs{display:flex;gap:0;border-bottom:1px solid var(--linea);margin:0 5vw}
.tab-btn{background:none;border:none;border-bottom:2px solid transparent;color:var(--gris);font-family:'Archivo',sans-serif;font-size:12px;letter-spacing:.34em;text-transform:uppercase;padding:24px 34px;cursor:pointer;transition:color .3s,border-color .3s}
.tab-btn.active{color:var(--oro);border-bottom-color:var(--oro)}
.tab-panel{display:none;padding:8vh 5vw;max-width:1280px;margin:0 auto}
.tab-panel.active{display:block;animation:fadeUp .7s var(--ease)}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.proy-info{display:grid;grid-template-columns:2fr 1fr;gap:6vw}
@media(max-width:880px){.proy-info{grid-template-columns:1fr}}
.proy-info .contenido{font-size:17px;line-height:2;color:var(--marfil)}
.proy-info .contenido p{margin-bottom:24px;color:var(--gris)}
.ficha{border:1px solid var(--linea);padding:36px;background:var(--humo);height:fit-content}
.ficha h4{font-family:'Italiana',serif;font-size:24px;font-weight:400;margin-bottom:26px;letter-spacing:.05em}
.ficha dl{display:grid;gap:18px}
.ficha dt{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--oro)}
.ficha dd{font-size:15px;color:var(--marfil);margin-top:4px}
.equipo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:26px;margin-bottom:9vh}
.miembro{border:1px solid var(--linea);background:var(--humo);text-align:center;padding-bottom:26px;transition:border-color .4s}
.miembro:hover{border-color:var(--oro)}
.miembro .foto{aspect-ratio:1/1;background:var(--carbon);overflow:hidden;margin-bottom:20px}
.miembro .foto img{width:100%;height:100%;object-fit:cover;filter:grayscale(.4);transition:filter .5s}
.miembro:hover .foto img{filter:none}
.miembro .foto .sin{display:flex;align-items:center;justify-content:center;height:100%;font-family:'Italiana',serif;font-size:54px;color:var(--oro-dim)}
.miembro strong{display:block;font-family:'Italiana',serif;font-size:20px;font-weight:400;letter-spacing:.04em}
.miembro span{display:block;margin-top:8px;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--oro)}

/* Single noticia / páginas */
.articulo{max-width:820px;margin:0 auto;padding:20vh 5vw 12vh}
.articulo h1{font-family:'Italiana',serif;font-size:clamp(38px,5.6vw,72px);line-height:1.12;letter-spacing:.03em;margin-bottom:20px}
.articulo time{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--oro)}
.articulo .cuerpo{margin-top:7vh;font-size:17px;line-height:2;color:var(--gris)}
.articulo .cuerpo p{margin-bottom:26px}
.articulo .cuerpo h2,.articulo .cuerpo h3{font-family:'Italiana',serif;color:var(--marfil);font-weight:400;margin:40px 0 18px}
.articulo .cuerpo img{border:1px solid var(--linea)}
.volver{display:inline-block;margin-bottom:5vh;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--oro)}

/* Reveals */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  #grain{display:none}
}
