/* Rooftop Glow · Portfolio-first (Charlotte). Sample site.
   Editorial, gallery-led, the work is the hero. Deep night-blue canvas, icy-blue accent,
   warm gold lives only inside the photos. Display: Cormorant Garamond · Body: Public Sans.
   Instrument Serif (named in the brief) swapped for Cormorant Garamond: Instrument Serif is a
   banned LLM-default display serif. Cormorant is a justified editorial serif, dramatic at large sizes.
   Shape lock: near-sharp (6px) on media and panels, hairline icy rules, generous magazine gutters. Accent: icy blue, locked. */
:root{
  --night:#0B1220;
  --night-2:#101a2e;
  --panel:#0E1626;
  --ice:#9FC7FF;
  --ice-deep:#6FA6EE;
  --text:#EAF2FF;
  --text-soft:#A6B4CE;
  --text-dim:#6E7C95;
  --line:rgba(159,199,255,0.16);
  --line-2:rgba(159,199,255,0.10);
  --display:'Cormorant Garamond',Georgia,serif;
  --body:'Public Sans',system-ui,sans-serif;
  --r:6px;
  --wrap:1200px;
  --wrap-wide:1480px;
  --ease:cubic-bezier(0.22,1,0.36,1);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--night);color:var(--text);font-family:var(--body);font-weight:400;font-size:16.5px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(22px,5vw,48px);}
.wrap-wide{max-width:var(--wrap-wide);margin-inline:auto;padding-inline:clamp(22px,5vw,48px);}
h1,h2,h3{font-family:var(--display);font-weight:500;margin:0;line-height:1.04;letter-spacing:0.005em;}
p{margin:0;}
.serif-em{font-style:italic;color:var(--ice);}

/* Sample bar */
.sample-bar{background:#070C15;color:var(--text-soft);font-family:var(--body);font-size:12px;font-weight:500;letter-spacing:0.04em;text-align:center;padding:9px 16px;border-bottom:1px solid var(--line-2);}
.sample-bar b{color:var(--text);font-weight:700;}
.sample-bar a{color:var(--ice);font-weight:600;text-decoration:underline;text-underline-offset:2px;}

/* Header (transparent over hero, solid on scroll) */
header.site{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .3s var(--ease),border-color .3s var(--ease),backdrop-filter .3s var(--ease);border-bottom:1px solid transparent;}
header.site .bar{max-width:var(--wrap-wide);margin-inline:auto;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px clamp(22px,5vw,48px);}
header.site.scrolled{background:rgba(11,18,32,0.86);backdrop-filter:blur(14px) saturate(1.3);border-bottom-color:var(--line);}
.brand{font-family:var(--display);font-weight:600;font-size:25px;letter-spacing:0.01em;color:var(--text);white-space:nowrap;}
.brand em{font-style:italic;color:var(--ice);}
nav.main{display:flex;align-items:center;gap:6px;}
nav.main a{font-family:var(--body);font-size:14px;font-weight:500;letter-spacing:0.02em;color:var(--text-soft);padding:9px 14px;border-radius:var(--r);transition:color .18s var(--ease);}
nav.main a:hover,nav.main a.active{color:var(--text);}
.menu-btn{display:none;background:transparent;border:1px solid var(--line);border-radius:var(--r);width:44px;height:44px;align-items:center;justify-content:center;color:var(--text);cursor:pointer;}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--body);font-weight:600;font-size:14px;letter-spacing:0.04em;text-transform:uppercase;padding:14px 26px;border-radius:var(--r);min-height:50px;cursor:pointer;border:1px solid transparent;transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease),transform .14s var(--ease);}
.btn-ice{background:var(--ice);color:#08111F;}
.btn-ice:hover{background:#BAD6FF;}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line);}
.btn-ghost:hover{border-color:var(--ice);color:var(--ice);}
.btn:active{transform:translateY(1px);}

/* Hero (full-bleed image) */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;}
.hero .bg{position:absolute;inset:0;z-index:0;}
.hero .bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);animation:kenburns 18s ease-out forwards;}
@keyframes kenburns{to{transform:scale(1);}}
.hero .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(7,12,21,0.55) 0%,rgba(7,12,21,0.15) 38%,rgba(7,12,21,0.78) 100%);}
.hero .wrap-wide{position:relative;z-index:2;padding-bottom:clamp(54px,8vw,104px);padding-top:140px;width:100%;}
.hero .eyebrow{font-family:var(--body);font-size:12.5px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--ice);margin-bottom:22px;}
.hero h1{font-size:clamp(48px,8.5vw,116px);font-weight:500;line-height:0.98;max-width:15ch;letter-spacing:0;}
.hero h1 em{font-style:italic;color:var(--ice);}
.hero .lead{font-size:clamp(16px,1.5vw,19px);color:var(--text-soft);max-width:50ch;margin:26px 0 32px;}
.hero .ctas{display:flex;gap:14px;flex-wrap:wrap;}

/* Hero · sparse atelier variant. One editorial line, minimal chrome. */
.hero.sparse{align-items:flex-end;}
.hero.sparse .scrim{background:linear-gradient(180deg,rgba(7,12,21,0.42) 0%,rgba(7,12,21,0.08) 44%,rgba(7,12,21,0.72) 100%);}
.hero.sparse h1{font-size:clamp(44px,8vw,104px);max-width:18ch;font-weight:500;}
.hero.sparse .eyebrow{margin-bottom:20px;}
.hero.sparse .sub{font-family:var(--body);font-size:14px;letter-spacing:0.04em;color:var(--text-soft);margin-top:24px;}
.hero.sparse .sub a{color:var(--ice);border-bottom:1px solid var(--line);padding-bottom:1px;transition:border-color .18s var(--ease);}
.hero.sparse .sub a:hover{border-color:var(--ice);}

/* Section primitives */
section{padding:clamp(64px,10vw,128px) 0;}
.eyebrow{font-family:var(--body);font-size:12px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--ice);}
.section-head{max-width:780px;margin-bottom:54px;}
.section-head h2{font-size:clamp(34px,5.6vw,68px);font-weight:500;margin-top:16px;}
.section-head p{font-size:18px;color:var(--text-soft);margin-top:20px;max-width:60ch;}

/* Editorial statement */
.statement{border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.statement p{font-family:var(--display);font-size:clamp(26px,3.6vw,46px);font-weight:500;line-height:1.22;color:var(--text);max-width:22ch;}
.statement p em{font-style:italic;color:var(--ice);}
.statement .sub{font-family:var(--body);font-size:16px;line-height:1.7;color:var(--text-soft);max-width:52ch;margin-top:28px;}

/* Before/after slider (signature) */
.ba-block .label{display:flex;align-items:baseline;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:26px;}
.ba{position:relative;border-radius:var(--r);overflow:hidden;background:var(--panel);aspect-ratio:3/2;user-select:none;touch-action:pan-y;border:1px solid var(--line);}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none;}
.ba .after-wrap{position:absolute;inset:0;clip-path:inset(0 0 0 var(--split,50%));will-change:clip-path;}
.ba .ba-tag{position:absolute;top:16px;font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;padding:7px 13px;border-radius:var(--r);backdrop-filter:blur(6px);z-index:3;}
.ba .ba-tag.day{left:16px;background:rgba(7,12,21,0.7);color:var(--text);}
.ba .ba-tag.lit{right:16px;background:rgba(159,199,255,0.92);color:#08111F;}
.ba .handle{position:absolute;top:0;bottom:0;left:var(--split,50%);width:2px;background:var(--ice);transform:translateX(-1px);z-index:4;}
.ba .knob{position:absolute;top:50%;left:var(--split,50%);transform:translate(-50%,-50%);z-index:5;width:50px;height:50px;border-radius:50%;background:var(--ice);color:#08111F;display:flex;align-items:center;justify-content:center;cursor:ew-resize;box-shadow:0 8px 24px rgba(0,0,0,0.4);transition:transform .16s var(--ease);}
.ba .knob:active{transform:translate(-50%,-50%) scale(0.94);}
.ba .knob svg{width:22px;height:22px;}
.ba .ba-hint{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);z-index:3;font-size:11.5px;font-weight:500;letter-spacing:0.06em;color:var(--text);background:rgba(7,12,21,0.6);backdrop-filter:blur(6px);padding:6px 13px;border-radius:var(--r);transition:opacity .4s var(--ease);pointer-events:none;}
.ba.touched .ba-hint{opacity:0;}
.ba-range{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize;margin:0;z-index:6;}

/* Editorial numbered gallery */
.work{display:grid;gap:clamp(48px,7vw,96px);}
.work-item{display:grid;grid-template-columns:1fr;gap:0;}
.work-item .frame{position:relative;overflow:hidden;background:var(--panel);width:100vw;margin-left:calc(50% - 50vw);}
.work-item .frame img{width:100%;height:100%;object-fit:cover;aspect-ratio:21/9;transition:transform 1.4s var(--ease);}
.work-item .frame:hover img{transform:scale(1.04);}
.work-meta{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-top:22px;flex-wrap:wrap;}
.work-meta .no{font-family:var(--display);font-size:30px;font-weight:500;color:var(--ice);line-height:1;font-style:italic;}
.work-meta h3{font-size:clamp(24px,3vw,34px);font-weight:500;}
.work-meta .place{font-family:var(--body);font-size:12.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-dim);margin-top:6px;}
.work-meta p{font-size:15px;color:var(--text-soft);max-width:46ch;}
.work-meta .left{max-width:62%;}
.work-meta{margin-top:28px;align-items:flex-end;}
.work-meta .no{font-size:40px;}
.work-item:nth-child(even) .work-meta{flex-direction:row-reverse;}
.work-item:nth-child(even) .work-meta p{text-align:right;}

/* Services (editorial list, no prices) */
.svc-list{display:grid;gap:0;border-top:1px solid var(--line);}
.svc-item{display:grid;grid-template-columns:auto 1fr auto;gap:30px;align-items:baseline;padding:34px 4px;border-bottom:1px solid var(--line);}
.svc-item .no{font-family:var(--display);font-style:italic;font-size:26px;color:var(--ice);}
.svc-item h3{font-size:clamp(26px,3.4vw,40px);font-weight:500;}
.svc-item p{font-size:15.5px;color:var(--text-soft);margin-top:10px;max-width:60ch;}
.svc-item .flag{font-family:var(--body);font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--ice);white-space:nowrap;}

/* Process (white-glove cycle) */
.cycle{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;}
.cycle .c{background:var(--night);padding:30px 26px;}
.cycle .c .v{font-family:var(--display);font-style:italic;font-size:24px;color:var(--ice);margin-bottom:14px;}
.cycle .c h3{font-size:21px;font-weight:600;font-family:var(--body);letter-spacing:0.01em;margin-bottom:8px;}
.cycle .c p{font-size:14px;color:var(--text-soft);}

/* CTA band */
.cta{background:linear-gradient(180deg,var(--night) 0%,var(--night-2) 100%);border-top:1px solid var(--line);text-align:center;}
.cta h2{font-size:clamp(38px,6.5vw,82px);font-weight:500;}
.cta h2 em{font-style:italic;color:var(--ice);}
.cta p{font-size:18px;color:var(--text-soft);max-width:48ch;margin:20px auto 32px;}
.cta .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* Page hero (interior) */
.page-hero{padding-top:clamp(130px,16vw,180px);padding-bottom:clamp(30px,5vw,56px);border-bottom:1px solid var(--line);}
.page-hero h1{font-size:clamp(42px,8vw,92px);font-weight:500;margin-top:16px;max-width:16ch;}
.page-hero h1 em{font-style:italic;color:var(--ice);}
.page-hero .lead{font-size:18px;color:var(--text-soft);max-width:56ch;margin-top:22px;}

/* Gallery page grid */
.gal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,40px);}
.gal{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--panel);}
.gal .ph{overflow:hidden;aspect-ratio:3/2;}
.gal .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);}
.gal:hover .ph img{transform:scale(1.04);}
.gal .cap{padding:18px 20px 22px;display:flex;align-items:baseline;gap:14px;}
.gal .cap .no{font-family:var(--display);font-style:italic;font-size:22px;color:var(--ice);}
.gal .cap h3{font-size:20px;font-weight:500;}
.gal .cap .place{font-family:var(--body);font-size:11.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-dim);margin-top:3px;}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:clamp(36px,5vw,72px);align-items:start;}
.field{margin-bottom:20px;}
.field label{display:block;font-family:var(--body);font-weight:600;font-size:11.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-soft);margin-bottom:9px;}
.field input,.field textarea,.field select{width:100%;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:13px 15px;font-family:var(--body);font-size:15.5px;color:var(--text);}
.field input::placeholder,.field textarea::placeholder{color:var(--text-dim);}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--ice);box-shadow:0 0 0 3px rgba(159,199,255,0.18);}
.field textarea{min-height:130px;resize:vertical;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.contact-side{border:1px solid var(--line);border-radius:var(--r);padding:28px;background:var(--panel);}
.contact-side .row{margin-bottom:18px;}
.contact-side .row b{display:block;font-family:var(--body);font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--ice);margin-bottom:4px;}
.contact-side .row a{color:var(--text);font-weight:500;}
.big-phone{font-family:var(--display);font-size:clamp(28px,3.6vw,40px);color:var(--text);}
.success-msg{display:none;margin-top:16px;padding:14px 18px;border:1px solid var(--ice);border-radius:var(--r);background:rgba(159,199,255,0.1);color:var(--text);font-size:14.5px;}
.success-msg.show{display:block;}
.field .req{color:var(--ice);font-weight:700;}

/* Address type-ahead */
.addr-field{position:relative;margin-bottom:12px;}
.addr-suggestions{position:absolute;top:100%;left:0;right:0;z-index:30;margin:4px 0 0;padding:6px;list-style:none;background:var(--night-2);border:1px solid var(--line);border-radius:var(--r);box-shadow:0 14px 40px rgba(0,0,0,0.45);max-height:280px;overflow-y:auto;}
.addr-item{padding:11px 13px;font-family:var(--body);font-size:14.5px;color:var(--text-soft);border-radius:var(--r);cursor:pointer;}
.addr-item:hover{background:rgba(159,199,255,0.12);color:var(--text);}
.addr-credit{font-family:var(--body);font-size:11.5px;letter-spacing:0.02em;color:var(--text-dim);margin-top:7px;}
.addr-row{grid-template-columns:1.2fr 0.8fr 0.8fr;}

/* Photo drop zone */
.dropzone{position:relative;border:1px dashed var(--line);border-radius:var(--r);background:var(--panel);padding:30px 20px;text-align:center;cursor:pointer;transition:border-color .18s var(--ease),background .18s var(--ease);}
.dropzone:hover,.dropzone:focus-visible,.dropzone.drag{border-color:var(--ice);background:rgba(159,199,255,0.06);outline:none;}
.dz-input{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden;clip:rect(0 0 0 0);}
.dz-inner svg{color:var(--ice);margin:0 auto 10px;display:block;}
.dz-title{font-family:var(--body);font-size:15px;font-weight:600;color:var(--text);}
.dz-help{font-family:var(--body);font-size:13px;color:var(--text-dim);margin-top:6px;max-width:42ch;margin-inline:auto;}
.dz-previews{margin-top:14px;}
.dz-count{font-family:var(--body);font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--ice);margin-bottom:12px;}
.dz-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:12px;}
.dz-thumb{position:relative;aspect-ratio:1/1;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--night-2);}
.dz-thumb img{width:100%;height:100%;object-fit:cover;}
.dz-remove{position:absolute;top:5px;right:5px;width:24px;height:24px;border-radius:50%;border:none;background:rgba(7,12,21,0.8);color:var(--text);font-size:17px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);transition:background .16s var(--ease);}
.dz-remove:hover{background:var(--ice);color:#08111F;}

/* Pricing (lead with the range) */
.price-anchor{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(40px,6vw,72px) 0;}
.price-anchor .from{font-family:var(--body);font-size:12px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--ice);}
.price-anchor .num{font-family:var(--display);font-style:italic;font-size:clamp(56px,11vw,140px);font-weight:500;line-height:0.92;color:var(--text);margin:14px 0 0;letter-spacing:0;}
.price-anchor .num em{font-style:italic;color:var(--ice);}
.price-anchor .note{font-family:var(--body);font-size:16.5px;color:var(--text-soft);max-width:54ch;margin-top:22px;}
.price-rows{display:grid;gap:0;border-top:1px solid var(--line);margin-top:0;}
.price-rows .pr{display:grid;grid-template-columns:0.9fr 1.1fr;gap:30px;padding:28px 4px;border-bottom:1px solid var(--line);align-items:baseline;}
.price-rows .pr h3{font-size:clamp(20px,2.6vw,28px);font-weight:500;}
.price-rows .pr p{font-size:15.5px;color:var(--text-soft);}

/* Featured service block (image + copy, e.g. landscape lighting) */
.feature{display:grid;grid-template-columns:1.05fr 0.95fr;gap:clamp(32px,5vw,64px);align-items:center;}
.feature.flip{direction:rtl;}
.feature.flip > *{direction:ltr;}
.feature .feature-media{display:grid;grid-template-columns:1fr;gap:clamp(14px,2vw,20px);}
.feature .feature-media .stack{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,2vw,20px);}
.feature .feature-media figure{margin:0;overflow:hidden;border:1px solid var(--line);border-radius:var(--r);background:var(--panel);}
.feature .feature-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;transition:transform 1.2s var(--ease);}
.feature .feature-media figure:hover img{transform:scale(1.04);}
.feature .feature-copy .eyebrow{margin-bottom:14px;display:block;}
.feature .feature-copy h2{font-size:clamp(30px,4.6vw,54px);font-weight:500;}
.feature .feature-copy .lede{font-family:var(--display);font-size:clamp(20px,2.4vw,28px);font-weight:500;line-height:1.3;color:var(--text);margin-top:16px;max-width:30ch;}
.feature .feature-copy .lede em{font-style:italic;color:var(--ice);}
.feature .feature-copy p{font-size:15.5px;color:var(--text-soft);margin-top:18px;max-width:54ch;}
.feature .feature-list{list-style:none;padding:0;margin:22px 0 0;display:grid;gap:10px;}
.feature .feature-list li{font-size:15px;color:var(--text-soft);padding-left:22px;position:relative;}
.feature .feature-list li::before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;background:var(--ice);}
.feature .feature-price{font-family:var(--body);font-size:13.5px;letter-spacing:0.04em;color:var(--text-dim);margin-top:22px;}
.feature .feature-price b{color:var(--ice);font-weight:600;}

/* Service area */
.area-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:clamp(36px,5vw,64px);align-items:start;}
.hoods{columns:2;column-gap:28px;margin:20px 0 0;padding:0;list-style:none;}
.hoods li{padding:11px 0;border-bottom:1px solid var(--line-2);font-size:15.5px;color:var(--text-soft);break-inside:avoid;}
.hoods li::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--ice);margin-right:11px;vertical-align:middle;}

/* Footer */
footer.site{background:#070C15;border-top:1px solid var(--line);padding:64px 0 32px;}
.foot-main{display:grid;grid-template-columns:1.6fr 1fr;gap:48px;padding-bottom:34px;border-bottom:1px solid var(--line-2);}
.foot-brand .brand{margin-bottom:14px;display:inline-block;}
.foot-brand p{font-size:14.5px;color:var(--text-soft);max-width:42ch;}
.foot-contact{display:flex;flex-direction:column;gap:6px;font-size:14.5px;margin-top:16px;}
.foot-contact a{color:var(--ice);}
.foot-nav{display:flex;flex-direction:column;gap:12px;}
.foot-nav a{font-size:14.5px;color:var(--text-soft);}
.foot-nav a:hover{color:var(--text);}
.foot-bottom{padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:var(--text-dim);}
.foot-bottom a{color:var(--ice);}

:focus-visible{outline:2px solid var(--ice);outline-offset:3px;}

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

@media (max-width:980px){
  nav.main{position:fixed;inset:70px 16px auto 16px;flex-direction:column;align-items:stretch;gap:4px;background:rgba(11,18,32,0.97);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:var(--r);padding:12px;display:none;z-index:60;}
  nav.main.open{display:flex;}
  nav.main a{padding:13px 15px;font-size:16px;}
  .menu-btn{display:inline-flex;}
  .nav-cta{display:none;}
  .cycle{grid-template-columns:1fr 1fr;}
  .feature{grid-template-columns:1fr;gap:32px;}
  .feature.flip{direction:ltr;}
  .feature .feature-media{order:-1;}
  .contact-grid,.area-grid{grid-template-columns:1fr;}
  .foot-main{grid-template-columns:1fr;gap:28px;}
}
@media (max-width:680px){
  .gal-grid{grid-template-columns:1fr;}
  .cycle{grid-template-columns:1fr;}
  .svc-item{grid-template-columns:auto 1fr;}
  .svc-item .flag{grid-column:2;}
  .price-rows .pr{grid-template-columns:1fr;gap:8px;}
  .hoods{columns:1;}
  .field-row{grid-template-columns:1fr;}
  .addr-row{grid-template-columns:1fr;}
  .work-meta .left{max-width:100%;}
  .work-meta,.work-item:nth-child(even) .work-meta{flex-direction:column;align-items:flex-start;}
  .work-item:nth-child(even) .work-meta p{text-align:left;}
  .work-item .frame img{aspect-ratio:4/3;}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important;}
  .hero .bg img{animation:none;transform:none;}
  .work-item .frame img,.gal .ph img{transition:none;}
  html{scroll-behavior:auto;}
}
