:root {
  --bg: #0A0A0A; --bg-2: #141414; --bg-3: #1C1C1C;
  --gold: #C9A86C; --gold-bright: #E5C56F;
  --cream: #F5F0E8; --text: #F5F0E8; --text-dim: #B8B0A3; --text-muted: #7A7468;
  --line: rgba(201, 168, 108, 0.18); --line-strong: rgba(201, 168, 108, 0.4);
  --max-w: 1320px;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; background: var(--bg); color: var(--text); line-height: 1.6; font-weight: 300; font-size: 16px; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 24px; }
.eyebrow { font-size: 11px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--gold); font-weight: 400; margin-bottom: 16px; display: inline-block; }
h1, h2, h3, h4 { font-weight: 300; line-height: 1.15; letter-spacing: -0.01em; }
h1 { font-size: clamp(40px, 6vw, 84px); }
h2 { font-size: clamp(30px, 4vw, 52px); margin-bottom: 24px; }
h3 { font-size: clamp(20px, 2.4vw, 27px); margin-bottom: 12px; }
p { color: var(--text-dim); margin-bottom: 16px; }

/* UTILITY + HEADER */
.utility-bar { background: #050505; border-bottom: 1px solid var(--line); font-size: 12px; letter-spacing: 0.08em; color: var(--text-dim); }
.utility-bar .container { display: flex; justify-content: space-between; align-items: center; padding: 10px 24px; }
.utility-bar .left { display: flex; gap: 28px; }
.utility-bar .right { display: flex; gap: 24px; align-items: center; }
.utility-bar a:hover { color: var(--gold); }
.utility-bar .ig { color: var(--gold); }

.site-header { position: sticky; top: 0; z-index: 100; background: rgba(10, 10, 10, 0.94); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border-bottom: 1px solid var(--line); transition: transform 0.3s ease; }
.site-header.hide { transform: translateY(-100%); }
.site-header .container { display: flex; justify-content: space-between; align-items: center; padding: 16px 24px; }
.brand img { height: 60px; filter: none; }
.nav-main { display: flex; gap: 30px; align-items: center; }
.nav-main > a, .nav-main .has-dropdown > a { font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text); padding: 8px 0; font-weight: 400; transition: color 0.2s; }
.nav-main > a:hover, .nav-main .has-dropdown > a:hover { color: var(--gold); }
.has-dropdown { position: relative; }
.dropdown { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px); background: var(--bg-2); border: 1px solid var(--line); padding: 14px 0; min-width: 280px; opacity: 0; visibility: hidden; transition: all 0.25s ease; }
.has-dropdown:hover .dropdown { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.dropdown a { display: block; padding: 10px 24px; font-size: 12px; letter-spacing: 0.1em; }
.dropdown a:hover { background: var(--bg-3); color: var(--gold); }
.cta-pill { background: linear-gradient(135deg, var(--gold-bright) 0%, var(--gold) 58%, #b8965a 100%); color: #1a1408 !important; padding: 12px 30px; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 600; transition: transform .25s ease, box-shadow .25s ease, filter .25s ease; border: none; box-shadow: 0 6px 20px rgba(201,168,108,0.28), inset 0 1px 0 rgba(255,255,255,0.35); }
.cta-pill:hover { transform: translateY(-1px); filter: brightness(1.06); box-shadow: 0 10px 28px rgba(201,168,108,0.42), inset 0 1px 0 rgba(255,255,255,0.4); color: #1a1408 !important; }

/* MOBILE MENU */
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 8px; background: none; border: none; z-index: 120; }
.hamburger span { display: block; width: 26px; height: 2px; background: var(--gold); transition: all 0.3s ease; }
.mobile-nav { position: fixed; inset: 0; background: rgba(10,10,10,0.98); backdrop-filter: blur(10px); z-index: 110; transform: translateX(100%); transition: transform 0.35s cubic-bezier(0.7,0,0.3,1); display: flex; flex-direction: column; padding: 100px 32px 40px; overflow-y: auto; }
.mobile-nav.open { transform: translateX(0); }
.mobile-nav a { color: var(--cream); font-size: 18px; letter-spacing: 0.06em; padding: 15px 0; border-bottom: 1px solid var(--line); display: block; }
.mobile-nav a:hover, .mobile-nav a.sub { color: var(--gold); }
.mobile-nav a.sub { font-size: 14px; padding: 11px 0 11px 18px; color: var(--text-dim); }
.mobile-nav .m-label { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); margin-top: 24px; margin-bottom: 4px; }
.mobile-nav .m-cta { background: var(--gold); color: var(--bg); text-align: center; padding: 16px; margin-top: 28px; border: none; font-weight: 500; letter-spacing: 0.15em; text-transform: uppercase; font-size: 13px; }
.body-lock { overflow: hidden; }

/* BUTTONS */
.btn-primary, .btn-secondary { display: inline-block; padding: 17px 36px; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; font-weight: 500; transition: all 0.3s ease; cursor: pointer; }
.btn-primary { background: var(--gold); color: var(--bg); border: 1px solid var(--gold); }
.btn-primary:hover { background: var(--gold-bright); border-color: var(--gold-bright); }
.btn-secondary { background: transparent; color: var(--cream); border: 1px solid rgba(245, 240, 232, 0.35); }
.btn-secondary:hover { border-color: var(--gold); color: var(--gold); }

section { padding: 100px 0; }
.section-header { text-align: center; max-width: 760px; margin: 0 auto 60px; }
.section-header h2 .accent, h1 .accent, h2 .accent { color: var(--gold); font-style: italic; }

/* HERO (home) */
.hero { position: relative; min-height: 92vh; display: flex; align-items: center; overflow: hidden; background: var(--bg); }
.hero::before { content: ''; position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0.30; filter: grayscale(0.2) brightness(0.55); z-index: 0; }
.hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,10,10,0.5) 0%, rgba(10,10,10,0.4) 50%, rgba(10,10,10,0.95) 100%); z-index: 1; }
.hero .container { position: relative; z-index: 2; padding-top: 80px; padding-bottom: 80px; }
.hero-content { max-width: 920px; }
.hero h1 { font-weight: 200; margin-bottom: 28px; letter-spacing: -0.02em; }
.hero h1 .accent { font-weight: 300; }
.hero .subhead { font-size: clamp(17px, 1.7vw, 21px); color: var(--cream); max-width: 700px; margin-bottom: 12px; line-height: 1.5; }
.hero .mission { color: var(--gold); font-size: 14px; letter-spacing: 0.15em; text-transform: uppercase; margin-bottom: 44px; }
.hero-ctas { display: flex; gap: 16px; flex-wrap: wrap; }

/* SERVICE PAGE HERO */
.svc-hero { position: relative; min-height: 70vh; display: flex; align-items: flex-end; overflow: hidden; background: var(--bg); }
.svc-hero::before { content: ''; position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0.42; filter: grayscale(0.15) brightness(0.6); z-index: 0; }
.svc-hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,10,10,0.6) 0%, rgba(10,10,10,0.35) 45%, rgba(10,10,10,0.97) 100%); z-index: 1; }
.svc-hero .container { position: relative; z-index: 2; padding-top: 120px; padding-bottom: 64px; }
.breadcrumb { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 20px; }
.breadcrumb a { color: var(--gold); }
.breadcrumb span { margin: 0 8px; }
.svc-hero h1 { font-weight: 200; margin-bottom: 20px; max-width: 900px; }
.svc-hero .lead { font-size: clamp(16px, 1.8vw, 20px); color: var(--cream); max-width: 680px; margin-bottom: 32px; line-height: 1.55; }
.svc-hero .hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; }

/* TRUST STRIP */
.trust-strip { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 34px 0; background: #060606; }
.trust-strip .container { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; text-align: center; }
.trust-item .num { display: block; font-size: 36px; color: var(--gold); font-weight: 200; margin-bottom: 4px; }
.trust-item .label { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-dim); }

/* SVC BODY */
.svc-body { padding: 90px 0; }
.svc-layout { display: grid; grid-template-columns: 1fr 340px; gap: 72px; align-items: start; }
.svc-main h2 { margin-top: 8px; }
.svc-main h2:not(:first-child) { margin-top: 56px; }
.svc-main p { line-height: 1.8; margin-bottom: 18px; color: var(--text-dim); }
.svc-main strong { color: var(--cream); font-weight: 500; }
.svc-main a.inline { color: var(--gold); border-bottom: 1px solid var(--line-strong); }

/* OPTIONS LIST */
.options { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); margin: 28px 0; }
.option { background: var(--bg); padding: 22px 24px; display: flex; justify-content: space-between; align-items: baseline; gap: 16px; transition: background 0.3s; }
.option:hover { background: var(--bg-2); }
.option .o-name { color: var(--cream); font-size: 16px; font-weight: 400; }
.option .o-meta { color: var(--text-muted); font-size: 13px; white-space: nowrap; }
.option .o-desc { color: var(--text-muted); font-size: 13.5px; margin-top: 4px; line-height: 1.5; }

/* PROCESS STEPS */
.steps { display: grid; gap: 20px; margin: 28px 0; counter-reset: step; }
.step { display: flex; gap: 20px; align-items: flex-start; }
.step .s-num { flex-shrink: 0; width: 44px; height: 44px; border: 1px solid var(--gold); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 16px; font-weight: 300; }
.step .s-text h4 { color: var(--cream); font-size: 17px; font-weight: 400; margin-bottom: 6px; }
.step .s-text p { font-size: 14.5px; margin-bottom: 0; }

/* SIDEBAR */
.svc-sidebar { position: sticky; top: 100px; }
.side-card { border: 1px solid var(--line); background: var(--bg-2); padding: 30px; margin-bottom: 20px; }
.side-card h4 { color: var(--cream); font-size: 18px; font-weight: 400; margin-bottom: 18px; }
.side-card .info-row { display: flex; justify-content: space-between; padding: 11px 0; border-bottom: 1px solid var(--line); font-size: 14px; }
.side-card .info-row:last-of-type { border-bottom: none; }
.side-card .info-row .k { color: var(--text-muted); }
.side-card .info-row .v { color: var(--cream); text-align: right; }
.side-card .btn-primary { width: 100%; text-align: center; margin-top: 18px; }
.side-card.gold { background: linear-gradient(135deg, #1a1408 0%, #0f0f0f 100%); border-color: var(--line-strong); }

/* FAQ */
.faq-list { max-width: 880px; margin: 0 auto; }
.faq-item { border-top: 1px solid var(--line); padding: 26px 0; }
.faq-item:last-child { border-bottom: 1px solid var(--line); }
.faq-q { display: flex; justify-content: space-between; align-items: center; cursor: pointer; font-size: 17px; font-weight: 400; color: var(--cream); padding-right: 24px; transition: color 0.3s; gap: 16px; }
.faq-q:hover { color: var(--gold); }
.faq-q .toggle { color: var(--gold); font-size: 22px; font-weight: 200; width: 30px; text-align: center; flex-shrink: 0; transition: transform 0.3s; }
.faq-item.open .faq-q .toggle { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height 0.4s ease, padding 0.4s ease; color: var(--text-dim); }
.faq-item.open .faq-a { max-height: 500px; padding-top: 16px; }
.faq-a p { font-size: 15px; line-height: 1.7; margin-bottom: 0; }

/* RELATED */
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.related-card { border: 1px solid var(--line); padding: 28px 24px; transition: all 0.3s; background: var(--bg); }
.related-card:hover { border-color: var(--gold); background: var(--bg-2); }
.related-card h4 { color: var(--cream); font-size: 18px; font-weight: 400; margin-bottom: 8px; transition: color 0.3s; }
.related-card:hover h4 { color: var(--gold); }
.related-card p { font-size: 13.5px; color: var(--text-muted); margin-bottom: 14px; }
.related-card .arrow { color: var(--gold); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; }

/* HOME: services grid */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); }
.service-card { background: var(--bg); position: relative; transition: all 0.4s ease; cursor: pointer; min-height: 380px; display: flex; flex-direction: column; overflow: hidden; }
.service-card .card-img { height: 220px; background-size: cover; background-position: center; filter: grayscale(0.2) brightness(0.85); transition: filter 0.4s ease, transform 0.6s ease; }
.service-card:hover .card-img { filter: grayscale(0) brightness(1); transform: scale(1.05); }
.service-card .card-body { padding: 28px 28px 32px; flex: 1; display: flex; flex-direction: column; justify-content: space-between; }
.service-card .num { font-size: 10px; letter-spacing: 0.25em; color: var(--gold); margin-bottom: 12px; }
.service-card h3 { font-size: 22px; margin-bottom: 12px; font-weight: 300; transition: color 0.3s; }
.service-card:hover h3 { color: var(--gold); }
.service-card .desc { font-size: 13.5px; color: var(--text-muted); line-height: 1.6; margin-bottom: 20px; }
.service-card .arrow { color: var(--gold); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; transition: transform 0.3s; }
.service-card:hover .arrow { transform: translateX(8px); }

/* VIDEO BAND */
.video-band { padding: 0; background: #000; position: relative; }
.video-band .video-wrap { position: relative; width: 100%; aspect-ratio: 16 / 9; max-height: 720px; cursor: pointer; overflow: hidden; }
.video-band .thumb { position: absolute; inset: 0; background-size: cover; background-position: center; filter: grayscale(0.1) brightness(0.65); transition: filter 0.4s ease, transform 0.6s ease; }
.video-band .video-wrap:hover .thumb { filter: grayscale(0) brightness(0.8); transform: scale(1.02); }
.video-band .overlay { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; z-index: 2; }
.video-band .play-btn { width: 90px; height: 90px; border-radius: 50%; border: 2px solid var(--gold); background: rgba(201, 168, 108, 0.18); backdrop-filter: blur(8px); display: flex; align-items: center; justify-content: center; transition: all 0.3s ease; margin-bottom: 26px; }
.video-band .video-wrap:hover .play-btn { background: var(--gold); transform: scale(1.08); }
.video-band .play-btn svg { width: 30px; height: 30px; fill: var(--gold); transition: fill 0.3s; margin-left: 4px; }
.video-band .video-wrap:hover .play-btn svg { fill: var(--bg); }
.video-band .video-title { color: var(--cream); font-size: clamp(22px, 2.5vw, 36px); font-weight: 300; margin-bottom: 8px; }
.video-band .video-title em { color: var(--gold); font-style: italic; }
.video-band .video-sub { color: var(--text-dim); font-size: 14px; letter-spacing: 0.15em; text-transform: uppercase; }
.video-band iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: none; }
.video-band.playing .thumb, .video-band.playing .overlay { display: none; }
.video-band.playing iframe { display: block; }

/* GALLERY */
.gallery-section { background: var(--bg-2); }
.gallery-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 240px; gap: 16px; }
.gallery-item { background-size: cover; background-position: center; border: 1px solid var(--line); transition: filter 0.4s ease, transform 0.4s ease; cursor: pointer; filter: grayscale(0.15) brightness(0.95); position: relative; overflow: hidden; }
.gallery-item:hover { filter: grayscale(0) brightness(1.05); transform: scale(1.02); }
.gallery-item.tall { grid-row: span 2; }
.gallery-item.wide { grid-column: span 2; }
.gallery-cta { text-align: center; margin-top: 48px; }

/* SPLIT */
.featured-split { background: var(--bg); padding: 0; }
.split-row { display: grid; grid-template-columns: 1fr 1fr; min-height: 560px; }
.split-row + .split-row { border-top: 1px solid var(--line); }
.split-row:nth-child(even) .split-img { order: 2; }
.split-img { background-size: cover; background-position: center; filter: grayscale(0.1) brightness(0.92); }
.split-content { padding: 76px 60px; display: flex; flex-direction: column; justify-content: center; }
.split-content h2 { margin-bottom: 22px; }
.split-content .price { font-size: 13px; color: var(--gold); letter-spacing: 0.18em; text-transform: uppercase; margin: 14px 0 30px; display: block; }
.split-content .btn-secondary { align-self: flex-start; }
.sub-services { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 24px; margin: 20px 0 28px; }
.sub-services li { list-style: none; padding: 8px 0; color: var(--cream); font-size: 14px; border-bottom: 1px solid var(--line); position: relative; padding-left: 18px; }
.sub-services li::before { content: '·'; color: var(--gold); position: absolute; left: 0; font-size: 22px; line-height: 1; top: 6px; }

/* PARTNER */
.partner-band { background: linear-gradient(135deg, #0A0A0A 0%, #1C1C1C 100%); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 80px 0; }
.partner-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.partner-content h2 em { color: var(--gold); font-style: italic; }
.partner-logo { display: flex; align-items: center; gap: 24px; margin: 30px 0 0; padding-top: 24px; border-top: 1px solid var(--line); }
.partner-logo img { height: 40px; opacity: 0.85; }
.partner-logo span { font-size: 12px; color: var(--text-muted); letter-spacing: 0.15em; text-transform: uppercase; }
.partner-img { aspect-ratio: 4/5; background-size: cover; background-position: center; border: 1px solid var(--line); filter: grayscale(0.15); }

/* WHY */
.why-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); }
.why-item { padding: 56px 32px; border-right: 1px solid var(--line); text-align: center; }
.why-item:last-child { border-right: none; }
.why-item .icon { width: 60px; height: 60px; margin: 0 auto 24px; border: 1px solid var(--gold); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 24px; }
.why-item h4 { font-size: 18px; font-weight: 400; margin-bottom: 12px; }
.why-item p { font-size: 14px; color: var(--text-muted); }

/* TEAM */
.team-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 48px; max-width: 900px; margin: 0 auto; }
.team-card { text-align: center; }
.team-card .portrait { width: 100%; aspect-ratio: 3/4; background-size: cover; background-position: center top; margin-bottom: 24px; filter: grayscale(0.2); transition: filter 0.4s ease; border: 1px solid var(--line); }
.team-card:hover .portrait { filter: grayscale(0); }
.team-card h4 { font-size: 24px; color: var(--cream); margin-bottom: 6px; font-weight: 400; }
.team-card .role { color: var(--gold); font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; }

/* CONTACT */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.contact-info .info-block { margin-bottom: 32px; }
.contact-info .info-block .label { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); margin-bottom: 8px; }
.contact-info .info-block .val { font-size: 18px; color: var(--cream); font-weight: 300; line-height: 1.5; }
.contact-info .info-block .val a { color: var(--cream); }
.contact-info .info-block .val a:hover { color: var(--gold); }
.map-embed { width: 100%; aspect-ratio: 4/3; border: 1px solid var(--line); filter: grayscale(0.3) invert(0.92) hue-rotate(180deg) brightness(0.95); }

/* FINAL CTA */
.final-cta { background: linear-gradient(135deg, #0A0A0A 0%, #1C1C1C 100%); text-align: center; position: relative; overflow: hidden; }
.final-cta::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at center, rgba(201, 168, 108, 0.10) 0%, transparent 70%); }
.final-cta .container { position: relative; z-index: 1; }
.final-cta h2 { margin-bottom: 24px; font-size: clamp(36px, 5vw, 60px); }
.final-cta p { font-size: 18px; max-width: 580px; margin: 0 auto 40px; }

/* FOOTER */
.footer-cta-banner { background: var(--gold); color: var(--bg); text-align: center; padding: 48px 24px; }
.footer-cta-banner h3 { font-size: clamp(24px, 3vw, 34px); color: var(--bg); margin-bottom: 16px; font-weight: 300; }
.footer-cta-banner h3 em { font-style: italic; }
.footer-cta-banner p { color: rgba(10, 10, 10, 0.75); margin-bottom: 24px; }
.footer-cta-banner .btn-dark { display: inline-block; background: var(--bg); color: var(--gold); padding: 16px 36px; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; font-weight: 500; border: 1px solid var(--bg); transition: all 0.3s; }
.footer-cta-banner .btn-dark:hover { background: transparent; color: var(--bg); }

.site-footer { background: #050505; padding: 76px 0 30px; color: var(--text-dim); }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 48px; margin-bottom: 56px; }
.footer-col h5 { color: var(--gold); font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 20px; font-weight: 500; }
.footer-col ul { list-style: none; }
.footer-col li { margin-bottom: 10px; }
.footer-col a { font-size: 14px; color: var(--text-dim); transition: color 0.2s; }
.footer-col a:hover { color: var(--gold); }
.footer-brand img { height: 76px; margin-bottom: 20px; filter: none; }
.footer-brand p { font-size: 14px; line-height: 1.7; margin-bottom: 16px; }
.footer-social { display: flex; gap: 16px; margin-top: 20px; }
.footer-social a { width: 38px; height: 38px; border: 1px solid var(--line); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--gold); transition: all 0.3s; font-size: 11px; }
.footer-social a:hover { background: var(--gold); color: var(--bg); border-color: var(--gold); }
.footer-bottom { border-top: 1px solid var(--line); padding-top: 28px; display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: var(--text-muted); }
.footer-bottom a { color: var(--text-muted); }
.footer-bottom a:hover { color: var(--gold); }
.footer-bottom .legal { display: flex; gap: 20px; }
.footer-bottom .designed em { color: var(--gold); font-style: normal; }

.reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.8s ease, transform 0.8s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* RESPONSIVE */
@media (max-width: 1024px) {
  .nav-main { display: none; }
  .hamburger { display: flex; }
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery-grid { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 200px; }
  .svc-layout { grid-template-columns: 1fr; gap: 48px; }
  .svc-sidebar { position: static; }
  .split-row { grid-template-columns: 1fr; min-height: auto; }
  .split-row:nth-child(even) .split-img { order: 0; }
  .split-img { min-height: 320px; }
  .split-content { padding: 56px 32px; }
  .related-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .why-grid { grid-template-columns: repeat(2, 1fr); }
  .why-item:nth-child(2) { border-right: none; }
  .why-item:nth-child(1), .why-item:nth-child(2) { border-bottom: 1px solid var(--line); }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .partner-grid { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: 1fr; max-width: 400px; }
  .sub-services { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .utility-bar .left span:nth-child(2) { display: none; }
  .services-grid { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; gap: 8px; }
  .gallery-item.wide { grid-column: span 1; }
  .trust-strip .container { grid-template-columns: repeat(2, 1fr); gap: 32px; }
  .why-grid { grid-template-columns: 1fr; }
  .why-item { border-right: none; border-bottom: 1px solid var(--line); }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; gap: 12px; }
  section { padding: 64px 0; }
  .svc-body { padding: 56px 0; }
  .split-content { padding: 44px 24px; }
  .video-band .play-btn { width: 68px; height: 68px; margin-bottom: 14px; }
  .options .option { flex-direction: column; gap: 4px; }
  .option .o-meta { white-space: normal; }
}

/* ===== Instagram sections (added) ===== */
.ig-section{padding:90px 0;background:var(--bg);}
.ig-section.alt{background:var(--bg-2);}
.ig-accent{color:var(--gold);font-style:italic;}
.ig-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;margin-top:38px;}
.ig-photo{position:relative;display:block;aspect-ratio:1/1;background-size:cover;background-position:center;border:1px solid var(--line);overflow:hidden;transition:transform .45s ease,border-color .3s ease;}
.ig-photo:hover{transform:scale(1.025);border-color:var(--gold);}
.ig-photo::after{content:'↗';position:absolute;top:10px;right:12px;color:#fff;opacity:0;transition:opacity .3s ease;font-size:15px;text-shadow:0 1px 5px rgba(0,0,0,.6);}
.ig-photo:hover::after{opacity:1;}
.ig-reels{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;margin-top:30px;}
.ig-reel-cell{border:1px solid var(--gold);background:#fff;border-radius:3px;overflow:hidden;min-height:120px;}
.ig-reel-cell .instagram-media{margin:0 !important;min-width:0 !important;width:100% !important;border:0 !important;box-shadow:none !important;border-radius:0 !important;}
.ig-follow{margin-top:42px;text-align:center;}
@media(max-width:600px){.ig-photos{grid-template-columns:repeat(2,1fr);gap:8px;}.ig-section{padding:64px 0;}}

/* ===== Native editorial media (real IG photos + video woven into the page) ===== */
.media-band{position:relative;width:100%;height:72vh;min-height:440px;background-size:cover;background-position:center;display:flex;align-items:flex-end;}
.media-band .media-cap{padding:34px 28px;width:100%;background:linear-gradient(transparent,rgba(0,0,0,.55));}
.media-band .media-cap .eyebrow{color:var(--gold-bright);margin:0;}
.media-video{position:relative;width:100%;background:#000;overflow:hidden;}
.media-video video{width:100%;height:78vh;min-height:460px;object-fit:cover;display:block;}
.media-video-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:44px 28px;background:linear-gradient(transparent 45%,rgba(0,0,0,.7));pointer-events:none;}
.media-video-overlay .eyebrow{color:var(--gold-bright);margin-bottom:8px;}
.media-video-overlay h3{color:#fff;font-size:32px;font-weight:300;letter-spacing:.01em;line-height:1.12;max-width:620px;}
.media-duo{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.media-duo .duo-cell{aspect-ratio:4/5;background-size:cover;background-position:center;}
@media(max-width:700px){
  .media-band{height:56vh;min-height:340px;}
  .media-video video{height:64vh;min-height:380px;}
  .media-video-overlay h3{font-size:24px;}
  .media-duo{grid-template-columns:1fr;}
  .media-duo .duo-cell{aspect-ratio:4/3;}
}

/* ===== Refined editorial media v2 (contained, artful) ===== */
.ed-split{padding:108px 0;}
.ed-split .ed-inner{display:grid;grid-template-columns:1fr 0.82fr;gap:64px;align-items:center;}
.ed-split .ed-copy .eyebrow{margin-bottom:20px;}
.ed-split .ed-copy h2{font-size:30px;font-weight:300;line-height:1.22;letter-spacing:.005em;color:var(--cream);}
.ed-split .ed-copy h2 em{font-style:italic;color:var(--gold);}
.ed-split .ed-copy p{color:var(--text-dim);font-size:15px;line-height:1.75;max-width:44ch;margin-top:20px;}
.ed-split .ed-rule{width:54px;height:1px;background:var(--gold);margin-top:28px;}
.ed-frame{position:relative;width:100%;}
.ed-frame .ed-img{position:relative;z-index:1;aspect-ratio:4/5;background-size:cover;background-position:center;border:1px solid rgba(201,168,108,.55);filter:brightness(.97);}
.ed-frame::after{content:"";position:absolute;z-index:0;left:18px;top:18px;right:-18px;bottom:-18px;border:1px solid var(--gold);opacity:.4;}
.ed-strip{padding:0 0 108px;}
.ed-strip .ed-head{text-align:center;margin-bottom:36px;}
.ed-strip .ed-head h3{font-size:22px;font-weight:300;color:var(--cream);margin-top:10px;letter-spacing:.01em;}
.ed-strip .ed-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:980px;margin:0 auto;}
.ed-strip .ed-cell{aspect-ratio:4/5;background-size:cover;background-position:center;border:1px solid var(--line);filter:brightness(.9) saturate(.95);transition:border-color .45s ease,transform .6s cubic-bezier(.2,.7,.2,1),filter .6s ease;}
.ed-strip .ed-cell:hover{border-color:var(--gold);transform:translateY(-5px);filter:brightness(1.04) saturate(1.05);}
@media(max-width:760px){
  .ed-split{padding:64px 0;}
  .ed-split .ed-inner{grid-template-columns:1fr;gap:34px;}
  .ed-split .ed-copy h2{font-size:25px;}
  .ed-frame{max-width:330px;}
  .ed-frame::after{left:12px;top:12px;right:-12px;bottom:-12px;}
  .ed-strip{padding:0 0 64px;}
  .ed-strip .ed-grid{grid-template-columns:1fr 1fr;gap:10px;}
  .ed-strip .ed-cell:last-child{grid-column:1 / -1;aspect-ratio:16/10;}
}

/* ===== Native video sections (vertical reels, framed, silent autoplay) ===== */
.ed-video{padding:0 0 108px;}
.ed-video .ed-head{text-align:center;margin-bottom:34px;}
.ed-video .ed-head h3{font-size:22px;font-weight:300;color:var(--cream);margin-top:10px;letter-spacing:.01em;}
.ed-videos{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;}
.ed-vid{position:relative;width:300px;max-width:82vw;aspect-ratio:9/16;border:1px solid rgba(201,168,108,.55);overflow:hidden;background:#000;box-shadow:0 14px 50px rgba(0,0,0,.45);}
.ed-vid video{width:100%;height:100%;object-fit:cover;display:block;}
@media(max-width:760px){
  .ed-video{padding:0 0 64px;}
  .ed-videos{gap:12px;}
  .ed-vid{width:44%;max-width:44%;}
}


/* ===== Hero treatment video ===== */
.ed-hero-video{padding:52px 0 6px;}
.ed-hero-video .ed-head{text-align:center;margin-bottom:22px;}
.ed-hero-video .ed-head h3{font-size:21px;font-weight:300;color:var(--cream);margin-top:9px;letter-spacing:.01em;}
.hero-reel-wrap{display:flex;justify-content:center;}
.hero-reel{width:330px;max-width:78vw;aspect-ratio:9/16;border:1px solid rgba(201,168,108,.6);
overflow:hidden;background:#000;box-shadow:0 18px 64px rgba(0,0,0,.55);}
.hero-reel video{width:100%;height:100%;object-fit:cover;display:block;}

/* ===== Before & After results ===== */
.ed-results{padding:40px 0 92px;}
.ed-results .ed-head{text-align:center;margin-bottom:30px;}
.ed-results .ed-head h3{font-size:22px;font-weight:300;color:var(--cream);margin-top:9px;letter-spacing:.01em;}
.ba-reels{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-bottom:26px;}
.ba-reel{width:300px;max-width:80vw;aspect-ratio:9/16;border:1px solid rgba(201,168,108,.55);
overflow:hidden;background:#000;box-shadow:0 12px 44px rgba(0,0,0,.42);}
.ba-reel video{width:100%;height:100%;object-fit:cover;display:block;}
.ba-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.ba-grid .cell{position:relative;aspect-ratio:1/1;overflow:hidden;border:1px solid var(--line);background:#0c0c0c;}
.ba-grid .cell img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease;}
.ba-grid .cell:hover img{transform:scale(1.05);}

/* ===== Good to know ===== */
.ed-goodtoknow{padding:0 0 92px;}
.ed-goodtoknow .ed-head{text-align:center;margin-bottom:20px;}
.gtk{max-width:580px;margin:0 auto;display:flex;gap:18px;align-items:center;
border:1px solid var(--line);background:var(--bg-2,#141414);padding:16px;}
.gtk-img{flex:0 0 116px;aspect-ratio:1/1;overflow:hidden;border:1px solid rgba(201,168,108,.4);}
.gtk-img img{width:100%;height:100%;object-fit:cover;display:block;}
.gtk-txt p{font-size:12.5px;color:var(--text-dim,#B8B0A3);line-height:1.55;margin:0;}
@media(max-width:760px){
  .ed-results{padding:30px 0 60px;}
  .ba-grid{grid-template-columns:repeat(2,1fr);}
  .ba-reel{width:46%;max-width:46%;}
  .gtk{flex-direction:row;}
  .gtk-img{flex:0 0 88px;}
}


/* ===== Redesign batch v1: rounded buttons, hero video, service motion, split video, home tour, gallery v2, new pages ===== */
.btn-primary,.btn-secondary,.cta-pill,.mobile-nav .m-cta,.footer-cta-banner .btn-dark,.gallery-cta .btn-secondary,.split-content .btn-secondary{border-radius:100px;}
.btn-primary{box-shadow:0 6px 22px rgba(201,168,108,.18);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(201,168,108,.32);}
.btn-secondary:hover{transform:translateY(-2px);}

/* Hero background video */
.hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.55;filter:grayscale(.12) brightness(.5);}
.hero::before{opacity:.18;}

/* Service grid: staggered reveal + richer hover */
.services-grid .service-card{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1),box-shadow .45s ease;}
.services-grid .service-card.visible{opacity:1;transform:none;}
.services-grid .service-card:nth-child(2){transition-delay:.06s}
.services-grid .service-card:nth-child(3){transition-delay:.12s}
.services-grid .service-card:nth-child(4){transition-delay:.04s}
.services-grid .service-card:nth-child(5){transition-delay:.10s}
.services-grid .service-card:nth-child(6){transition-delay:.16s}
.services-grid .service-card:nth-child(7){transition-delay:.06s}
.services-grid .service-card:nth-child(8){transition-delay:.12s}
.services-grid .service-card:nth-child(9){transition-delay:.18s}
.services-grid .service-card:nth-child(10){transition-delay:.08s}
.services-grid .service-card:nth-child(11){transition-delay:.14s}
.service-card::after{content:'';position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--gold);transition:width .45s ease;z-index:3;}
.service-card:hover::after{width:100%;}
.service-card:hover{box-shadow:0 22px 60px rgba(0,0,0,.55);z-index:2;}

/* Featured split as video */
.split-video{position:relative;overflow:hidden;background:#000;}
.split-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.split-video::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,rgba(10,10,10,.22),transparent 60%);pointer-events:none;}

/* Home bottom clinic-tour video */
.home-tour{position:relative;width:100%;height:82vh;min-height:480px;overflow:hidden;background:#000;}
.home-tour video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.home-tour .ht-overlay{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 24px;background:linear-gradient(rgba(10,10,10,.42),rgba(10,10,10,.6));}
.home-tour .ht-overlay .eyebrow{color:var(--gold-bright);}
.home-tour .ht-overlay h2{color:#fff;margin-bottom:26px;}
@media(max-width:760px){.home-tour{height:62vh;min-height:380px;}}

/* Gallery v2 (filterable masonry) */
.gal-head{text-align:center;max-width:760px;margin:0 auto 36px;}
.gal-filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:40px;}
.gal-filters button{background:transparent;border:1px solid var(--line);color:var(--text-dim);padding:9px 18px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;border-radius:100px;transition:all .25s;}
.gal-filters button:hover{color:var(--gold);border-color:var(--gold);}
.gal-filters button.active{background:var(--gold);color:var(--bg);border-color:var(--gold);}
.gal-masonry{columns:4;column-gap:14px;}
.gal-item{break-inside:avoid;margin-bottom:14px;position:relative;overflow:hidden;border:1px solid var(--line);background:#0c0c0c;transition:border-color .35s ease;}
.gal-item:hover{border-color:var(--gold);}
.gal-item img,.gal-item video{width:100%;display:block;transition:transform .5s ease;}
.gal-item:hover img{transform:scale(1.04);}
.gal-item.is-hidden{display:none;}
.gal-item .gal-badge{position:absolute;top:10px;left:10px;z-index:2;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:#fff;background:rgba(201,168,108,.85);padding:3px 9px;border-radius:100px;}
@media(max-width:1024px){.gal-masonry{columns:3;}}
@media(max-width:640px){.gal-masonry{columns:2;column-gap:8px;}.gal-item{margin-bottom:8px;}}

/* New simple pages (finance/blog/reviews/how-to) + articles */
.page-body{padding:80px 0;}
.page-body .container{max-width:900px;}
.page-body h2{margin-top:46px;}
.page-body p{line-height:1.85;margin-bottom:18px;}
.lead-line{font-size:clamp(17px,1.8vw,20px);color:var(--cream);line-height:1.6;}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:14px;}
.info-card{border:1px solid var(--line);background:var(--bg-2);padding:30px 26px;transition:all .35s ease;}
.info-card:hover{border-color:var(--gold);transform:translateY(-4px);}
.info-card h3{font-size:19px;color:var(--cream);margin-bottom:10px;font-weight:300;}
.info-card p{font-size:14px;color:var(--text-muted);margin-bottom:0;}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.blog-card{border:1px solid var(--line);background:var(--bg);overflow:hidden;display:flex;flex-direction:column;transition:all .35s ease;}
.blog-card:hover{border-color:var(--gold);transform:translateY(-4px);}
.blog-card .bc-img{height:200px;background-size:cover;background-position:center;filter:grayscale(.15) brightness(.9);transition:.5s;}
.blog-card:hover .bc-img{filter:none;transform:scale(1.03);}
.blog-card .bc-body{padding:24px;display:flex;flex-direction:column;flex:1;}
.blog-card .bc-tag{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.blog-card h3{font-size:19px;font-weight:300;margin-bottom:10px;}
.blog-card p{font-size:13.5px;color:var(--text-muted);margin-bottom:16px;flex:1;}
.blog-card .bc-more{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);}
.review-grid{columns:3;column-gap:16px;}
.review-grid .r-shot{break-inside:avoid;margin-bottom:16px;border:1px solid var(--line);overflow:hidden;}
.review-grid .r-shot img{width:100%;display:block;}
.review-quote{border:1px solid var(--line);background:var(--bg-2);padding:28px;margin-bottom:16px;break-inside:avoid;}
.review-quote p{color:var(--cream);font-style:italic;margin-bottom:12px;}
.review-quote .r-name{color:var(--gold);font-size:12px;letter-spacing:.14em;text-transform:uppercase;}
@media(max-width:900px){.card-grid,.blog-grid{grid-template-columns:1fr 1fr;}.review-grid{columns:2;}}
@media(max-width:600px){.card-grid,.blog-grid{grid-template-columns:1fr;}.review-grid{columns:1;}}
.article-body{padding:64px 0 70px;}
.article-body .container{max-width:760px;}
.article-body .a-meta{color:var(--text-muted);font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:30px;}
.article-body h2{font-size:26px;margin:40px 0 14px;color:var(--cream);}
.article-body p{line-height:1.85;margin-bottom:18px;}
.article-body ul{margin:0 0 18px 20px;color:var(--text-dim);}
.article-body li{margin-bottom:8px;}
.article-cover{width:100%;height:44vh;min-height:300px;background-size:cover;background-position:center;border-bottom:1px solid var(--line);}


/* ===== Redesign v2: gold logo, visible hero, editorial cards, floating nav, vertical splits, testimonials ===== */

/* GOLD LOGO (overrides invert) */
.brand img{filter:none !important;}
.footer-brand img{filter:none !important;}

/* HERO VIDEO — MORE VISIBLE */
.hero .hero-bg{opacity:.72 !important;filter:grayscale(0) brightness(.62) !important;}
.hero::before{opacity:.1 !important;}

/* FLOATING / CURVED NAV */
.site-header{transition:all 0.4s cubic-bezier(.4,0,.2,1);}
.site-header.floating{margin:10px 20px;width:calc(100% - 40px);border-radius:100px;background:rgba(10,10,10,.8);border-color:var(--line-strong);box-shadow:0 8px 36px rgba(0,0,0,.5);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);}
@media(max-width:1024px){.site-header.floating{margin:8px 16px;width:calc(100% - 32px);border-radius:60px;}}

/* EDITORIAL SERVICE CARDS (full-bleed video + overlay) */
.services-grid .service-card{min-height:460px;position:relative;}
.service-card .card-media{position:absolute;inset:0;width:100%;height:100%;overflow:hidden;}
.service-card .card-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(.12) brightness(.78);transition:filter .6s ease,transform .7s ease;}
.service-card:hover .card-media video{filter:grayscale(0) brightness(.92);transform:scale(1.04);}
.service-card .card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.94) 0%,rgba(10,10,10,.48) 55%,rgba(10,10,10,.08) 100%);z-index:1;transition:background .4s;}
.service-card:hover .card-overlay{background:linear-gradient(to top,rgba(10,10,10,.97) 0%,rgba(10,10,10,.6) 58%,rgba(10,10,10,.14) 100%);}
.service-card .card-body{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:28px 28px 32px;display:flex;flex-direction:column;justify-content:space-between;height:auto;flex:unset;}
.service-card h3{color:#fff;font-size:20px;font-weight:300;margin-bottom:8px;transition:color .3s;}
.service-card:hover h3{color:var(--gold);}
.service-card .desc{color:rgba(245,240,232,.68);}
.service-card .num{color:var(--gold);}
.service-card .arrow{color:var(--gold);}
.service-card::after{height:3px;}

/* FEATURED SPLIT — VERTICAL VIDEO FRAME */
.split-video{display:flex !important;align-items:center;justify-content:center;background:var(--bg-2);padding:60px 40px;}
.split-video video{position:relative !important;inset:auto !important;width:280px;max-width:88%;height:auto;aspect-ratio:9/16;object-fit:cover;border:1px solid var(--line-strong);box-shadow:0 20px 64px rgba(0,0,0,.65);}
.split-video::after{display:none;}
@media(max-width:1024px){.split-video{padding:40px 24px;}.split-video video{width:220px;}}

/* SERVICE PAGE HERO VIDEO BG */
.svc-hero .svc-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.48;filter:grayscale(.1) brightness(.55);}
.svc-hero::before{opacity:.08 !important;}

/* TESTIMONIAL SECTION */
.testi-section{background:var(--bg-2);padding:100px 0;}
.testi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:36px;}
.testi-grid img{width:100%;display:block;border:1px solid var(--line);transition:border-color .35s,transform .45s;}
.testi-grid img:hover{border-color:var(--gold);transform:scale(1.025);}
.testi-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
@media(max-width:900px){.testi-grid{grid-template-columns:repeat(2,1fr);}}


/* ===== Fix: hero overlays lighter so video is clearly visible ===== */
/* Home hero — much lighter top/mid, kept dark only at bottom for text */
.hero::after{
  background:linear-gradient(180deg,
    rgba(10,10,10,.12) 0%,
    rgba(10,10,10,.08) 40%,
    rgba(10,10,10,.80) 100%) !important;
}
.hero .hero-bg{ opacity:.80 !important; filter:grayscale(0) brightness(.7) !important; }

/* Service page hero — lighter top so video treatment shows clearly */
.svc-hero::after{
  background:linear-gradient(180deg,
    rgba(10,10,10,.18) 0%,
    rgba(10,10,10,.12) 40%,
    rgba(10,10,10,.90) 100%) !important;
}
.svc-hero .svc-hero-bg{ opacity:.62 !important; filter:grayscale(0) brightness(.65) !important; }

/* Before/After grid — taller cells so portrait IG photos show more content */
.ba-grid{ grid-template-columns:repeat(3,1fr); gap:12px; }
.ba-grid .cell{ aspect-ratio:3/4 !important; overflow:hidden; }
.ba-grid .cell img{ object-fit:cover; object-position:center top; width:100%; height:100%; }
@media(max-width:760px){
  .ba-grid{ grid-template-columns:repeat(2,1fr); }
  .ba-grid .cell:last-child:nth-child(odd){ grid-column:1/-1; aspect-ratio:16/9 !important; }
}


/* ===== v3: floated vertical video beside service description ===== */
.svc-float-video{float:right;width:248px;margin:6px 0 22px 34px;aspect-ratio:9/16;position:relative;border:1px solid var(--line-strong);box-shadow:0 18px 50px rgba(0,0,0,.55);overflow:hidden;}
.svc-float-video video{width:100%;height:100%;object-fit:cover;display:block;}
.svc-float-cap{position:absolute;left:0;right:0;bottom:0;padding:18px 14px 10px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--cream);background:linear-gradient(to top,rgba(10,10,10,.85),transparent);}
@media(max-width:760px){.svc-float-video{float:none;display:block;width:210px;margin:8px auto 26px;}}

/* ===== v5: denser 6-up vertical cards · darker overlay ===== */
.services-grid{grid-template-columns:repeat(6,1fr);}
.services-grid .service-card{min-height:0;aspect-ratio:9/16;}
.service-card .card-media video{filter:grayscale(.05) brightness(.6);}
.service-card:hover .card-media video{filter:grayscale(0) brightness(.82);transform:scale(1.05);}
.service-card .card-overlay{background:linear-gradient(to top,rgba(10,10,10,.97) 0%,rgba(10,10,10,.8) 38%,rgba(10,10,10,.58) 70%,rgba(10,10,10,.42) 100%);}
.service-card:hover .card-overlay{background:linear-gradient(to top,rgba(10,10,10,.97) 0%,rgba(10,10,10,.74) 40%,rgba(10,10,10,.5) 72%,rgba(10,10,10,.34) 100%);}
.service-card .card-body{padding:16px 15px 18px;}
.service-card .num{font-size:9px;margin-bottom:7px;}
.service-card h3{font-size:18px;line-height:1.14;font-weight:500;margin-bottom:6px;}
.service-card .desc{font-size:11px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:10px;}
.service-card .arrow{font-size:9.5px;}
@media(max-width:1200px){.services-grid{grid-template-columns:repeat(5,1fr);}}
@media(max-width:980px){.services-grid{grid-template-columns:repeat(4,1fr);}}
@media(max-width:720px){.services-grid{grid-template-columns:repeat(3,1fr);}.service-card h3{font-size:16px;}}
@media(max-width:520px){.services-grid{grid-template-columns:repeat(2,1fr);}.service-card h3{font-size:17px;}.service-card .card-body{padding:16px 14px 18px;}}

/* ===== v6: service category filter bar ===== */
.svc-cats{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 auto 36px;max-width:var(--max-w);padding:0 24px;}
.cat-pill{font-family:inherit;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);background:transparent;border:1px solid var(--line-strong);border-radius:100px;padding:10px 20px;cursor:pointer;transition:color .3s ease,background .3s ease,border-color .3s ease;}
.cat-pill:hover{color:var(--cream);border-color:var(--gold);}
.cat-pill.active{background:var(--gold);border-color:var(--gold);color:#0A0A0A;font-weight:600;}
.service-card.cat-hidden{display:none;}
@media(max-width:520px){.svc-cats{gap:7px;}.cat-pill{font-size:10.5px;padding:8px 14px;letter-spacing:.08em;}}

/* ===== v7: browse-by-category cards (separate section, click reveals related services) ===== */
.cat-browse-eyebrow{max-width:var(--max-w);margin:0 auto;padding:0 24px 14px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);text-align:center;}
.cat-cards{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;max-width:var(--max-w);margin:0 auto;padding:0 24px;}
.cat-card{position:relative;aspect-ratio:3/4;border:1px solid var(--line-strong);border-radius:14px;overflow:hidden;cursor:pointer;background-size:cover;background-position:center;padding:0;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;text-align:left;font-family:inherit;transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease;}
.cat-card:hover{transform:translateY(-4px);border-color:var(--gold);box-shadow:0 16px 40px rgba(0,0,0,.5);}
.cat-card.is-active{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold) inset,0 16px 40px rgba(0,0,0,.5);}
.cat-card-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.92) 0%,rgba(10,10,10,.4) 55%,rgba(10,10,10,.12) 100%);z-index:1;}
.cat-card-label{position:relative;z-index:2;padding:0 12px 3px;font-size:13px;font-weight:600;color:var(--cream);}
.cat-card-count{position:relative;z-index:2;padding:0 12px 13px;font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);}
.cat-card.cat-all{background:linear-gradient(150deg,var(--gold) 0%,var(--gold-bright) 100%);}
.cat-card.cat-all .cat-card-label{color:#0A0A0A;}
.cat-card.cat-all .cat-card-count{color:rgba(10,10,10,.72);}
.cat-card.cat-all.is-active{box-shadow:0 0 0 2px #0A0A0A inset,0 16px 40px rgba(0,0,0,.5);}
.svc-now{max-width:var(--max-w);margin:22px auto 20px;padding:0 24px;display:flex;align-items:baseline;gap:12px;}
.svc-now-eyebrow{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--text-muted);}
#svc-now-label{font-size:18px;font-weight:500;color:var(--cream);}
@media(max-width:980px){.cat-cards{grid-template-columns:repeat(4,1fr);}}
@media(max-width:560px){.cat-cards{grid-template-columns:repeat(3,1fr);gap:7px;}.cat-card-label{font-size:11px;}.cat-card-count{font-size:8px;letter-spacing:.1em;}}

/* ===== Mega menu: Services + Concerns (added) ===== */
.nav-caret{color:var(--gold);font-size:10px;}
.mega{position:absolute;top:100%;background:var(--bg-2);border:1px solid var(--line);padding:26px 30px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .25s ease;z-index:120;box-shadow:0 24px 60px rgba(0,0,0,.5);}
.has-dropdown:hover .mega{opacity:1;visibility:visible;transform:translateY(0);}
.mega--services{left:50%;transform:translateX(-50%) translateY(8px);width:min(820px,calc(100vw - 48px));}
.has-dropdown:hover .mega--services{transform:translateX(-50%) translateY(0);}
.mega--concerns{right:0;width:min(520px,calc(100vw - 48px));}
.mega-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px 30px;}
.mega--concerns .mega-grid{grid-template-columns:1fr 1fr;gap:0 30px;}
.mega-col h4{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin:0 0 10px;font-weight:600;border-bottom:1px solid var(--line);padding-bottom:8px;white-space:nowrap;}
.mega-col a{display:block;padding:7px 0;font-size:12.5px;letter-spacing:.03em;color:var(--text-dim);}
.mega-col a:hover{color:var(--gold);}
.mobile-nav .m-cat{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);margin-top:14px;margin-bottom:2px;}

/* ===== tech + concern detail pages (added) ===== */
.tp-hero{position:relative;padding:120px 0 60px;border-bottom:1px solid var(--line);}
.tp-hero .container{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center;}
.tp-htext .eyebrow{margin-bottom:14px;}
.tp-brand{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}
.tp-hero h1{font-size:clamp(30px,4.4vw,52px);font-weight:300;line-height:1.05;letter-spacing:-0.01em;margin-bottom:16px;}
.tp-tagline{font-size:18px;color:var(--text-dim);margin-bottom:22px;max-width:520px;}
.tp-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:26px;}
.tp-chips span{font-size:11.5px;letter-spacing:.04em;color:var(--text);border:1px solid var(--line-strong);border-radius:100px;padding:6px 13px;}
.tp-hbtns{display:flex;gap:13px;flex-wrap:wrap;}
.tp-media{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#0f0e0c;aspect-ratio:4/5;}
.tp-media img,.tp-media video,.tp-media iframe{width:100%;height:100%;object-fit:cover;display:block;border:0;}
.tp-media.contain{aspect-ratio:4/5;}
.tp-media.contain img{object-fit:contain;padding:22px;background:radial-gradient(120% 120% at 50% 18%,rgba(201,168,108,.12),rgba(10,10,10,.96));}
.tp-sec{padding:64px 0;border-bottom:1px solid var(--line);}
.tp-sec.alt{background:var(--bg-2);}
.tp-wrap{max-width:920px;margin:0 auto;}
.tp-wrap.wide{max-width:var(--max-w);}
.tp-sec h2{font-size:clamp(24px,3vw,34px);font-weight:300;letter-spacing:-0.01em;margin-bottom:18px;}
.tp-sec h3{font-size:18px;font-weight:500;color:var(--gold-bright);margin:26px 0 8px;}
.tp-sec p{color:var(--text-dim);font-size:15.5px;line-height:1.8;margin-bottom:14px;}
.tp-sec p strong{color:var(--text);font-weight:600;}
.tp-steps{list-style:none;padding:0;margin:18px 0 0;counter-reset:s;}
.tp-steps li{position:relative;padding:14px 0 14px 52px;border-top:1px solid var(--line);counter-increment:s;}
.tp-steps li:before{content:counter(s);position:absolute;left:0;top:13px;width:32px;height:32px;border-radius:50%;border:1px solid var(--gold);color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:13px;}
.tp-steps li b{display:block;color:var(--text);font-weight:600;margin-bottom:2px;font-size:15px;}
.tp-steps li span{color:var(--text-dim);font-size:14px;}
.tp-grid2{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center;}
.tp-grid2 .tp-media{aspect-ratio:5/4;}
.tp-relwrap{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.tp-relcard{display:block;border:1px solid var(--line);border-radius:14px;padding:22px 24px;background:var(--bg-2);transition:border-color .25s,transform .25s;}
.tp-relcard:hover{border-color:var(--line-strong);transform:translateY(-3px);}
.tp-relcard .k{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px;}
.tp-relcard .v{font-size:18px;color:var(--text);font-weight:500;}
.tp-relcard .a{color:var(--gold);font-size:13px;margin-top:10px;display:inline-block;}
.tp-faq{max-width:920px;margin:0 auto;}
.tp-faq .qa{border-top:1px solid var(--line);padding:18px 0;}
.tp-faq .qa:last-child{border-bottom:1px solid var(--line);}
.tp-faq .q{font-size:16px;color:var(--text);font-weight:500;margin-bottom:7px;}
.tp-faq .a{color:var(--text-dim);font-size:14.5px;line-height:1.75;}
.tp-cta{padding:80px 0;text-align:center;}
.tp-cta h2{font-size:clamp(26px,3.4vw,40px);font-weight:300;margin-bottom:14px;}
.tp-cta p{color:var(--text-dim);max-width:540px;margin:0 auto 26px;}
.tp-cta .b{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.tp-discl{max-width:920px;margin:26px auto 0;font-size:11.5px;color:var(--text-muted);line-height:1.6;text-align:center;}
/* technology hub */
.th-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.th-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--bg-2);transition:border-color .25s,transform .25s;}
.th-card:hover{border-color:var(--line-strong);transform:translateY(-4px);}
.th-cmedia{aspect-ratio:16/11;background:#0f0e0c;border-bottom:1px solid var(--line);overflow:hidden;}
.th-cmedia img,.th-cmedia video{width:100%;height:100%;object-fit:cover;display:block;}
.th-cmedia.contain img{object-fit:contain;padding:16px;background:radial-gradient(120% 120% at 50% 20%,rgba(201,168,108,.12),rgba(10,10,10,.95));}
.th-cb{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1;}
.th-cb .brand{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:8px;}
.th-cb h3{font-size:20px;font-weight:500;margin-bottom:8px;}
.th-cb p{color:var(--text-dim);font-size:14px;margin-bottom:16px;flex:1;}
.th-cb .more{color:var(--gold);font-size:13px;letter-spacing:.04em;font-weight:500;}
/* concern detail */
.cn-hero{padding:118px 0 50px;border-bottom:1px solid var(--line);}
.cn-hero .container{max-width:860px;}
.cn-hero .eyebrow{margin-bottom:14px;}
.cn-hero h1{font-size:clamp(30px,4.4vw,50px);font-weight:300;line-height:1.06;letter-spacing:-0.01em;margin-bottom:16px;}
.cn-hero p{font-size:17px;color:var(--text-dim);max-width:640px;margin-bottom:24px;}
.cn-body{padding:60px 0;}
.cn-body .container{display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:start;}
.cn-main h2{font-size:22px;font-weight:500;margin:30px 0 10px;letter-spacing:-0.01em;}
.cn-main h2:first-child{margin-top:0;}
.cn-main p{color:var(--text-dim);font-size:15.5px;line-height:1.8;margin-bottom:14px;}
.cn-main p strong{color:var(--text);font-weight:600;}
.cn-side{position:sticky;top:110px;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--bg-2);}
.cn-sthumb{aspect-ratio:4/3;background:#0f0e0c;background-size:cover;background-position:center;border-bottom:1px solid var(--line);}
.cn-stile{display:flex;align-items:center;justify-content:center;background:radial-gradient(120% 120% at 30% 20%,rgba(201,168,108,.20),rgba(10,10,10,.9));}
.cn-stile span{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-bright);font-weight:600;text-align:center;padding:0 16px;}
.cn-sb{padding:22px 22px 24px;}
.cn-sb .lbl{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px;}
.cn-sb .dev{font-size:18px;color:var(--text);font-weight:500;margin-bottom:6px;}
.cn-sb p{color:var(--text-dim);font-size:13.5px;line-height:1.65;margin-bottom:16px;}
.cn-sb .btn-primary{width:100%;text-align:center;margin-bottom:10px;}
.cn-sb .btn-secondary{width:100%;text-align:center;}
.cn-sb .techlink{display:block;text-align:center;margin-top:12px;color:var(--gold);font-size:13px;}
.cn-cta{padding:76px 0;text-align:center;border-top:1px solid var(--line);}
.cn-cta h2{font-size:clamp(24px,3.2vw,38px);font-weight:300;margin-bottom:14px;}
.cn-cta p{color:var(--text-dim);max-width:520px;margin:0 auto 24px;}
.cn-cta .b{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
@media(max-width:900px){
 .tp-hero .container{grid-template-columns:1fr;gap:28px;}
 .tp-media,.tp-media.contain{aspect-ratio:16/10;max-height:420px;}
 .tp-grid2{grid-template-columns:1fr;}
 .tp-relwrap{grid-template-columns:1fr;}
 .th-grid{grid-template-columns:1fr 1fr;}
 .cn-body .container{grid-template-columns:1fr;}
 .cn-side{position:static;max-width:420px;}
}
@media(max-width:600px){.th-grid{grid-template-columns:1fr;}.tp-hero{padding:100px 0 44px;}}
.cn-sthumb video{width:100%;height:100%;object-fit:cover;display:block;}
.cs-cthumb video{width:100%;height:100%;object-fit:cover;display:block;}
.mz-splitimg img{width:100%;height:100%;object-fit:cover;display:block;}
/* richer gold book buttons (mobile + primary) */
.mobile-nav .m-cta{background:linear-gradient(135deg,var(--gold-bright) 0%,var(--gold) 58%,#b8965a 100%);color:#1a1408;font-weight:600;box-shadow:0 6px 20px rgba(201,168,108,.30),inset 0 1px 0 rgba(255,255,255,.35);border:none;}
.btn-primary{background:linear-gradient(135deg,var(--gold-bright) 0%,var(--gold) 58%,#b8965a 100%);color:#1a1408;border:none;box-shadow:0 6px 18px rgba(201,168,108,.24),inset 0 1px 0 rgba(255,255,255,.3);}
.btn-primary:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 10px 26px rgba(201,168,108,.38);}
/* ===== mobile polish pass (defensive) ===== */
html,body{overflow-x:hidden;}
img,video,iframe{max-width:100%;}
@media(max-width:600px){
  .cn-hero{padding:96px 0 40px;}
  .cn-hero p{font-size:16px;}
  .cn-body{padding:48px 0;}
  .tp-body,.tp-rel{padding:48px 0;}
  .btn-primary,.btn-secondary,.cta-pill,.mobile-nav .m-cta{min-height:46px;display:inline-flex;align-items:center;justify-content:center;}
  .cn-hero .btn-primary,.cn-hero .btn-secondary,.cn-cta .btn-primary,.cn-cta .btn-secondary{width:100%;}
  .cn-cta .b{flex-direction:column;gap:10px;}
}
