@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..700;1,9..144,400..600&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  --orange:#F4791D;
  --orange-dark:#D85F0A;
  --teal:#1C6B6B;
  --teal-dark:#123F3F;
  --ink:#1A1A1A;
  --ink-soft:#54534A;
  --paper:#FFFFFF;
  --paper-2:#F4F2EC;
  --line: rgba(26,26,26,0.12);
  --line-light: rgba(255,255,255,0.22);
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
#services, #weddings, #work, #photo, #web, #graphics, #wedding, #voice, #adverts, #portfolio{scroll-margin-top:110px;}
body{font-family:'Inter', sans-serif; background:var(--paper); color:var(--ink); overflow-x:hidden;}
img,svg{display:block; max-width:100%;}
a{color:inherit; text-decoration:none;}
button{font-family:inherit; cursor:pointer; border:none; background:none;}

.eyebrow{
  font-family:'JetBrains Mono', monospace; font-size:12px; letter-spacing:.12em;
  text-transform:uppercase; display:flex; align-items:center; gap:8px;
}
.eyebrow::before{content:''; width:6px; height:6px; background:var(--orange); border-radius:50%; display:inline-block;}

h1,h2,h3{font-family:'Fraunces', serif; font-weight:500; letter-spacing:-0.01em; line-height:1.05;}

.play::before{
  content:''; display:inline-block; width:0; height:0;
  border-top:5px solid transparent; border-bottom:5px solid transparent;
  border-left:8px solid var(--teal); margin-right:8px;
}

/* ===== NAV ===== */
/* ===== TOP UTILITY BAR ===== */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:210;
  background:var(--ink); color:rgba(255,255,255,0.85);
  display:flex; align-items:center; justify-content:space-between;
  padding:9px 5%; font-family:'JetBrains Mono', monospace; font-size:12px; letter-spacing:.02em;
}
.topbar .topbar-links{display:flex; gap:24px; align-items:center;}
.topbar .topbar-links a{display:flex; align-items:center; gap:6px; transition:color .2s ease;}
.topbar .topbar-links a:hover{color:var(--orange);}
.topbar .topbar-tag{opacity:.7; display:flex; align-items:center; gap:6px;}
.topbar .topbar-tag::before{content:''; width:6px; height:6px; border-radius:50%; background:#5FD89A; display:inline-block;}

nav{
  position:fixed; top:36px; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 5%; background:rgba(255,255,255,0.92); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.logo{display:flex; align-items:center; gap:8px; font-family:'Fraunces', serif; font-weight:600; font-size:21px;}
.logo .mark{width:26px; height:26px; position:relative;}
.logo .mark svg{width:100%; height:100%;}
.logo span{color:var(--orange);}
.nav-links{display:flex; gap:34px; font-size:14px; font-weight:500;}
.nav-links a{position:relative; padding:4px 0; font-size:14px; font-weight:500;}
.nav-links a::after{content:''; position:absolute; left:0; bottom:0; width:0; height:2px; background:var(--orange); transition:width .25s ease;}
.nav-links a:hover::after, .nav-links a.current::after{width:100%;}
.nav-cta{
  font-size:13px; font-weight:700; padding:11px 22px; border-radius:30px;
  font-family:'JetBrains Mono', monospace; text-transform:uppercase; letter-spacing:.05em;
  background:var(--teal); color:#fff; transition:all .25s ease;
}
.nav-cta:hover{background:var(--teal-dark);}
.nav-icon{margin-right:7px; font-size:14px; display:inline-block; transform:translateY(1px);}
.nav-cta .nav-icon{margin-right:6px;}
.mobile-menu a .nav-icon{margin-right:12px; font-size:16px;}

/* ===== TRANSPARENT HEADER (home page only) ===== */
body.home-page nav{
  background:transparent; border-bottom-color:transparent;
  transition:background .35s ease, border-color .35s ease, box-shadow .35s ease;
}
body.home-page nav .logo, body.home-page nav .nav-links a{color:#fff;}
body.home-page nav .logo span{color:var(--orange);}
body.home-page nav .burger span{background:#fff;}
body.home-page nav.nav-scrolled{
  background:rgba(255,255,255,0.94); backdrop-filter:blur(10px);
  border-bottom-color:var(--line); box-shadow:0 2px 20px rgba(0,0,0,0.06);
}
body.home-page nav.nav-scrolled .logo, body.home-page nav.nav-scrolled .nav-links a{color:var(--ink);}
body.home-page nav.nav-scrolled .burger span{background:var(--ink);}
@media (max-width:900px){
  body.home-page nav{background:rgba(255,255,255,0.92); border-bottom-color:var(--line);}
  body.home-page nav .logo, body.home-page nav .nav-links a{color:var(--ink);}
  body.home-page nav .burger span{background:var(--ink);}
}
.burger{display:none; flex-direction:column; gap:5px; padding:6px;}
.burger span{width:24px; height:2px; background:var(--ink); display:block;}
.mobile-menu{
  position:fixed; top:0; right:-100%; width:78%; max-width:320px; height:100vh;
  background:var(--teal-dark); z-index:300; padding:90px 30px 30px; transition:right .35s ease;
  display:flex; flex-direction:column; gap:26px;
}
.mobile-menu.open{right:0;}
.mobile-menu a{color:#fff; font-size:18px; text-align:left; font-family:'Fraunces',serif;}
.mobile-menu .nav-cta{align-self:flex-start; margin-top:10px;}
.menu-close{position:absolute; top:24px; right:24px; color:#fff; font-size:26px;}
.overlay{position:fixed; inset:0; background:rgba(0,0,0,0.4); z-index:250; opacity:0; pointer-events:none; transition:opacity .3s ease;}
.overlay.show{opacity:1; pointer-events:auto;}

/* ===== PAGE HEADER (non-home pages) ===== */
.page-header{
  background:var(--teal-dark); color:#fff; padding:206px 5% 70px; text-align:center;
}
.page-header.parallax-header{position:relative; overflow:hidden; padding:230px 5% 90px;}
.page-header.parallax-header .scrim{position:absolute; inset:0; background:rgba(10,10,10,0.55); z-index:1;}
.page-header h1{font-size:clamp(34px,5vw,56px); color:#fff;}
.page-header p{margin-top:14px; color:rgba(255,255,255,0.75); max-width:520px; margin-left:auto; margin-right:auto;}

/* ===== PARALLAX ===== */
.parallax-img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;
  transform:scale(1.15); will-change:transform;
}

/* ===== HERO SLIDER (home) ===== */
.hero{position:relative; height:92vh; min-height:560px; overflow:hidden; color:#fff;}
.slides{position:absolute; inset:0;}
.slide{
  position:absolute; inset:0; opacity:0; transition:opacity .9s ease;
  display:flex; align-items:center; padding:0 5%;
}
.slide.active{opacity:1;}
.slide img.bg{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; filter:contrast(1.08) saturate(1.12) brightness(1.02);}
.slide img.bg.kenburns{animation:kenburns 7s ease-out forwards;}
@keyframes kenburns{
  from{transform:scale(1.0);}
  to{transform:scale(1.12);}
}
.slide .scrim{position:absolute; inset:0; background:linear-gradient(100deg, rgba(18,18,18,0.78) 0%, rgba(18,18,18,0.45) 45%, rgba(18,18,18,0.15) 75%); z-index:1;}
.slide-content{max-width:600px; position:relative; z-index:2;}
.slide-content .eyebrow{color:#FFD9B0;}
.slide-content .eyebrow::before{background:#fff;}
.slide-content h1{font-size:clamp(36px,5.4vw,64px); margin-top:16px; color:#fff;}
.slide-content p{margin-top:18px; font-size:16px; line-height:1.6; color:rgba(255,255,255,0.85); max-width:460px;}
.slide-ctas{display:flex; gap:14px; margin-top:30px; flex-wrap:wrap;}
.btn-primary{
  background:#fff; color:var(--ink); padding:15px 28px; border-radius:30px;
  font-weight:700; font-size:14px; transition:transform .2s ease; display:inline-block;
}
.btn-primary:hover{transform:translateY(-2px);}
.btn-ghost{
  border:1px solid rgba(255,255,255,0.5); color:#fff; padding:15px 28px; border-radius:30px;
  font-weight:700; font-size:14px; transition:all .2s ease; display:inline-block;
}
.btn-ghost:hover{border-color:#fff; background:rgba(255,255,255,0.1);}

.slider-nav{position:absolute; bottom:30px; left:5%; display:flex; gap:10px; z-index:3;}
.slider-nav button{width:34px; height:4px; background:rgba(255,255,255,0.4); border-radius:4px; transition:background .25s ease;}
.slider-nav button.active{background:#fff;}
.slider-arrows{position:absolute; bottom:26px; right:5%; display:flex; gap:10px; z-index:3;}
.slider-arrows button{
  width:42px; height:42px; border-radius:50%; border:1px solid rgba(255,255,255,0.5);
  color:#fff; display:flex; align-items:center; justify-content:center; font-size:18px;
  transition:all .2s ease;
}
.slider-arrows button:hover{background:rgba(255,255,255,0.15);}

.radial-divider{
  background:var(--ink); padding:14px 0; overflow:hidden; position:relative;
  border-top:1px solid var(--line-light); border-bottom:1px solid var(--line-light);
}
.marquee{
  display:flex; gap:40px; white-space:nowrap; color:#fff;
  font-family:'JetBrains Mono', monospace; font-size:13px; letter-spacing:.1em; text-transform:uppercase;
  animation: scroll 26s linear infinite; width:max-content;
}
@keyframes scroll{ from{transform:translateX(0);} to{transform:translateX(-50%);} }
.marquee span{opacity:.9;}
.marquee span.dot{color:var(--orange);}

section{padding:100px 5%;}
.section-inner{max-width:1760px; margin:0 auto;}
.section-head{display:flex; justify-content:space-between; align-items:flex-end; gap:24px; margin-bottom:50px; flex-wrap:wrap;}
.section-head h2{font-size:clamp(30px,4vw,46px);}
.section-head p{max-width:380px; color:var(--ink-soft); font-size:15px; line-height:1.6;}

.service-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(280px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line);}
.service-card{background:var(--paper); padding:36px 28px; transition:background .25s ease; position:relative;}
.service-card:hover{background:var(--paper-2);}
.service-tc{font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--orange-dark); letter-spacing:.05em;}
.service-card h3{font-size:22px; margin-top:14px; font-weight:500;}
.service-card p{margin-top:10px; font-size:14px; line-height:1.6; color:var(--ink-soft);}
.service-card .arrow{
  margin-top:18px; font-family:'JetBrains Mono', monospace; font-size:12px;
  display:inline-flex; align-items:center; gap:6px; color:var(--teal); font-weight:600;
}
.service-card .arrow:hover{text-decoration:underline;}

.work{background:var(--teal-dark); color:#fff;}
.work .section-head p{color:rgba(255,255,255,0.7);}
.work-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(240px,1fr)); gap:14px;}
.work-item{
  aspect-ratio:3/4; border-radius:6px; position:relative; overflow:hidden;
  display:flex; flex-direction:column; justify-content:flex-end; padding:16px; cursor:pointer;
  transition:transform .25s ease;
}
.work-item img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;}
.work-item .scrim{position:absolute; inset:0; background:linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.65) 100%); z-index:1;}
.work-item .work-tag, .work-item .work-title{position:relative; z-index:2;}
.work-item:hover{transform:translateY(-4px);}
.work-item.tall{grid-row:span 2; aspect-ratio:auto;}
.work-tag{font-family:'JetBrains Mono', monospace; font-size:11px; text-transform:uppercase; letter-spacing:.08em; opacity:.9; color:#fff;}
.work-title{font-family:'Fraunces',serif; font-size:18px; margin-top:6px; color:#fff;}

.wedding{background:var(--paper-2);}
.wedding-grid{display:grid; grid-template-columns:0.9fr 1.1fr; gap:60px; align-items:center;}
.wedding-visual{
  aspect-ratio:4/5; border-radius:8px; position:relative; overflow:hidden;
  display:flex; align-items:flex-end; padding:26px; cursor:pointer;
}
.wedding-visual img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;}
.wedding-visual .scrim{position:absolute; inset:0; background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.6) 100%); z-index:1;}
.wedding-visual .badge{
  font-family:'JetBrains Mono', monospace; font-size:12px; color:#fff; position:relative; z-index:2;
  background:rgba(0,0,0,0.35); padding:8px 14px; border-radius:30px;
}
.wedding-copy h2{font-size:clamp(28px,4vw,42px); margin:16px 0 18px;}
.wedding-copy p{font-size:16px; line-height:1.7; color:var(--ink-soft); max-width:460px; margin-bottom:26px;}
.wedding-list{display:flex; flex-direction:column; gap:12px; margin-bottom:30px;}
.wedding-list div{display:flex; gap:10px; font-size:14px; align-items:baseline;}

.testimonial{background:var(--ink); color:#fff; text-align:center;}
.testimonial blockquote{
  font-family:'Fraunces', serif; font-style:italic; font-size:clamp(22px,3.2vw,36px);
  font-weight:400; max-width:780px; margin:0 auto; line-height:1.4;
}
.testimonial cite{
  display:block; margin-top:24px; font-family:'JetBrains Mono', monospace; font-size:13px;
  color:var(--orange); font-style:normal; letter-spacing:.05em;
}
.testimonial-dots{display:flex; gap:8px; justify-content:center; margin-top:34px;}
.testimonial-dots button{width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,0.3);}
.testimonial-dots button.active{background:var(--orange);}

/* ===== CONTACT PAGE ===== */
.contact-band{background:var(--orange); color:#fff;}
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start;}
.contact-band h2{font-size:clamp(30px,4.4vw,48px); color:#fff;}
.contact-band p{margin-top:14px; opacity:.95; font-size:16px; max-width:420px;}
.contact-cards{display:flex; flex-direction:column; gap:16px; margin-top:30px;}
.contact-cards a{
  display:flex; align-items:center; gap:14px; background:rgba(255,255,255,0.15);
  padding:16px 20px; border-radius:10px; font-weight:600; transition:background .2s ease;
}
.contact-cards a:hover{background:rgba(255,255,255,0.25);}
.contact-cards .icon{font-size:18px;}
.contact-extra{margin-top:34px; padding-top:30px; border-top:1px solid rgba(255,255,255,0.3);}
.contact-extra h4{font-family:'JetBrains Mono',monospace; font-size:12px; text-transform:uppercase; letter-spacing:.06em; margin-bottom:10px;}
.contact-extra p{font-size:14px; line-height:1.7; opacity:.9;}

.form-card{background:#fff; color:var(--ink); border-radius:14px; padding:34px; box-shadow:0 20px 50px rgba(0,0,0,0.15);}
.form-card h3{font-size:22px; margin-bottom:18px;}
.form-row{margin-bottom:16px;}
.form-row label{display:block; font-size:12px; font-family:'JetBrains Mono', monospace; text-transform:uppercase; letter-spacing:.05em; margin-bottom:6px; color:var(--ink-soft);}
.form-row input, .form-row select, .form-row textarea{
  width:100%; padding:12px 14px; border:1px solid var(--line); border-radius:8px; font-family:'Inter'; font-size:14px;
}
.form-row textarea{resize:vertical; min-height:90px;}
.form-submit{
  width:100%; background:var(--teal); color:#fff; padding:15px; border-radius:8px;
  font-weight:700; font-size:14px; margin-top:6px; transition:background .2s ease;
}
.form-submit:hover{background:var(--teal-dark);}
.form-note{font-size:12px; color:var(--ink-soft); margin-top:10px;}

/* ===== PORTFOLIO PAGE — PASSGALLERY STYLE ===== */
.gallery-cover{
  position:relative; height:62vh; min-height:420px; overflow:hidden;
  display:flex; align-items:center; justify-content:center; text-align:center; color:#fff;
}
.gallery-cover img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;}
.gallery-cover .scrim{position:absolute; inset:0; background:rgba(10,10,10,0.55); z-index:1;}
.gallery-cover-content{position:relative; z-index:2; padding:0 20px;}
.gallery-cover-content .eyebrow{justify-content:center; color:#FFD9B0;}
.gallery-cover-content .eyebrow::before{background:#fff;}
.gallery-cover-content h1{font-size:clamp(38px,6vw,68px); color:#fff; margin-top:14px; font-style:italic; font-weight:400;}
.gallery-cover-content p{margin-top:14px; color:rgba(255,255,255,0.8); max-width:480px; margin-left:auto; margin-right:auto;}
.scroll-cue{
  position:absolute; bottom:24px; left:50%; transform:translateX(-50%); z-index:2;
  color:#fff; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:6px; opacity:.8;
}
.scroll-cue .line{width:1px; height:26px; background:rgba(255,255,255,0.6); animation:scrollcue 1.8s ease-in-out infinite;}
@keyframes scrollcue{0%{transform:scaleY(0.3); opacity:.4;} 50%{transform:scaleY(1); opacity:1;} 100%{transform:scaleY(0.3); opacity:.4;}}

.portfolio-tabs{display:flex; gap:10px; margin-bottom:8px; justify-content:center;}
.ptab{
  padding:10px 26px; border-radius:30px; font-size:13px; font-weight:700;
  font-family:'JetBrains Mono', monospace; text-transform:uppercase; letter-spacing:.05em;
  border:1px solid var(--line); color:var(--ink-soft); transition:all .2s ease;
}
.ptab.active{background:var(--ink); color:#fff; border-color:var(--ink);}

/* Album view */
.album-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(240px,1fr)); gap:22px; margin-top:50px;}
.album-card{cursor:pointer; transition:transform .25s ease;}
.album-card:hover{transform:translateY(-4px);}
.album-cover{aspect-ratio:1/1; border-radius:6px; overflow:hidden; position:relative;}
.album-cover img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .4s ease;}
.album-card:hover .album-cover img{transform:scale(1.06);}
.album-cover .scrim{position:absolute; inset:0; background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.55) 100%);}
.album-meta{margin-top:14px; text-align:center;}
.album-meta h3{font-size:19px; font-style:italic; font-weight:400;}
.album-meta span{display:block; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); margin-top:4px;}

/* Justified/masonry gallery view */
.gallery-back{
  display:inline-flex; align-items:center; gap:8px; font-family:'JetBrains Mono', monospace;
  font-size:12px; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-soft);
  margin-bottom:30px; cursor:pointer;
}
.gallery-back:hover{color:var(--orange-dark);}
.gallery-view-title{text-align:center; margin-bottom:40px;}
.gallery-view-title h2{font-style:italic; font-weight:400;}
.gallery-view-title span{display:block; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); margin-top:8px;}

.masonry{column-count:3; column-gap:6px;}
@media (min-width:1200px){ .masonry{column-count:4;} }
@media (min-width:1600px){ .masonry{column-count:5;} }
.masonry .m-item{margin-bottom:6px; border-radius:4px; overflow:hidden; cursor:pointer; break-inside:avoid; position:relative;}
.masonry .m-item img{width:100%; display:block; transition:transform .4s ease;}
.masonry .m-item:hover img{transform:scale(1.03);}

.video-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:50px;}
.video-item{
  aspect-ratio:16/9; border-radius:8px; overflow:hidden; cursor:pointer; position:relative;
  display:flex; align-items:center; justify-content:center; transition:transform .25s ease;
  background:linear-gradient(160deg,#1C6B6B,#123F3F);
  background-size:cover; background-position:center;
}
.video-item:hover{transform:scale(1.02);}
.video-item .vplay{
  width:54px; height:54px; border-radius:50%; background:rgba(255,255,255,0.92);
  display:flex; align-items:center; justify-content:center; z-index:2;
}
.video-item .vplay::before{
  content:''; width:0; height:0; border-top:9px solid transparent; border-bottom:9px solid transparent;
  border-left:15px solid var(--teal-dark); margin-left:3px;
}
.video-item .vlabel{position:absolute; bottom:12px; left:14px; color:#fff; font-family:'Fraunces',serif; font-size:15px; z-index:2;}
.video-item .vtag{position:absolute; top:12px; left:14px; color:#fff; font-family:'JetBrains Mono',monospace; font-size:10px; text-transform:uppercase; letter-spacing:.08em; background:rgba(0,0,0,0.35); padding:4px 9px; border-radius:20px; z-index:2;}
.video-item .voverlay{position:absolute; inset:0; background:rgba(0,0,0,0.25);}
.video-category-head{margin:50px 0 0; text-align:center;}
.video-category-head:first-child{margin-top:0;}
.video-category-head h3{font-style:italic; font-weight:400; font-size:24px;}


/* ===== LIGHTBOX — full-screen passgallery style ===== */
.lightbox-overlay{
  position:fixed; inset:0; background:#0a0a0a; z-index:500; display:none;
  flex-direction:column; align-items:center; justify-content:center;
}
.lightbox-overlay.show{display:flex;}
.lightbox-top{
  position:absolute; top:0; left:0; right:0; display:flex; justify-content:space-between;
  align-items:center; padding:22px 28px; z-index:10; color:#fff;
}
.lightbox-counter{font-family:'JetBrains Mono', monospace; font-size:12px; letter-spacing:.08em; opacity:.8;}
.lightbox-frame{
  flex:1; width:100%; display:flex; align-items:center; justify-content:center; position:relative; padding:80px 80px 0;
}
.lightbox-frame img{max-width:100%; max-height:70vh; object-fit:contain; border-radius:2px;}
.lightbox-caption{color:#fff; margin-top:16px; font-family:'JetBrains Mono', monospace; font-size:12px; opacity:.75; text-align:center;}
.lightbox-close{position:relative; color:#fff; font-size:24px; z-index:10;}
.lightbox-arrow{
  position:fixed; top:50%; transform:translateY(-50%); color:#fff; font-size:30px;
  width:50px; height:50px; display:flex; align-items:center; justify-content:center; opacity:.7; transition:opacity .2s ease;
}
.lightbox-arrow:hover{opacity:1;}
.lightbox-arrow.left{left:14px;} .lightbox-arrow.right{right:14px;}
.thumb-strip{
  display:flex; gap:8px; padding:16px 20px; overflow-x:auto; max-width:90vw; margin-top:14px;
}
.thumb-strip img{
  width:56px; height:56px; object-fit:cover; border-radius:4px; cursor:pointer; opacity:.5;
  transition:opacity .2s ease, outline .2s ease; flex-shrink:0;
}
.thumb-strip img.active{opacity:1; outline:2px solid var(--orange);}

.video-frame{width:min(90vw,900px); aspect-ratio:16/9; border-radius:6px; overflow:hidden; background:#000; position:relative;}
.video-frame video{width:100%; height:100%; object-fit:contain; background:#000; cursor:pointer;}

.player-overlay-play{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:opacity .2s ease; background:rgba(0,0,0,0.15);
}
.video-frame.playing .player-overlay-play{opacity:0; pointer-events:none;}
.player-big-play-btn{
  width:76px; height:76px; border-radius:50%; background:rgba(255,255,255,0.92);
  display:flex; align-items:center; justify-content:center; transition:transform .2s ease;
}
.player-overlay-play:hover .player-big-play-btn{transform:scale(1.08);}
.player-big-play-btn::before{
  content:''; width:0; height:0; border-top:14px solid transparent; border-bottom:14px solid transparent;
  border-left:22px solid var(--teal-dark); margin-left:6px;
}

.player-controls{
  position:absolute; left:0; right:0; bottom:0; z-index:5;
  display:flex; align-items:center; gap:12px; padding:10px 16px;
  background:linear-gradient(0deg, rgba(0,0,0,0.85), rgba(0,0,0,0));
}
.player-btn{
  width:30px; height:30px; flex-shrink:0; color:#fff; display:flex; align-items:center; justify-content:center;
  font-size:14px; position:relative;
}
#playerPlayBtn .icon-play, #playerPlayBtn .icon-pause{
  width:0; height:0; position:absolute;
}
#playerPlayBtn .icon-play{
  border-top:7px solid transparent; border-bottom:7px solid transparent; border-left:11px solid #fff; margin-left:2px;
}
.video-frame.playing #playerPlayBtn .icon-play{display:none;}
.video-frame:not(.playing) #playerPlayBtn .icon-pause{display:none;}
#playerPlayBtn .icon-pause{
  width:9px; height:12px; border-left:3px solid #fff; border-right:3px solid #fff; background:transparent;
}
#playerMuteBtn .icon-vol::before{content:'🔊'; font-size:14px;}
#playerMuteBtn .icon-mute::before{content:'🔇'; font-size:14px;}
.video-frame:not(.muted) #playerMuteBtn .icon-mute{display:none;}
.video-frame.muted #playerMuteBtn .icon-vol{display:none;}
.player-time{color:rgba(255,255,255,0.85); font-family:'JetBrains Mono', monospace; font-size:11px; flex-shrink:0; min-width:34px;}
.player-progress{
  flex:1; height:4px; background:rgba(255,255,255,0.25); border-radius:4px; position:relative; cursor:pointer;
}
.player-progress-fill{position:absolute; top:0; left:0; height:100%; background:var(--orange); border-radius:4px; width:0%;}
.player-progress-handle{
  position:absolute; top:50%; left:0%; width:11px; height:11px; border-radius:50%; background:#fff;
  transform:translate(-50%,-50%); box-shadow:0 0 0 2px rgba(0,0,0,0.2);
}
.player-error{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center; text-align:center;
  color:#fff; font-family:'JetBrains Mono', monospace; font-size:13px; background:var(--teal-dark); padding:20px;
}

@media (max-width:900px){
  .album-grid{grid-template-columns:repeat(2,1fr);}
  .masonry{column-count:2;}
  .video-grid{grid-template-columns:1fr;}
  .lightbox-frame{padding:70px 16px 0;}
  .lightbox-arrow{display:none;}
  .thumb-strip{display:none;}
}

/* ===== WEDDING PACKAGES ===== */
.packages-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:start;}
.package-card{
  background:#fff; border:1px solid var(--line); border-radius:16px; padding:38px 30px;
  text-align:center; position:relative; transition:transform .25s ease, box-shadow .25s ease;
}
.package-card:hover{transform:translateY(-6px); box-shadow:0 24px 50px rgba(0,0,0,0.08);}
.package-card.featured{border-color:var(--orange); box-shadow:0 20px 50px rgba(244,121,29,0.15);}
.package-badge{
  position:absolute; top:-13px; left:50%; transform:translateX(-50%);
  background:var(--orange); color:#fff; font-family:'JetBrains Mono', monospace; font-size:11px;
  text-transform:uppercase; letter-spacing:.06em; padding:5px 16px; border-radius:20px;
}
.package-name{font-family:'Fraunces',serif; font-style:italic; font-size:28px; font-weight:400; color:var(--orange-dark);}
.package-price{font-size:clamp(30px,3.4vw,40px); font-weight:600; margin:10px 0 4px; font-family:'Fraunces',serif;}
.package-price span{font-size:14px; font-family:'Inter'; font-weight:500; color:var(--ink-soft);}
.package-cameras{font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--ink-soft); text-transform:uppercase; letter-spacing:.05em; margin-bottom:24px;}
.package-list{list-style:none; text-align:left; display:flex; flex-direction:column; gap:11px; margin-bottom:28px;}
.package-list li{display:flex; gap:8px; font-size:14px; line-height:1.4; color:var(--ink);}
.package-list li::before{content:'✓'; color:var(--teal); font-weight:700; flex-shrink:0;}
.package-card .btn-primary{width:100%; background:var(--teal); color:#fff; box-shadow:none;}
.package-card.featured .btn-primary{background:var(--orange);}

@media (max-width:900px){
  .packages-grid{grid-template-columns:1fr; max-width:440px; margin:0 auto;}
}
.booking-section{background:var(--paper-2);}
.booking-form-card{
  background:#fff; border-radius:16px; padding:42px; max-width:700px; margin:0 auto;
  box-shadow:0 20px 50px rgba(0,0,0,0.08);
}
.booking-form-card h3{font-size:24px; margin-bottom:6px;}
.booking-form-card .booking-sub{font-size:14px; color:var(--ink-soft); margin-bottom:28px;}
.booking-row-2{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
.selected-package-badge{
  display:inline-flex; align-items:center; gap:8px; background:var(--paper-2); border:1px solid var(--line);
  padding:8px 16px; border-radius:30px; font-family:'JetBrains Mono', monospace; font-size:12px;
  margin-bottom:24px; color:var(--ink-soft);
}
.selected-package-badge strong{color:var(--orange-dark);}
@media (max-width:600px){
  .booking-row-2{grid-template-columns:1fr;}
  .booking-form-card{padding:28px;}
}

.service-detail{display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center;}
.service-detail.flip .service-detail-visual{order:2;}
.service-detail.flip .service-detail-copy{order:1;}
.service-detail-visual{aspect-ratio:5/4; border-radius:14px; overflow:hidden; position:relative;}
.service-detail-visual img{width:100%; height:100%; object-fit:cover;}
.service-detail-copy .service-tc{font-size:13px;}
.service-detail-copy h2{font-size:clamp(28px,3.6vw,40px); margin:14px 0 18px;}
.service-detail-copy p{font-size:16px; line-height:1.75; color:var(--ink-soft); margin-bottom:18px; max-width:520px;}
.service-includes{display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:20px 0 28px;}
.service-includes div{display:flex; gap:8px; font-size:14px; align-items:baseline;}
.service-divider{height:1px; background:var(--line); margin:0 5%;}
.cta-band-final{background:var(--teal-dark); color:#fff; text-align:center;}
.cta-band-final h2{color:#fff; font-size:clamp(28px,4vw,42px);}
.cta-band-final p{margin-top:14px; color:rgba(255,255,255,0.75); max-width:480px; margin-left:auto; margin-right:auto;}
@media (max-width:900px){
  .service-detail, .service-detail.flip{grid-template-columns:1fr;}
  .service-detail.flip .service-detail-visual, .service-detail.flip .service-detail-copy{order:initial;}
  .service-includes{grid-template-columns:1fr;}
}
footer{background:var(--teal-dark); color:rgba(255,255,255,0.65); padding:64px 5% 26px;}
.footer-grid{max-width:1280px; margin:0 auto; display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:46px; border-bottom:1px solid rgba(255,255,255,0.12);}
.footer-grid h4{font-family:'JetBrains Mono', monospace; font-size:12px; text-transform:uppercase; letter-spacing:.08em; color:#fff; margin-bottom:18px;}
.footer-grid ul{list-style:none; display:flex; flex-direction:column; gap:10px; font-size:14px;}
.footer-grid ul a, .footer-grid ul button{font-size:14px; text-align:left;}
.footer-grid ul a:hover, .footer-grid ul button:hover{color:var(--orange);}
.footer-logo{display:flex; align-items:center; gap:8px; font-family:'Fraunces',serif; font-size:23px; color:#fff; margin-bottom:14px;}
.footer-logo span{color:var(--orange);}
.footer-bottom{max-width:1280px; margin:22px auto 0; display:flex; justify-content:space-between; font-size:12px; font-family:'JetBrains Mono', monospace; flex-wrap:wrap; gap:10px;}

/* ===== ABOUT PAGE ===== */
section.paper-2{background:var(--paper-2);}
.about-grid{display:grid; grid-template-columns:0.9fr 1.1fr; gap:60px; align-items:center;}
.about-visual{aspect-ratio:4/5; border-radius:10px; overflow:hidden; position:relative;}
.about-visual img{width:100%; height:100%; object-fit:cover;}
.about-copy h2{font-size:clamp(28px,4vw,42px); margin:14px 0 18px;}
.about-copy p{font-size:16px; line-height:1.75; color:var(--ink-soft); margin-bottom:16px; max-width:480px;}
.values-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:24px;}
.value-card{background:#fff; border:1px solid var(--line); border-radius:12px; padding:28px 24px;}
.value-card h3{font-size:19px; margin-top:12px; font-weight:500;}
.value-card p{margin-top:10px; font-size:14px; line-height:1.6; color:var(--ink-soft);}

/* ===== STATS / COUNTER STRIP ===== */
.stats-strip{background:var(--ink); color:#fff; padding:60px 5%;}
.stats-grid{
  max-width:1760px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr);
  gap:30px; text-align:center;
}
.stat-item h3{
  font-size:clamp(34px,4.5vw,52px); color:var(--orange); font-weight:500;
  display:flex; align-items:baseline; justify-content:center; gap:4px;
}
.stat-item span.suffix{font-size:0.5em; color:var(--orange);}
.stat-item p{margin-top:8px; font-family:'JetBrains Mono', monospace; font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:rgba(255,255,255,0.65);}

@media (max-width:900px){
  .stats-grid{grid-template-columns:repeat(2,1fr); gap:36px 20px;}
}
.reveal{opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s ease;}
.reveal.in-view{opacity:1; transform:translateY(0);}

.service-card.reveal:nth-child(1){transition-delay:.0s;}
.service-card.reveal:nth-child(2){transition-delay:.08s;}
.service-card.reveal:nth-child(3){transition-delay:.16s;}
.service-card.reveal:nth-child(4){transition-delay:.24s;}
.service-card.reveal:nth-child(5){transition-delay:.32s;}
.service-card.reveal:nth-child(6){transition-delay:.4s;}
.work-item.reveal:nth-child(1){transition-delay:.0s;}
.work-item.reveal:nth-child(2){transition-delay:.07s;}
.work-item.reveal:nth-child(3){transition-delay:.14s;}
.work-item.reveal:nth-child(4){transition-delay:.21s;}
.work-item.reveal:nth-child(5){transition-delay:.28s;}
.work-item.reveal:nth-child(6){transition-delay:.35s;}
.album-card.reveal:nth-child(1){transition-delay:.0s;}
.album-card.reveal:nth-child(2){transition-delay:.08s;}
.album-card.reveal:nth-child(3){transition-delay:.16s;}
.album-card.reveal:nth-child(4){transition-delay:.24s;}
.album-card.reveal:nth-child(5){transition-delay:.32s;}
.why-card.reveal:nth-child(1){transition-delay:.0s;}
.why-card.reveal:nth-child(2){transition-delay:.08s;}
.why-card.reveal:nth-child(3){transition-delay:.16s;}
.why-card.reveal:nth-child(4){transition-delay:.24s;}
.why-card.reveal:nth-child(5){transition-delay:.32s;}
.why-card.reveal:nth-child(6){transition-delay:.4s;}

/* ===== BACK TO TOP ===== */
.back-to-top{
  position:fixed; bottom:28px; right:28px; width:46px; height:46px; border-radius:50%;
  background:var(--ink); color:#fff; font-size:18px; display:flex; align-items:center; justify-content:center;
  z-index:150; opacity:0; pointer-events:none; transform:translateY(10px);
  transition:opacity .3s ease, transform .3s ease, background .2s ease;
}
.back-to-top.show{opacity:1; pointer-events:auto; transform:translateY(0);}
.back-to-top:hover{background:var(--orange);}

@media (max-width:900px){
  .topbar{display:none;}
  nav{top:0;}
  #services, #weddings, #work, #photo, #web, #graphics, #wedding, #voice, #adverts, #portfolio{scroll-margin-top:80px;}
  .about-grid{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:repeat(2,1fr);}
  .nav-links{display:none;}
  .burger{display:flex;}
  .service-grid{grid-template-columns:1fr;}
  .work-grid{grid-template-columns:repeat(2,1fr);}
  .work-item.tall{grid-row:auto; aspect-ratio:3/4;}
  .wedding-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .hero{height:88vh;}
  .video-grid{grid-template-columns:1fr;}
  .lightbox-arrow{display:none;}
}
@media (max-width:600px){
  .values-grid{grid-template-columns:1fr;}
}

/* ===== WHATSAPP CHAT BUBBLE ===== */
.wa-bubble{
  position:fixed; bottom:88px; right:28px; z-index:300;
  width:56px; height:56px; border-radius:50%;
  background:#25D366; box-shadow:0 6px 24px rgba(37,211,102,0.45);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:transform .25s ease, box-shadow .25s ease;
  text-decoration:none;
}
.wa-bubble:hover{transform:scale(1.1); box-shadow:0 10px 30px rgba(37,211,102,0.55);}
.wa-bubble svg{width:30px; height:30px; fill:#fff;}
.wa-tooltip{
  position:fixed; bottom:98px; right:92px; z-index:299;
  background:var(--ink); color:#fff; font-family:'JetBrains Mono', monospace;
  font-size:12px; padding:8px 14px; border-radius:8px; white-space:nowrap;
  opacity:0; pointer-events:none; transition:opacity .2s ease;
}
.wa-tooltip::after{
  content:''; position:absolute; right:-8px; top:50%; transform:translateY(-50%);
  border:5px solid transparent; border-left-color:var(--ink);
}
.wa-bubble:hover + .wa-tooltip{ opacity:1; }

/* ===== WHY CHOOSE US ===== */
.why-us{background:var(--teal-dark); color:#fff;}
.why-us .section-head h2{color:#fff;}
.why-us .section-head p{color:rgba(255,255,255,0.7);}
.why-grid{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr));
  gap:24px;
}
.why-card{
  background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.1);
  border-radius:14px; padding:32px 26px; transition:background .25s ease, transform .25s ease;
  position:relative; overflow:hidden;
}
.why-card::before{
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--orange),var(--orange-dark));
  transform:scaleX(0); transform-origin:left; transition:transform .35s ease;
}
.why-card:hover{ background:rgba(255,255,255,0.12); transform:translateY(-4px);}
.why-card:hover::before{transform:scaleX(1);}
.why-icon{font-size:32px; margin-bottom:16px; display:block;}
.why-card h3{font-size:19px; color:#fff; margin-bottom:10px; font-weight:500;}
.why-card p{font-size:14px; line-height:1.65; color:rgba(255,255,255,0.7);}

/* ===== E-CARD PAGE ===== */
.ecard-hero{
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
  position:relative; overflow:hidden; color:#fff; padding:120px 5% 60px;
}
.ecard-hero img.bg{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;}
.ecard-hero .scrim{position:absolute; inset:0; background:rgba(8,8,8,0.65); z-index:1;}
.ecard-hero-content{position:relative; z-index:2; max-width:780px; margin:0 auto;}
.ecard-names{
  font-family:'Fraunces', serif; font-size:clamp(48px,8vw,96px); font-weight:400;
  font-style:italic; line-height:1.05; color:#fff;
  text-shadow:0 2px 30px rgba(0,0,0,0.4);
}
.ecard-names .ampersand{color:var(--orange); font-size:0.7em;}
.ecard-date{
  font-family:'JetBrains Mono', monospace; font-size:14px; letter-spacing:.2em;
  text-transform:uppercase; margin:20px 0; color:rgba(255,255,255,0.8);
  display:flex; align-items:center; justify-content:center; gap:16px;
}
.ecard-date::before,.ecard-date::after{content:''; flex:1; max-width:80px; height:1px; background:rgba(255,255,255,0.4);}
.ecard-tagline{font-size:18px; line-height:1.6; color:rgba(255,255,255,0.85); max-width:560px; margin:0 auto 36px;}

.ecard-countdown{
  display:flex; gap:18px; justify-content:center; margin:30px 0;
  flex-wrap:wrap;
}
.ecard-unit{
  background:rgba(255,255,255,0.12); backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.2); border-radius:12px;
  padding:18px 24px; min-width:90px; text-align:center;
}
.ecard-unit .num{
  font-family:'Fraunces', serif; font-size:clamp(32px,5vw,52px);
  font-weight:400; color:#fff; display:block; line-height:1;
}
.ecard-unit .lbl{
  font-family:'JetBrains Mono', monospace; font-size:10px;
  text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,0.65);
  margin-top:6px; display:block;
}

.ecard-body{background:var(--paper-2);}
.ecard-details{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(280px,1fr));
  gap:24px; margin-top:50px;
}
.ecard-detail-card{
  background:#fff; border-radius:14px; padding:32px 28px;
  border:1px solid var(--line); text-align:center;
  transition:transform .25s ease, box-shadow .25s ease;
}
.ecard-detail-card:hover{transform:translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,0.08);}
.ecard-detail-card .icon{font-size:36px; display:block; margin-bottom:14px;}
.ecard-detail-card h3{font-size:20px; margin-bottom:10px;}
.ecard-detail-card p{font-size:15px; color:var(--ink-soft); line-height:1.6;}
.ecard-detail-card .detail-label{
  font-family:'JetBrains Mono', monospace; font-size:11px; text-transform:uppercase;
  letter-spacing:.08em; color:var(--orange-dark); margin-bottom:6px; display:block;
}

.ecard-gallery{display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-top:50px;}
.ecard-gallery .g-item{aspect-ratio:1/1; overflow:hidden; border-radius:8px; cursor:pointer;}
.ecard-gallery .g-item img{width:100%; height:100%; object-fit:cover; transition:transform .4s ease;}
.ecard-gallery .g-item:hover img{transform:scale(1.06);}

.ecard-rsvp{background:var(--orange); color:#fff;}
.ecard-rsvp h2{color:#fff; font-size:clamp(28px,4vw,44px);}
.ecard-rsvp p{color:rgba(255,255,255,0.9); margin-top:12px; max-width:480px; margin-left:auto; margin-right:auto; text-align:center;}
.rsvp-form{
  background:#fff; color:var(--ink); max-width:560px; margin:34px auto 0;
  border-radius:16px; padding:38px; box-shadow:0 20px 50px rgba(0,0,0,0.15);
}

@media(max-width:900px){
  .ecard-gallery{grid-template-columns:repeat(2,1fr);}
}

/* ===== TEAM SECTION (about page) ===== */
.team-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:28px;}
.team-card{text-align:center;}
.team-photo{
  aspect-ratio:1/1; border-radius:14px; overflow:hidden; position:relative;
  background:linear-gradient(160deg, var(--paper-2), #e7e3d8);
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line);
}
.team-photo svg{width:42%; height:42%; opacity:.35;}
.team-photo img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover;}
.team-name{font-family:'Fraunces', serif; font-size:19px; margin-top:16px; font-weight:500;}
.team-role{
  font-family:'JetBrains Mono', monospace; font-size:11px; text-transform:uppercase;
  letter-spacing:.07em; color:var(--orange-dark); margin-top:4px;
}
.team-bio{font-size:13px; line-height:1.6; color:var(--ink-soft); margin-top:10px; max-width:260px; margin-left:auto; margin-right:auto;}

/* ===== ABOUT DETAIL LIST ===== */
.about-highlights{display:flex; flex-direction:column; gap:12px; margin:20px 0 26px;}
.about-highlights div{display:flex; gap:10px; font-size:14px; align-items:baseline;}
.about-lead{
  font-family:'JetBrains Mono', monospace; font-size:12px; text-transform:uppercase;
  letter-spacing:.08em; color:var(--orange-dark); margin-bottom:10px; display:block;
}

/* ===== CONTACT MAP ===== */
.map-section{background:var(--paper-2);}
.map-wrap{
  border-radius:16px; overflow:hidden; border:1px solid var(--line);
  box-shadow:0 20px 50px rgba(0,0,0,0.06); position:relative;
}
.map-wrap iframe{width:100%; height:420px; display:block; border:0;}
.map-caption{
  display:flex; flex-wrap:wrap; gap:10px 28px; justify-content:center;
  margin-top:22px; font-family:'JetBrains Mono', monospace; font-size:12px;
  color:var(--ink-soft); text-transform:uppercase; letter-spacing:.04em;
}
.map-caption span{display:flex; align-items:center; gap:6px;}
