/* ============================================================
   CSS VARIABLES & RESET
============================================================ */
:root {
  --black:    #090909;
  --dark:     #111111;
  --card:     #161616;
  --border:   rgba(255,255,255,0.07);
  --white:    #f4f1ea;
  --gold:     #c9a84c;
  --gold2:    #e8c97a;
  --muted:    rgba(244,241,234,0.45);
  --accent:   #c0392b;
  --radius:   0px;
  --nav-h:    72px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--black);color:var(--white);font-family:'DM Sans',sans-serif;font-weight:300;overflow-x:hidden;line-height:1.6}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none}

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

/* Pages */
.page{display:none;animation:pageIn .45s ease both}
.page.active{display:block}
@keyframes pageIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   NAVIGATION
============================================================ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 4rem;
  background:rgba(9,9,9,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .3s;
}
nav.scrolled{border-color:var(--border)}

.logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.45rem;letter-spacing:-.02em;color:var(--white)}
.logo span{color:var(--gold)}

.nav-center{display:flex;gap:0;list-style:none}
.nav-center>li{position:relative}
.nav-center>li>a{
  display:flex;align-items:center;gap:.3rem;
  font-family:'Syne',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);padding:.5rem 1.1rem;
  transition:color .25s;
}
.nav-center>li>a:hover,.nav-center>li>a.active{color:var(--gold)}
.nav-center>li>a svg{width:10px;height:10px;transition:transform .25s}
.nav-center>li:hover>a svg{transform:rotate(180deg)}

/* Dropdown */
.dropdown{
  position:absolute;top:calc(100%+8px);left:0;
  background:var(--dark);border:1px solid var(--border);
  min-width:220px;padding:.5rem 0;
  opacity:0;pointer-events:none;transform:translateY(8px);
  transition:opacity .25s,transform .25s;
}
.nav-center>li:hover .dropdown{opacity:1;pointer-events:all;transform:translateY(0)}
.dropdown a{
  display:block;padding:.65rem 1.2rem;
  font-family:'Syne',sans-serif;font-size:.7rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
  transition:color .2s,background .2s;
}
.dropdown a:hover{color:var(--gold);background:rgba(201,168,76,.06)}

.nav-cta{
  font-family:'Syne',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.65rem 1.6rem;border:1px solid var(--gold);
  color:var(--gold);transition:all .25s;white-space:nowrap;
}
.nav-cta:hover{background:var(--gold);color:var(--black)}

/* Mobile burger */
.burger{display:none;flex-direction:column;gap:5px;padding:.4rem;cursor:pointer}
.burger span{display:block;width:22px;height:1.5px;background:var(--white);transition:all .3s}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile drawer */
.mobile-nav{
  display:none;position:fixed;inset:0;top:var(--nav-h);z-index:999;
  background:var(--dark);flex-direction:column;padding:2rem;
  overflow-y:auto;
}
.mobile-nav.open{display:flex}
.mobile-nav a{
  font-family:'Syne',sans-serif;font-size:1rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
  padding:.9rem 0;border-bottom:1px solid var(--border);
  transition:color .25s;
}
.mobile-nav a:hover{color:var(--gold)}
.mobile-nav .m-sub{padding-left:1rem;font-size:.82rem;font-weight:600}

/* ============================================================
   HERO (HOME)
============================================================ */
.hero{
  min-height:100vh;display:grid;grid-template-columns:1fr 1fr;
  padding-top:var(--nav-h);position:relative;overflow:hidden;
}
.hero-left{
  display:flex;flex-direction:column;justify-content:center;
  padding:5rem 4rem 5rem;
}
.tag-line{
  display:flex;align-items:center;gap:1rem;
  font-family:'Syne',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gold);
  margin-bottom:2rem;
}
.tag-line::before{content:'';width:36px;height:1px;background:var(--gold)}

.hero h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,5.5vw,5.6rem);font-weight:300;line-height:1.06;
  margin-bottom:1.8rem;
}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero-desc{font-size:.95rem;line-height:1.9;color:var(--muted);max-width:400px;margin-bottom:2.8rem}
.btn-row{display:flex;gap:1rem;flex-wrap:wrap}

.btn-gold{
  font-family:'Syne',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.9rem 2.2rem;background:var(--gold);color:var(--black);
  transition:background .3s,color .3s;display:inline-flex;align-items:center;gap:.6rem;
}
.btn-gold:hover{background:var(--gold2)}
.btn-ghost{
  font-family:'Syne',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.9rem 2.2rem;border:1px solid rgba(244,241,234,.2);
  color:var(--white);transition:border-color .3s,color .3s;
  display:inline-flex;align-items:center;gap:.6rem;
}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

.hero-right{position:relative;overflow:hidden}
.hero-right img{width:100%;height:100%;object-fit:cover;filter:brightness(.65);transform:scale(1.04);transition:transform 9s ease}
.hero:hover .hero-right img{transform:scale(1)}
.hero-right::before{content:'';position:absolute;inset:0;background:linear-gradient(to right,var(--black) 0%,transparent 35%);z-index:1}

.hero-stats{
  position:absolute;bottom:0;left:0;right:0;
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--border);z-index:2;
}
.stat-box{
  padding:1.6rem 2rem;border-right:1px solid var(--border);
  background:rgba(9,9,9,.75);backdrop-filter:blur(10px);
}
.stat-box:last-child{border-right:none}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:600;color:var(--gold);display:block;line-height:1}
.stat-lbl{font-family:'Syne',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.3rem}

/* ============================================================
   TICKER
============================================================ */
.ticker{background:var(--gold);padding:.75rem 0;overflow:hidden}
.ticker-track{display:flex;gap:0;width:max-content;animation:tick 22s linear infinite}
.ticker-item{
  font-family:'Syne',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--black);
  padding:0 2.5rem;white-space:nowrap;display:flex;align-items:center;gap:2rem;
}
.ticker-item::after{content:'✦';font-size:.45rem}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   SECTIONS — SHARED
============================================================ */
section{padding:7rem 4rem}
.section-label{
  font-family:'Syne',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gold);
  display:block;margin-bottom:1rem;
}
.section-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,4vw,3.8rem);font-weight:300;line-height:1.1;
}
.section-head{margin-bottom:4rem}
.section-head.center{text-align:center}

/* reveal */
.rv{opacity:0;transform:translateY(32px);transition:opacity .75s ease,transform .75s ease}
.rv.in{opacity:1;transform:translateY(0)}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}.rv.d3{transition-delay:.3s}.rv.d4{transition-delay:.4s}

/* ============================================================
   HOME — ABOUT STRIP
============================================================ */
.about-strip{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;background:var(--dark)}
.about-strip-text p{font-size:.95rem;color:var(--muted);line-height:1.9;margin-bottom:1.2rem}
.about-strip-text .btn-gold{margin-top:.8rem}
.about-vis{position:relative}
.about-vis img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:contrast(1.05)}
.about-badge{
  position:absolute;bottom:-1.5rem;left:-1.5rem;
  background:var(--gold);color:var(--black);padding:1.8rem;
  width:148px;height:148px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
}
.about-badge b{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:600;line-height:1}
.about-badge small{font-family:'Syne',sans-serif;font-size:.58rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-top:.4rem}

/* ============================================================
   HOME — SERVICES GRID
============================================================ */
.services-wrap{background:var(--card)}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.srv-card{position:relative;overflow:hidden;/*aspect-ratio:3/4;*/cursor:pointer}
.srv-card img{width:100%;height:100%;object-fit:cover;filter:brightness(.45) contrast(1.1);transition:transform .7s ease,filter .5s}
.srv-card:hover img{transform:scale(1.07);filter:brightness(.25) contrast(1.1)}
.srv-body{
  position:absolute;inset:0;display:flex;flex-direction:column;
  justify-content:flex-end;padding:2rem 1.8rem;
}
.srv-num{font-family:'Cormorant Garamond',serif;font-size:.9rem;color:var(--gold);margin-bottom:.4rem}
.srv-card h3{font-family:'Syne',sans-serif;font-size:26px;font-weight:700;margin-bottom:.8rem}
.srv-desc{
  font-size:.85rem;line-height:1.7;color:rgba(244,241,234,.7);
  max-height:0;overflow:hidden;transition:max-height .5s ease,opacity .4s;opacity:0;
}
.srv-card:hover .srv-desc{max-height:100px;opacity:1}
.srv-more{
  font-family:'Syne',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--gold);
  display:flex;align-items:center;gap:.5rem;margin-top:.9rem;
  opacity:0;transition:opacity .35s .1s;cursor:pointer;
}
.srv-card:hover .srv-more{opacity:1}
.srv-more::after{content:'→';transition:transform .25s}
.srv-more:hover::after{transform:translateX(4px)}
.wk-video {
  position: relative;
  width: 100%;
  height: 200px;
  overflow: hidden;
}

.wk-video iframe {
  width: 100%;
  height: 100%;
}
/* ============================================================
   HOME — WORKS MASONRY
============================================================ */
.works-section{}
.works-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem}
.works-hdr h2{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,4vw,3.6rem);font-weight:300}
.works-grid{display:grid;grid-template-columns:repeat(2,1fr);gap: 20px;}
.wk{position:relative;overflow:hidden;cursor:pointer;background:var(--card)}

/*.wk:nth-child(1){grid-column:span 7;aspect-ratio:16/9}
.wk:nth-child(2){grid-column:span 5;aspect-ratio:4/5}
.wk:nth-child(3){grid-column:span 5;aspect-ratio:4/5}
.wk:nth-child(4){grid-column:span 7;aspect-ratio:16/9}*/
.wk-bg{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  transition:transform .6s ease;
}
.wk:hover .wk-bg{transform:scale(1.05)}
.play{
  width:56px;height:56px;border-radius:50%;
  border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;
  color:var(--gold);font-size:1rem;transition:all .3s;
}
.wk:hover .play{background:var(--gold);color:var(--black);transform:scale(1.1)}
.wk-ov{
  position:absolute;inset:0;background:linear-gradient(to top,rgba(9,9,9,.85) 0%,transparent 60%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:1.4rem;
  opacity:0;transition:opacity .35s;
}
.wk:hover .wk-ov{opacity:1}
.wk-tag{font-family:'Syne',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:.3rem}
.wk-name{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:400}

/* work placeholders */
.wk-ph{width:100%;height:100%;min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}

/* ============================================================
   HOME — PROCESS
============================================================ */
.process-wrap{background:var(--dark)}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:4.5rem}
.proc-step{padding:2.5rem 2rem;border-left:1px solid var(--border);position:relative;overflow:hidden}
.proc-step::before{
  content:attr(data-n);
  position:absolute;top:-1.5rem;right:1rem;
  font-family:'Cormorant Garamond',serif;font-size:7rem;font-weight:600;
  color:rgba(201,168,76,.06);line-height:1;pointer-events:none;
}
.proc-step h3{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:300;margin:1rem 0 .8rem}
.proc-step p{font-size:.85rem;color:var(--muted);line-height:1.8}
.proc-lbl{font-family:'Syne',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}

/* ============================================================
   HOME — CLIENTS
============================================================ */
.clients-wrap{overflow:hidden}
.cl-track{display:flex;gap:0;width:max-content;animation:tick 20s linear infinite}
.cl-item{
  display:flex;align-items:center;justify-content:center;
  width:150px;height:64px;flex-shrink:0;
  border:1px solid var(--border);margin:0 .5rem;
  font-family:'Syne',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:rgba(244,241,234,.2);
  transition:border-color .3s,color .3s;cursor:pointer;
}
.cl-item:hover{border-color:var(--gold);color:var(--gold)}

/* ============================================================
   HOME — TESTIMONIALS
============================================================ */
.testi-wrap{background:var(--card);overflow:hidden}
.testi-inner{max-width:820px;margin:0 auto;text-align:center;position:relative}
.testi-inner::before{
  content:'"';position:absolute;top:-4rem;left:-3rem;
  font-family:'Cormorant Garamond',serif;font-size:18rem;font-weight:600;
  color:rgba(201,168,76,.05);line-height:1;pointer-events:none;
}
.testi-slide{display:none}
.testi-slide.active{display:block}
.testi-text{
  font-family:'Cormorant Garamond',serif;font-size:clamp(1.5rem,2.8vw,2.2rem);
  font-weight:300;font-style:italic;line-height:1.55;margin-bottom:2rem;
  color:rgba(244,241,234,.9);
}
.testi-author{font-family:'Syne',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.testi-role{font-size:.78rem;color:var(--muted);margin-top:.3rem}
.testi-dots{display:flex;justify-content:center;gap:.6rem;margin-top:2.5rem}
.testi-dots span{
  width:28px;height:2px;background:var(--border);cursor:pointer;transition:background .3s;display:block;
}
.testi-dots span.active{background:var(--gold)}

/* ============================================================
   CTA BANNER
============================================================ */
.cta-banner{
  background:var(--gold);padding:5rem 4rem;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;
}
.cta-banner h2{
  font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,4vw,3.2rem);
  font-weight:300;color:var(--black);line-height:1.1;
}
.cta-banner h2 em{font-style:italic;font-weight:600}
.btn-dark{
  font-family:'Syne',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.9rem 2.4rem;background:var(--black);color:var(--white);
  white-space:nowrap;transition:all .3s;
}
.btn-dark:hover{background:var(--dark)}

/* ============================================================
   FAQ
============================================================ */
.faq-wrap{background:var(--dark)}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--border);margin-top:4rem}
.faq-item{background:var(--dark);padding:1.8rem 2rem;cursor:pointer;transition:background .25s}
.faq-item:hover{background:rgba(201,168,76,.04)}
.faq-q{font-family:'Syne',sans-serif;font-size:.85rem;font-weight:600;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}
.faq-ic{color:var(--gold);font-size:1.3rem;flex-shrink:0;transition:transform .3s;line-height:1}
.faq-item.open .faq-ic{transform:rotate(45deg)}
.faq-a{font-size:.85rem;color:var(--muted);line-height:1.8;max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s}
.faq-item.open .faq-a{max-height:200px;padding-top:.9rem}

/* ============================================================
   CONTACT FORM
============================================================ */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:7rem;align-items:start}
.contact-info-block{margin-top:2.5rem;display:flex;flex-direction:column;gap:1.2rem}
.info-row{display:flex;align-items:flex-start;gap:1rem}
.info-ico{
  width:36px;height:36px;border:1px solid var(--border);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;color:var(--gold);
}
.info-ico svg{width:15px;height:15px}
.info-row span{font-size:.88rem;color:var(--muted);line-height:1.6}
.info-row a{color:var(--muted);transition:color .25s}
.info-row a:hover{color:var(--gold)}
.locations{margin-top:2rem;font-family:'Syne',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

.form-field{margin-bottom:1.4rem}
.form-field label{
  display:block;font-family:'Syne',sans-serif;font-size:.62rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:.55rem;
}
.form-field input,.form-field textarea,.form-field select{
  width:100%;background:transparent;border:none;
  border-bottom:1px solid rgba(244,241,234,.12);
  color:var(--white);font-family:'DM Sans',sans-serif;font-size:.95rem;
  padding:.7rem 0;outline:none;transition:border-color .3s;
  appearance:none;resize:none;
}
.form-field input::placeholder,.form-field textarea::placeholder{color:rgba(244,241,234,.2)}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{border-color:var(--gold)}
.form-field select option{background:var(--dark);color:var(--white)}
.form-field textarea{min-height:90px}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.form-submit{
  font-family:'Syne',sans-serif;font-size:.75rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:1rem 2.8rem;background:var(--gold);color:var(--black);
  transition:background .3s;width:100%;margin-top:.5rem;
}
.form-submit:hover{background:var(--gold2)}

/* ============================================================
   PAGE HERO (inner pages)
============================================================ */
.page-hero{
  padding-top:var(--nav-h);min-height:44vh;
  display:flex;flex-direction:column;justify-content:flex-end;
  position:relative;overflow:hidden;
}
.page-hero-bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  filter:brightness(.35);
}
.page-hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,var(--black) 0%,transparent 70%)}
.page-hero-content{position:relative;z-index:2;padding:0 4rem 4rem}
.breadcrumb{display:flex;gap:.5rem;align-items:center;margin-bottom:1rem;font-family:'Syne',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.breadcrumb span{color:var(--gold)}
.breadcrumb::before{content:'';width:28px;height:1px;background:var(--gold)}
.page-hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.8rem,6vw,5rem);font-weight:300;line-height:1.05}
.page-hero h1 em{font-style:italic;color:var(--gold)}
.page-hero p{font-size:1rem;color:var(--muted);max-width:560px;margin-top:1.2rem;line-height:1.8}

/* ============================================================
   ABOUT PAGE
============================================================ */
.about-main{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;background:var(--dark)}
.about-main img{width:100%;aspect-ratio:3/2;object-fit:cover}
.about-main h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3vw,2.8rem);font-weight:300;margin-bottom:1.2rem;line-height:1.15}
.about-main p{font-size:.92rem;color:var(--muted);line-height:1.9;margin-bottom:1.1rem}

.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:4rem}
.val-card{background:var(--card);padding:2rem;border-top:2px solid var(--gold)}
.val-card h4{font-family:'Syne',sans-serif;font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem}
.val-card p{font-size:.85rem;color:var(--muted);line-height:1.7}

.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:4rem}
.review-card{background:var(--card);padding:2rem;border:1px solid var(--border)}
.stars{color:var(--gold);font-size:.9rem;margin-bottom:.9rem}
.review-card blockquote{font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic;color:rgba(244,241,234,.8);line-height:1.7;margin-bottom:1rem}
.review-card cite{font-family:'Syne',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);display:block}
.review-card .rev-role{font-size:.78rem;color:var(--muted);margin-top:.2rem}

/* ============================================================
   SERVICES PAGE
============================================================ */
.srv-page-grid{display:grid;grid-template-columns:1fr;gap:0}
.srv-row{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border-bottom:1px solid var(--border);
}
.srv-row:nth-child(even){direction:rtl}
.srv-row>*{direction:ltr}
.srv-row-img{overflow:hidden;aspect-ratio:16/10}
.srv-row-img img{width:100%;height:100%;object-fit:cover;filter:brightness(.7);transition:transform .7s ease,filter .5s}
.srv-row:hover .srv-row-img img{transform:scale(1.05);filter:brightness(.55)}
.srv-row-text{padding:4rem;display:flex;flex-direction:column;justify-content:center}
.srv-row-text h3{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3vw,2.6rem);font-weight:300;margin-bottom:1.2rem}
.srv-row-text p{font-size:.9rem;color:var(--muted);line-height:1.9;margin-bottom:.9rem}
.srv-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin:1rem 0 1.5rem}
.srv-list li{font-size:.85rem;color:var(--muted);display:flex;align-items:center;gap:.6rem}
.srv-list li::before{content:'→';color:var(--gold);flex-shrink:0}

/* sub-service cards */
.srv-sub-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:5rem}
.srv-sub{background:var(--card);padding:2rem;border-bottom:2px solid var(--border);transition:border-color .3s}
.srv-sub:hover{border-color:var(--gold)}
.srv-sub h4{font-family:'Syne',sans-serif;font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.7rem;color:var(--white)}
.srv-sub p{font-size:.82rem;color:var(--muted);line-height:1.7;margin-bottom:1rem}
.srv-sub a{font-family:'Syne',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}

/* ============================================================
   WORKS PAGE
============================================================ */
.works-filter{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:3rem}
.filter-btn{
  font-family:'Syne',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.5rem 1.2rem;border:1px solid var(--border);color:var(--muted);
  cursor:pointer;transition:all .25s;background:transparent;
}
.filter-btn:hover,.filter-btn.active{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.06)}
.works-full-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.wf-card{position:relative;overflow:hidden;cursor:pointer;background:var(--card)}
.wf-card:nth-child(4n+1){grid-column:span 2}
.wf-inner{aspect-ratio:16/9;overflow:hidden}
.wf-card:nth-child(4n+1) .wf-inner{aspect-ratio:16/9}
.wf-card:not(:nth-child(4n+1)) .wf-inner{aspect-ratio:1/1}
.wf-ph{width:100%;height:100%;min-height:200px;display:flex;align-items:center;justify-content:center;transition:transform .6s ease}
.wf-card:hover .wf-ph{transform:scale(1.04)}
.wf-info{padding:1.2rem 1.4rem}
.wf-cat{font-family:'Syne',sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.wf-title{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:400;margin-top:.3rem}

/* ============================================================
   CONTACT PAGE
============================================================ */
.contact-page .contact-wrap{padding:7rem 4rem;background:var(--dark)}
.map-strip{height:320px;background:var(--card);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.map-placeholder{text-align:center}
.map-placeholder svg{width:40px;height:40px;color:var(--gold);margin:0 auto 1rem}
.map-placeholder p{font-family:'Syne',sans-serif;font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* ============================================================
   FOOTER
============================================================ */
footer{background:#060606;padding:5rem 4rem 2rem;border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:4rem;margin-bottom:4rem}
.footer-brand .logo{display:inline-block;margin-bottom:1.2rem}
.footer-brand p{font-size:.85rem;color:var(--muted);line-height:1.8;max-width:260px}
.footer-locs{margin-top:1rem;font-family:'Syne',sans-serif;font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(244,241,234,.2);line-height:2}
.foot-col h4{font-family:'Syne',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.4rem}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:.75rem}
.foot-col a{font-size:.85rem;color:var(--muted);transition:color .25s}
.foot-col a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid var(--border);padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-size:.75rem;color:rgba(244,241,234,.2)}
.socials{display:flex;gap:1.5rem}
.socials a{font-family:'Syne',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(244,241,234,.25);transition:color .25s}
.socials a:hover{color:var(--gold)}

/* ============================================================
   RESPONSIVE
============================================================ */
@media(max-width:1200px){
  .works-full-grid{grid-template-columns:1fr 1fr}
  .wf-card:nth-child(4n+1){grid-column:span 1}
  .wf-card:nth-child(4n+1) .wf-inner{aspect-ratio:1/1}
}
@media(max-width:1024px){
  nav{padding:0 2rem}
  .nav-center{display:none}
  .burger{display:flex}
  section{padding:5rem 2rem}
  .hero{grid-template-columns:1fr}
  .hero-left{padding:4rem 2rem 3rem}
  .hero-right{height:60vw}
  .hero-right::before{background:linear-gradient(to bottom,var(--black) 0%,transparent 50%)}
  .hero-stats{position:static;grid-template-columns:repeat(3,1fr)}
  .about-strip{grid-template-columns:1fr;gap:3rem}
  .about-badge{left:-1rem;bottom:-1rem}
  .srv-grid{grid-template-columns:1fr 1fr}
  .works-grid{grid-template-columns:1fr 1fr}
  .wk:nth-child(n){grid-column:span 1;aspect-ratio:16/9}
  .proc-grid{grid-template-columns:1fr 1fr}
  .about-main{grid-template-columns:1fr;gap:3rem}
  .values-grid{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:1fr 1fr}
  .srv-row{grid-template-columns:1fr}
  .srv-row:nth-child(even){direction:ltr}
  .srv-sub-grid{grid-template-columns:1fr 1fr}
  .contact-wrap{grid-template-columns:1fr;gap:3rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:3rem}
  .cta-banner{flex-direction:column;align-items:flex-start}
  .faq-grid{grid-template-columns:1fr}
  .page-hero-content{padding:0 2rem 3rem}
}
@media(max-width:640px){
  :root{--nav-h:60px}
  nav{padding:0 1.2rem}
  .logo{font-size:1.2rem}
  .nav-cta{display:none}
  section{padding:4rem 1.2rem}
  .hero-left{padding:3rem 1.2rem 2rem}
  .hero-right{height:70vw}
  .hero-stats{grid-template-columns:1fr 1fr 1fr;overflow-x:auto}
  .stat-box{padding:1.2rem 1rem}
  .stat-num{font-size:1.8rem}
  .srv-grid{grid-template-columns:1fr}
  .works-grid{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .srv-sub-grid{grid-template-columns:1fr}
  .works-full-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .form-2col{grid-template-columns:1fr}
  .works-hdr{flex-direction:column;align-items:flex-start;gap:1rem}
  .cta-banner{padding:3rem 1.2rem}
  .page-hero-content{padding:0 1.2rem 2.5rem}
  .about-badge{width:110px;height:110px;padding:1.2rem}
  .about-badge b{font-size:1.8rem}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}
/* Hero Section */
.hero {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
}

/* Video */
.hero-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: translate(-50%, -50%);
}

/* Overlay Content */
.hero-content {
  position: relative;
  z-index: 2;
  color: #fff;
  text-align: center;
  top: 50%;
  transform: translateY(-50%);
}

/* Optional Dark Overlay */
.hero::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.5);
  z-index: 1;
}

/* Button */
.btn {
  display: inline-block;
  margin-top: 20px;
  padding: 10px 20px;
  background: #00bcd4;
  color: #fff;
  text-decoration: none;
  border-radius: 5px;
}

.burger {
  width: 30px;
  cursor: pointer;
  display: none;
  flex-direction: column;
  gap: 6px;
}

.burger span {
  height: 3px;
  width: 100%;
  background: #fff;
  display: block;
}

/* Show only on mobile */
@media (max-width: 768px) {
  .burger {
    display: flex;
  }
}
.mobile-nav {
  position: fixed;
  top: 50px;
  right: -100%;
  width: 260px;
  height: 100%;
  background: #0f172a;
  padding: 30px;
  transition: 0.3s ease;
  z-index: 999;
}

.mobile-nav.active {
  right: 0;
}
@media (max-width: 768px) {
  .nav-center,
  .nav-cta {
    display: none;
  }

  .burger {
    display: flex;
  }
}


.yt-card {
  position: relative;
  display: block;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 12px;
}

.yt-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* SMALL CENTER ICON */
.yt-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.yt-icon svg {
  width: 50px; /* smaller icon */
  height: auto;
}
