/* ═══════════════════════════════════════════
   JAEL TORRES PHOTOGRAPHY — MASTER STYLESHEET v2
═══════════════════════════════════════════ */
:root{
  --bg:#F6F2ED; --dark:#111009; --gold:#C4A882; --gold2:#9A7A56;
  --gold-lt:#E8DECE; --muted:#6B6158; --surface:#EDE8E0; --white:#FFFFFF;
  --serif:'Playfair Display',Georgia,serif; --sans:'Outfit',Arial,sans-serif;
  --max:1280px; --nav-h:76px; --ease:cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--dark);line-height:1.72;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}

/* LAYOUT */
.container{width:min(var(--max),calc(100% - 3rem));margin:0 auto}
.section{padding:6rem 0}
.section-dark{background:var(--dark);color:var(--white)}
.section-dark .display{color:var(--white)}
.section-dark .muted{color:rgba(246,242,237,.65)}
.center{text-align:center}
.mt-1{margin-top:.9rem}.mt-2{margin-top:1.8rem}.mt-3{margin-top:3rem}
.mb-1{margin-bottom:.9rem}.mb-2{margin-bottom:1.8rem}.mb-3{margin-bottom:3rem}

/* TYPOGRAPHY */
.eyebrow{font-size:.68rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:.9rem}
.display{font-family:var(--serif);font-size:clamp(2rem,4.2vw,4.2rem);line-height:1.04;font-weight:400}
.display em{font-style:italic;color:var(--gold)}
.kicker{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem}
.muted{color:var(--muted)}
.price{font-family:var(--serif);font-size:1.05rem;font-style:italic;color:var(--gold)}
.note{font-size:.8rem;color:var(--muted);margin-top:.8rem}

/* BUTTONS */
.btn-row{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.85rem 1.7rem;border-radius:999px;font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);border:1.5px solid transparent;cursor:pointer;white-space:nowrap}
.btn-dark{background:var(--dark);color:var(--white)}
.btn-dark:hover{background:var(--gold);color:var(--dark);border-color:var(--gold)}
.btn-outline{background:transparent;border-color:rgba(196,168,130,.55);color:var(--dark)}
.btn-outline:hover{background:var(--gold);border-color:var(--gold);color:var(--dark)}
.btn-light{background:transparent;border-color:rgba(255,255,255,.3);color:var(--white)}
.btn-light:hover{background:var(--gold);border-color:var(--gold);color:var(--dark)}
.btn-gold{background:var(--gold);color:var(--dark);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold2);color:var(--white);border-color:var(--gold2)}

/* BADGES */
.badge-row{display:flex;gap:.55rem;flex-wrap:wrap}
.badge{padding:.4rem .85rem;border:1px solid rgba(196,168,130,.35);border-radius:999px;font-size:.7rem;color:var(--gold);text-transform:uppercase;letter-spacing:.08em}

/* NAV */
.site-header{position:sticky;top:0;z-index:900;background:rgba(246,242,237,.95);backdrop-filter:blur(16px);border-bottom:1px solid rgba(196,168,130,.15)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;min-height:var(--nav-h)}
.logo{display:flex;align-items:center;flex-shrink:0}
.logo img{height:52px;width:auto;object-fit:contain;display:block}
.logo-text{font-family:var(--serif);font-size:1.15rem;letter-spacing:.06em;color:var(--dark)}
.logo-text span{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:1.4rem;list-style:none;padding:0}
.nav-links a{font-size:.73rem;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);font-weight:600;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--dark)}
.nav-cta{display:flex;gap:.75rem;align-items:center}
.menu-toggle{display:none;background:none;border:none;font-size:1.5rem;color:var(--dark);cursor:pointer;padding:.25rem}
.mobile-panel{display:none;padding:0 1.4rem 1.4rem;border-top:1px solid rgba(196,168,130,.15);background:rgba(246,242,237,.98)}
.mobile-panel.open{display:block}
.mobile-panel a{display:block;padding:.9rem 0;border-bottom:1px solid rgba(196,168,130,.12);font-size:.9rem;color:var(--dark)}

/* HERO */
.hero{padding:4rem 0 0}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.hero-copy p{max-width:580px;margin:1rem 0 0;color:var(--muted)}
.stats{display:flex;gap:2rem;flex-wrap:wrap;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--gold-lt)}
.stat strong{display:block;font-family:var(--serif);font-size:2rem;color:var(--dark);line-height:1}
.stat span{font-size:.68rem;letter-spacing:.09em;text-transform:uppercase;color:var(--muted)}
.hero-visual{display:grid;grid-template-rows:1fr auto;gap:6px;height:680px}
.hero-main{border-radius:18px;overflow:hidden;background:linear-gradient(155deg,#c8b49a,#6f5849);background-size:cover;background-position:center top;height:100%}
.hero-row{display:grid;grid-template-columns:1fr 1fr;gap:6px;height:200px}
.hero-small{border-radius:14px;overflow:hidden;background:linear-gradient(155deg,#b49f88,#745f52);background-size:cover;background-position:center;height:100%}
.hero-small:nth-child(2){background:linear-gradient(155deg,#a7907d,#635247)}

/* PAGE HERO */
.page-hero{padding:4.5rem 0 3rem}
.page-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}

/* ─────────────────────────────────────────
   IMAGE PROPORTIONS — FIXED
   All images use aspect-ratio so they never
   crop heads or feet. object-position:center top
   keeps faces in frame.
───────────────────────────────────────── */
.page-hero-visual,.media-card,.media-card.tall,.wide-media{
  overflow:hidden;border-radius:20px;
  background:linear-gradient(155deg,#c8b49a,#8a7060);
  background-size:cover;background-position:center top;
  position:relative;
}
.page-hero-visual{aspect-ratio:3/4}
.media-card{aspect-ratio:4/3;border-radius:18px}
.media-card.tall{aspect-ratio:3/4}
.wide-media{aspect-ratio:16/10;background-position:center}

.page-hero-visual img,.media-card img,.wide-media img{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  display:block;transition:transform .5s var(--ease);
}
.wide-media img{object-position:center}
.media-card:hover img,.wide-media:hover img{transform:scale(1.04)}

/* MARQUEE */
.split-band{background:var(--dark);padding:1.2rem 0;overflow:hidden}
.marquee{overflow:hidden}
.marquee-track{display:inline-flex;gap:3.5rem;white-space:nowrap;animation:marquee 22s linear infinite}
.marquee-track:hover{animation-play-state:paused}
.marquee-track span{font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(246,242,237,.5);flex-shrink:0}
.marquee-track span.g{color:var(--gold)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* TWO COL */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}

/* SERVICE CARDS */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem}
.service-card{background:var(--white);border-radius:22px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.07);transition:transform .3s var(--ease)}
.service-card:hover{transform:translateY(-4px)}
.service-copy{padding:1.5rem 1.8rem 2rem}
.service-copy h3{font-family:var(--serif);font-size:1.5rem;font-weight:400;margin-bottom:.4rem}
.service-copy p{color:var(--muted);font-size:.92rem}
.service-meta{margin-top:1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}

/* CARDS */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.card{background:var(--white);padding:2rem 1.8rem;border-radius:20px;box-shadow:0 8px 32px rgba(0,0,0,.07)}
.card h3{font-family:var(--serif);font-size:1.45rem;font-weight:400;margin-bottom:.5rem}
.card p{color:var(--muted);font-size:.92rem}

/* CHECK LIST */
.check-list{list-style:none;padding:0;display:grid;gap:.6rem}
.check-list li{position:relative;padding-left:1.4rem;font-size:.92rem}
.check-list li::before{content:'✓';position:absolute;left:0;color:var(--gold);font-weight:700}

/* SUBNAV */
.subnav{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.2rem}
.subnav a{font-size:.74rem;padding:.5rem .9rem;border:1px solid var(--gold-lt);border-radius:999px;color:var(--muted);transition:.2s}
.subnav a:hover{border-color:var(--gold);color:var(--dark)}

/* REVIEWS */
.review-grid{display:grid;gap:1rem}
.review{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);padding:1.8rem;border-radius:16px}
.review p{color:rgba(246,242,237,.7);font-size:.92rem}
.review strong{display:block;margin-top:.9rem;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}

/* FAQ */
.faqs{display:grid;gap:.8rem}
details{background:var(--white);padding:1.2rem 1.5rem;border-radius:14px;box-shadow:0 4px 16px rgba(0,0,0,.06)}
summary{cursor:pointer;font-weight:700;font-size:.95rem}
details p{margin-top:.7rem;color:var(--muted);font-size:.9rem}

/* FORMS */
.form-card{background:var(--white);padding:2.5rem;border-radius:22px;box-shadow:0 8px 32px rgba(0,0,0,.07)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group.full{grid-column:1/-1}
label{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
input,select,textarea{width:100%;padding:.85rem 1rem;border:1.5px solid var(--gold-lt);border-radius:10px;background:var(--bg);color:var(--dark);transition:border-color .2s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold)}
textarea{min-height:130px;resize:vertical;line-height:1.6}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23C4A882'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}

/* ─────────────────────────────────────────
   GALLERY TILES — FIXED PROPORTIONS
   4:5 portrait keeps faces in frame.
   Never crops heads or feet.
───────────────────────────────────────── */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.gallery-tile{
  position:relative;overflow:hidden;border-radius:12px;
  background:#d9d0c4;
  aspect-ratio:4/5; /* portrait — suits people photos */
}
.gallery-tile.large{
  grid-column:span 2;grid-row:span 2;
  aspect-ratio:4/5;border-radius:16px;
}
.gallery-tile img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center top; /* keeps faces in frame */
  display:block;transition:transform .5s var(--ease);cursor:pointer;
}
.gallery-tile:hover img{transform:scale(1.045)}
.tile-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.5),rgba(0,0,0,.1));
  color:#fff;display:flex;align-items:flex-end;
  padding:1rem 1.1rem;opacity:0;
  transition:opacity .3s var(--ease);
  font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
}
.gallery-tile:hover .tile-overlay{opacity:1}

/* ══════════════════════════════════════════
   PORTFOLIO — DYNAMIC MASONRY
══════════════════════════════════════════ */
.portfolio-masonry{
  columns:3;column-gap:10px;
}
.pm-item{
  break-inside:avoid;margin-bottom:10px;
  border-radius:14px;overflow:hidden;
  cursor:pointer;position:relative;background:#d9d0c4;
}
.pm-item img{
  width:100%;height:auto;display:block;
  transition:transform .5s var(--ease);
  object-fit:cover;border-radius:14px;
}
.pm-item:hover img{transform:scale(1.04)}
.pm-item .tile-overlay{
  border-radius:0 0 14px 14px;
  background:linear-gradient(to top,rgba(0,0,0,.55),transparent);
  opacity:0;
}
.pm-item:hover .tile-overlay{opacity:1}

/* Portfolio filter tabs */
.ptabs{
  display:flex;gap:0;
  border-bottom:1px solid rgba(196,168,130,.2);
  margin-bottom:2.5rem;
  overflow-x:auto;-webkit-overflow-scrolling:touch;
}
.ptab{
  font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);padding:.8rem 1.6rem;background:none;
  border:none;border-bottom:2.5px solid transparent;
  cursor:pointer;transition:.25s;white-space:nowrap;
}
.ptab.on{color:var(--dark);border-bottom-color:var(--gold)}
.ptab:hover{color:var(--dark)}

.port-intro{
  display:grid;grid-template-columns:1fr 1fr;
  gap:4rem;align-items:end;
  padding-bottom:3rem;border-bottom:1px solid var(--gold-lt);margin-bottom:3.5rem;
}

/* LIGHTBOX */
.lightbox{
  display:none;position:fixed;inset:0;
  background:rgba(10,10,10,.94);
  align-items:center;justify-content:center;
  z-index:9999;padding:2rem;
}
.lightbox.open{display:flex}
.lightbox img{
  max-width:90vw;max-height:88vh;
  object-fit:contain;border-radius:8px;
  box-shadow:0 24px 80px rgba(0,0,0,.5);
}
.lb-close{
  position:fixed;top:1.5rem;right:1.8rem;
  color:rgba(255,255,255,.7);font-size:2rem;cursor:pointer;
  z-index:10000;background:none;border:none;line-height:1;transition:color .2s;
}
.lb-close:hover{color:var(--gold)}
.lb-nav{
  position:fixed;top:50%;transform:translateY(-50%);
  color:rgba(255,255,255,.6);font-size:2.5rem;cursor:pointer;
  z-index:10000;background:none;border:none;padding:.5rem 1rem;transition:color .2s;
}
.lb-nav:hover{color:var(--gold)}
.lb-prev{left:1rem}.lb-next{right:1rem}
.lb-counter{
  position:fixed;bottom:1.8rem;left:50%;transform:translateX(-50%);
  font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.45);
}

/* FOOTER */
.footer{background:var(--dark);color:var(--white);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(196,168,130,.12)}
.footer .logo img{height:48px;filter:brightness(0) invert(1);opacity:.85}
.footer p{color:rgba(246,242,237,.45);font-size:.88rem;line-height:1.85;max-width:320px;margin-top:.8rem}
.footer small{display:block;margin-top:1.2rem;color:rgba(246,242,237,.28);font-size:.78rem}
.footer .eyebrow{color:var(--gold);margin-bottom:.9rem}
.footer a{color:rgba(246,242,237,.5);font-size:.88rem;line-height:2;transition:color .2s}
.footer a:hover{color:var(--gold)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.8rem;font-size:.75rem;color:rgba(246,242,237,.25)}
.footer-soc{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.2rem}
.footer-soc a{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(246,242,237,.35);border:1px solid rgba(196,168,130,.18);padding:.38rem .9rem;border-radius:999px;transition:.2s}
.footer-soc a:hover{color:var(--gold);border-color:rgba(196,168,130,.5)}

/* MOBILE FLOATING BAR */
#mob-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:800;background:rgba(17,16,9,.97);backdrop-filter:blur(8px);border-top:1px solid rgba(196,168,130,.18);padding:.8rem 1.2rem}
.mob-bar-inner{display:flex;gap:.7rem}
.mob-bar-inner a{flex:1;text-align:center;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.75rem .5rem;transition:.25s}

/* RESPONSIVE TABLET */
@media(max-width:1050px){
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{height:auto}
  .hero-main{aspect-ratio:16/9;height:auto}
  .hero-row{height:auto}
  .hero-small{aspect-ratio:16/9}
  .page-hero-grid,.two-col{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr 1fr}
  .services-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .gallery-tile.large{grid-column:span 2;grid-row:span 1;aspect-ratio:16/9}
  .portfolio-masonry{columns:2}
  .port-intro{grid-template-columns:1fr;gap:1.5rem}
}

/* RESPONSIVE MOBILE */
@media(max-width:700px){
  :root{--nav-h:64px}
  .nav-links,.nav-cta .btn{display:none}
  .menu-toggle{display:block}
  .logo img{height:42px}
  .section{padding:4.5rem 0}
  .hero{padding:2.5rem 0 0}
  .page-hero{padding:3rem 0 2rem}
  .cards{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr 1fr;gap:6px}
  .gallery-tile{aspect-ratio:1/1}
  .gallery-tile.large{grid-column:span 2;grid-row:span 1;aspect-ratio:4/3}
  .portfolio-masonry{columns:2;column-gap:6px}
  .portfolio-masonry .pm-item{margin-bottom:6px}
  .form-grid{grid-template-columns:1fr}
  .form-group.full{grid-column:span 1}
  .footer-grid{grid-template-columns:1fr}
  .two-col{gap:2rem}
  .tile-overlay{opacity:1;background:linear-gradient(to top,rgba(0,0,0,.4),transparent);font-size:.62rem;padding:.75rem}
  #mob-bar{display:block}
  footer{padding-bottom:5rem}
  .lb-nav{font-size:1.8rem;padding:.25rem .6rem}
  .lb-prev{left:.2rem}.lb-next{right:.2rem}
}
