
:root{
  --porcelain:#F1F0EB;
  --paper:#FAFAF6;
  --ink:#1F2528;
  --ink-soft:#4E585D;
  --glaze:#2F6E68;
  --glaze-deep:#1E4D49;
  --brass:#A8793C;
  --linen:#E7E4DA;
  --line:#D8D5CB;
  --radius:14px;
  --shadow:0 18px 50px -22px rgba(31,37,40,.28);
  --display:'Marcellus',serif;
  --body:'Hanken Grotesk',system-ui,sans-serif;
  --mono:'DM Mono',ui-monospace,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--porcelain);color:var(--ink);line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%}
a{color:inherit}
button{font:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--glaze);outline-offset:3px;border-radius:4px}

/* ---------- header ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(241,240,235,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{max-width:1240px;margin:0 auto;display:flex;align-items:center;gap:26px;padding:14px 28px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand .mark{width:34px;height:34px;flex:none}
.brand b{font-family:var(--display);font-weight:400;font-size:21px;letter-spacing:.04em}
.brand small{display:block;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);font-family:var(--mono)}
.navlinks{display:flex;gap:4px;margin-left:auto;align-items:center}
.navlinks a{padding:9px 14px;border-radius:999px;text-decoration:none;font-weight:500;font-size:15px;color:var(--ink-soft);transition:.2s}
.navlinks a:hover{color:var(--ink);background:rgba(31,37,40,.06)}
.navlinks a[aria-current="page"]{color:var(--paper);background:var(--ink)}
.cta-mini{margin-left:8px;background:var(--glaze);color:#fff !important;font-weight:600}
.cta-mini:hover{background:var(--glaze-deep) !important}
.burger{display:none;margin-left:auto;background:none;border:1px solid var(--line);border-radius:10px;padding:8px 11px;font-size:18px;line-height:1}

/* ---------- shared ---------- */
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}
section.block{padding:84px 0}
.eyebrow{font-family:var(--mono);font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);display:flex;align-items:center;gap:12px;margin-bottom:18px}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--brass)}
h1,h2,h3{font-family:var(--display);font-weight:400;line-height:1.12}
h1{font-size:clamp(40px,5.4vw,68px);letter-spacing:-.01em}
h2{font-size:clamp(30px,3.6vw,44px);margin-bottom:14px}
h3{font-size:22px}
.lede{font-size:19px;color:var(--ink-soft);max-width:640px}
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;border-radius:999px;border:none;text-decoration:none;font-weight:600;font-size:16px;transition:.22s}
.btn.primary{background:var(--glaze);color:#fff}
.btn.primary:hover{background:var(--glaze-deep);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}
.mono{font-family:var(--mono);font-size:13px;letter-spacing:.04em;color:var(--ink-soft)}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- pages ---------- */
.page{display:none}
.page.active{display:block;animation:pageIn .45s ease}
@keyframes pageIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---------- hero ---------- */
.hero{display:grid;grid-template-columns:1.05fr .95fr;min-height:calc(100vh - 64px);align-items:stretch}
.hero-copy{display:flex;flex-direction:column;justify-content:center;padding:70px 56px 70px 28px;max-width:660px;margin-left:auto}
.hero-copy .lede{margin:22px 0 34px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-proof{display:flex;gap:26px;margin-top:46px;flex-wrap:wrap}
.hero-proof span{font-family:var(--mono);font-size:13px;color:var(--ink-soft);display:flex;align-items:center;gap:8px}
.hero-proof i{width:7px;height:7px;border-radius:2px;background:var(--brass);display:inline-block}
.hero-tilewall{position:relative;overflow:hidden;background:var(--glaze-deep)}
.hero-tilewall svg{position:absolute;inset:0;width:100%;height:100%}
.hero-badge{position:absolute;left:26px;bottom:26px;background:rgba(250,250,246,.94);border-radius:12px;padding:13px 18px;font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;box-shadow:var(--shadow)}
@keyframes tileIn{from{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}
.ht{transform-box:fill-box;transform-origin:center;animation:tileIn .55s cubic-bezier(.2,.7,.3,1) both}

/* ---------- service cards ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:42px}
.svc{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:26px;transition:.25s;text-decoration:none;display:block}
.svc:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.svc .chiprow{display:flex;gap:6px;margin-bottom:16px}
.svc .chiprow i{width:14px;height:14px;border-radius:3px;display:block}
.svc h3{margin-bottom:8px}
.svc p{color:var(--ink-soft);font-size:15.5px}
.svc .go{margin-top:14px;font-weight:600;font-size:14.5px;color:var(--glaze)}

/* ---------- gallery ---------- */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:42px}
.gal-2{grid-template-columns:repeat(2,1fr)}
.tilecard{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-align:left;padding:0;transition:.25s;display:block;width:100%}
.tilecard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.tilecard .ph{aspect-ratio:4/3;overflow:hidden;position:relative}
.tilecard .ph svg{width:100%;height:100%;transition:transform .6s ease}
.tilecard:hover .ph svg{transform:scale(1.06)}
.tilecard .ph::after{content:"View larger +";position:absolute;right:12px;bottom:12px;background:rgba(31,37,40,.78);color:#fff;font-size:12px;font-family:var(--mono);padding:6px 11px;border-radius:999px;opacity:0;transition:.25s}
.tilecard:hover .ph::after{opacity:1}
.tilecard figcaption{padding:16px 18px}
.tilecard figcaption b{display:block;font-weight:600;font-size:16px}
.tilecard figcaption span{font-family:var(--mono);font-size:12.5px;color:var(--ink-soft)}

/* ---------- process ---------- */
.process{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:42px;counter-reset:step}
.step{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:22px;position:relative}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--mono);color:var(--brass);font-size:13px;letter-spacing:.1em}
.step h3{font-size:19px;margin:10px 0 6px;color:var(--ink)}
.step p{font-size:14.5px;color:var(--ink-soft)}

/* ---------- band / reviews / chips ---------- */
.band{background:var(--ink);color:var(--porcelain)}
.band .eyebrow{color:var(--brass)}
.band h2{color:var(--paper)}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:42px}
.review{background:rgba(250,250,246,.06);border:1px solid rgba(250,250,246,.14);border-radius:var(--radius);padding:26px}
.review .stars{color:var(--brass);letter-spacing:3px;margin-bottom:12px}
.review p{font-size:15.5px;color:#D8D9D2}
.review footer{margin-top:16px;font-family:var(--mono);font-size:12.5px;color:#9aa39f}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.chip{padding:9px 17px;border-radius:999px;border:1px solid var(--line);background:var(--paper);font-size:14.5px;font-weight:500}
.chip.hot{background:var(--glaze);border-color:var(--glaze);color:#fff}

/* ---------- page hero strip ---------- */
.pagehero{padding:74px 0 30px}
.pagehero .lede{margin-top:16px}

/* ---------- info split ---------- */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.split ul{list-style:none;margin-top:20px;display:grid;gap:12px}
.split li{display:flex;gap:12px;align-items:flex-start;font-size:16px}
.split li::before{content:"";width:16px;height:16px;flex:none;margin-top:5px;border-radius:4px;background:
  linear-gradient(135deg,var(--glaze) 50%,var(--brass) 50%)}
.framedsvg{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3}
.framedsvg svg{width:100%;height:100%}

/* ---------- table ---------- */
.pricetable{width:100%;border-collapse:collapse;margin-top:36px;background:var(--paper);border-radius:var(--radius);overflow:hidden;box-shadow:0 1px 0 var(--line)}
.pricetable th,.pricetable td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--line);font-size:15.5px}
.pricetable th{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);background:var(--linen)}
.pricetable td:last-child{font-family:var(--mono);white-space:nowrap}
.finenote{font-size:13.5px;color:var(--ink-soft);margin-top:12px}

/* ---------- accordion ---------- */
.acc{margin-top:36px;display:grid;gap:10px}
.acc-item{background:var(--paper);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.acc-h{width:100%;background:none;border:none;display:flex;justify-content:space-between;align-items:center;padding:18px 22px;font-weight:600;font-size:16.5px;text-align:left;gap:16px}
.acc-h::after{content:"+";font-family:var(--mono);font-size:20px;color:var(--brass);transition:.25s}
.acc-item.open .acc-h::after{transform:rotate(45deg)}
.acc-b{max-height:0;overflow:hidden;transition:max-height .35s ease}
.acc-b p{padding:0 22px 20px;color:var(--ink-soft);font-size:15.5px}

/* ---------- before / after ---------- */
.ba{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:16/9;margin-top:42px;user-select:none;touch-action:none}
.ba .layer{position:absolute;inset:0}
.ba .layer svg{width:100%;height:100%}
.ba .after{clip-path:inset(0 50% 0 0)}
.ba .divider{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;box-shadow:0 0 0 1px rgba(0,0,0,.15)}
.ba .knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--ink);box-shadow:var(--shadow);font-weight:700}
.ba .tag{position:absolute;top:16px;font-family:var(--mono);font-size:12px;letter-spacing:.12em;background:rgba(31,37,40,.78);color:#fff;padding:6px 12px;border-radius:999px;pointer-events:none}
.ba .tag.before{left:16px}.ba .tag.after{right:16px}
.ba input[type=range]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize}

/* ---------- tile lab ---------- */
.lab{display:grid;grid-template-columns:380px 1fr;gap:32px;margin-top:42px;align-items:start}
.lab-panel{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:26px;position:sticky;top:90px}
.lab-panel h3{font-size:15px;font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin:22px 0 12px;font-weight:500}
.lab-panel h3:first-child{margin-top:0}
.optrow{display:flex;flex-wrap:wrap;gap:8px}
.opt{border:1.5px solid var(--line);background:var(--porcelain);border-radius:999px;padding:8px 15px;font-size:14px;font-weight:500;transition:.18s}
.opt:hover{border-color:var(--ink)}
.opt[aria-pressed="true"]{background:var(--ink);border-color:var(--ink);color:#fff}
.swrow{display:flex;flex-wrap:wrap;gap:10px}
.sw{width:36px;height:36px;border-radius:10px;border:2px solid rgba(0,0,0,.1);transition:.18s;position:relative}
.sw:hover{transform:scale(1.12)}
.sw[aria-pressed="true"]{box-shadow:0 0 0 3px var(--paper),0 0 0 5.5px var(--glaze)}
.lab-slider{width:100%;accent-color:var(--glaze);margin-top:4px}
.lab-stage{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.lab-stage .view{aspect-ratio:4/3}
.lab-stage .view svg{width:100%;height:100%}
.lab-spec{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;padding:18px 22px;border-top:1px solid var(--line)}
.lab-spec div b{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}
.lab-spec div span{font-weight:600;font-size:15px}
.lab-foot{padding:0 22px 22px;display:flex;gap:12px;flex-wrap:wrap}

/* ---------- contact ---------- */
.contact{display:grid;grid-template-columns:1fr .85fr;gap:48px;align-items:start}
.form{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:34px;display:grid;gap:18px}
.fld label{display:block;font-weight:600;font-size:14px;margin-bottom:7px}
.fld input,.fld select,.fld textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;background:var(--porcelain);font:inherit;font-size:15.5px;transition:.18s}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--glaze);background:#fff}
.fld textarea{min-height:120px;resize:vertical}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.formok{display:none;background:#EAF3EE;border:1px solid #BFD8C9;color:#1E4D38;border-radius:10px;padding:16px 18px;font-size:15px}
.cinfo{display:grid;gap:14px}
.cinfo .card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.cinfo .card b{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);display:block;margin-bottom:8px;font-weight:500}
.cinfo .big{font-family:var(--display);font-size:26px}

/* ---------- footer ---------- */
footer.site{background:var(--ink);color:#B9BFBA;margin-top:90px}
.foot{max-width:1240px;margin:0 auto;padding:56px 28px 30px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
.foot h4{font-family:var(--mono);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:#8C948F;margin-bottom:14px;font-weight:500}
.foot a{display:block;text-decoration:none;color:#C9CEC8;padding:4px 0;font-size:15px}
.foot a:hover{color:#fff}
.foot .brand b{color:#fff}
.foot .brand small{color:#8C948F}
.legal{border-top:1px solid rgba(255,255,255,.12);padding:20px 28px;text-align:center;font-size:13px;color:#7E867F;font-family:var(--mono)}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;background:rgba(23,27,29,.66);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:90;padding:24px}
.modal.open{display:flex}
.modal-card{background:var(--paper);border-radius:18px;max-width:880px;width:100%;overflow:hidden;box-shadow:var(--shadow);animation:pageIn .3s ease}
.modal-card .ph{aspect-ratio:16/9}
.modal-card .ph svg{width:100%;height:100%}
.modal-card .body{padding:24px 28px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.modal-close{position:absolute;top:20px;right:24px;background:#fff;border:none;width:44px;height:44px;border-radius:50%;font-size:18px;box-shadow:var(--shadow)}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
@media (max-width:1020px){
  .hero{grid-template-columns:1fr;min-height:0}
  .hero-tilewall{min-height:380px;order:-1}
  .hero-copy{padding:54px 28px;margin:0}
  .svc-grid,.gal,.reviews{grid-template-columns:repeat(2,1fr)}
  .process{grid-template-columns:repeat(2,1fr)}
  .split,.contact,.lab{grid-template-columns:1fr}
  .lab-panel{position:static}
  .foot{grid-template-columns:1fr 1fr}
}
@media (max-width:700px){
  .navlinks{display:none;position:absolute;top:100%;left:0;right:0;background:var(--paper);flex-direction:column;align-items:stretch;padding:14px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .navlinks.open{display:flex}
  .navlinks a{padding:13px 16px}
  .burger{display:block}
  .svc-grid,.gal,.reviews,.process{grid-template-columns:1fr}
  .f2{grid-template-columns:1fr}
  section.block{padding:60px 0}
}

/* ---------- v2 additions ---------- */
.dd{position:relative}
.dd-btn{background:none;border:none;padding:9px 14px;border-radius:999px;font-weight:500;font-size:15px;color:var(--ink-soft);display:flex;align-items:center;gap:6px;transition:.2s}
.dd-btn:hover{color:var(--ink);background:rgba(31,37,40,.06)}
.dd-btn .car{font-size:10px;transition:.2s}
.dd.open .dd-btn .car{transform:rotate(180deg)}
.dd-btn.current{color:var(--paper);background:var(--ink)}
.dd-menu{position:absolute;top:calc(100% + 10px);left:0;background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:8px;min-width:268px;display:none;z-index:70}
.dd.open .dd-menu{display:block}
.dd-menu a{display:block;padding:10px 14px;border-radius:9px;text-decoration:none;font-size:15px;color:var(--ink);font-weight:500}
.dd-menu a:hover{background:var(--linen)}
.dd-menu a[aria-current="page"]{background:var(--ink);color:#fff}
.dd-menu .sep{height:1px;background:var(--line);margin:7px 6px}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-top:34px}
.review.light{background:var(--paper);border:1px solid var(--line);max-width:680px;margin-top:46px}
.review.light p{color:var(--ink-soft)}
.review.light footer{color:var(--ink-soft)}
.crumbs{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--ink-soft);margin-bottom:18px;text-transform:uppercase}
.crumbs a{color:var(--ink-soft);text-decoration:none}
.crumbs a:hover{color:var(--ink)}
.fileline{display:block;font-family:var(--mono);font-size:11px;color:var(--brass);margin-top:5px;font-style:normal;word-break:break-all}
.ratebar{display:flex;align-items:center;gap:22px;margin-top:34px;flex-wrap:wrap}
.ratebar .num{font-family:var(--display);font-size:64px;line-height:1}
.ratebar .stars{color:var(--brass);font-size:24px;letter-spacing:4px}
.ratebar .sub{font-family:var(--mono);font-size:13px;color:var(--ink-soft)}
.reviews.light .review{background:var(--paper);border:1px solid var(--line)}
.reviews.light .review p{color:var(--ink-soft)}
.reviews.light .review footer{color:var(--ink-soft)}
.ba-wrap h3{margin-top:54px}
.ba-wrap .ba{margin-top:18px}
.otherareas{margin-top:54px}
@media (max-width:700px){
  .dd{width:100%}
  .dd-btn{width:100%;justify-content:space-between;padding:13px 16px}
  .dd-menu{position:static;display:none;box-shadow:none;border:none;background:var(--linen);min-width:0;margin:4px 0}
}

.page{display:block;animation:none}

/* hide gallery filename captions */
.fileline{display:none !important}

/* keep service name on one line, allow description to wrap */
.split li b{white-space:nowrap}
@media (max-width:560px){
  .split li{flex-wrap:wrap}
  .split li b{flex-basis:100%}
}
