*{box-sizing:border-box;margin:0;padding:0}
:root{
  --cream:#F7F2E8;
  --ink:#111;
  --pink:#FF2D8B;
  --blush:#F9C8D8;
  --warm:#EDE5D5;
  --gray:#999;
}
html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:'DM Mono', monospace;
  overflow-x:hidden;
  cursor:none;
}
/* CURSOR */
.cursor{position:fixed;width:10px;height:10px;background:var(--pink);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:multiply}
.cursor-trail{position:fixed;width:40px;height:40px;border:1.5px solid var(--ink);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all 0.18s ease}

/* GRAIN */
body::after{
  content:'';
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
  pointer-events:none;z-index:999;mix-blend-mode:overlay;
}

/* ══ NAV ══ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.5rem 3rem;
  mix-blend-mode:multiply;
}
.nav-brand{
  font-family:'Playfair Display',serif;
  font-style:italic;font-size:1rem;
  letter-spacing:0.04em;
}
.nav-links{display:flex;gap:2.5rem;align-items:center}
.nav-links a{
  font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase;
  text-decoration:none;color:var(--ink);transition:color 0.2s;
}
.nav-links a:hover{color:var(--pink)}
.nav-contact{
  border-bottom:1px solid var(--ink);padding-bottom:2px;
  transition:color 0.2s,border-color 0.2s;
}
.nav-contact:hover{color:var(--pink)!important;border-color:var(--pink)!important}

/* ══ HERO ══ */
.hero{
  min-height:100vh;
  display:grid;
  grid-template-rows:1fr auto;
  padding:0;
  position:relative;
  overflow:hidden;
}
.hero-bg-text{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-family:'Playfair Display',serif;
  font-size:28vw;
  font-weight:900;
  font-style:italic;
  color:transparent;
  -webkit-text-stroke:1px rgba(0,0,0,0.06);
  white-space:nowrap;
  user-select:none;
  pointer-events:none;
  line-height:1;
}
/* Florals */
.floral-hero-l{
  position:absolute;left:-60px;top:50%;
  transform:translateY(-55%) rotate(-8deg);
  width:340px;opacity:0.55;pointer-events:none;
  mix-blend-mode:multiply;
  filter:contrast(1.1);
}
.floral-hero-r{
  position:absolute;right:-50px;top:5%;
  transform:rotate(175deg);
  width:280px;opacity:0.5;pointer-events:none;
  mix-blend-mode:multiply;
  filter:contrast(1.1);
}
.floral-hero-center{
  position:absolute;right:5%;bottom:5%;
  width:200px;opacity:0.35;pointer-events:none;
  mix-blend-mode:multiply;
  filter:contrast(1.05) rotate(0deg);
  transform:rotate(15deg);
}
.hero-inner{
  align-self:end;
  padding:0 3rem 0;
  position:relative;z-index:2;
}
.hero-eyebrow{
  font-size:0.6rem;letter-spacing:0.25em;text-transform:uppercase;
  color:var(--pink);margin-bottom:1.2rem;
}
.hero-name{
  font-family:'Playfair Display',serif;
  font-weight:900;
  line-height:0.85;
  letter-spacing:-0.03em;
}
.hero-name .line1{
  font-size:clamp(3.5rem,9.5vw,9rem);
  display:block;color:var(--ink);
  letter-spacing:-0.04em;
}
.hero-name .line2{
  font-size:clamp(5rem,14vw,13rem);
  display:block;
  font-style:italic;
  color:var(--pink);
}
.hero-name .line3{
  font-size:clamp(5rem,14vw,13rem);
  display:block;
  -webkit-text-stroke:2px var(--ink);
  color:transparent;
}
.hero-bottom{
  display:flex;align-items:flex-end;justify-content:space-between;
  padding:1.5rem 3rem 3rem;
  position:relative;z-index:2;
}
.hero-desc{
  font-size:0.72rem;line-height:1.9;
  color:#666;max-width:340px;
}
.hero-counters{
  display:flex;gap:3rem;
}
.hero-counter .n{
  font-family:'Playfair Display',serif;
  font-size:3.5rem;font-weight:900;font-style:italic;
  line-height:1;display:block;
}
.hero-counter .l{
  font-size:0.55rem;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--gray);margin-top:0.2rem;display:block;
}

/* SCROLLING STRIP */
.strip{
  overflow:hidden;
  border-top:1px solid var(--ink);
  border-bottom:1px solid var(--ink);
  background:var(--pink);
  padding:0.55rem 0;
}
.strip-track{
  display:flex;white-space:nowrap;
  animation:scroll 18s linear infinite;
}
.strip-item{
  font-size:0.62rem;letter-spacing:0.2em;
  text-transform:uppercase;color:#fff;
  padding:0 2rem;
}
.strip-dot{color:rgba(255,255,255,0.4);margin-right:2rem}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══ ABOUT (antes de proyectos) ══ */
.about{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:90vh;
  position:relative;
  overflow:hidden;
}
.about-left{
  background:var(--ink);
  padding:5rem 3.5rem;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
}
.about-floral-bg{
  position:absolute;bottom:-30px;left:-10px;
  width:320px;opacity:0.18;
  filter:invert(1) contrast(1.2);
  mix-blend-mode:screen;
  pointer-events:none;
}
.about-section-num{
  font-size:0.58rem;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--pink);margin-bottom:1.5rem;
}
.about-left h2{
  font-family:'Playfair Display',serif;
  font-size:clamp(3.5rem,6vw,5.5rem);
  font-weight:900;line-height:0.88;
  color:var(--cream);margin-bottom:2rem;
}
.about-left h2 em{font-style:italic;color:var(--pink)}
.about-badge{
  display:inline-flex;align-items:center;gap:0.5rem;
  border:1px solid #333;padding:0.3rem 0.9rem;border-radius:2rem;
  font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;color:#777;
  width:fit-content;margin-bottom:3rem;
}
.about-badge::before{content:'';width:6px;height:6px;background:var(--pink);border-radius:50%}
.about-contact-block{margin-top:1.5rem}
.about-photo{
  display:block;
  width:75%;
  max-width:300px;
  margin: 2rem auto 0;
  object-fit:contain;
  filter:drop-shadow(0 20px 40px rgba(0,0,0,0.5));
  position:relative;
  z-index:2;
}
.about-contact-label{
  font-size:0.55rem;letter-spacing:0.18em;text-transform:uppercase;
  color:#555;margin-bottom:0.75rem;
}
.about-contact-item{
  font-size:0.75rem;color:var(--cream);
  margin-bottom:0.4rem;line-height:1.5;
}
.about-contact-item span{color:var(--pink)}
.about-right{
  background:var(--warm);
  padding:5rem 3.5rem;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
}
.about-right-decoration{
  position:absolute;top:-40px;right:-30px;
  font-family:'Playfair Display',serif;
  font-size:16rem;font-weight:900;font-style:italic;
  color:transparent;-webkit-text-stroke:1px rgba(0,0,0,0.05);
  line-height:1;user-select:none;pointer-events:none;
}
.about-text p{
  font-size:0.8rem;line-height:1.9;
  color:#555;margin-bottom:1.2rem;
  text-align:justify;
  position:relative;z-index:1;
}
.about-text p strong{color:var(--ink);font-weight:700}
.about-tags{
  display:flex;flex-wrap:wrap;gap:6px;
  margin-top:1.5rem;
}
.about-tag{
  padding:4px 11px;border:1px solid rgba(0,0,0,0.15);
  font-size:0.58rem;letter-spacing:0.1em;text-transform:uppercase;color:#888;
  transition:all 0.2s;
}
.about-tag:hover{background:var(--pink);border-color:var(--pink);color:#fff}

/* ══ PROJECTS ══ */
.projects-intro{
  padding:5rem 3rem 2.5rem;
  display:flex;align-items:flex-end;justify-content:space-between;
  border-top:1px solid rgba(0,0,0,0.1);
}
.projects-intro h2{
  font-family:'Playfair Display',serif;
  font-size:clamp(2.5rem,5vw,4.5rem);
  font-weight:900;line-height:0.88;
}
.projects-intro h2 em{font-style:italic;color:var(--pink)}
.projects-meta{font-size:0.6rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--gray)}

/* GRID */
.grid{
  padding:0 3rem 5rem;
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:12px;
}

/* BASE CARD */
.card{
  position:relative;overflow:hidden;
  cursor:none;background:#ddd;
}
.card img{
  width:100%;height:100%;object-fit:cover;
  display:block;
  transition:transform 0.8s cubic-bezier(0.25,0.46,0.45,0.94), filter 0.4s;
  filter:grayscale(15%) saturate(0.9);
}
.card:hover img{transform:scale(1.06);filter:grayscale(0%) saturate(1)}
.card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(160deg, transparent 40%, rgba(17,17,17,0.85));
  opacity:0;transition:opacity 0.4s;
}
.card:hover .card-overlay{opacity:1}
.card-meta{
  position:absolute;bottom:0;left:0;right:0;
  padding:1.5rem 1.75rem;
  transform:translateY(6px);
  transition:transform 0.35s ease;
}
.card:hover .card-meta{transform:translateY(0)}
.card-num-tag{
  font-size:0.55rem;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--blush);margin-bottom:0.3rem;
}
.card-name{
  font-family:'Playfair Display',serif;
  font-size:1.1rem;font-weight:700;
  color:#fff;line-height:1.2;
}
.card-desc{
  font-size:0.62rem;line-height:1.55;
  color:rgba(255,255,255,0.82);
  margin-top:0.55rem;max-width:92%;
  opacity:0;transform:translateY(6px);
  transition:opacity 0.4s ease 0.05s, transform 0.4s ease 0.05s;
}
.card:hover .card-desc{opacity:1;transform:translateY(0)}
.card-corner{
  position:absolute;top:1.25rem;right:1.25rem;
  width:30px;height:30px;
  border:1px solid rgba(255,255,255,0.35);
  display:flex;align-items:center;justify-content:center;
  font-size:0.8rem;color:white;
  opacity:0;transition:opacity 0.3s,transform 0.3s;
  transform:rotate(-45deg);
  backdrop-filter:blur(4px);
}
.card:hover .card-corner{opacity:1;transform:rotate(0deg)}
/* Pink accent bottom bar */
.card::after{
  content:'';position:absolute;bottom:0;left:0;
  width:0;height:3px;background:var(--pink);
  transition:width 0.5s ease;
}
.card:hover::after{width:100%}

/* SIZES */
.c7{grid-column:span 7;height:480px}
.c5{grid-column:span 5;height:480px}
.c8{grid-column:span 8;height:340px}
.c4{grid-column:span 4;height:340px}

/* WIDE CARD with side text */
.card-wide{
  grid-column:span 12;
  display:grid;
  grid-template-columns:1fr 1fr;
  background:var(--ink);
  height:300px;
}
.card-wide .cw-img{overflow:hidden}
.card-wide .cw-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.8s ease, filter 0.4s;
  filter:grayscale(20%);
}
.card-wide:hover .cw-img img{transform:scale(1.05);filter:grayscale(0%)}
.card-wide .cw-body{
  padding:2.5rem 3rem;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
}
.card-wide .cw-body::before{
  content:'03';
  position:absolute;right:1rem;bottom:-1rem;
  font-family:'Playfair Display',serif;
  font-size:8rem;font-weight:900;font-style:italic;
  color:rgba(255,255,255,0.04);line-height:1;
}
.cw-cat{
  font-size:0.58rem;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--pink);margin-bottom:0.5rem;
}
.cw-title{
  font-family:'Playfair Display',serif;
  font-size:1.6rem;font-weight:900;font-style:italic;
  color:var(--cream);line-height:1.1;margin-bottom:0.75rem;
}
.cw-desc{
  font-size:0.7rem;line-height:1.75;color:#888;
}

/* FLORAL BREAK */
.floral-break{
  padding:3rem 3rem;
  display:flex;align-items:center;gap:2rem;
  border-top:1px solid rgba(0,0,0,0.08);
}
.floral-break svg{opacity:0.13;flex-shrink:0}
.floral-break-line{flex:1;height:1px;background:rgba(0,0,0,0.1)}
.floral-break-text{
  font-family:'Playfair Display',serif;
  font-style:italic;font-size:0.85rem;
  color:var(--gray);white-space:nowrap;
}

/* ══ SKILLS ══ */
.skills{
  background:var(--warm);
  padding:5rem 3rem;
  display:grid;
  grid-template-columns:280px 1fr;
  gap:4rem;
  align-items:start;
  border-top:1px solid rgba(0,0,0,0.1);
}
.skills-left label{
  font-size:0.55rem;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--pink);display:block;margin-bottom:0.75rem;
}
.skills-left h3{
  font-family:'Playfair Display',serif;
  font-size:2.2rem;font-weight:900;line-height:1;margin-bottom:0.5rem;
}
.skills-left h3 em{font-style:italic;color:var(--pink)}
.skills-left p{font-size:0.7rem;color:var(--gray);line-height:1.7;margin-top:1rem}
.pills{display:flex;flex-wrap:wrap;gap:7px}
.pill{
  padding:7px 14px;
  border:1px solid rgba(0,0,0,0.18);
  font-size:0.62rem;letter-spacing:0.08em;text-transform:uppercase;
  color:#666;transition:all 0.2s;cursor:none;
}
.pill:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.pill.hot{background:var(--pink);border-color:var(--pink);color:#fff;font-weight:700}

/* ══ FOOTER ══ */
footer{
  background:var(--ink);
  color:var(--cream);
  padding:3.5rem 3rem;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:2rem;
  position:relative;overflow:hidden;
}
.footer-floral{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:280px;opacity:0.12;
  filter:invert(1) contrast(1.1);
  mix-blend-mode:screen;
  pointer-events:none;
}
.footer-left .fn{
  font-family:'Playfair Display',serif;
  font-size:1.1rem;font-style:italic;
  margin-bottom:0.3rem;
}
.footer-left .fs{font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;color:#666}
.footer-center{
  display:flex;flex-direction:column;align-items:center;gap:0.5rem;
}
.footer-links{display:flex;flex-direction:column;gap:6px;align-items:flex-end}
.fl{
  font-size:0.68rem;letter-spacing:0.06em;color:#888;
  text-decoration:none;transition:color 0.2s;
}
.fl:hover{color:var(--pink)}
.footer-year{
  font-family:'Playfair Display',serif;
  font-style:italic;font-size:0.7rem;color:#444;
  text-align:center;
}
.footer-pink-bar{
  position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--pink);
}

/* ══ VISOR DE PROYECTO (MODAL PDF) ══ */
/* las tarjetas se sienten clickeables */
[data-pdf]{cursor:none}
.pdf-modal{
  position:fixed;inset:0;z-index:1000;
  display:none;align-items:center;justify-content:center;
  padding:2.5rem;
}
.pdf-modal.open{display:flex}
.pdf-modal-backdrop{
  position:absolute;inset:0;
  background:rgba(17,17,17,0.82);
  backdrop-filter:blur(3px);
}
.pdf-modal-box{
  position:relative;z-index:1;
  width:100%;max-width:1100px;height:100%;
  background:var(--cream);
  display:flex;flex-direction:column;
  box-shadow:0 30px 80px rgba(0,0,0,0.5);
  animation:modalIn 0.35s cubic-bezier(0.16,1,0.3,1);
}
@keyframes modalIn{
  from{opacity:0;transform:translateY(20px) scale(0.98)}
  to{opacity:1;transform:none}
}
.pdf-modal-bar{
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;padding:1rem 1.5rem;
  background:var(--ink);color:var(--cream);
  flex-shrink:0;
}
.pdf-modal-title{
  font-family:'Playfair Display',serif;
  font-style:italic;font-size:1rem;
}
.pdf-modal-actions{display:flex;align-items:center;gap:1.25rem}
.pdf-modal-open{
  font-size:0.6rem;letter-spacing:0.15em;text-transform:uppercase;
  color:var(--blush);text-decoration:none;
  border-bottom:1px solid var(--blush);padding-bottom:2px;
  transition:color 0.2s,border-color 0.2s;white-space:nowrap;
}
.pdf-modal-open:hover{color:var(--pink);border-color:var(--pink)}
.pdf-modal-close{
  background:none;border:1px solid #444;color:var(--cream);
  width:30px;height:30px;border-radius:50%;
  font-size:0.8rem;cursor:pointer;line-height:1;flex-shrink:0;
  transition:all 0.2s;
}
.pdf-modal-close:hover{background:var(--pink);border-color:var(--pink)}
.pdf-modal-frame{
  flex:1;width:100%;border:0;background:#fff;
}
body.modal-open{overflow:hidden}

/* ══ COLLAGE dentro de About (columna negra) ══ */
.collage-stage{
  position:relative;
  width:100%;max-width:460px;
  margin:2.4rem auto 2.8rem;
}
/* foto en papel */
.collage-photo{
  position:relative;z-index:2;
  background:#fff;
  padding:12px 12px 18px;
  box-shadow:0 22px 45px rgba(0,0,0,0.45);
  transform:rotate(-3deg);
}
.collage-photo img{
  display:block;width:100%;height:680px;
  object-fit:cover;object-position:34% 38%;
  filter:grayscale(1) contrast(1.06);
}
/* clip rosa */
.collage-clip{
  position:absolute;z-index:4;
  top:-40px;left:50%;
  width:38px;height:auto;
  transform:translateX(-70%) rotate(7deg);
  filter:drop-shadow(0 4px 6px rgba(0,0,0,0.3));
}
/* trazos rosados: sobre negro van a color pleno (sin multiply) */
.collage-halftone{
  position:absolute;z-index:3;
  top:-8%;left:-18%;
  width:150%;height:130%;
  pointer-events:none;
}
@media(max-width:900px){
  .collage-photo img{height:300px}
}
