/* ===== FONTS ===== */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600;1,700&family=Inter:wght@300;400;500;600&display=swap');

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
img,video{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font:inherit}
ul,ol{list-style:none}

/* ===== VARIABLES ===== */
:root{
  --bg: #f5f0e8;
  --fg: #1a2744;
  --ink: #4a6fa5;
  --bone: #ece5d5;
  --blush: #c4917a;
  --muted: #7a8ba0;
  --border: rgba(74,111,165,.2);
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-sans: 'Inter', system-ui, sans-serif;
  --max-w: 1400px;
  --px: 24px;
  --header-h: 72px;
}

/* ===== BASE ===== */
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--font-sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--ink);color:var(--bg)}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:300;letter-spacing:-0.02em;word-break:break-word;overflow-wrap:break-word}

/* ===== HEADER ===== */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:40;
  backdrop-filter:blur(14px);
  background:rgba(245,240,232,.75);
  border-bottom:1px solid var(--border);
}
.header-inner{
  max-width:var(--max-w);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px var(--px);
}
.header-logo img{height:36px;width:auto}
.header-nav{display:flex;gap:40px;align-items:center}
.header-nav a{
  font-size:11px;text-transform:uppercase;letter-spacing:.3em;
  color:rgba(26,39,68,.65);transition:color .3s;
}
.header-nav a:hover,.header-nav a.active{color:var(--fg)}
.header-nav .nav-num{margin-right:8px;color:var(--ink);opacity:.5}
.menu-btn{
  display:none;font-size:11px;text-transform:uppercase;letter-spacing:.3em;color:var(--fg);
}

/* ===== MOBILE MENU ===== */
.mobile-menu{
  position:fixed;inset:0;z-index:50;background:var(--bg);
  display:none;flex-direction:column;
}
.mobile-menu.open{display:flex}
.mobile-menu-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px var(--px);border-bottom:1px solid var(--border);
}
.mobile-menu-header img{height:36px}
.mobile-menu-close{font-size:11px;text-transform:uppercase;letter-spacing:.3em}
.mobile-menu nav{display:flex;flex-direction:column;gap:24px;padding:40px var(--px)}
.mobile-menu nav a{
  font-family:var(--font-display);font-size:2.5rem;font-style:italic;color:var(--ink);
}
.mobile-menu nav .mob-num{
  font-size:14px;font-style:normal;color:var(--muted);margin-right:12px;
}

/* ===== SIDE RAIL ===== */
.side-rail{
  position:fixed;left:16px;top:0;z-index:30;height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  padding:24px 0;pointer-events:none;
}
.side-rail span{
  writing-mode:vertical-rl;transform:rotate(180deg);
  font-size:10px;text-transform:uppercase;letter-spacing:.4em;color:var(--muted);
}

/* ===== MAIN ===== */
main{padding-top:var(--header-h)}

/* ===== CONTAINER ===== */
.container{max-width:var(--max-w);margin:0 auto;padding-left:var(--px);padding-right:var(--px)}

/* ===== HERO ===== */
.hero{padding-top:40px;padding-bottom:96px}
.hero-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px;align-items:end}
.hero-text{grid-column:span 12}
.hero-img-wrap{grid-column:span 12;position:relative}
.hero-section-label{
  font-size:10px;text-transform:uppercase;letter-spacing:.4em;color:var(--muted);margin-bottom:24px;
}
.hero h1{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(3.5rem,11vw,11rem);line-height:.9;color:var(--fg);
}
.hero h1 .italic{font-style:italic;color:var(--ink)}
.hero-img-container{position:relative;overflow:hidden}
.hero-img-container img{
  width:100%;height:60vh;object-fit:cover;
  animation:slowZoom 18s ease-in-out infinite alternate;
}
.hero-img-label{display:none}
.hero-desc{margin-top:64px;display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.hero-desc-text{grid-column:span 12}
.hero-desc p{font-size:1.1rem;line-height:1.8;color:rgba(26,39,68,.8);max-width:440px}
.hero-desc em{font-family:var(--font-display);color:var(--ink);font-style:italic}
.cta-link{
  display:inline-flex;align-items:center;gap:12px;margin-top:32px;
  font-size:11px;text-transform:uppercase;letter-spacing:.3em;color:var(--ink);
}

/* ===== HOVER UNDERLINE ===== */
.hover-underline{
  background-image:linear-gradient(currentColor,currentColor);
  background-size:0% 1px;background-repeat:no-repeat;background-position:0 100%;
  transition:background-size .5s ease;
}
.hover-underline:hover{background-size:100% 1px}

/* ===== MARQUEE ===== */
.marquee-section{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:24px 0;overflow:hidden}
.marquee-track{display:flex;animation:marquee 40s linear infinite;white-space:nowrap}
.marquee-track span{
  font-family:var(--font-display);font-style:italic;font-size:clamp(1.8rem,5vw,3.2rem);
  color:rgba(74,111,165,.8);display:flex;align-items:center;gap:48px;padding-right:48px;
}
.marquee-dot{color:rgba(26,39,68,.2)}

/* ===== PORTFOLIO CAROUSEL (HOME) ===== */
.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px}
.section-label{font-size:10px;text-transform:uppercase;letter-spacing:.4em;color:var(--muted);margin-bottom:16px}
.section-title{font-family:var(--font-display);font-size:clamp(2.5rem,7vw,4.5rem);font-weight:300}
.section-title .italic{font-style:italic;color:var(--ink)}

/* Mobile: horizontal snap-scroll carousel */
.portfolio-carousel{
  display:flex;gap:12px;
  overflow-x:auto;overflow-y:hidden;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding-bottom:8px;
}
.portfolio-carousel::-webkit-scrollbar{display:none}

.portfolio-card{
  position:relative;overflow:hidden;cursor:pointer;
  flex:0 0 85vw;aspect-ratio:3/4;
  scroll-snap-align:center;
  border-radius:4px;
}
.portfolio-card img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform 1.5s ease;
}
.portfolio-card:hover img{transform:scale(1.05)}
.portfolio-card .overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(74,111,165,.7),rgba(74,111,165,.1),transparent);
  opacity:.8;transition:opacity .4s;
}
.portfolio-card:hover .overlay{opacity:1}
.portfolio-card .card-content{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-between;padding:24px;
}
.portfolio-card .card-num{font-family:var(--font-display);font-style:italic;font-size:1.2rem;color:rgba(245,240,232,.9)}
.portfolio-card .card-title{font-family:var(--font-display);font-size:clamp(1.5rem,4vw,2.5rem);color:var(--bg)}
.portfolio-card .card-blurb{font-size:14px;color:rgba(245,240,232,.8);max-width:280px;margin-top:4px}

/* Carousel dots */
.carousel-dots{
  display:flex;justify-content:center;gap:8px;margin-top:16px;
}
.carousel-dots .dot{
  width:8px;height:8px;border-radius:50%;background:var(--border);
  border:none;cursor:pointer;padding:0;transition:all .3s;
}
.carousel-dots .dot.active{background:var(--ink);transform:scale(1.3)}

/* ===== QUOTE ===== */
.quote-section{max-width:1100px;margin:0 auto;padding:48px var(--px);text-align:center}
.quote-section p.quote{
  font-family:var(--font-display);font-style:italic;
  font-size:clamp(1.5rem,5vw,3.2rem);line-height:1.3;color:rgba(26,39,68,.9);
}
.quote-section .quote .highlight{color:var(--ink)}
.quote-section .quote-author{
  margin-top:32px;font-size:11px;text-transform:uppercase;letter-spacing:.4em;color:var(--muted);
}

/* ===== ABOUT PAGE ===== */
.about-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:32px;align-items:start}
.about-img-col{grid-column:span 12}
.about-img-col img{width:100%;aspect-ratio:3/4;object-fit:cover}
.about-name{margin-top:24px;font-family:var(--font-display);font-size:2rem;font-style:italic;color:var(--ink)}
.about-role{font-size:11px;text-transform:uppercase;letter-spacing:.3em;color:var(--muted);margin-top:4px}
.about-text-col{grid-column:span 12}
.about-text-col h1{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2.5rem,7vw,5rem);line-height:.95;margin-bottom:48px;
}
.about-text-col h1 .italic{font-style:italic;color:var(--ink)}
.about-body{display:flex;flex-direction:column;gap:24px;max-width:640px}
.about-body p{font-size:1.1rem;line-height:1.8;color:rgba(26,39,68,.85)}
.about-body em{font-family:var(--font-display);color:var(--ink);font-style:italic}
.about-body .year{font-family:var(--font-display);font-style:italic;color:var(--ink);font-size:1.5rem}
.about-stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:32px;
  border-top:1px solid var(--border);padding-top:40px;margin-top:64px;
}
.about-stats .stat-val{font-family:var(--font-display);font-style:italic;font-size:2rem;color:var(--ink)}
.about-stats .stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.3em;color:var(--muted);margin-top:8px}

/* ===== PORTFOLIO LIST PAGE ===== */
.portfolio-list{padding-top:64px;padding-bottom:64px}
.portfolio-list-item{
  display:block;position:relative;border-top:1px solid var(--border);padding:32px 0;
  transition:background .3s;
}
.portfolio-list-item:last-child{border-bottom:1px solid var(--border)}
.portfolio-list-item:hover{background:rgba(74,111,165,.03)}
.pli-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px;align-items:center}
.pli-num{grid-column:span 2;font-family:var(--font-display);font-style:italic;font-size:1.5rem;color:var(--ink)}
.pli-name{
  grid-column:span 10;font-family:var(--font-display);font-size:clamp(2rem,6vw,3.5rem);font-weight:300;
  transition:transform .7s;
}
.portfolio-list-item:hover .pli-name{transform:translateX(12px)}
.pli-blurb{display:none;grid-column:span 4;font-size:14px;color:var(--muted)}
.pli-action{display:none;grid-column:span 2;text-align:right;font-size:11px;text-transform:uppercase;letter-spacing:.3em;color:rgba(26,39,68,.5)}
.portfolio-list-item:hover .pli-action{color:var(--ink)}

/* ===== CATEGORY PAGE ===== */
.cat-hero{position:relative;height:80vh;min-height:500px;overflow:hidden}
.cat-hero img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  animation:slowZoom 18s ease-in-out infinite alternate;
}
.cat-hero .cat-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent,transparent 50%,var(--bg));
}
.cat-hero .cat-hero-content{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:24px var(--px);
}
.cat-hero .cat-hero-num{font-family:var(--font-display);font-style:italic;font-size:1.5rem;color:rgba(245,240,232,.9)}
.cat-hero .cat-hero-title{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(3.5rem,12vw,11rem);line-height:.9;color:var(--bg);
}
.cat-blurb{
  font-family:var(--font-display);font-style:italic;font-size:clamp(1.3rem,3vw,1.8rem);
  color:var(--ink);max-width:640px;margin-bottom:48px;
}
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.gallery-item{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:3/4;border-radius:4px}
.gallery-item img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s ease;
}
.gallery-item:hover img{transform:scale(1.05)}

/* Override old span classes — all uniform now */
.gi-wide,.gi-tall,.gi-square,.gi-half{grid-column:span 1;aspect-ratio:3/4}

.cat-nav{
  margin-top:96px;display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid var(--border);padding-top:40px;
}
.cat-nav-back{font-size:11px;text-transform:uppercase;letter-spacing:.3em}
.cat-nav-next{text-align:right}
.cat-nav-next .label{font-size:11px;text-transform:uppercase;letter-spacing:.3em;color:var(--muted)}
.cat-nav-next .name{
  font-family:var(--font-display);font-style:italic;font-size:clamp(1.5rem,4vw,2.5rem);
  color:var(--ink);margin-top:4px;transition:transform .3s;
}
.cat-nav-next:hover .name{transform:translateX(8px)}

/* ===== CONTACT PAGE ===== */
.contact-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:40px}
.contact-left{grid-column:span 12;min-width:0}
.contact-left h1{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2.2rem,8vw,8rem);line-height:.95;
}
.contact-left h1 .italic{display:block;font-style:italic;color:var(--ink)}
.contact-left .contact-desc{margin-top:40px;max-width:440px;font-size:1.1rem;color:rgba(26,39,68,.8);line-height:1.8}
.contact-right{grid-column:span 12;display:flex;flex-direction:column;gap:32px;min-width:0}
.contact-block{border-top:1px solid var(--border);padding-top:24px;min-width:0}
.contact-block .cb-label{font-size:10px;text-transform:uppercase;letter-spacing:.3em;color:var(--muted);margin-bottom:8px}
.contact-block .cb-value{
  font-family:var(--font-display);font-style:italic;
  font-size:clamp(1.3rem,5vw,2.5rem);color:var(--ink);
  word-break:break-all;overflow-wrap:break-word;display:block;
}
.contact-block .cb-value-sm{
  font-family:var(--font-display);font-style:italic;
  font-size:clamp(1.2rem,4vw,2rem);color:var(--fg);
  word-break:break-word;
}
.wa-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;
  padding:12px 20px;background:var(--ink);color:var(--bg);
  font-size:10px;text-transform:uppercase;letter-spacing:.2em;transition:background .3s;
  width:100%;max-width:280px;box-sizing:border-box;
}
.wa-btn:hover{background:var(--fg)}

/* ===== FOOTER ===== */
.site-footer{border-top:1px solid var(--border);margin-top:128px}
.footer-grid{
  max-width:var(--max-w);margin:0 auto;padding:64px var(--px);
  display:grid;gap:40px;grid-template-columns:1fr;
}
.footer-brand img{height:48px;margin-bottom:16px}
.footer-brand p{font-size:14px;color:var(--muted);max-width:300px;line-height:1.7}
.footer-contact .fc-label{font-size:10px;text-transform:uppercase;letter-spacing:.3em;color:var(--muted);margin-bottom:16px}
.footer-contact .fc-phone{font-family:var(--font-display);font-style:italic;font-size:1.5rem;color:var(--ink)}
.footer-contact .fc-email{font-size:14px;margin-top:8px}
.footer-contact .fc-loc{font-size:14px;color:var(--muted);margin-top:4px}
.footer-social .fs-label{font-size:10px;text-transform:uppercase;letter-spacing:.3em;color:var(--muted);margin-bottom:16px}
.footer-social .fs-ig{font-family:var(--font-display);font-style:italic;font-size:1.5rem;color:var(--ink)}
.footer-social .fs-wa{font-size:14px;margin-top:16px}
.footer-copy{
  border-top:1px solid var(--border);padding:24px 0;text-align:center;
  font-size:10px;text-transform:uppercase;letter-spacing:.3em;color:var(--muted);
}

/* ===== LIGHTBOX ===== */
.lightbox{
  position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.92);
  display:none;align-items:center;justify-content:center;
  opacity:0;transition:opacity .4s;
}
.lightbox.active{display:flex;opacity:1}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:4px}
.lightbox-close{
  position:absolute;top:24px;right:24px;color:#fff;font-size:14px;
  text-transform:uppercase;letter-spacing:.2em;cursor:pointer;z-index:101;
}
.lightbox-prev,.lightbox-next{
  position:absolute;top:50%;transform:translateY(-50%);
  color:#fff;font-size:2rem;cursor:pointer;padding:20px;z-index:101;
  opacity:.6;transition:opacity .3s;
}
.lightbox-prev:hover,.lightbox-next:hover{opacity:1}
.lightbox-prev{left:16px}
.lightbox-next{right:16px}

/* ===== ANIMATIONS ===== */
@keyframes slowZoom{from{transform:scale(1)}to{transform:scale(1.08)}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp 1.2s cubic-bezier(.2,.8,.2,1) both}

/* ===== RESPONSIVE ===== */
@media(min-width:768px){
  :root{--px:48px}
  .menu-btn{display:none}
  .header-nav{display:flex}
  .hero-text{grid-column:span 7}
  .hero-img-wrap{grid-column:span 5}
  .hero-img-container img{height:70vh}
  .hero-img-label{display:block;position:absolute;top:-24px;left:-24px;writing-mode:vertical-rl;transform:rotate(180deg);font-size:10px;text-transform:uppercase;letter-spacing:.4em;color:rgba(74,111,165,.7)}
  .hero-desc-text{grid-column:8/span 5}
  /* Portfolio: 3-col tight grid on desktop */
  .portfolio-carousel{
    display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
    overflow:visible;scroll-snap-type:none;
  }
  .portfolio-card{flex:none;aspect-ratio:3/4;border-radius:4px}
  .carousel-dots{display:none}
  .about-img-col{grid-column:span 5;position:sticky;top:112px}
  .about-text-col{grid-column:span 7}
  .about-stats{grid-template-columns:repeat(4,1fr)}
  .pli-num{grid-column:span 1}
  .pli-name{grid-column:span 5}
  .pli-blurb{display:block}
  .pli-action{display:block}
  .contact-left{grid-column:span 7}
  .contact-right{grid-column:span 5;padding-top:40px}
  .footer-grid{grid-template-columns:repeat(3,1fr)}
  /* Gallery: 3-col tight grid on desktop */
  .gallery-grid{grid-template-columns:repeat(3,1fr);gap:8px}
  .gi-wide,.gi-tall,.gi-square,.gi-half{grid-column:span 1;aspect-ratio:3/4}
}
@media(max-width:767px){
  .header-nav{display:none}
  .menu-btn{display:block}
  .side-rail{display:none}
  .contact-grid{gap:24px}
  .wa-btn{max-width:100%}
}
@media(min-width:1024px){
  :root{--px:64px}
  .about-img-col{grid-column:span 4}
  .about-text-col{grid-column:span 8}
}
