/* Bronze Age Lighting & Metal Works - shared site stylesheet */
:root{
 --dark:#201F1D;
 --bg:#FFFFFF;
 --surface:#F7F5F0;
 --ink:#3B4048;
 --muted:#6B7280;
 --primary:#8A6A3A;
 --gold:#C7A15C;
 --on-primary:#FFFFFF;
 --line:#E4E0D8;
 --success:#3F7A4C;
 --danger:#A6371A;
 --radius:2px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){ html{scroll-behavior:auto} }
body{
 background:var(--bg);
 color:var(--ink);
 font-family:'Jost',sans-serif;
 font-size:16px;
 line-height:1.65;
 -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit}
h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:600;line-height:1.15;color:var(--dark)}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px}
@media (min-width:900px){ .wrap{padding:0 48px} }

.skip-link{
 position:absolute;left:12px;top:-60px;background:var(--primary);color:#fff;
 padding:12px 18px;border-radius:var(--radius);font-weight:600;z-index:200;transition:top .18s ease;
}
.skip-link:focus{top:12px}
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
 outline:2px solid var(--primary); outline-offset:3px; border-radius:2px;
}

/* ---------- reveal ---------- */
html.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .55s ease,transform .55s ease}
html.js .reveal.in{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion:reduce){ html.js .reveal{transition:none;opacity:1;transform:none} }

/* ---------- header ---------- */
header.site{background:var(--dark);border-bottom:1px solid rgba(255,255,255,.08);position:sticky;top:0;z-index:100}
.site-bar{display:flex;align-items:center;justify-content:space-between;padding-block:16px;gap:16px}
.wordmark{font-family:'Cormorant Garamond',serif;font-size:1.7rem;letter-spacing:.03em;text-decoration:none;color:var(--gold);white-space:nowrap}
.wordmark small{display:block;font-family:'Jost',sans-serif;font-size:.56rem;letter-spacing:.22em;color:#B9AF9E;font-weight:400;margin-top:2px}
nav.primary{display:none;gap:17px;align-items:center;flex-wrap:nowrap}
@media (min-width:1200px){ nav.primary{display:flex} }
nav.primary a{text-decoration:none;font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:#E7E2D6;opacity:.86;padding:6px 2px;border-bottom:1px solid transparent;white-space:nowrap}
nav.primary a:hover, nav.primary a[aria-current]{opacity:1;border-color:var(--gold);color:var(--gold)}
.hdr-right{display:flex;align-items:center;gap:12px}
.phone-chip{display:none;font-size:.82rem;color:#E7E2D6;text-decoration:none}
@media (min-width:1340px){ .phone-chip{display:inline} }
.btn{
 display:inline-flex;align-items:center;justify-content:center;gap:.5em;
 padding:.8em 1.3em;border-radius:var(--radius);font-weight:600;font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;
 text-decoration:none;border:1px solid var(--primary);cursor:pointer;transition:filter .15s ease, background .15s ease, color .15s ease;
 min-height:44px;
}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{filter:brightness(1.08)}
.btn-line{border-color:var(--gold);color:var(--dark);background:transparent}
.btn-line:hover{background:var(--gold);color:var(--dark)}
.btn-on-dark{border-color:var(--gold);color:var(--gold)}
.btn-on-dark:hover{background:var(--gold);color:var(--dark)}

.hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;background:none;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius)}
@media (min-width:1200px){ .hamburger{display:none} }
.hamburger span{display:block;width:20px;height:2px;background:var(--gold);margin:0 auto}
#mobnav{display:none;border-top:1px solid rgba(255,255,255,.1);padding-block:14px 22px}
#mobnav.open{display:block}
@media (min-width:1200px){ #mobnav{display:none !important} }
#mobnav a{display:block;padding:12px 4px;text-decoration:none;color:#E7E2D6;font-size:1rem;border-bottom:1px solid rgba(255,255,255,.08)}

/* ---------- page hero band ---------- */
.page-hero{padding:56px 0 40px;border-bottom:1px solid var(--line)}
.page-hero .eyebrow{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);margin-bottom:10px}
.page-hero h1{font-size:2.6rem}
@media (min-width:768px){ .page-hero h1{font-size:3.4rem} }
.page-hero p{max-width:62ch;color:var(--muted);margin-top:14px;font-size:1.05rem}

/* full-bleed photo hero (home) */
.photo-hero{position:relative;overflow:hidden;background:var(--dark)}
.photo-hero img{width:100%;height:56vw;max-height:640px;min-height:340px;object-fit:cover;opacity:.92}
.photo-hero-copy{position:absolute;inset:0;display:flex;align-items:flex-end}
.photo-hero-copy .wrap{padding-bottom:48px;width:100%}
.photo-hero-scrim{position:absolute;inset:0;background:linear-gradient(0deg, rgba(16,14,10,.86) 0%, rgba(16,14,10,.25) 55%, rgba(16,14,10,.05) 100%)}
.photo-hero h1{color:#fff;font-size:2.4rem;max-width:16ch}
@media (min-width:768px){ .photo-hero h1{font-size:3.6rem} }
.photo-hero p{color:#EDE7D9;max-width:52ch;margin-top:14px;font-size:1.05rem}
@media (max-width:767px){
 .photo-hero{overflow:visible}
 .photo-hero img{height:230px;min-height:0;opacity:1}
 .photo-hero-scrim{display:none}
 .photo-hero-copy{position:static;background:var(--dark)}
 .photo-hero-copy .wrap{padding-top:30px;padding-bottom:38px}
 .photo-hero h1{font-size:2rem;max-width:none}
 .photo-hero p{max-width:none}
}

/* ---------- sections ---------- */
.sec-pad{padding:64px 0}
@media (min-width:900px){ .sec-pad{padding:92px 0} }
.sec-pad.alt{background:var(--surface)}
.sec-head{margin-bottom:40px;max-width:70ch}
.sec-head .eyebrow{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);margin-bottom:10px}
.sec-head h2{font-size:2rem}
@media (min-width:768px){ .sec-head h2{font-size:2.6rem} }
.sec-head p{color:var(--muted);margin-top:12px;font-size:1rem}
.center{text-align:center;margin-left:auto;margin-right:auto}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- cards / grids ---------- */
.grid3{display:grid;gap:28px;grid-template-columns:1fr}
@media (min-width:640px){ .grid3{grid-template-columns:1fr 1fr} }
@media (min-width:980px){ .grid3{grid-template-columns:1fr 1fr 1fr} }
.card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.card img{aspect-ratio:4/3;width:100%;object-fit:cover}
.card .card-body{padding:20px 22px}
.card h3{font-size:1.25rem;margin-bottom:6px}
.card p{color:var(--muted);font-size:.92rem}
.card .card-cta{display:inline-block;margin-top:12px;font-size:.82rem;font-weight:600;color:var(--primary);text-decoration:none;letter-spacing:.03em}
.card .card-cta:hover{text-decoration:underline}

/* project name-only row (unphotographed installs) */
.name-rows{list-style:none;border-top:1px solid var(--line)}
.name-rows li{padding:14px 4px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;gap:14px;font-size:.98rem}
.name-rows .tag{font-size:.76rem;color:var(--muted);letter-spacing:.03em}

/* ---------- custom work rows ---------- */
.cw-row{display:grid;gap:28px;align-items:center;padding:48px 0;border-bottom:1px solid var(--line)}
@media (min-width:820px){ .cw-row{grid-template-columns:1fr 1fr;gap:56px} }
.cw-row.rev .cw-photo{order:2}
@media (min-width:820px){ .cw-row.rev .cw-copy{order:1} .cw-row.rev .cw-photo{order:2} }
.cw-photo img{width:100%;border-radius:var(--radius);aspect-ratio:4/3;object-fit:cover}
.cw-copy .num{font-family:'Cormorant Garamond',serif;font-size:1rem;color:var(--gold);letter-spacing:.08em}
.cw-copy h3{font-size:1.9rem;margin:8px 0 12px}
.cw-copy p{color:var(--muted)}

/* ---------- testimonials ---------- */
.testi-band{position:relative;background:var(--dark);color:#fff;padding:64px 0}
.testi-band img.bgphoto{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.28}
.testi-band .wrap{position:relative}
.testi-band h2{color:#fff}
.testi-grid{display:grid;gap:20px;grid-template-columns:1fr;margin-top:32px}
@media (min-width:720px){ .testi-grid{grid-template-columns:1fr 1fr 1fr} }
.testi-card{background:rgba(255,255,255,.96);color:var(--ink);border-radius:var(--radius);padding:26px 22px;text-align:center}
.testi-card .avatar{width:52px;height:52px;border-radius:50%;background:var(--surface);color:var(--primary);display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:1.4rem;margin:0 auto 12px}
.stars{color:var(--gold);letter-spacing:.12em;margin-bottom:10px;font-size:1rem}
.testi-card h3{font-size:1.05rem;margin-bottom:8px;color:var(--dark)}
.testi-card p{font-size:.92rem;font-style:italic;color:var(--muted)}
.testi-card .cite{margin-top:12px;font-size:.8rem;color:var(--primary);font-weight:600}

/* ---------- retailers ---------- */
.retail-region{margin-bottom:36px}
.retail-region h2{font-size:1.1rem;letter-spacing:.06em;text-transform:uppercase;color:var(--primary);margin-bottom:16px}
.retail-list{list-style:none;display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width:720px){ .retail-list{grid-template-columns:1fr 1fr 1fr} }
.retail-list li{border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.retail-list .r-name{font-weight:700;margin-bottom:6px}
.retail-list .r-addr{font-size:.86rem;color:var(--muted);margin-bottom:4px}
.retail-list a{font-size:.86rem;color:var(--primary);text-decoration:none}
.retail-list a:hover{text-decoration:underline}

/* ---------- finishes ---------- */
.finish-grid{display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}
@media (min-width:640px){ .finish-grid{grid-template-columns:repeat(3,1fr)} }
@media (min-width:980px){ .finish-grid{grid-template-columns:repeat(4,1fr)} }
.finish-swatch{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-align:center;background:#fff}
.finish-swatch .chip{height:74px}
.finish-swatch .fname{padding:12px 8px;font-size:.82rem;font-weight:600}

/* ---------- ordering / policy content ---------- */
.policy h2{font-size:1.25rem;margin:34px 0 10px;color:var(--dark)}
.policy h2:first-child{margin-top:0}
.policy p{margin-bottom:12px;color:var(--ink)}
.policy ul{margin:0 0 12px 22px;color:var(--ink)}
.policy li{margin-bottom:6px}
.policy strong{color:var(--dark)}

/* ---------- media grid ---------- */
.media-grid{display:grid;gap:28px;grid-template-columns:1fr}
@media (min-width:640px){ .media-grid{grid-template-columns:1fr 1fr} }
.media-grid figure img{width:100%;border-radius:var(--radius);aspect-ratio:3/4;object-fit:cover;border:1px solid var(--line)}
.media-grid figcaption{margin-top:10px;font-weight:600;font-size:.94rem;text-align:center}

/* ---------- contact ---------- */
.contact-grid{display:grid;gap:44px}
@media (min-width:900px){ .contact-grid{grid-template-columns:1fr 1fr;gap:64px} }
.contact-facts{list-style:none;margin:20px 0 24px}
.contact-facts li{padding:12px 0;border-bottom:1px solid var(--line);display:flex;gap:14px;font-size:.95rem}
.contact-facts .cf-label{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--primary);min-width:90px}
form.quote{display:flex;flex-direction:column;gap:16px}
form.quote label{display:block;font-size:.82rem;margin-bottom:6px;color:var(--muted)}
form.quote input, form.quote select, form.quote textarea{
 width:100%;background:#fff;border:1px solid var(--line);color:var(--ink);
 padding:.85em .9em;border-radius:var(--radius);font:inherit;font-size:.95rem;min-height:44px;
}
form.quote textarea{min-height:110px;resize:vertical}
.form-status{font-size:.88rem;color:var(--primary);min-height:1.2em}

/* ---------- footer ---------- */
footer.site{background:var(--dark);color:#EDE7D9;padding:64px 0 0}
.foot-grid{display:grid;gap:36px;grid-template-columns:1fr}
@media (min-width:820px){ .foot-grid{grid-template-columns:1.3fr 1fr 1fr 1fr} }
.foot-h{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
footer.site .wordmark{margin-bottom:12px}
footer.site p{color:#C9C2B2;font-size:.9rem}
.foot-links{list-style:none}
.foot-links li{margin-bottom:9px}
.foot-links a{color:#C9C2B2;text-decoration:none;font-size:.92rem}
.foot-links a:hover{color:var(--gold)}
.foot-social{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.foot-social a{display:inline-flex;align-items:center;gap:7px;padding:8px 13px;border:1px solid rgba(255,255,255,.2);border-radius:999px;color:#C9C2B2;text-decoration:none;font-size:.8rem;font-weight:600;min-height:40px;transition:border-color .15s ease,color .15s ease}
.foot-social a:hover{border-color:var(--gold);color:var(--gold)}
.foot-social svg{width:16px;height:16px;flex:none}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:44px;padding:22px 0;display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;font-size:.82rem;color:#9A927E}
.credit{color:#C9C2B2;text-decoration:none;border-bottom:1px solid transparent}
.credit:hover{border-color:currentColor;color:var(--gold)}

@media (pointer:coarse){
 .btn, .card-cta, nav.primary a{min-height:44px}
}

/* ---------- fw widgets ---------- */
.fw-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;padding:.85em 1.15em;border-radius:var(--radius);background:var(--primary);color:#fff;font:inherit;font-weight:600;text-decoration:none;min-height:44px}
.fw-btn:hover{filter:brightness(1.08)}
.fw-btn svg{width:1.1em;height:1.1em;flex:none}
fw-hours{display:inline-flex;align-items:center;gap:.5em;font:inherit;line-height:1;color:var(--ink);padding:.5em .9em;border-radius:999px;background:color-mix(in srgb, var(--fw-status,#888) 12%, transparent);border:1px solid color-mix(in srgb, var(--fw-status,#888) 26%, transparent)}
.fw-hours.is-open{--fw-status:var(--success)}
.fw-hours.is-closed{--fw-status:var(--danger)}
.fw-hours-dot{width:.6em;height:.6em;border-radius:50%;background:var(--fw-status,#999);flex:none}
.fw-hours.is-open .fw-hours-dot{animation:fw-pulse 2.6s ease-out infinite}
@keyframes fw-pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb, var(--fw-status) 55%, transparent)}70%{box-shadow:0 0 0 .5em color-mix(in srgb, var(--fw-status) 0%, transparent)}100%{box-shadow:0 0 0 0 color-mix(in srgb, var(--fw-status) 0%, transparent)}}
.fw-hours-text{font-weight:600}
.fw-map--standalone{padding:1.15em;text-align:center;border:1px solid var(--line);border-radius:var(--radius)}
.fw-map-addr{display:block;margin-bottom:.75em;color:var(--ink);font-weight:600}
.map-card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface)}
.map-frame{width:100%;aspect-ratio:16/10;border:0;display:block;filter:grayscale(.15)}
.map-foot{padding:.85em;display:flex}
.map-foot .fw-btn{flex:1}
@media (prefers-reduced-motion:reduce){ .fw-hours.is-open .fw-hours-dot{animation:none} }

/* ---------- Instagram strip ---------- */
.ig-strip{display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}
@media (min-width:560px){ .ig-strip{grid-template-columns:repeat(3,1fr)} }
@media (min-width:900px){ .ig-strip{grid-template-columns:repeat(6,1fr)} }
.ig-tile{position:relative;display:block;overflow:hidden;border-radius:var(--radius);aspect-ratio:1;background:var(--surface);border:1px solid var(--line)}
.ig-tile img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.ig-tile:hover img,.ig-tile:focus-visible img{transform:scale(1.06)}
.ig-ov{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(32,31,29,0);color:#fff;opacity:0;transition:opacity .3s ease,background .3s ease}
.ig-tile:hover .ig-ov,.ig-tile:focus-visible .ig-ov{opacity:1;background:rgba(32,31,29,.44)}
.ig-ov svg{width:26px;height:26px}
@media (prefers-reduced-motion:reduce){ .ig-tile img{transition:none} .ig-tile:hover img,.ig-tile:focus-visible img{transform:none} }

/* ---------- fw-contact-bar (mobile sticky) ---------- */
fw-contact-bar{display:none}
@media (max-width:640px){
 fw-contact-bar{position:fixed;left:0;right:0;bottom:0;display:flex;z-index:60;background:var(--dark);border-top:1px solid var(--gold);padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -8px 26px -10px rgba(0,0,0,.55)}
 body{padding-bottom:64px}
}
.fw-contact-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:9px 0 8px;min-height:56px;color:#EDE7D9;text-decoration:none;font-weight:600;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase}
.fw-contact-btn svg{width:20px;height:20px;color:var(--gold)}
.fw-contact-btn:not(:last-child){box-shadow:inset -1px 0 0 rgba(255,255,255,.12)}
.fw-contact-btn:active{background:rgba(255,255,255,.06)}
.fw-contact-btn:focus-visible{outline:2px solid var(--gold);outline-offset:-2px}
