/* ============================================
   CAPTURE MEDIA CO — DESIGN SYSTEM
   Black + Gold luxury editorial theme
   ============================================ */

:root{
  --black:      #0a0a0b;
  --black-2:    #121213;
  --black-3:    #19191b;
  --line:       rgba(201,165,86,0.18);
  --gold:       #c9a556;
  --gold-light: #e8cd8f;
  --gold-dim:   #8a7038;
  --cream:      #f4efe4;
  --white:      #ffffff;
  --gray:       #a7a5a0;
  --gray-dim:   #7a7873;

  --serif: 'Playfair Display', Georgia, serif;
  --sans: 'Jost', 'Helvetica Neue', Arial, sans-serif;

  --container: 1240px;
  --radius: 2px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--black);
  color:var(--cream);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:600;
  color:var(--white);
  margin:0 0 .5em;
  line-height:1.15;
  letter-spacing:.01em;
}
p{ margin:0 0 1em; color:var(--gray); }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:var(--sans); cursor:pointer; }

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 32px;
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-family:var(--sans);
  font-size:12.5px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:18px;
}
.eyebrow::before{
  content:'';
  width:26px; height:1px;
  background:var(--gold);
}

.script{
  font-family:'Playfair Display', serif;
  font-style:italic;
  font-weight:500;
  color:var(--gold-light);
}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:16px 34px;
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  border-radius:var(--radius);
  border:1px solid transparent;
  transition:all .35s var(--ease);
  white-space:nowrap;
}
.btn-gold{
  background:linear-gradient(135deg,var(--gold-light),var(--gold) 60%,var(--gold-dim));
  color:#151107;
  font-weight:600;
  box-shadow:0 8px 24px -8px rgba(201,165,86,.5);
}
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 14px 30px -8px rgba(201,165,86,.65); }
.btn-outline{
  border-color:rgba(244,239,228,.35);
  color:var(--cream);
}
.btn-outline:hover{ border-color:var(--gold); color:var(--gold-light); }
.btn-block{ width:100%; }

/* ---------- NAV ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:18px 0;
  transition:background .3s var(--ease), padding .3s var(--ease), border-color .3s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(10,10,11,.92);
  backdrop-filter:blur(10px);
  padding:12px 0;
  border-color:var(--line);
}
.nav-row{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:56px; width:auto; transition:height .3s var(--ease); }
.site-header.scrolled .brand img{ height:44px; }
.brand-word{ display:none; }

.nav-links{ display:flex; align-items:center; gap:38px; }
.nav-links a{
  font-size:13px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--cream); position:relative; padding:4px 0;
}
.nav-links a::after{
  content:''; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--gold); transition:width .3s var(--ease);
}
.nav-links a:hover::after, .nav-links a.active::after{ width:100%; }
.nav-links a.active{ color:var(--gold-light); }

.nav-right{ display:flex; align-items:center; gap:22px; }
.nav-phone{ font-size:13px; letter-spacing:.05em; color:var(--gray); display:flex; align-items:center; gap:8px; }
.nav-phone svg{ width:14px; height:14px; fill:var(--gold); }

.nav-toggle{
  display:none; flex-direction:column; gap:5px; background:none; border:none; padding:6px;
}
.nav-toggle span{ width:24px; height:1.5px; background:var(--cream); }

.mobile-menu{
  position:fixed; inset:0; background:var(--black); z-index:1200;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:34px;
  transform:translateY(-100%); transition:transform .4s var(--ease);
}
.mobile-menu.open{ transform:translateY(0); }
.mobile-menu a{ font-family:var(--serif); font-size:26px; color:var(--cream); }
.mobile-menu .btn{ margin-top:10px; }
.mobile-close{ position:absolute; top:26px; right:28px; background:none; border:none; color:var(--cream); font-size:28px; }

/* ---------- HERO ---------- */
.hero{
  position:relative;
  min-height:100vh;
  display:flex; align-items:flex-end;
  background:#000;
  overflow:hidden;
}
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media img{ width:100%; height:100%; object-fit:cover; object-position:center 65%; }
.hero-media::after{
  content:'';
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(8,8,9,.55) 0%, rgba(8,8,9,.25) 30%, rgba(8,8,9,.55) 68%, rgba(8,8,9,.96) 100%),
    linear-gradient(90deg, rgba(8,8,9,.55) 0%, rgba(8,8,9,0) 45%);
}
.hero-content{
  position:relative; z-index:1;
  padding:0 0 100px;
  width:100%;
}
.hero-tag{ font-size:19px; margin-bottom:22px; display:block; }
.hero h1{
  font-size:clamp(40px,7vw,84px);
  max-width:920px;
  margin-bottom:24px;
}
.hero h1 em{ font-style:italic; color:var(--gold-light); font-weight:500; }
.hero-sub{
  max-width:520px; font-size:17px; color:#d8d5cc; margin-bottom:38px;
}
.hero-ctas{ display:flex; gap:18px; flex-wrap:wrap; margin-bottom:52px; }
.hero-trust{
  display:flex; gap:40px; flex-wrap:wrap;
  padding-top:26px; border-top:1px solid rgba(244,239,228,.16);
}
.hero-trust div{ font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--gray); }
.hero-trust strong{ display:block; font-family:var(--serif); font-size:22px; color:var(--gold-light); font-weight:600; letter-spacing:0; text-transform:none; margin-bottom:4px; }

.scroll-cue{
  position:absolute; bottom:28px; right:40px; z-index:1;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  color:var(--gray); font-size:11px; letter-spacing:.2em; text-transform:uppercase;
}
.scroll-cue .line{ width:1px; height:44px; background:linear-gradient(var(--gold),transparent); animation:scrollpulse 2s infinite; }
@keyframes scrollpulse{ 0%{opacity:.2} 50%{opacity:1} 100%{opacity:.2} }

/* ---------- SECTION SCAFFOLD ---------- */
section{ position:relative; padding:120px 0; }
.section-tight{ padding:80px 0; }
.section-head{ max-width:680px; margin-bottom:64px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head p{ font-size:17px; }
.bg-2{ background:var(--black-2); }
.divider{ height:1px; background:var(--line); width:100%; }

/* ---------- STATEMENT / TURNING POINT ---------- */
.statement{
  text-align:center;
  padding:140px 0;
  position:relative;
}
.statement .eyebrow{ justify-content:center; }
.statement .eyebrow::before{ display:none; }
.statement h2{
  font-size:clamp(30px,4.6vw,58px);
  max-width:920px;
  margin:0 auto 28px;
}
.statement p{ max-width:640px; margin:0 auto; font-size:18px; }
.statement-frame{
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}

/* ---------- SERVICES ---------- */
.services-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:2px;
  background:var(--line);
}
.service-card{
  position:relative; background:var(--black); aspect-ratio:4/5; overflow:hidden;
  display:flex; align-items:flex-end;
}
.service-card img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transition:transform .8s var(--ease), filter .5s var(--ease);
  filter:grayscale(15%) brightness(.72);
}
.service-card:hover img{ transform:scale(1.08); filter:grayscale(0%) brightness(.55); }
.service-card::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 30%, rgba(8,8,9,.92) 100%);
}
.service-body{ position:relative; z-index:1; padding:30px; }
.service-num{ font-family:var(--serif); font-style:italic; color:var(--gold); font-size:14px; }
.service-body h3{ font-size:23px; margin:8px 0 8px; }
.service-body p{ font-size:14.5px; margin-bottom:0; color:#cfccc4; }

/* ---------- PORTFOLIO GRID ---------- */
.portfolio-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px;
}
.portfolio-grid .tall{ grid-row:span 2; }
.p-item{
  position:relative; overflow:hidden; aspect-ratio:1/1; background:var(--black-3);
  cursor:pointer;
}
.portfolio-grid .tall .p-item{ aspect-ratio:1/2.06; }
.p-item img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .7s var(--ease);
}
.p-item:hover img{ transform:scale(1.09); }
.p-item::after{
  content:''; position:absolute; inset:0; opacity:0;
  background:linear-gradient(180deg,rgba(10,10,11,0) 40%,rgba(10,10,11,.88));
  transition:opacity .35s var(--ease);
}
.p-item:hover::after{ opacity:1; }
.p-tag{
  position:absolute; left:18px; bottom:18px; z-index:1;
  font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-light);
  opacity:0; transform:translateY(8px);
  transition:all .35s var(--ease);
}
.p-item:hover .p-tag{ opacity:1; transform:translateY(0); }

/* ---------- RESULTS / WHY IT WORKS ---------- */
.results-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); }
.result-card{ background:var(--black); padding:44px 30px; }
.result-card svg{ width:30px; height:30px; fill:none; stroke:var(--gold); stroke-width:1.4; margin-bottom:22px; }
.result-card h4{ font-size:19px; margin-bottom:10px; }
.result-card p{ font-size:14.5px; margin-bottom:0; }

/* ---------- PROCESS ---------- */
.process{ display:grid; grid-template-columns:repeat(4,1fr); gap:36px; }
.process-step{ position:relative; padding-top:26px; border-top:1px solid var(--line); }
.process-step .n{ font-family:var(--serif); font-style:italic; font-size:34px; color:var(--gold); display:block; margin-bottom:14px; }
.process-step h4{ font-size:18px; margin-bottom:8px; }
.process-step p{ font-size:14px; margin-bottom:0; }

/* ---------- TESTIMONIALS (placeholder-friendly) ---------- */
.testi-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.testi-card{
  background:var(--black-2); border:1px solid var(--line); padding:34px;
}
.testi-stars{ color:var(--gold); font-size:14px; letter-spacing:2px; margin-bottom:18px; }
.testi-card p{ font-size:15.5px; color:#d9d6cd; font-style:italic; }
.testi-name{ display:flex; align-items:center; gap:12px; margin-top:20px; }
.testi-name .dot{ width:34px; height:34px; border-radius:50%; background:linear-gradient(135deg,var(--gold-light),var(--gold-dim)); flex:none; }
.testi-name strong{ display:block; font-size:14px; color:var(--white); font-weight:500; }
.testi-name span{ font-size:12px; color:var(--gray-dim); }
.testi-note{
  text-align:center; font-size:12.5px; color:var(--gray-dim); margin-top:28px; letter-spacing:.03em;
}

/* ---------- CTA BAND ---------- */
.cta-band{
  padding:110px 0; text-align:center; position:relative;
  background:radial-gradient(ellipse at 50% 0%, rgba(201,165,86,.14), transparent 60%), var(--black-2);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.cta-band h2{ font-size:clamp(30px,5vw,54px); max-width:760px; margin:0 auto 22px; }
.cta-band p{ max-width:520px; margin:0 auto 36px; font-size:16.5px; }
.cta-actions{ display:flex; gap:18px; justify-content:center; flex-wrap:wrap; }

/* ---------- FOOTER ---------- */
footer{ background:#050506; padding:80px 0 30px; border-top:1px solid var(--line); }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; margin-bottom:60px; }
.footer-brand img{ height:60px; margin-bottom:18px; }
.footer-brand p{ font-size:14px; max-width:280px; }
.footer-col h5{ font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; }
.footer-col a, .footer-col p{ display:block; font-size:14.5px; color:var(--gray); margin-bottom:12px; }
.footer-col a:hover{ color:var(--gold-light); }
.social-row{ display:flex; gap:14px; margin-top:6px; }
.social-row a{
  width:36px; height:36px; border-radius:50%; border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center;
}
.social-row a:hover{ border-color:var(--gold); }
.social-row svg{ width:15px; height:15px; fill:var(--gray); }
.social-row a:hover svg{ fill:var(--gold-light); }
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;
  padding-top:26px; border-top:1px solid var(--line);
  font-size:12.5px; color:var(--gray-dim);
}
.footer-bottom a{ color:var(--gray-dim); }

/* ---------- STICKY MOBILE CTA (lead capture net) ---------- */
.sticky-cta{
  position:fixed; left:0; right:0; bottom:0; z-index:900;
  display:none;
  background:rgba(10,10,11,.97); backdrop-filter:blur(8px);
  border-top:1px solid var(--line);
  padding:12px 16px;
  gap:10px;
}
.sticky-cta a{ flex:1; text-align:center; padding:14px 10px; font-size:12.5px; }

/* ---------- PAGE HERO (sub pages) ---------- */
.page-hero{
  padding:190px 0 90px; text-align:center; position:relative; overflow:hidden;
  background:linear-gradient(180deg, var(--black-2), var(--black));
}
.page-hero::before{
  content:''; position:absolute; top:-200px; left:50%; transform:translateX(-50%);
  width:900px; height:500px; background:radial-gradient(circle, rgba(201,165,86,.14), transparent 65%);
}
.page-hero h1{ font-size:clamp(34px,5.5vw,58px); position:relative; z-index:1; }
.page-hero p{ max-width:560px; margin:18px auto 0; position:relative; z-index:1; font-size:16.5px; }
.breadcrumb{ font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--gray-dim); position:relative; z-index:1; }
.breadcrumb a{ color:var(--gold); }

/* ---------- FAQ ACCORDION ---------- */
.faq-group{ margin-bottom:58px; }
.faq-group h3{
  font-size:14px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold);
  font-family:var(--sans); font-weight:500; margin-bottom:22px;
}
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{
  display:flex; justify-content:space-between; align-items:center; gap:20px;
  padding:26px 4px; cursor:pointer; background:none; border:none; width:100%; text-align:left;
}
.faq-q h4{ font-family:var(--serif); font-size:19px; color:var(--cream); font-weight:600; margin:0; }
.faq-q .plus{ flex:none; font-size:20px; color:var(--gold); transition:transform .3s var(--ease); font-family:var(--serif); }
.faq-item.open .faq-q .plus{ transform:rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .35s var(--ease); }
.faq-a-inner{ padding:0 4px 26px; font-size:15.5px; color:var(--gray); max-width:760px; }

/* ---------- LEAD FORM (Book Now) ---------- */
.book-layout{ display:grid; grid-template-columns:1.15fr .85fr; gap:64px; align-items:flex-start; }
.form-card{ background:var(--black-2); border:1px solid var(--line); padding:44px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field{ margin-bottom:20px; }
.field label{ display:block; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--gray); margin-bottom:9px; }
.field input, .field select, .field textarea{
  width:100%; background:var(--black); border:1px solid rgba(244,239,228,.16);
  color:var(--cream); padding:14px 16px; font-family:var(--sans); font-size:14.5px;
  border-radius:var(--radius); transition:border-color .25s;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--gold); }
.field textarea{ resize:vertical; min-height:110px; }
.field-required{ color:var(--gold); }
.consent{ display:flex; gap:10px; align-items:flex-start; font-size:12.5px; color:var(--gray-dim); margin-bottom:26px; }
.consent input{ margin-top:3px; width:auto; }

.side-info{ display:flex; flex-direction:column; gap:28px; }
.side-card{ background:var(--black-2); border:1px solid var(--line); padding:30px; }
.side-card h4{ font-size:16px; margin-bottom:14px; }
.side-steps{ display:flex; flex-direction:column; gap:16px; }
.side-steps div{ display:flex; gap:14px; font-size:14px; color:var(--gray); }
.side-steps .n{ flex:none; width:26px; height:26px; border-radius:50%; border:1px solid var(--gold); color:var(--gold); font-size:12px; display:flex; align-items:center; justify-content:center; font-family:var(--serif); }
.side-contact a{ display:flex; align-items:center; gap:10px; font-size:15px; color:var(--cream); margin-bottom:12px; }
.side-contact svg{ width:16px; height:16px; fill:var(--gold); }

.form-success{
  display:none; text-align:center; padding:60px 20px;
}
.form-success.show{ display:block; }
.form-success .check{
  width:64px; height:64px; border-radius:50%; border:1px solid var(--gold); margin:0 auto 24px;
  display:flex; align-items:center; justify-content:center;
}
.form-success .check svg{ width:26px; height:26px; stroke:var(--gold); fill:none; stroke-width:2; }

/* ---------- REVEAL ANIMATION ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:translateY(0); }

/* ---------- RESPONSIVE ---------- */
@media (max-width:1080px){
  .services-grid{ grid-template-columns:repeat(2,1fr); }
  .results-grid{ grid-template-columns:repeat(2,1fr); }
  .process{ grid-template-columns:repeat(2,1fr); }
  .portfolio-grid{ grid-template-columns:repeat(3,1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; }
  .book-layout{ grid-template-columns:1fr; }
}
@media (max-width:760px){
  .container{ padding:0 22px; }
  section{ padding:80px 0; }
  .nav-links, .nav-phone{ display:none; }
  .nav-toggle{ display:flex; }
  .hero-content{ padding-bottom:120px; }
  .hero-trust{ gap:24px; }
  .services-grid{ grid-template-columns:1fr; }
  .results-grid{ grid-template-columns:1fr; }
  .process{ grid-template-columns:1fr; gap:30px; }
  .portfolio-grid{ grid-template-columns:repeat(2,1fr); gap:8px; }
  .portfolio-grid .tall{ grid-row:span 1; }
  .portfolio-grid .tall .p-item{ aspect-ratio:1/1; }
  .testi-grid{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr 1fr; gap:30px; }
  .footer-brand{ grid-column:1/-1; }
  .form-row{ grid-template-columns:1fr; }
  .sticky-cta{ display:flex; }
  .scroll-cue{ display:none; }
}
