
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--gs-bg);color:var(--gs-text);font-family:var(--gs-font-body);line-height:1.65}
img{max-width:100%;height:auto;display:block}
h1,h2,h3{font-family:var(--gs-font-heading);line-height:1.12;letter-spacing:-.02em;margin:0 0 .4em}
a{color:var(--gs-primary);text-decoration:none}
.wrap{max-width:var(--gs-container);margin-inline:auto;padding-inline:20px}
section{padding-block:var(--gs-section-y)}
.btn{display:inline-block;background:var(--gs-accent);color:var(--gs-text);font-family:var(--gs-font-heading);font-weight:700;padding:13px 24px;border-radius:var(--gs-radius);border:0;cursor:pointer;text-transform:uppercase;letter-spacing:.4px}
.btn-primary{background:var(--gs-primary);color:#fff}
.eyebrow{color:var(--gs-primary);font-family:var(--gs-font-heading);text-transform:uppercase;letter-spacing:2px;font-weight:700;font-size:.9rem}
.lead{color:var(--gs-muted);max-width:60ch;font-size:1.08rem}
.grid{display:grid;gap:22px}
.g3{grid-template-columns:repeat(3,1fr)}.g2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--gs-surface);border-radius:var(--gs-radius);box-shadow:var(--gs-shadow);overflow:hidden}
.card-body{padding:22px}.card .tag{color:var(--gs-primary);font-weight:700;font-size:.8rem;text-transform:uppercase}
.card-thumb{aspect-ratio:3/2;overflow:hidden;display:block}.card-thumb img{width:100%;height:100%;object-fit:cover}
.topbar{background:var(--gs-primary);color:#fff;font-size:.9rem}
.topbar .wrap{display:flex;justify-content:space-between;gap:10px;padding-block:8px;flex-wrap:wrap}
.topbar a{color:#fff}
header.site{position:sticky;top:0;z-index:50;background:var(--gs-surface);box-shadow:var(--gs-shadow)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-block:10px}
header.site .logo svg{height:46px;width:auto}
nav.main{display:flex;gap:20px;align-items:center}
nav.main a{font-family:var(--gs-font-heading);text-transform:uppercase;font-size:.92rem;color:var(--gs-text)}
.menu-btn{display:none}
.hero{position:relative;color:#fff;padding-block:84px;background:linear-gradient(rgba(0,0,0,.45),rgba(0,0,0,.6)),var(--hero-img) center/cover}
.hero h1{color:#fff;font-size:clamp(2rem,1.2rem+3vw,3.2rem);max-width:18ch}
.hero p{color:#eef;max-width:52ch;font-size:1.15rem;margin:14px 0 24px}
.cta-row{display:flex;gap:12px;flex-wrap:wrap}
.badges-row{display:flex;gap:14px 26px;flex-wrap:wrap;align-items:center;justify-content:center}
.brands-row{display:flex;gap:20px 32px;flex-wrap:wrap;align-items:center;justify-content:center}
.brands-row img{filter:grayscale(100%);opacity:.72;transition:.2s}.brands-row img:hover{filter:none;opacity:1}
.section-alt{background:var(--gs-surface-alt,color-mix(in srgb,var(--gs-bg) 92%,var(--gs-text)))}
.breadcrumb{font-size:.85rem;color:var(--gs-muted);padding-block:10px}
.video-facade{position:relative;display:block;width:100%;aspect-ratio:16/9;border:0;padding:0;cursor:pointer;border-radius:var(--gs-radius);overflow:hidden;background:var(--gs-secondary)}
.video-facade .vf-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.82)}
.video-facade iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:62px;height:62px;border-radius:50%;background:var(--gs-accent);color:var(--gs-text);display:flex;align-items:center;justify-content:center;font-size:1.3rem}
.masonry{column-count:4;column-gap:14px}.masonry a{display:block;margin:0 0 14px;break-inside:avoid;border-radius:var(--gs-radius);overflow:hidden}
.gcard{background:var(--gs-surface);border-radius:var(--gs-radius);box-shadow:var(--gs-shadow);padding:20px}
.gstars{color:#fbbc05}
footer.site{background:var(--gs-primary);color:#fff;padding-block:46px 20px}
footer.site a{color:#fff;opacity:.9}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:28px}
.foot-brands{display:flex;gap:12px 18px;flex-wrap:wrap;justify-content:center;align-items:center;padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid rgba(255,255,255,.2)}
.foot-brands img{background:#fff;border-radius:6px;padding:5px 8px}
.float-call{position:fixed;right:18px;bottom:18px;z-index:60;background:var(--gs-accent);color:var(--gs-text);width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:var(--gs-shadow)}
.mobile-cta{display:none}
.lead-modal{position:fixed;inset:0;z-index:1000;display:none;align-items:flex-start;justify-content:center;padding:24px 16px;overflow:auto;background:rgba(8,18,40,.62)}
.lead-modal.is-open{display:flex}
.lead-modal__card{background:var(--gs-surface);border-radius:var(--gs-radius);max-width:480px;width:100%;margin:auto;padding:26px;box-shadow:var(--gs-shadow)}
.lead-form label{display:block;font-family:var(--gs-font-heading);font-size:.92rem;margin-top:10px}
.lead-form input,.lead-form select,.lead-form textarea{width:100%;padding:11px;border:1px solid var(--gs-muted);border-radius:8px;margin-top:4px;font:inherit}
@media(max-width:900px){.g3{grid-template-columns:1fr 1fr}.foot-grid{grid-template-columns:1fr 1fr}nav.main{display:none}.masonry{column-count:3}}
@media(max-width:768px){.float-call{display:none}.mobile-cta{display:grid;grid-template-columns:1fr 1fr;position:fixed;left:0;right:0;bottom:0;z-index:80}.mobile-cta a{display:flex;align-items:center;justify-content:center;gap:8px;min-height:58px;font-family:var(--gs-font-heading);font-weight:700;text-transform:uppercase}.mobile-cta .m-call{background:var(--gs-accent);color:var(--gs-text)}.mobile-cta .m-est{background:var(--gs-primary);color:#fff}body{padding-bottom:64px}}
@media(max-width:680px){.g3,.g2{grid-template-columns:1fr}.masonry{column-count:2}.foot-grid{grid-template-columns:1fr}}

/* ---- logo wordmark (never truncate) ---- */
.logo{display:flex;align-items:center;gap:11px;text-decoration:none;max-width:64%}
.logo-mark{flex:0 0 auto;display:block}.logo-mark svg{height:46px;width:46px;display:block}
.brand-name{font-family:var(--gs-font-heading);font-weight:700;color:var(--gs-text);line-height:1.05;font-size:clamp(.95rem,1.4vw,1.25rem);letter-spacing:.2px;white-space:normal}
@media(max-width:480px){.logo-mark svg{height:38px;width:38px}.brand-name{font-size:.82rem}}

/* ---- hero variants (archetype feel) ---- */
.hero--centered{text-align:center}.hero--centered h1,.hero--centered p{margin-inline:auto}.hero--centered .cta-row{justify-content:center}
.hero--band{background:linear-gradient(120deg,color-mix(in srgb,var(--gs-primary) 90%,#000),var(--gs-secondary))!important;padding-block:96px}
.hero--band .badge-line{display:inline-block;background:var(--gs-accent);color:var(--gs-text);font-family:var(--gs-font-heading);padding:6px 14px;border-radius:999px;margin-bottom:14px;text-transform:uppercase;letter-spacing:1px;font-size:.78rem}
.hero--minimal{background:var(--gs-bg)!important;color:var(--gs-text);padding-block:92px;border-bottom:5px solid var(--gs-accent)}
.hero--minimal h1{color:var(--gs-text)}.hero--minimal p{color:var(--gs-muted)}

/* ---- service card variants ---- */
.cards--wide .grid{grid-template-columns:1fr!important;max-width:880px;margin-inline:auto}
.cards--wide .card{display:grid;grid-template-columns:230px 1fr;align-items:stretch}
.cards--wide .card-thumb{aspect-ratio:auto;height:100%}
.cards--minimal .card{box-shadow:none;border:1px solid color-mix(in srgb,var(--gs-text) 14%,transparent)}
.cards--minimal .card-thumb{aspect-ratio:16/9}
@media(max-width:680px){.cards--wide .card{grid-template-columns:1fr}}

/* ---- Google/Facebook-style reviews (matches Atlantic) ---- */
.grating{background:var(--gs-surface);border-radius:var(--gs-radius);box-shadow:var(--gs-shadow);padding:22px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-top:18px;border-left:4px solid var(--gs-accent)}
.grating-score{text-align:center}.grating .score{font-family:var(--gs-font-heading);font-size:3rem;color:var(--gs-text);line-height:1}
.grating .gstars{font-size:1.4rem}
.gcard{position:relative;background:var(--gs-surface);border-radius:var(--gs-radius);box-shadow:var(--gs-shadow);padding:22px 22px 18px}
.gcard .glogo{position:absolute;top:16px;right:16px}
.gcard-top{display:flex;align-items:center;gap:12px;padding-right:30px}
.gavatar{flex:0 0 auto;width:44px;height:44px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--gs-font-heading);font-weight:600;font-size:1.05rem}
.gmeta{display:flex;flex-direction:column;line-height:1.25}
.gname{font-weight:700;color:var(--gs-text);font-size:1rem}.gname svg{margin-left:3px}
.gdate{color:var(--gs-muted);font-size:.85rem}
.gstars{color:#fbbc05;letter-spacing:1px}
.gtext{color:var(--gs-text);margin:12px 0}
.gloc{color:var(--gs-muted);font-size:.85rem;border-top:1px solid color-mix(in srgb,var(--gs-text) 10%,transparent);padding-top:10px}

/* ---- video section (fixed framing, no face-crop, premium touches) ---- */
.video-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.video-card{margin:0}
.video-facade{position:relative;display:block;width:100%;aspect-ratio:16/9;border:0;padding:0;cursor:pointer;border-radius:var(--gs-radius);overflow:hidden;background:var(--gs-secondary)}
.video-facade .vf-poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%;filter:brightness(.86)}
.video-facade .vf-stars{position:absolute;left:12px;top:10px;color:#ffd54a;font-size:1rem;letter-spacing:1px;text-shadow:0 1px 4px rgba(0,0,0,.65)}
.video-facade .video-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:var(--gs-accent);color:var(--gs-text);display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:0 4px 16px rgba(0,0,0,.35)}
.vf-cap{margin-top:8px;font-family:var(--gs-font-heading);font-size:.92rem;color:var(--gs-muted);display:flex;align-items:center;gap:6px}
.vf-cap::before{content:"\2714";color:var(--gs-primary)}
@media(max-width:680px){.video-grid{grid-template-columns:1fr}}

/* ===== STRUCTURAL COMPOSITION ===== */
/* rhythm */
.gs-rhythm-compact{--gs-section-y:clamp(2.4rem,4vw,4rem)}
.gs-rhythm-normal{--gs-section-y:clamp(3rem,6vw,6rem)}
.gs-rhythm-airy{--gs-section-y:clamp(4.5rem,9vw,9rem)}
.sec{padding-block:var(--gs-section-y)}
/* base hero override: neutral unless .hero-photo */
.hero{position:relative;color:var(--gs-text);padding-block:74px;background:var(--gs-bg)}
.hero h1{color:inherit}.hero p{color:var(--gs-muted);max-width:54ch;font-size:1.12rem;margin:14px 0 22px}
.hero-photo{color:#fff;background:linear-gradient(rgba(8,12,20,.46),rgba(8,12,20,.64)),var(--hero-img) center/cover}
.hero-photo h1{color:#fff}.hero-photo p{color:#eef}
/* bento hero */
.hero-bento .wrap{display:grid;grid-template-columns:1.05fr 1fr;gap:34px;align-items:center}
.hb-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:12px;height:360px}
.hb-grid picture:first-child{grid-row:1/3}.hb-grid picture{height:100%;border-radius:var(--gs-radius);overflow:hidden;box-shadow:var(--gs-shadow)}.hb-grid img{height:100%}
/* editorial hero */
.hero-editorial{padding-bottom:0}.hero-editorial .wrap{display:grid;grid-template-columns:1.3fr 1fr;gap:30px;align-items:end;padding-bottom:34px}
.hero-editorial h1{font-size:clamp(2.2rem,1.4rem+3vw,4rem);margin:0}.he-aside{border-left:3px solid var(--gs-accent);padding-left:20px}
.he-band{height:300px;background:var(--hero-img) center/cover;border-top:6px solid var(--gs-accent)}
/* masthead */
.hero-masthead{text-align:center;padding-block:110px}.hero-masthead .huge{font-size:clamp(2.6rem,1.5rem+5vw,6rem);letter-spacing:-.03em;line-height:.98}.hero-masthead p{margin-inline:auto}.hero-masthead .cta-row{justify-content:center}
/* prooffirst */
.hp-stats{display:flex;gap:14px 28px;flex-wrap:wrap;margin-top:22px}.hp-stats span{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);padding:8px 14px;border-radius:30px;font-size:.95rem}.hp-stats b{color:var(--gs-accent)}
/* archival */
.hero-archival{padding-block:56px;border-bottom:2px solid color-mix(in srgb,var(--gs-text) 12%,transparent)}.hero-archival h1{font-size:clamp(1.8rem,1.2rem+2.5vw,3rem)}
/* stepped */
.hs-steps{list-style:none;display:flex;gap:14px;flex-wrap:wrap;margin:22px 0 0;padding:0}.hs-steps li{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:12px;padding:12px 16px;font-family:var(--gs-font-heading)}.hs-steps b{display:inline-flex;width:26px;height:26px;border-radius:50%;background:var(--gs-accent);color:var(--gs-text);align-items:center;justify-content:center;margin-right:8px}
/* storyspine */
.hero-storyspine .wrap{display:grid;grid-template-columns:6px 1fr;gap:26px}.ss-line{background:linear-gradient(var(--gs-accent),transparent);border-radius:3px}
/* galleryled */
.hero-galleryled{padding:0;color:#fff}.hg-mosaic{display:grid;grid-template-columns:repeat(5,1fr);height:460px;gap:4px}.hg-mosaic img{width:100%;height:100%;object-fit:cover}.hg-mosaic img:first-child{grid-column:1/3;grid-row:1}.hg-overlay{position:absolute;inset:0;display:flex;align-items:center;background:linear-gradient(90deg,rgba(8,12,20,.82),rgba(8,12,20,.35))}.hg-overlay h1{color:#fff}.hg-overlay p{color:#eef}
/* cinema */
.hero-cinema .wrap{display:grid;grid-template-columns:1fr 1.05fr;gap:34px;align-items:center}.hc-video{border-radius:var(--gs-radius);overflow:hidden;box-shadow:var(--gs-shadow)}
/* floating */
.hero-floating{min-height:420px;display:flex;align-items:center}.hf-card{background:var(--gs-surface);color:var(--gs-text);max-width:560px;padding:34px;border-radius:var(--gs-radius);box-shadow:var(--gs-shadow)}.hf-card p{color:var(--gs-muted)}
/* callfirst */
.hero-callfirst .wrap{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}.cf-call{background:var(--gs-surface);color:var(--gs-text);padding:28px;border-radius:var(--gs-radius);box-shadow:var(--gs-shadow);text-align:center}.cf-phone{display:block;font-family:var(--gs-font-heading);font-size:2.4rem;color:var(--gs-primary);margin:6px 0 14px}
/* scrapbook */
.hero-scrapbook .wrap{display:grid;grid-template-columns:1.1fr 1fr;gap:30px;align-items:center}.sb-photos{position:relative;height:340px}.sb-photos img{position:absolute;width:58%;border:7px solid #fff;box-shadow:0 10px 26px rgba(0,0,0,.22);border-radius:4px}.sb-photos img:nth-child(1){top:0;left:0;transform:rotate(-5deg)}.sb-photos img:nth-child(2){top:40px;right:0;transform:rotate(4deg)}.sb-photos img:nth-child(3){bottom:0;left:24%;transform:rotate(-2deg)}
/* service card renderers */
.svc-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:24px}
.svc-card{background:var(--gs-surface);border-radius:var(--gs-radius);box-shadow:var(--gs-shadow);overflow:hidden}.svc-card .svc-thumb{display:block;aspect-ratio:3/2;overflow:hidden}.svc-card .svc-b{padding:20px}
.svc-list{display:grid;gap:16px;margin-top:24px;max-width:920px}.svc-wide{display:grid;grid-template-columns:200px 1fr;background:var(--gs-surface);border-radius:var(--gs-radius);box-shadow:var(--gs-shadow);overflow:hidden;text-decoration:none;color:inherit}.svc-wide .svc-thumb{height:100%}.svc-wide .svc-b{padding:18px 22px}
.svc-numgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:24px}.svc-num{display:grid;grid-template-columns:auto 1fr;gap:16px;background:var(--gs-surface);border:1px solid color-mix(in srgb,var(--gs-text) 12%,transparent);border-radius:var(--gs-radius);padding:18px;text-decoration:none;color:inherit}.svc-n{font-family:var(--gs-font-heading);font-size:1.8rem;color:var(--gs-accent);line-height:1}
.svc-lines{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:24px}.svc-line{padding:20px;border-bottom:1px solid color-mix(in srgb,var(--gs-text) 12%,transparent);text-decoration:none;color:inherit}.svc-line:hover{background:color-mix(in srgb,var(--gs-text) 4%,transparent)}.svc-line h3{margin-bottom:4px}
.svc-bentogrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}.svc-bento{background:var(--gs-surface);border-radius:var(--gs-radius);box-shadow:var(--gs-shadow);overflow:hidden;text-decoration:none;color:inherit}.svc-bento .svc-thumb{aspect-ratio:16/10;overflow:hidden}.svc-bento .svc-b{padding:16px}.svc-bento.svc-big{grid-column:span 2}.svc-bento.svc-big .svc-thumb{aspect-ratio:21/9}
.svc .tag{color:var(--gs-primary);font-weight:700;font-size:.78rem;text-transform:uppercase}.svc h3{font-size:1.15rem;margin:.2em 0}.svc .more{color:var(--gs-primary);font-weight:700}
/* areas */
.area-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px}.area-card{display:block;background:var(--gs-surface);border-radius:var(--gs-radius);box-shadow:var(--gs-shadow);overflow:hidden;text-decoration:none;color:inherit}.area-card img{width:100%}.ac-b{padding:16px}.ac-b h3{font-size:1.1rem}
/* proof */
.proof-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}.proof-item{background:var(--gs-surface);border-radius:var(--gs-radius);box-shadow:var(--gs-shadow);padding:22px}.proof-item b{display:block;font-family:var(--gs-font-heading);font-size:2rem;color:var(--gs-primary)}.proof-item span{color:var(--gs-muted);font-size:.9rem}
/* about band */
.about-band{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
/* cta band */
.sec-ctaband{background:var(--gs-primary);color:#fff}.sec-ctaband h2{color:#fff}.sec-ctaband .lead{color:rgba(255,255,255,.85)}.sec-ctaband .cta-row{justify-content:center}
/* gallery treatments */
.gal-masonry{column-count:4;column-gap:12px}.gal-masonry a{display:block;margin:0 0 12px;break-inside:avoid;border-radius:var(--gs-radius);overflow:hidden}.gal-masonry img{width:100%;display:block}
.gal-mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:150px;gap:10px}.gal-mosaic a{border-radius:var(--gs-radius);overflow:hidden}.gal-mosaic img{width:100%;height:100%;object-fit:cover}.gal-mosaic a:nth-child(6n+1){grid-column:span 2;grid-row:span 2}
.gal-minimal{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.gal-minimal a{border-radius:var(--gs-radius);overflow:hidden;aspect-ratio:1}.gal-minimal img{width:100%;height:100%;object-fit:cover}
.gal-cinema{display:flex;gap:12px;overflow-x:auto;padding:6px 20px 16px;scroll-snap-type:x mandatory}.gal-cinema a{flex:0 0 320px;scroll-snap-align:start;border-radius:var(--gs-radius);overflow:hidden}.gal-cinema img{width:320px;height:200px;object-fit:cover}
/* gallery page masonry */
.masonry{column-count:4;column-gap:12px}.masonry a{display:block;margin:0 0 12px;break-inside:avoid;border-radius:var(--gs-radius);overflow:hidden;cursor:zoom-in}.masonry img{width:100%;display:block}
@media(max-width:1000px){.svc-grid3,.svc-bentogrid,.area-grid,.gal-masonry,.gal-mosaic,.gal-minimal,.masonry{grid-template-columns:repeat(3,1fr);column-count:3}.proof-row{grid-template-columns:1fr 1fr}}
@media(max-width:820px){.hero-bento .wrap,.hero-editorial .wrap,.hero-cinema .wrap,.hero-callfirst .wrap,.hero-scrapbook .wrap,.about-band{grid-template-columns:1fr}.hb-grid{height:260px}.sb-photos{height:260px}.he-band{height:220px}}
@media(max-width:680px){.svc-grid3,.svc-bentogrid,.svc-numgrid,.svc-lines,.area-grid,.gal-mosaic,.gal-minimal{grid-template-columns:1fr}.svc-bento.svc-big{grid-column:span 1}.gal-masonry,.masonry{column-count:2}.proof-row{grid-template-columns:1fr 1fr}.svc-wide{grid-template-columns:1fr}}