/* ============================================================
   ORIANA BOTTARO — Official Site
   Shared stylesheet
   ============================================================ */

:root{
  --bg:#0A0907;
  --bg-2:#13110D;
  --bg-3:#1C1813;
  --gold:#C9A66B;
  --gold-bright:#D8B97A;
  --gold-dim:#8A7048;
  --cream:#EFE9DC;
  --text:#F5F1EA;
  --text-mute:#A8A299;
  --text-dim:#6E6860;
  --hairline:rgba(201,166,107,0.22);

  --serif:'Cormorant Garamond', 'Playfair Display', Garamond, serif;
  --sans:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  --gutter:clamp(20px, 3vw, 48px);
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-size:15px;
  line-height:1.5;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:var(--gold); color:var(--bg);}
a{color:inherit; text-decoration:none;}
img{max-width:100%; display:block;}
button{font:inherit; color:inherit; background:none; border:none; cursor:pointer;}

/* ============ HEADER / NAV ============ */
.site-header{
  position:fixed; top:0; left:0; right:0;
  z-index:100;
  padding:24px var(--gutter);
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:32px;
  background:linear-gradient(180deg, rgba(10,9,7,0.85) 0%, rgba(10,9,7,0.4) 70%, transparent 100%);
  transition:background .3s ease, padding .3s ease;
}
.site-header.scrolled,
.site-header.solid{
  background:rgba(10,9,7,0.96);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  padding:14px var(--gutter);
  border-bottom:1px solid var(--hairline);
}

.brand{ line-height:1.15; }
.brand a{display:block;}
.brand-name{
  font-family:var(--serif);
  font-size:20px;
  letter-spacing:0.18em;
  font-weight:400;
  color:var(--text);
}
.brand-tag{
  font-family:var(--sans);
  font-size:9px;
  letter-spacing:0.28em;
  color:var(--gold);
  font-weight:400;
  margin-top:4px;
  text-transform:uppercase;
}

.main-nav{ display:flex; justify-content:center; gap:36px; }
.main-nav a{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.22em;
  font-weight:500;
  color:var(--text);
  padding:6px 0;
  position:relative;
  transition:color .25s ease;
}
.main-nav a:hover{color:var(--gold-bright);}
.main-nav a.active{color:var(--gold-bright);}
.main-nav a.active::after{
  content:""; position:absolute;
  left:50%; transform:translateX(-50%);
  bottom:-6px;
  width:18px; height:1.5px;
  background:var(--gold);
}

.header-right{ display:flex; align-items:center; gap:24px; }
.lang{
  font-size:11px;
  letter-spacing:0.18em;
  color:var(--text);
  font-weight:500;
  display:flex;
  align-items:center;
  gap:6px;
  cursor:pointer;
}
.lang::after{
  content:"";
  width:0; height:0;
  border-left:4px solid transparent;
  border-right:4px solid transparent;
  border-top:5px solid var(--text);
  margin-left:2px;
}
.menu-btn{
  width:28px; height:20px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  cursor:pointer;
}
.menu-btn span{
  display:block; width:100%; height:1.5px; background:var(--text);
  transition:transform .3s ease;
}
.menu-btn span:nth-child(2){width:70%; align-self:flex-end;}

@media (max-width:1100px){
  .main-nav{gap:22px;}
  .main-nav a{font-size:10px; letter-spacing:0.18em;}
}
@media (max-width:880px){
  .main-nav{display:none;}
  .site-header{grid-template-columns:1fr auto;}
}

/* Mobile drawer */
.mobile-nav{
  position:fixed;
  top:0; right:-100%;
  width:min(360px, 80vw);
  height:100vh;
  background:var(--bg-2);
  z-index:200;
  padding:100px 32px 40px;
  display:flex;
  flex-direction:column;
  gap:24px;
  transition:right .35s cubic-bezier(0.22, 1, 0.36, 1);
  border-left:1px solid var(--hairline);
}
.mobile-nav.open{ right:0; }
.mobile-nav a{
  font-family:var(--serif);
  font-size:22px;
  letter-spacing:0.06em;
  color:var(--text);
  padding:8px 0;
  border-bottom:1px solid rgba(201,166,107,0.1);
}
.mobile-nav a.active{color:var(--gold-bright);}
.mobile-nav-close{
  position:absolute;
  top:24px; right:24px;
  width:30px; height:30px;
  cursor:pointer;
  color:var(--text);
}
.mobile-nav-close::before, .mobile-nav-close::after{
  content:"";
  position:absolute;
  left:50%; top:50%;
  width:24px; height:1.5px;
  background:currentColor;
  transform-origin:center;
}
.mobile-nav-close::before{transform:translate(-50%,-50%) rotate(45deg);}
.mobile-nav-close::after{transform:translate(-50%,-50%) rotate(-45deg);}
.overlay{
  position:fixed; inset:0;
  background:rgba(10,9,7,0.7);
  z-index:150;
  opacity:0; pointer-events:none;
  transition:opacity .3s ease;
}
.overlay.open{opacity:1; pointer-events:auto;}

/* ============ HERO (HOME) ============ */
.hero{
  position:relative;
  min-height:100vh;
  overflow:hidden;
  isolation:isolate;
}
.hero-bg{
  position:absolute; inset:0;
  z-index:-2;
  background: #0a0907 url('img/hero.jpg') no-repeat;
  background-size: cover;
  background-position: 55% 15%;
}
.hero-bg::before{
  content:"";
  position:absolute; inset:0;
  /* Subtle warmth retained from photo atmosphere */
  background:linear-gradient(180deg, transparent 60%, rgba(5,4,2,0.5) 100%);
}
.hero-bg::after{ display:none; }
.hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(90deg,
    rgba(10,9,7,0.88) 0%,
    rgba(10,9,7,0.6) 22%,
    rgba(10,9,7,0.2) 42%,
    transparent 60%);
  z-index:-1;
}
.hero-inner{
  position:relative;
  padding:140px var(--gutter) 80px;
  min-height:100vh;
  display:grid;
  grid-template-columns:60px 1fr 60px;
  gap:32px;
  align-items:center;
}

.socials{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:22px;
  position:relative;
}
.socials::after{
  content:"";
  width:1px; height:90px;
  background:linear-gradient(180deg, var(--gold) 0%, transparent 100%);
  margin-top:8px;
}
.socials a{
  width:18px; height:18px;
  color:var(--text);
  opacity:0.85;
  transition:opacity .25s ease, color .25s ease, transform .25s ease;
}
.socials a:hover{color:var(--gold-bright); opacity:1; transform:translateY(-2px);}
.socials a svg{width:100%; height:100%;}

.hero-content{ max-width:680px; }
.hero-name{
  font-family:var(--serif);
  font-size:clamp(54px, 7.2vw, 108px);
  font-weight:400;
  letter-spacing:0.04em;
  line-height:0.94;
  color:var(--text);
  text-transform:uppercase;
}
.hero-name span{ display:block; }
.hero-title{
  margin-top:18px;
  font-family:var(--serif);
  font-size:clamp(18px, 1.8vw, 24px);
  letter-spacing:0.32em;
  color:var(--gold-bright);
  font-weight:500;
  text-transform:uppercase;
}
.hero-roles{
  margin-top:18px;
  font-family:var(--sans);
  font-size:13px;
  letter-spacing:0.22em;
  color:var(--text);
  font-weight:300;
}
.hero-roles .sep{color:var(--gold); margin:0 10px;}
.hero-quote{
  margin-top:36px;
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(18px, 1.8vw, 22px);
  line-height:1.45;
  color:var(--text);
  max-width:420px;
  font-weight:300;
}
.hero-cta{
  margin-top:42px;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  padding:14px 26px;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.22em;
  font-weight:600;
  text-transform:uppercase;
  border:1px solid var(--gold);
  color:var(--text);
  background:var(--gold);
  transition:all .3s ease;
  cursor:pointer;
}
.btn:hover{background:var(--gold-bright); border-color:var(--gold-bright);}
.btn-ghost{
  background:transparent;
  color:var(--text);
  border:1px solid rgba(255,255,255,0.55);
}
.btn-ghost:hover{
  background:var(--text);
  color:var(--bg);
  border-color:var(--text);
}
.btn .icon{ display:inline-flex; transition:transform .3s ease; }
.btn:hover .icon{transform:translateX(3px);}
.btn-ghost:hover .icon{transform:translateY(2px);}

.locations{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:14px;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.28em;
  color:var(--text);
  font-weight:500;
}
.locations::before{
  content:"";
  width:1px; height:80px;
  background:linear-gradient(180deg, transparent 0%, var(--gold) 100%);
  margin-bottom:10px;
}

.hero-bottom{
  position:absolute;
  left:var(--gutter); right:var(--gutter);
  bottom:32px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:0.28em;
  color:var(--text);
  font-weight:500;
}
.scroll-indicator{
  display:flex;
  align-items:center;
  gap:12px;
  margin-left:80px;
}
.scroll-indicator::before{
  content:"";
  width:1px; height:32px;
  background:var(--text);
  animation:scrollPulse 2.2s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%, 100%{opacity:0.3; transform:scaleY(0.6); transform-origin:bottom;}
  50%{opacity:1; transform:scaleY(1); transform-origin:bottom;}
}
.pagination{ color:var(--text-mute); }
.pagination b{color:var(--text); font-weight:500;}

@media (max-width:880px){
  .hero-inner{
    grid-template-columns:40px 1fr;
    padding:120px var(--gutter) 100px;
  }
  .locations{display:none;}
  .scroll-indicator{margin-left:60px;}
  .hero-bg{ background-position: 55% 10%; }
  .hero-overlay{
    background:linear-gradient(180deg,
      rgba(10,9,7,0.3) 0%,
      rgba(10,9,7,0.15) 30%,
      rgba(10,9,7,0.7) 70%,
      rgba(10,9,7,0.95) 100%);
  }
}
@media (max-width:540px){
  .hero-inner{grid-template-columns:1fr; padding:120px var(--gutter) 100px;}
  .socials{flex-direction:row; gap:20px; justify-self:start;}
  .socials::after{display:none;}
  .hero-content{order:-1;}
  .hero-cta{flex-direction:column; align-items:stretch;}
  .btn{width:100%;}
}

/* ============ STATS BAR ============ */
.stats{
  background:var(--cream);
  color:var(--bg);
  padding:36px var(--gutter);
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
}
.stat{ text-align:center; position:relative; }
.stat:not(:last-child)::after{
  content:"";
  position:absolute;
  right:-12px; top:50%;
  transform:translateY(-50%);
  width:1px; height:50%;
  background:rgba(10,9,7,0.18);
}
.stat-num{
  font-family:var(--serif);
  font-size:clamp(28px, 3.6vw, 44px);
  font-weight:400;
  line-height:1;
  color:var(--bg);
}
.stat-label{
  margin-top:8px;
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:0.32em;
  color:var(--text-dim);
  font-weight:500;
  text-transform:uppercase;
}
@media (max-width:680px){
  .stats{grid-template-columns:repeat(2, 1fr); gap:32px 16px; padding:28px var(--gutter);}
  .stat:nth-child(2)::after{display:none;}
}

/* ============ CARD GRID (HOME) ============ */
.cards{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:2px;
  background:var(--bg);
}
.card{
  position:relative;
  aspect-ratio:5/6;
  overflow:hidden;
  cursor:pointer;
  isolation:isolate;
  display:block;
}
.card-img{
  position:absolute; inset:0;
  z-index:-2;
  transition:transform .8s cubic-bezier(0.22, 1, 0.36, 1);
}
.card:hover .card-img{transform:scale(1.06);}
.card-1 .card-img{background: #0a0907 url('img/about-portrait.jpg') center 30%/cover no-repeat;}
.card-2 .card-img{background: #0a0907 url('img/portfolio-portrait-03.jpg') center 25%/cover no-repeat;}
.card-3 .card-img{background: #0a0907 url('img/media-ktsm-anchor.jpg') center 20%/cover no-repeat;}
.card-4 .card-img{background: #0a0907 url('img/projects-ucpb-280sl.jpg') center center/cover no-repeat;}
.card-5 .card-img{background: #0a0907 url('img/philanthropy-gift-of-life.jpg') center 30%/cover no-repeat;}
.card-img::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 45%, rgba(10,9,7,0.85) 100%);
}
.card-content{
  position:absolute;
  bottom:24px;
  left:24px;
  right:24px;
  z-index:2;
}
.card-label{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.28em;
  color:var(--gold);
  font-weight:500;
  text-transform:uppercase;
  margin-bottom:10px;
}
.card-desc{
  font-family:var(--serif);
  font-size:15px;
  line-height:1.3;
  color:var(--text);
  font-weight:400;
}
@media (max-width:1100px){
  .cards{grid-template-columns:repeat(3, 1fr);}
  .card{aspect-ratio:4/5;}
}
@media (max-width:680px){
  .cards{grid-template-columns:repeat(2, 1fr);}
  .card-5{grid-column:span 2; aspect-ratio:16/9;}
}

/* ============ FEATURED IN ============ */
.featured{
  background:transparent;
  padding:36px var(--gutter);
  display:grid;
  grid-template-columns:auto 1fr;
  gap:48px;
  align-items:center;
  border-top:1px solid var(--hairline);
}
.featured-label{
  font-family:var(--serif);
  font-size:16px;
  letter-spacing:0.28em;
  color:var(--gold);
  font-weight:400;
  text-transform:uppercase;
}
.featured-logos{
  display:flex;
  justify-content:space-around;
  align-items:center;
  gap:clamp(20px, 4vw, 56px);
  flex-wrap:wrap;
}
.logo-placeholder{
  font-family:var(--serif);
  font-size:18px;
  letter-spacing:0.06em;
  color:var(--text);
  font-weight:400;
  opacity:0.85;
  transition:opacity .25s ease;
}
.logo-placeholder:hover{opacity:1;}
.logo-placeholder.sans{
  font-family:var(--sans);
  font-weight:600;
  letter-spacing:0.02em;
  font-size:16px;
}
.logo-placeholder.italic{font-style:italic;}
.logo-placeholder.condensed{font-stretch:condensed; letter-spacing:0.18em;}
@media (max-width:880px){
  .featured{grid-template-columns:1fr; gap:24px; text-align:center;}
  .featured-logos{justify-content:center;}
}

/* ============ SUBPAGE HERO ============ */
.page-hero{
  position:relative;
  padding:160px var(--gutter) 80px;
  background:
    radial-gradient(ellipse at 70% 30%, rgba(201,166,107,0.10), transparent 60%),
    linear-gradient(160deg, #1a1812 0%, #0a0907 100%);
  border-bottom:1px solid var(--hairline);
}
.page-hero-inner{
  max-width:1280px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr auto;
  gap:32px;
  align-items:end;
}
.breadcrumb{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.22em;
  color:var(--text-mute);
  text-transform:uppercase;
  font-weight:500;
  margin-bottom:24px;
}
.breadcrumb a{
  color:var(--text-mute);
  transition:color .25s ease;
}
.breadcrumb a:hover{color:var(--gold-bright);}
.breadcrumb .sep{ color:var(--gold-dim); margin:0 10px; }
.breadcrumb b{ color:var(--gold-bright); font-weight:500; }

.page-title{
  font-family:var(--serif);
  font-size:clamp(48px, 7vw, 96px);
  font-weight:400;
  letter-spacing:0.02em;
  line-height:1;
  color:var(--text);
  text-transform:uppercase;
}
.page-subtitle{
  margin-top:18px;
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(18px, 1.6vw, 22px);
  color:var(--gold-bright);
  font-weight:400;
  max-width:540px;
  line-height:1.4;
}
.page-meta{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.22em;
  color:var(--text-mute);
  text-transform:uppercase;
  text-align:right;
  font-weight:500;
}
.page-meta b{ color:var(--gold-bright); display:block; font-weight:500; }

@media (max-width:880px){
  .page-hero{padding:130px var(--gutter) 60px;}
  .page-hero-inner{grid-template-columns:1fr;}
  .page-meta{text-align:left;}
}

/* ============ SECTION BASE ============ */
.section{
  padding:100px var(--gutter);
  max-width:1280px;
  margin:0 auto;
}
.section-narrow{
  max-width:920px;
}
.section-title{
  font-family:var(--serif);
  font-size:clamp(32px, 4.4vw, 56px);
  font-weight:400;
  letter-spacing:0.01em;
  line-height:1.05;
  color:var(--text);
  margin-bottom:48px;
}
.section-title em{
  font-style:italic;
  color:var(--gold-bright);
}
.eyebrow{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.28em;
  color:var(--gold);
  text-transform:uppercase;
  font-weight:500;
  margin-bottom:16px;
}

/* ============ ABOUT PAGE ============ */
.about-grid{
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:clamp(32px, 6vw, 96px);
  align-items:start;
}
.about-portrait{
  position:relative;
  aspect-ratio:3/4;
  background: #0a0907 url('img/about-portrait.jpg') center 25%/cover no-repeat;
  border:1px solid var(--hairline);
}
.about-portrait::after{ display:none; }
.about-body{
  font-family:var(--serif);
  font-size:clamp(18px, 1.6vw, 22px);
  line-height:1.55;
  color:var(--text);
  font-weight:300;
}
.about-body p{ margin-bottom:1.3em; }
.about-body p:first-child::first-letter{
  font-family:var(--serif);
  float:left;
  font-size:5em;
  line-height:0.85;
  margin:0.1em 0.12em -0.05em 0;
  color:var(--gold-bright);
  font-weight:400;
}

.about-facts{
  margin-top:48px;
  padding-top:32px;
  border-top:1px solid var(--hairline);
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:32px;
}
.fact-label{
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:0.28em;
  color:var(--gold);
  text-transform:uppercase;
  font-weight:500;
  margin-bottom:8px;
}
.fact-value{
  font-family:var(--serif);
  font-size:18px;
  color:var(--text);
  line-height:1.4;
}

.mission-callout{
  background:var(--bg-2);
  padding:clamp(48px, 6vw, 96px);
  margin:80px 0;
  border:1px solid var(--hairline);
  text-align:center;
}
.mission-callout .eyebrow{ justify-content:center; }
.mission-text{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(24px, 3vw, 36px);
  line-height:1.35;
  color:var(--text);
  max-width:760px;
  margin:0 auto;
  font-weight:300;
}
.mission-text em{ color:var(--gold-bright); font-style:normal; }

@media (max-width:880px){
  .about-grid{grid-template-columns:1fr;}
  .about-portrait{max-width:420px; aspect-ratio:1/1;}
  .about-facts{grid-template-columns:1fr; gap:24px;}
}

/* ============ PORTFOLIO PAGE ============ */
.filters{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:48px;
  border-bottom:1px solid var(--hairline);
  padding-bottom:24px;
}
.filter-btn{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--text-mute);
  padding:8px 16px;
  border:1px solid transparent;
  transition:all .25s ease;
  cursor:pointer;
}
.filter-btn:hover{color:var(--text);}
.filter-btn.active{
  color:var(--gold-bright);
  border-color:var(--gold);
}

.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:16px;
}
.shot{
  position:relative;
  overflow:hidden;
  cursor:pointer;
  isolation:isolate;
}
.shot::after{
  content:attr(data-label);
  position:absolute; bottom:14px; left:14px;
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:rgba(245,241,234,0.9);
  z-index:2;
  font-weight:500;
}
.shot-img{
  position:absolute; inset:0;
  transition:transform .8s cubic-bezier(0.22, 1, 0.36, 1);
}
.shot:hover .shot-img{transform:scale(1.05);}
.shot-img::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(10,9,7,0.8) 100%);
}
.shot-1{grid-column:span 7; aspect-ratio:4/3;}
.shot-2{grid-column:span 5; aspect-ratio:3/4;}
.shot-3{grid-column:span 4; aspect-ratio:1/1;}
.shot-4{grid-column:span 4; aspect-ratio:1/1;}
.shot-5{grid-column:span 4; aspect-ratio:1/1;}
.shot-6{grid-column:span 6; aspect-ratio:4/3;}
.shot-7{grid-column:span 6; aspect-ratio:4/3;}
.shot-8{grid-column:span 12; aspect-ratio:21/9;}

.shot-1 .shot-img{background: #0a0907 url('img/portfolio-portrait-03.jpg') center 20%/cover no-repeat;}
.shot-2 .shot-img{background: #0a0907 url('img/portfolio-editorial-01.jpg') center center/cover no-repeat;}
.shot-3 .shot-img{background: #0a0907 url('img/portfolio-editorial-02.jpg') center center/cover no-repeat;}
.shot-4 .shot-img{background: #0a0907 url('img/portfolio-portrait-01.jpg') center 20%/cover no-repeat;}
.shot-5 .shot-img{background: #0a0907 url('img/portfolio-tv-red.jpg') center 30%/cover no-repeat;}
.shot-6 .shot-img{background: #0a0907 url('img/projects-pagoda-equestrian.jpg') center center/cover no-repeat;}
.shot-7 .shot-img{background: #0a0907 url('img/portfolio-behind-scenes.jpg') center center/cover no-repeat;}
.shot-8 .shot-img{background: #0a0907 url('img/projects-pagoda-red.jpg') center center/cover no-repeat;}

@media (max-width:880px){
  .shot-1, .shot-2, .shot-3, .shot-4, .shot-5, .shot-6, .shot-7{grid-column:span 12; aspect-ratio:3/4;}
  .shot-8{aspect-ratio:4/3;}
}

/* ============ MEDIA / PRESS PAGE ============ */
.press-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:32px;
}
.press-item{
  border:1px solid var(--hairline);
  padding:32px;
  background:var(--bg-2);
  transition:border-color .3s ease, transform .3s ease;
  display:block;
}
.press-item:hover{
  border-color:var(--gold);
  transform:translateY(-3px);
}
.press-source{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin-bottom:16px;
}
.press-title{
  font-family:var(--serif);
  font-size:24px;
  line-height:1.3;
  color:var(--text);
  margin-bottom:14px;
  font-weight:400;
}
.press-date{
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--text-mute);
  font-weight:500;
}
.press-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:18px;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold-bright);
  font-weight:600;
}
@media (max-width:680px){
  .press-grid{grid-template-columns:1fr;}
}

/* ============ PROJECTS PAGE ============ */
.project{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:clamp(32px, 5vw, 80px);
  align-items:center;
  padding:64px 0;
  border-bottom:1px solid var(--hairline);
}
.project:last-child{border-bottom:none;}
.project.reversed{
  grid-template-columns:1fr 1.4fr;
}
.project.reversed .project-visual{order:2;}
.project-visual{
  position:relative;
  aspect-ratio:4/3;
  background:linear-gradient(155deg, #2a2418 0%, #0a0907 100%);
  border:1px solid var(--hairline);
}
.project-num{
  position:absolute;
  top:18px; left:18px;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.28em;
  color:var(--gold);
  font-weight:500;
}
.project-eyebrow{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.28em;
  color:var(--gold);
  text-transform:uppercase;
  font-weight:500;
  margin-bottom:16px;
}
.project-name{
  font-family:var(--serif);
  font-size:clamp(28px, 3.4vw, 42px);
  line-height:1.05;
  font-weight:400;
  color:var(--text);
  margin-bottom:20px;
}
.project-name em{ font-style:italic; color:var(--gold-bright); }
.project-desc{
  font-size:16px;
  line-height:1.65;
  color:var(--text-mute);
  margin-bottom:24px;
}
.project-meta{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  padding-top:20px;
  border-top:1px solid var(--hairline);
}

@media (max-width:880px){
  .project, .project.reversed{grid-template-columns:1fr; gap:32px;}
  .project.reversed .project-visual{order:0;}
}

/* ============ PHILANTHROPY PAGE ============ */
.philanthropy-lead{
  font-family:var(--serif);
  font-size:clamp(24px, 2.8vw, 34px);
  line-height:1.35;
  color:var(--text);
  max-width:820px;
  margin-bottom:64px;
  font-weight:300;
}
.philanthropy-lead em{ font-style:italic; color:var(--gold-bright); }

.programs{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:32px;
  margin:64px 0;
}
.program{
  background:var(--bg-2);
  padding:36px 28px;
  border:1px solid var(--hairline);
  transition:transform .3s ease, border-color .3s ease;
}
.program:hover{transform:translateY(-4px); border-color:var(--gold-dim);}
.program-num{
  font-family:var(--serif);
  font-style:italic;
  font-size:42px;
  color:var(--gold-bright);
  line-height:1;
  margin-bottom:16px;
  font-weight:300;
}
.program-name{
  font-family:var(--serif);
  font-size:22px;
  color:var(--text);
  line-height:1.3;
  margin-bottom:14px;
  font-weight:400;
}
.program-desc{
  font-size:14px;
  color:var(--text-mute);
  line-height:1.6;
}

.impact-stats{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  padding:48px 0;
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
}
.impact-stat{ text-align:center; }
.impact-num{
  font-family:var(--serif);
  font-size:clamp(40px, 5vw, 64px);
  font-weight:300;
  color:var(--gold-bright);
  line-height:1;
}
.impact-label{
  margin-top:10px;
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--text-mute);
  font-weight:500;
}

@media (max-width:880px){
  .programs{grid-template-columns:1fr;}
  .impact-stats{grid-template-columns:1fr; gap:32px;}
}

/* ============ CONTACT PAGE ============ */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:clamp(32px, 6vw, 96px);
}
.contact-lead{
  font-family:var(--serif);
  font-size:clamp(28px, 3.4vw, 42px);
  line-height:1.2;
  color:var(--text);
  font-weight:300;
  margin-bottom:24px;
}
.contact-lead em{ font-style:italic; color:var(--gold-bright); }
.contact-intro{
  font-size:16px;
  line-height:1.7;
  color:var(--text-mute);
  margin-bottom:36px;
}

.contact-list{
  display:flex;
  flex-direction:column;
  gap:24px;
}
.contact-card{
  padding:28px;
  background:var(--bg-2);
  border:1px solid var(--hairline);
  transition:border-color .3s ease;
}
.contact-card:hover{border-color:var(--gold);}
.contact-card-label{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin-bottom:10px;
}
.contact-card-email{
  font-family:var(--serif);
  font-size:22px;
  color:var(--text);
  font-weight:400;
}
.contact-card-email:hover{ color:var(--gold-bright); }

.contact-social{
  margin-top:48px;
  padding-top:32px;
  border-top:1px solid var(--hairline);
}
.contact-social h3{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin-bottom:18px;
}
.contact-social-list{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
}
.contact-social-list a{
  font-family:var(--serif);
  font-size:18px;
  color:var(--text);
  padding-bottom:2px;
  border-bottom:1px solid var(--hairline);
  transition:color .25s ease, border-color .25s ease;
}
.contact-social-list a:hover{
  color:var(--gold-bright);
  border-color:var(--gold);
}

@media (max-width:880px){
  .contact-grid{grid-template-columns:1fr;}
}

/* ============ FOOTER ============ */
.site-footer{
  background:var(--bg-2);
  padding:64px var(--gutter) 32px;
  border-top:1px solid var(--hairline);
}
.footer-inner{
  max-width:1280px;
  margin:0 auto;
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:48px;
  padding-bottom:48px;
  border-bottom:1px solid var(--hairline);
}
.footer-brand .brand-name{ font-size:24px; }
.footer-brand .brand-tag{ font-size:10px; margin-top:6px; }
.footer-brand p{
  margin-top:18px;
  color:var(--text-mute);
  font-size:14px;
  line-height:1.6;
  max-width:380px;
}
.footer-col h4{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin-bottom:18px;
}
.footer-col ul{ list-style:none; }
.footer-col li{ margin-bottom:10px; }
.footer-col a{
  font-size:14px;
  color:var(--text);
  font-weight:300;
  transition:color .25s ease;
}
.footer-col a:hover{ color:var(--gold-bright); }

.footer-bottom{
  max-width:1280px;
  margin:0 auto;
  padding-top:32px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--text-mute);
  font-weight:400;
  flex-wrap:wrap;
  gap:16px;
}
.footer-bottom .gold{ color:var(--gold); }

@media (max-width:880px){
  .footer-inner{grid-template-columns:1fr; gap:32px;}
}

/* ============ REVEAL ============ */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity 1s cubic-bezier(0.22, 1, 0.36, 1), transform 1s cubic-bezier(0.22, 1, 0.36, 1);
}
.reveal.in{opacity:1; transform:translateY(0);}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1; transform:none; transition:none;}
  .scroll-indicator::before{animation:none;}
  html{scroll-behavior:auto;}
}

:focus-visible{outline:2px solid var(--gold); outline-offset:3px;}

/* ============================================
   BTV INSTAGRAM SLIDESHOW
   Venezuela through her lens — @Oriana.BTV
   ============================================ */
.btv-section{
  background: linear-gradient(180deg, #050403 0%, #0a0907 50%, #050403 100%);
  padding: 120px var(--gutter) 140px;
  position: relative;
  overflow: hidden;
}
.btv-section::before{
  content: "";
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 1px; height: 80px;
  background: linear-gradient(180deg, transparent, var(--gold), transparent);
}
.btv-header{
  text-align: center;
  max-width: 720px;
  margin: 0 auto 70px;
}
.btv-eyebrow{
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  letter-spacing: 0.4em;
  color: var(--gold);
  margin-bottom: 28px;
  font-weight: 500;
}
.btv-title{
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: clamp(2.2rem, 5vw, 4rem);
  color: var(--cream);
  margin: 0 0 24px;
  letter-spacing: -0.01em;
  line-height: 1.05;
}
.btv-sub{
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  line-height: 1.7;
  color: rgba(245, 241, 234, 0.7);
  font-weight: 300;
  margin: 0 0 24px;
}
.btv-handle{
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  letter-spacing: 0.15em;
  color: var(--gold);
  text-decoration: none;
  padding-bottom: 4px;
  border-bottom: 1px solid rgba(201, 166, 107, 0.4);
  transition: border-color 0.3s;
}
.btv-handle:hover{ border-bottom-color: var(--gold); }

/* Carousel container */
.btv-carousel{
  display: grid;
  grid-template-columns: 60px 1fr 60px;
  align-items: center;
  gap: 20px;
  max-width: 1280px;
  margin: 0 auto;
}
.btv-track-wrap{
  overflow: hidden;
  width: 100%;
  position: relative;
  padding: 8px 0;
}
.btv-track{
  display: flex;
  gap: 24px;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

/* Each slide is a dark editorial frame around the IG embed */
.btv-slide{
  flex: 0 0 calc(33.333% - 16px);
  min-width: 0;
  background: #0d0c0a;
  border: 1px solid rgba(201, 166, 107, 0.15);
  border-radius: 4px;
  padding: 18px 18px 14px;
  box-shadow: 0 18px 60px -20px rgba(0,0,0,0.8), 0 0 0 1px rgba(255,255,255,0.02) inset;
  transition: transform 0.4s, border-color 0.4s, box-shadow 0.4s;
  position: relative;
  overflow: hidden;
}
.btv-slide:hover{
  transform: translateY(-4px);
  border-color: rgba(201, 166, 107, 0.35);
  box-shadow: 0 24px 70px -20px rgba(0,0,0,0.9), 0 0 0 1px rgba(201,166,107,0.1) inset;
}
.btv-slide::before{
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,166,107,0.4), transparent);
}

/* Reset Instagram's own white background to blend - it will still show but framed */
.btv-slide .instagram-media{
  margin: 0 auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  border-radius: 2px !important;
  background: #fff !important;
}

/* Arrows */
.btv-arrow{
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: transparent;
  border: 1px solid rgba(201, 166, 107, 0.4);
  cursor: pointer;
  position: relative;
  transition: all 0.3s;
  flex-shrink: 0;
  padding: 0;
}
.btv-arrow::before{
  content: "";
  position: absolute;
  top: 50%; left: 50%;
  width: 12px; height: 12px;
  border-top: 1.5px solid var(--gold);
  border-right: 1.5px solid var(--gold);
  transition: border-color 0.3s;
}
.btv-prev::before{
  transform: translate(-30%, -50%) rotate(-135deg);
}
.btv-next::before{
  transform: translate(-70%, -50%) rotate(45deg);
}
.btv-arrow:hover{
  border-color: var(--gold);
  background: rgba(201, 166, 107, 0.08);
}
.btv-arrow:disabled{
  opacity: 0.25;
  cursor: not-allowed;
}

/* Dots */
.btv-dots{
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 36px;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
}
.btv-dot{
  width: 28px;
  height: 2px;
  background: rgba(201, 166, 107, 0.2);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background 0.3s;
}
.btv-dot.active{ background: var(--gold); }

/* CTA */
.btv-cta{
  text-align: center;
  margin-top: 60px;
}
.btv-follow{
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 18px 36px;
  border: 1px solid var(--gold);
  color: var(--cream);
  text-decoration: none;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 500;
  transition: all 0.3s;
  position: relative;
  overflow: hidden;
}
.btv-follow::before{
  content: "";
  position: absolute;
  inset: 0;
  background: var(--gold);
  transform: translateX(-101%);
  transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
  z-index: -1;
}
.btv-follow:hover{ color: #0a0907; }
.btv-follow:hover::before{ transform: translateX(0); }
.btv-follow .btv-arrow-icon{
  font-size: 16px;
  transition: transform 0.3s;
}
.btv-follow:hover .btv-arrow-icon{ transform: translateX(4px); }

/* Loading state for embeds */
.btv-slide:not(.btv-loaded) .instagram-media{
  min-height: 580px !important;
  background: linear-gradient(135deg, #1a1815 0%, #0d0c0a 100%) !important;
  position: relative;
}
.btv-slide:not(.btv-loaded) .instagram-media::after{
  content: "Loading reel…";
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  color: var(--gold);
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  letter-spacing: 0.3em;
  opacity: 0.7;
}

/* TABLET — 2 slides visible */
@media (max-width: 1024px){
  .btv-section{ padding: 100px var(--gutter) 120px; }
  .btv-slide{ flex: 0 0 calc(50% - 12px); }
  .btv-carousel{ grid-template-columns: 48px 1fr 48px; gap: 14px; }
  .btv-arrow{ width: 44px; height: 44px; }
}

/* MOBILE — 1 slide visible, arrows on top */
@media (max-width: 720px){
  .btv-section{ padding: 80px 20px 100px; }
  .btv-header{ margin-bottom: 50px; }
  .btv-eyebrow{ font-size: 10px; letter-spacing: 0.3em; }
  .btv-carousel{
    grid-template-columns: 1fr;
    gap: 0;
  }
  .btv-arrow{
    display: none;
  }
  .btv-track-wrap{
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 8px;
  }
  .btv-track-wrap::-webkit-scrollbar{ display: none; }
  .btv-track{
    gap: 16px;
    transition: none;
    padding: 0 4px;
  }
  .btv-slide{
    flex: 0 0 88%;
    scroll-snap-align: center;
    padding: 14px 14px 10px;
  }
  .btv-dots{ margin-top: 24px; }
  .btv-cta{ margin-top: 40px; }
  .btv-follow{
    padding: 16px 28px;
    font-size: 11px;
    letter-spacing: 0.15em;
  }
  .btv-slide:not(.btv-loaded) .instagram-media{ min-height: 520px !important; }
}

/* Hint micro-typography when scrolling on mobile */
@media (max-width: 720px){
  .btv-track-wrap::before{
    content: "";
    position: absolute;
    top: 50%; right: 8px;
    width: 18px; height: 18px;
    transform: translateY(-50%);
    background: linear-gradient(90deg, transparent, rgba(201,166,107,0.4));
    pointer-events: none;
    z-index: 2;
    border-radius: 50%;
    opacity: 0.6;
  }
}
