/* ------------------------------
   BASE
------------------------------ */
*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#0f0f0f;--text:#f5f5f5;--accent:#b4975a;--subtext:#cfcfcf}
@media (prefers-color-scheme:light){:root{--bg:#fafafa;--text:#111;--accent:#b4975a;--subtext:#444}}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;line-height:1.7;scroll-behavior:smooth;transition:background .4s,color .4s}

/* Skip link */
.skip-link{position:absolute;left:-9999px;top:auto}
.skip-link:focus{left:16px;top:16px;background:#000;color:#fff;padding:8px 12px;border-radius:6px;z-index:999}

/* ------------------------------
   HEADER / NAV
------------------------------ */
header{position:fixed;top:0;width:100%;background:rgba(15,15,15,.9);backdrop-filter:blur(10px);padding:16px 40px;z-index:10}
@media (prefers-color-scheme:light){header{background:rgba(255,255,255,.9)}}
nav{display:flex;align-items:center;justify-content:space-between;gap:20px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text)}
.logo-img{width:42px;height:auto;display:block;background:transparent;filter:none;transition:transform .3s}
@media (prefers-color-scheme:dark){.logo-img{filter:invert(1)}}
.logo:hover .logo-img{transform:scale(1.06)}
.logo-text{font-family:'Playfair Display',serif;font-weight:700;letter-spacing:2px;text-transform:uppercase}
.nav-links{list-style:none;display:flex;gap:24px}
.nav-links a{color:var(--text);text-decoration:none;transition:.3s;font-family:'Playfair Display',serif;text-transform:uppercase;letter-spacing:1px}
.nav-links a:hover{color:var(--accent)}
.lang-btn{border:1px solid var(--subtext);background:transparent;color:var(--text);padding:6px 10px;border-radius:999px;cursor:pointer;transition:.3s}
.lang-btn:hover{border-color:var(--text)}

/* ------------------------------
   HERO
------------------------------ */
.hero{height:100vh;background:url('hero.jpg') center 35%/cover no-repeat;display:flex;align-items:center;justify-content:center;text-align:center;position:relative}
.hero::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.45)}
.hero-text{position:relative;z-index:2}
.hero-text h2{font-size:clamp(1.8rem,4vw,2.8rem);letter-spacing:1px;font-family:'Playfair Display',serif;text-transform:uppercase}
.btn{display:inline-block;margin-top:16px;padding:10px 24px;background:var(--accent);color:#000;border-radius:28px;text-decoration:none;font-weight:600;transition:.3s;font-family:'Inter',sans-serif}
.btn:hover{transform:scale(1.04)}
.btn-ghost{background:transparent;border:1px solid var(--accent);color:var(--text);margin-left:10px}

/* ------------------------------
   QUOTE
------------------------------ */
.quote{padding:60px 10%;display:flex;justify-content:center;background:var(--bg)}
blockquote{text-align:center;font-style:italic;color:var(--subtext);font-size:clamp(1rem,2.3vw,1.4rem);max-width:700px;margin:auto;opacity:0;transform:translateY(20px);animation:fadeIn 1.2s ease-out .2s forwards;font-family:'Playfair Display',serif;letter-spacing:.5px}
.quote-text{font-style:italic;text-transform:none;color:var(--subtext)}
blockquote cite{display:block;margin-top:8px;color:var(--accent);font-style:normal;font-weight:600;letter-spacing:1px}
@keyframes fadeIn{to{opacity:1;transform:translateY(0)}}

/* ------------------------------
   SECTIONS
------------------------------ */
section{padding:80px 10%}
h2{font-family:'Playfair Display',serif;text-transform:uppercase;text-align:center;margin-bottom:28px;font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:700;letter-spacing:1px}

/* ------------------------------
   SHOWREEL (Video)
------------------------------ */
.video-container{max-width:1200px;margin:0 auto}
.video-wrapper{position:relative;width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden}
.video-wrapper iframe{position:absolute;inset:0;width:100%;height:100%}

/* ------------------------------
   PORTFOLIO (Galería)
------------------------------ */
.gallery{background:var(--bg)}
.grid{column-count:3;column-gap:15px;max-width:1200px;margin:0 auto}
@media (max-width:900px){.grid{column-count:2}}
@media (max-width:600px){.grid{column-count:1}}
.grid img{width:100%;margin-bottom:15px;border-radius:10px;display:block;transition:transform .3s,opacity .3s}
.grid img:hover{transform:scale(1.02);opacity:.95}

/* ------------------------------
   LIGHTBOX
------------------------------ */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.9);display:flex;justify-content:center;align-items:center;visibility:hidden;opacity:0;transition:.3s;z-index:100}
.lightbox.active{visibility:visible;opacity:1}
.lightbox img{max-width:90%;max-height:90%;border-radius:10px}
.lightbox-close{position:absolute;top:24px;right:36px;font-size:2rem;color:#fff;cursor:pointer}

/* ------------------------------
   CV (Currículum)
------------------------------ */
.cv{background:#141414;padding:100px 10%}
@media (prefers-color-scheme:light){.cv{background:#f7f7f7}}
.cv-header{text-align:left;margin-bottom:42px;color:var(--subtext);font-size:.95rem;font-family:'Inter',sans-serif}
.cv-header p{margin:6px 0}
.cv-header a{color:var(--accent);text-decoration:none}

.cv-table{max-width:900px;margin:0 auto}
.cv-table h3{border-bottom:2px solid var(--subtext);margin-top:36px;padding-bottom:6px;font-weight:600;font-family:'Playfair Display',serif;text-transform:uppercase;letter-spacing:.5px;color:var(--accent)}
.cv-row{display:grid;grid-template-columns:1.3fr .8fr 1.5fr;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.12);font-family:'Inter',sans-serif}
.cv-project{font-weight:500}
.cv-role{text-align:center}
.cv-info{text-align:right}
@media (prefers-color-scheme:light){.cv-row{border-bottom:1px solid rgba(0,0,0,.12)}}

.cv-download{text-align:center;margin-top:36px}

/* CTA floating */
.cta-fab{position:fixed;right:16px;bottom:16px;background:var(--accent);color:#000;padding:12px 16px;border-radius:999px;text-decoration:none;font-weight:600;box-shadow:0 8px 30px rgba(0,0,0,.25);z-index:50;font-family:'Inter',sans-serif}
@media(min-width:900px){.cta-fab{display:none}}

/* ------------------------------
   CONTACT / FOOTER
------------------------------ */
.contact{text-align:center;padding:80px 10%}
.contact a{color:var(--accent);text-decoration:none;font-weight:500;font-family:'Inter',sans-serif}
footer{text-align:center;padding:36px;color:var(--subtext);font-family:'Inter',sans-serif}

/* ------------------------------
   ACCESSIBILITY
------------------------------ */
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
a:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* ------------------------------
   RESPONSIVE
------------------------------ */
@media (max-width:768px){
  .nav-links{display:none}
  .cv-row{grid-template-columns:1fr}
  .cv-info,.cv-role{text-align:left}
}
