:root{
  --bg:#f5f7fb;
  --surface:#ffffff;
  --surface-2:#eef4fb;
  --surface-3:#f8fbff;
  --text:#163768;
  --text-strong:#0f2d5a;
  --muted:#5f6f88;
  --line:#dbe4f1;
  --line-strong:#cad8ea;
  --brand:#143d7b;
  --brand-2:#1e4f99;
  --accent:#f47a18;
  --accent-2:#da6810;
  --success:#198754;
  --shadow:0 20px 55px rgba(20,61,123,.12);
  --shadow-soft:0 10px 30px rgba(20,61,123,.08);
  --container:1240px;
  --sticky-mobile-h:92px;
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:Inter, "Segoe UI", Arial, sans-serif;
  color:var(--text);
  background:linear-gradient(180deg,#f8fbff 0,#f4f7fb 260px,#ffffff 620px,#f5f7fb 100%);
  line-height:1.55;
}

body.nav-open{
  overflow:hidden;
}

img{
  display:block;
  max-width:100%;
}

a{
  color:inherit;
  text-decoration:none;
}

button,
input,
select,
textarea{
  font:inherit;
}

button{
  cursor:pointer;
}

:focus-visible{
  outline:3px solid rgba(244,122,24,.42);
  outline-offset:2px;
}

.container{
  width:min(var(--container), calc(100% - 32px));
  margin-inline:auto;
}

/* BUTTONS */

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:54px;
  padding:0 24px;
  border-radius:16px;
  border:1px solid transparent;
  font-weight:850;
  letter-spacing:.01em;
  transition:transform .18s ease, background-color .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.btn:hover{
  transform:translateY(-1px);
}

.btn:active{
  transform:translateY(0);
}

.btn--primary{
  background:var(--accent);
  color:#fff;
}

.btn--primary:hover{
  background:var(--accent-2);
  box-shadow:0 12px 24px rgba(244,122,24,.22);
}

.btn--secondary{
  background:#fff;
  color:var(--brand);
  border-color:#adc0db;
}

.btn--secondary:hover{
  background:#f9fbff;
  border-color:#8eabd2;
}

.btn--full{
  width:100%;
}

/* TOP BAR */

.top-strip{
  background:var(--brand);
  color:#fff;
}

.top-strip__inner{
  min-height:48px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
}

.top-strip__list{
  display:flex;
  align-items:center;
  gap:32px;
  list-style:none;
  padding:0;
  margin:0;
  font-size:13px;
  font-weight:850;
}

.top-strip__list li,
.top-strip__phone{
  display:inline-flex;
  align-items:center;
  gap:9px;
  white-space:nowrap;
}

.top-strip__phone{
  font-size:15px;
  font-weight:900;
}

.top-icon{
  display:inline-grid;
  place-items:center;
  width:17px;
  height:17px;
  font-size:14px;
  opacity:.95;
}

/* HEADER */

.site-header{
  position:sticky;
  top:0;
  z-index:80;
  background:rgba(255,255,255,.94);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid rgba(219,228,241,.95);
}

.site-header__inner{
  min-height:92px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.brand img{
  width:auto;
  height:58px;
}

.desktop-nav{
  margin-left:auto;
}

.desktop-nav__list{
  display:flex;
  align-items:center;
  gap:23px;
  list-style:none;
  padding:0;
  margin:0;
}

.desktop-nav__list a{
  display:inline-flex;
  align-items:center;
  gap:5px;
  position:relative;
  color:#0d2d5f;
  font-size:14px;
  font-weight:850;
  padding:12px 0;
}

.desktop-nav__list a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:6px;
  height:2px;
  border-radius:999px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .2s ease;
}

.desktop-nav__list a:hover::after,
.desktop-nav__list a.is-active::after{
  transform:scaleX(1);
}

.btn--header{
  min-height:54px;
  padding-inline:24px;
  border-radius:16px;
  white-space:nowrap;
}

.menu-toggle{
  display:none;
  width:54px;
  height:54px;
  border:1px solid var(--line);
  background:#fff;
  border-radius:18px;
  box-shadow:var(--shadow-soft);
  padding:0;
}

.menu-toggle span{
  display:block;
  width:23px;
  height:2px;
  background:var(--brand);
  border-radius:999px;
  margin:5px auto;
}

/* MOBILE NAV */

.mobile-nav{
  position:fixed;
  inset:0;
  z-index:200;
  visibility:hidden;
  opacity:0;
  background:rgba(15,45,90,.26);
  backdrop-filter:blur(8px);
  transition:opacity .22s ease, visibility .22s ease;
}

body.nav-open .mobile-nav{
  visibility:visible;
  opacity:1;
}

.mobile-nav__panel{
  position:absolute;
  inset:0 0 0 auto;
  width:min(420px, 92vw);
  background:#f8fbff;
  padding:24px;
  transform:translateX(100%);
  transition:transform .24s ease;
  box-shadow:-20px 0 45px rgba(15,45,90,.18);
  overflow:auto;
}

body.nav-open .mobile-nav__panel{
  transform:translateX(0);
}

.mobile-nav__close{
  position:absolute;
  top:18px;
  right:18px;
  width:54px;
  height:54px;
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  color:var(--brand);
  font-size:34px;
  line-height:1;
}

.brand--mobile img{
  height:58px;
  margin-bottom:24px;
}

.mobile-nav__links{
  display:grid;
  gap:12px;
  margin:18px 0;
}

.mobile-nav__links a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:58px;
  padding:0 18px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  color:var(--text-strong);
  font-weight:850;
  box-shadow:0 8px 20px rgba(20,61,123,.05);
}

.mobile-nav__phone{
  display:block;
  margin-top:18px;
  text-align:center;
  color:var(--brand);
  font-size:1.25rem;
  font-weight:900;
}

/* HERO */

.case-hero{
  padding:34px 0 24px;
}

.case-hero__grid{
  display:grid;
  grid-template-columns:minmax(0,1.02fr) minmax(480px,.98fr);
  gap:58px;
  align-items:center;
}

.case-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:9px;
  color:#1162c7;
  font-size:13px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.case-hero h1{
  max-width:680px;
  margin:18px 0 12px;
  color:var(--text-strong);
  font-size:clamp(2.7rem,4.25vw,4.8rem);
  line-height:.98;
  letter-spacing:-.055em;
}

.case-hero__lead{
  margin:0 0 18px;
  max-width:660px;
  color:#18385f;
  font-size:clamp(1.05rem,1.4vw,1.24rem);
  font-weight:850;
  line-height:1.45;
}

.case-hero__text{
  margin:0;
  max-width:640px;
  color:var(--muted);
  font-size:1.02rem;
  line-height:1.68;
}

.case-hero__actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:26px;
}

.case-mini-stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:0;
  max-width:560px;
  margin-top:30px;
  padding:18px 16px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow-soft);
}

.case-mini-stat{
  min-width:0;
  text-align:center;
  padding:0 12px;
}

.case-mini-stat:not(:last-child){
  border-right:1px solid var(--line);
}

.case-mini-stat__icon{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  margin:0 auto 8px;
  border-radius:50%;
  background:#edf4ff;
  color:var(--brand);
  font-weight:900;
}

.case-mini-stat strong{
  display:block;
  color:var(--text-strong);
  font-size:1.06rem;
  line-height:1.1;
}

.case-mini-stat span:last-child{
  display:block;
  margin-top:3px;
  color:#4f6079;
  font-size:.84rem;
  font-weight:750;
  line-height:1.2;
}

.case-hero__visual{
  position:relative;
  padding:8px;
  background:#fff;
  border:1px solid #d8e4f3;
  border-radius:24px;
  box-shadow:0 18px 44px rgba(20,61,123,.16);
}

.case-hero__visual img{
  width:100%;
  aspect-ratio:1.36 / 1;
  height:auto;
  object-fit:cover;
  object-position:center;
  border-radius:18px;
}

.case-photo-badge{
  position:absolute;
  left:24px;
  bottom:24px;
  display:inline-flex;
  align-items:center;
  gap:9px;
  min-height:42px;
  padding:0 16px;
  background:rgba(255,255,255,.96);
  color:var(--brand);
  border:1px solid rgba(210,222,238,.9);
  border-radius:12px;
  font-size:.92rem;
  font-weight:900;
  box-shadow:0 10px 22px rgba(15,45,90,.13);
}

.case-photo-badge span{
  width:22px;
  height:22px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:#edf4ff;
}

/* COMMON */

.case-section{
  padding:28px 0;
}

.case-section--triad{
  padding-top:8px;
}

.case-section-title{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:18px;
  margin-bottom:22px;
}

.case-section-title span{
  height:1px;
  background:linear-gradient(90deg, transparent, #cfdceb);
}

.case-section-title span:last-child{
  background:linear-gradient(90deg, #cfdceb, transparent);
}

.case-section-title h2{
  margin:0;
  color:var(--text-strong);
  font-size:clamp(1.55rem,2vw,2rem);
  line-height:1.1;
  text-align:center;
  text-transform:uppercase;
  letter-spacing:.02em;
}

/* TRIAD */

.case-triad{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
  padding:24px 0 8px;
  border-top:1px solid rgba(219,228,241,.8);
}

.case-triad__item{
  display:grid;
  grid-template-columns:54px minmax(0,1fr);
  gap:20px;
  min-height:190px;
  padding:20px 22px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(219,228,241,.95);
  border-radius:22px;
  box-shadow:0 10px 24px rgba(20,61,123,.04);
}

.case-triad__icon{
  width:54px;
  height:54px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:var(--brand);
  color:#fff;
  font-size:1.5rem;
  font-weight:900;
}

.case-triad h2{
  margin:0 0 8px;
  color:var(--text-strong);
  font-size:1.13rem;
  line-height:1.15;
  text-transform:uppercase;
  letter-spacing:.04em;
}

.case-triad p{
  margin:0 0 10px;
  color:#263e61;
  font-size:.98rem;
  font-weight:650;
  line-height:1.48;
}

.case-triad ul{
  display:grid;
  gap:6px;
  margin:0;
  padding-left:18px;
  color:var(--muted);
  font-size:.94rem;
  line-height:1.38;
}

/* SCROLL UX */

.scroll-shell{
  position:relative;
}

.scroll-shell::after{
  content:"";
  display:none;
  position:absolute;
  top:0;
  right:-1px;
  bottom:0;
  width:42px;
  pointer-events:none;
  background:linear-gradient(90deg, rgba(245,247,251,0), #f5f7fb 82%);
}

/* JOURNEY */

.case-section--journey{
  padding-top:16px;
}

.journey-scroll{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:22px;
  position:relative;
}

.journey-card{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 10px 24px rgba(20,61,123,.05);
}

.journey-card:not(:last-child)::after{
  content:"→";
  position:absolute;
  top:50%;
  right:-18px;
  transform:translateY(-50%);
  z-index:2;
  color:var(--brand);
  font-size:1.6rem;
  font-weight:900;
}

.journey-card__media{
  overflow:hidden;
  background:#edf3fb;
}

.journey-card__media img{
  width:100%;
  aspect-ratio:1.36 / .75;
  height:auto;
  object-fit:cover;
  object-position:center;
  transition:transform .26s ease;
}

.journey-card:hover .journey-card__media img{
  transform:scale(1.035);
}

.journey-card__body{
  position:relative;
  padding:16px 16px 18px;
}

.journey-card__num{
  position:absolute;
  top:-18px;
  left:14px;
  width:30px;
  height:30px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:var(--brand);
  color:#fff;
  border:3px solid #fff;
  font-size:.9rem;
  font-weight:900;
  box-shadow:0 6px 14px rgba(20,61,123,.18);
}

.journey-card h3{
  margin:0 0 8px;
  padding-left:36px;
  color:var(--text-strong);
  font-size:1rem;
  line-height:1.15;
  text-transform:uppercase;
  letter-spacing:.03em;
}

.journey-card p{
  margin:0;
  color:var(--muted);
  font-size:.92rem;
  line-height:1.45;
}

.mobile-dots{
  display:none;
}

/* COMPLETED SECTIONS */

.case-section--completed{
  padding-top:18px;
}

.completed-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:24px;
}

.completed-card{
  display:grid;
  grid-template-columns:minmax(230px,.75fr) minmax(0,1.25fr);
  gap:18px;
  align-items:stretch;
  padding:18px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:0 12px 28px rgba(20,61,123,.055);
}

.completed-card__copy{
  padding:6px 2px 4px;
}

.completed-card h2{
  margin:0 0 10px;
  color:var(--text-strong);
  font-size:1.35rem;
  line-height:1.1;
}

.completed-card p{
  margin:0 0 14px;
  color:var(--muted);
  font-size:.98rem;
  line-height:1.55;
}

.completed-card ul{
  display:grid;
  gap:8px;
  margin:0;
  padding:0;
  list-style:none;
  color:#4d5e76;
  font-size:.94rem;
  font-weight:700;
}

.completed-card li{
  position:relative;
  padding-left:24px;
}

.completed-card li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:1px;
  width:17px;
  height:17px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:#edf4ff;
  color:var(--brand);
  font-size:.7rem;
  font-weight:900;
}

.completed-card__photos{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  min-width:0;
}

.completed-card__photos img{
  width:100%;
  aspect-ratio:1.18 / .82;
  height:auto;
  object-fit:cover;
  object-position:center;
  border-radius:16px;
}

/* GALLERY */

.case-section--gallery{
  padding-top:12px;
}

.gallery-scroll{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:18px;
}

.gallery-item{
  display:grid;
  gap:9px;
  color:var(--text-strong);
  font-weight:850;
  text-align:center;
  font-size:.92rem;
}

.gallery-item img{
  width:100%;
  aspect-ratio:1.35 / .78;
  height:auto;
  object-fit:cover;
  object-position:center;
  border-radius:16px;
  box-shadow:0 10px 24px rgba(20,61,123,.07);
  transition:transform .2s ease;
}

.gallery-item:hover img{
  transform:translateY(-2px);
}

/* LOVE PANEL */

.case-section--love{
  padding-top:18px;
}

.love-panel{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(320px,.75fr);
  gap:24px;
  align-items:stretch;
  padding:22px;
  background:linear-gradient(180deg,#ffffff 0%,#f5f9ff 100%);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:0 12px 28px rgba(20,61,123,.05);
}

.love-panel__benefits h2{
  margin:0 0 18px;
  color:var(--text-strong);
  font-size:1.45rem;
  line-height:1.1;
  text-align:center;
  text-transform:uppercase;
  letter-spacing:.02em;
}

.love-benefits-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}

.love-benefit{
  text-align:center;
  padding:10px 8px;
}

.love-benefit span{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  margin:0 auto 10px;
  border-radius:50%;
  background:#edf4ff;
  color:var(--brand);
  font-size:1.55rem;
  font-weight:900;
}

.love-benefit strong{
  display:block;
  color:var(--text-strong);
  font-size:.96rem;
  line-height:1.18;
}

.love-benefit p{
  margin:7px 0 0;
  color:var(--muted);
  font-size:.86rem;
  line-height:1.42;
}

.love-quote{
  margin:0;
  padding:18px 0 18px 24px;
  border-left:1px solid var(--line-strong);
}

.love-quote__mark{
  color:var(--brand);
  font-size:4rem;
  line-height:.65;
  font-weight:900;
}

.love-quote blockquote{
  margin:0;
  color:#28415f;
  font-size:1rem;
  line-height:1.6;
}

.love-quote figcaption{
  margin-top:14px;
  display:grid;
  gap:4px;
}

.stars{
  color:#f3bd2c;
  letter-spacing:.12em;
}

.love-quote strong{
  color:var(--brand);
  font-size:.95rem;
}

/* ESTIMATE */

.case-section--estimate{
  padding:20px 0 30px;
}

.estimate-panel{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(460px,.85fr);
  gap:28px;
  align-items:center;
  padding:24px 26px;
  background:linear-gradient(180deg,#f8fbff 0%, #eef4fb 100%);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--shadow-soft);
}

.estimate-panel__intro{
  display:grid;
  grid-template-columns:104px minmax(0,1fr);
  gap:24px;
  align-items:center;
}

.estimate-panel__icon{
  width:104px;
  height:104px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:var(--brand);
  color:#fff;
  font-size:3rem;
  box-shadow:0 15px 30px rgba(20,61,123,.18);
}

.estimate-panel h2{
  margin:0 0 8px;
  color:var(--text-strong);
  font-size:clamp(1.6rem,2.5vw,2.35rem);
  line-height:1.05;
  letter-spacing:-.035em;
}

.estimate-panel p{
  margin:0;
  color:var(--muted);
}

.estimate-checks{
  display:flex;
  flex-wrap:wrap;
  gap:18px 28px;
  list-style:none;
  padding:0;
  margin:18px 0 0;
}

.estimate-checks li{
  position:relative;
  padding-left:25px;
  color:#43556e;
  font-size:.94rem;
  font-weight:750;
}

.estimate-checks li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  width:18px;
  height:18px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:#e9f1ff;
  color:var(--brand);
  font-size:.75rem;
  font-weight:900;
}

.estimate-form{
  display:grid;
  gap:12px;
}

.estimate-form__grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}

.estimate-form input,
.estimate-form select{
  width:100%;
  min-height:48px;
  padding:0 14px;
  border:1px solid #d7e3f1;
  border-radius:10px;
  background:#fff;
  color:var(--text);
  font-size:.94rem;
}

.estimate-form input:focus,
.estimate-form select:focus{
  border-color:#8aacdd;
  box-shadow:0 0 0 4px rgba(20,61,123,.08);
  outline:none;
}

.estimate-form__privacy{
  margin:0;
  text-align:center;
  color:#7a8799;
  font-size:.82rem;
}

/* FOOTER */

.site-footer{
  position:relative;
  padding:38px 0 90px;
  background:#fff;
  border-top:1px solid #e2eaf4;
  overflow:hidden;
}

.site-footer__grid{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) repeat(3,minmax(0,.85fr));
  gap:42px;
  position:relative;
  z-index:1;
}

.footer-logo img{
  width:auto;
  height:58px;
}

.site-footer__brand p{
  margin:16px 0 18px;
  max-width:440px;
  color:var(--muted);
  font-size:1rem;
  line-height:1.58;
}

.site-footer h3{
  margin:0 0 16px;
  color:var(--text-strong);
  font-size:1.05rem;
}

.footer-link-list,
.footer-contact-list,
.footer-mini-list{
  display:grid;
  gap:12px;
  list-style:none;
  padding:0;
  margin:0;
}

.footer-link-list a{
  color:var(--muted);
  font-weight:750;
}

.footer-link-list a:hover{
  color:var(--brand);
}

.footer-contact-list li,
.footer-mini-list li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:var(--muted);
  font-weight:650;
}

.footer-contact-list span,
.footer-mini-list span{
  flex:0 0 18px;
  color:var(--brand);
}

.footer-contact-list a:hover{
  color:var(--brand);
}

.site-footer__bottom{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-top:34px;
  padding-top:26px;
  border-top:1px solid #e7edf5;
  color:#6c778a;
  font-size:.95rem;
}

.site-footer__bottom p{
  margin:0;
}

.site-footer__bottom-links{
  display:flex;
  gap:22px;
}

.site-footer__bottom-links a:hover{
  color:var(--brand);
}

.site-footer__mountains{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:118px;
  background:
    linear-gradient(160deg, transparent 0 40%, rgba(235,241,249,.72) 40% 63%, transparent 63%) 0 0/220px 118px repeat-x,
    linear-gradient(200deg, transparent 0 43%, rgba(222,232,245,.7) 43% 64%, transparent 64%) 0 20px/260px 100px repeat-x;
  opacity:.85;
}

/* MOBILE STICKY CTA */

.mobile-sticky-cta{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:70;
  display:none;
  gap:10px;
  padding:10px 14px calc(env(safe-area-inset-bottom,0px) + 10px);
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(10px);
  border-top:1px solid rgba(214,224,239,.9);
}

.mobile-sticky-cta a{
  flex:1;
  min-height:54px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:16px;
  color:#fff;
  font-weight:900;
  text-transform:uppercase;
}

.mobile-sticky-cta__call{
  background:var(--brand);
}

.mobile-sticky-cta__estimate{
  background:var(--accent);
}

/* TABLET */

@media (max-width:1180px){
  .desktop-nav__list{
    gap:15px;
  }

  .desktop-nav__list a{
    font-size:13px;
  }

  .case-hero__grid{
    gap:34px;
  }

  .journey-scroll{
    display:flex;
    gap:18px;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior-x:contain;
    padding:2px 30px 12px 2px;
    margin:0 -2px;
    scrollbar-width:none;
  }

  .journey-scroll::-webkit-scrollbar{
    display:none;
  }

  .journey-card{
    flex:0 0 320px;
    scroll-snap-align:start;
  }

  .journey-card:not(:last-child)::after{
    display:none;
  }

  .scroll-shell::after{
    display:block;
  }

  .gallery-scroll{
    display:flex;
    gap:16px;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior-x:contain;
    padding:2px 30px 12px 2px;
    margin:0 -2px;
    scrollbar-width:none;
  }

  .gallery-scroll::-webkit-scrollbar{
    display:none;
  }

  .gallery-item{
    flex:0 0 280px;
    scroll-snap-align:start;
  }

  .completed-grid{
    grid-template-columns:1fr;
  }

  .love-panel{
    grid-template-columns:1fr;
  }

  .love-quote{
    padding:22px;
    border-left:none;
    border-top:1px solid var(--line-strong);
  }

  .estimate-panel{
    grid-template-columns:1fr;
  }
}

@media (max-width:980px){
  .top-strip__list{
    gap:18px;
    font-size:12px;
  }

  .desktop-nav,
  .btn--header{
    display:none;
  }

  .menu-toggle{
    display:block;
  }

  .site-header__inner{
    min-height:82px;
  }

  .case-hero__grid{
    grid-template-columns:1fr;
  }

  .case-hero__visual{
    order:-1;
  }

  .case-hero h1{
    max-width:none;
  }

  .case-mini-stats{
    max-width:none;
  }

  .case-triad{
    grid-template-columns:1fr;
    gap:16px;
  }

  .case-triad__item{
    min-height:0;
  }

  .completed-card{
    grid-template-columns:1fr;
  }

  .completed-card__photos{
    display:flex;
    gap:12px;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    padding:2px 24px 10px 2px;
    margin:0 -2px;
    scrollbar-width:none;
  }

  .completed-card__photos::-webkit-scrollbar{
    display:none;
  }

  .completed-card__photos img{
    flex:0 0 min(60vw, 360px);
    scroll-snap-align:start;
  }

  .love-benefits-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .site-footer__grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

/* MOBILE */

@media (max-width:760px){
  body{
    padding-bottom:calc(var(--sticky-mobile-h) + env(safe-area-inset-bottom,0px));
  }

  .container{
    width:min(var(--container), calc(100% - 22px));
  }

  .top-strip__inner{
    min-height:52px;
    justify-content:center;
  }

  .top-strip__phone{
    display:none;
  }

  .top-strip__list{
    width:100%;
    justify-content:space-between;
    gap:10px;
    font-size:10px;
  }

  .top-strip__list li{
    gap:6px;
    white-space:normal;
    line-height:1.25;
  }

  .top-icon{
    width:14px;
    height:14px;
    font-size:12px;
  }

  .brand img{
    height:50px;
  }

  .case-hero{
    padding:20px 0 18px;
  }

  .case-hero__grid{
    gap:20px;
  }

  .case-hero__copy{
    padding:0 2px;
  }

  .case-eyebrow{
    font-size:11px;
    letter-spacing:.055em;
  }

  .case-hero h1{
    margin:14px 0 10px;
    font-size:2.15rem;
    line-height:1.02;
    letter-spacing:-.045em;
  }

  .case-hero__lead{
    font-size:1rem;
    line-height:1.45;
    margin-bottom:14px;
  }

  .case-hero__text{
    font-size:.98rem;
    line-height:1.6;
  }

  .case-hero__actions{
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    margin-top:20px;
  }

  .case-hero__visual{
    padding:6px;
    border-radius:22px;
  }

  .case-hero__visual img{
    aspect-ratio:1.18 / .82;
    border-radius:17px;
  }

  .case-photo-badge{
    left:16px;
    bottom:16px;
    min-height:38px;
    padding:0 13px;
    font-size:.84rem;
  }

  .case-mini-stats{
    display:flex;
    gap:0;
    overflow:hidden;
    margin-top:20px;
    padding:14px 10px;
  }

  .case-mini-stat{
    flex:1;
    padding:0 8px;
  }

  .case-mini-stat__icon{
    width:34px;
    height:34px;
    margin-bottom:7px;
    font-size:.85rem;
  }

  .case-mini-stat strong{
    font-size:.84rem;
  }

  .case-mini-stat span:last-child{
    font-size:.7rem;
  }

  .case-section{
    padding:22px 0;
  }

  .case-triad{
    padding-top:0;
    border-top:0;
  }

  .case-triad__item{
    grid-template-columns:44px minmax(0,1fr);
    gap:14px;
    padding:18px 16px;
    border-radius:20px;
  }

  .case-triad__icon{
    width:44px;
    height:44px;
    font-size:1.18rem;
  }

  .case-triad h2{
    font-size:1rem;
  }

  .case-triad p{
    font-size:.94rem;
  }

  .case-triad ul{
    font-size:.9rem;
    gap:5px;
  }

  .case-section-title{
    gap:10px;
    margin-bottom:16px;
  }

  .case-section-title h2{
    font-size:1.28rem;
  }

  .journey-scroll{
    gap:14px;
    padding:2px 28px 10px 2px;
  }

  .journey-card{
    flex:0 0 min(78vw, 300px);
    border-radius:20px;
  }

  .journey-card__media img{
    aspect-ratio:1.22 / .72;
  }

  .journey-card__body{
    padding:15px 14px 16px;
  }

  .journey-card h3{
    font-size:.95rem;
  }

  .journey-card p{
    font-size:.88rem;
  }

  .completed-card{
    padding:16px;
    border-radius:22px;
  }

  .completed-card h2{
    font-size:1.25rem;
  }

  .completed-card p{
    font-size:.95rem;
  }

  .completed-card__photos img{
    flex:0 0 min(78vw, 300px);
    aspect-ratio:1.2 / .78;
    border-radius:16px;
  }

  .gallery-scroll{
    gap:14px;
    padding:2px 28px 10px 2px;
  }

  .gallery-item{
    flex:0 0 min(74vw, 290px);
    font-size:.86rem;
  }

  .gallery-item img{
    aspect-ratio:1.25 / .75;
    border-radius:16px;
  }

  .mobile-dots{
    display:flex;
    justify-content:center;
    gap:7px;
    margin-top:10px;
  }

  .mobile-dots span{
    width:7px;
    height:7px;
    border-radius:50%;
    background:#c8d7ea;
  }

  .mobile-dots .is-active{
    background:var(--brand);
  }

  .love-panel{
    padding:18px;
    border-radius:22px;
  }

  .love-panel__benefits h2{
    font-size:1.18rem;
    line-height:1.2;
  }

  .scroll-shell--mobile-only::after{
    display:block;
  }

  .love-benefits-grid{
    display:flex;
    gap:14px;
    overflow-x:auto;
    overflow-y:hidden;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    padding:2px 24px 8px 2px;
    margin:0 -2px;
    scrollbar-width:none;
  }

  .love-benefits-grid::-webkit-scrollbar{
    display:none;
  }

  .love-benefit{
    flex:0 0 min(70vw, 230px);
    scroll-snap-align:start;
    padding:16px 12px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:18px;
  }

  .love-quote{
    padding:18px 0 0;
  }

  .love-quote__mark{
    font-size:3rem;
  }

  .estimate-panel{
    padding:20px 16px;
    border-radius:22px;
    gap:18px;
  }

  .estimate-panel__intro{
    grid-template-columns:1fr;
    gap:14px;
    text-align:left;
  }

  .estimate-panel__icon{
    width:82px;
    height:82px;
    font-size:2.3rem;
  }

  .estimate-panel h2{
    font-size:2rem;
  }

  .estimate-checks{
    gap:12px;
  }

  .estimate-form__grid{
    grid-template-columns:1fr;
  }

  .estimate-form input,
  .estimate-form select{
    min-height:52px;
    border-radius:14px;
  }

  .site-footer{
    padding:34px 0 calc(var(--sticky-mobile-h) + 96px);
  }

  .site-footer__grid{
    grid-template-columns:1fr;
    gap:26px;
  }

  .site-footer__brand p{
    max-width:none;
  }

  .site-footer__bottom{
    flex-direction:column;
    align-items:flex-start;
  }

  .site-footer__bottom-links{
    flex-wrap:wrap;
  }

  .mobile-sticky-cta{
    display:flex;
  }
}

@media (max-width:480px){
  .top-strip__list{
    font-size:9px;
  }

  .case-hero h1{
    font-size:1.92rem;
  }

  .case-mini-stat{
    padding:0 5px;
  }

  .case-mini-stat strong{
    font-size:.76rem;
  }

  .case-mini-stat span:last-child{
    font-size:.64rem;
  }

  .journey-card,
  .completed-card__photos img,
  .gallery-item{
    flex-basis:min(82vw, 286px);
  }
}
.gallery-item {
  cursor: zoom-in;
}

.gallery-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 28px;
  background: rgba(9, 24, 48, .86);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.gallery-modal.is-open {
  display: flex;
}

.gallery-modal__figure {
  position: relative;
  width: min(1120px, 100%);
  max-height: calc(100vh - 80px);
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.gallery-modal__img {
  width: auto;
  max-width: 100%;
  max-height: calc(100vh - 150px);
  object-fit: contain;
  border-radius: 22px;
  box-shadow: 0 28px 80px rgba(0, 0, 0, .45);
  background: #0b1f3f;
}

.gallery-modal__caption {
  margin-top: 14px;
  padding: 10px 16px;
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 999px;
  background: rgba(255, 255, 255, .08);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  text-align: center;
  line-height: 1.35;
}

.gallery-modal__close {
  position: fixed;
  top: max(18px, env(safe-area-inset-top));
  right: max(18px, env(safe-area-inset-right));
  z-index: 2;
  width: 46px;
  height: 46px;
  border: 1px solid rgba(255, 255, 255, .24);
  border-radius: 999px;
  background: rgba(255, 255, 255, .12);
  color: #fff;
  font-size: 32px;
  line-height: 1;
  cursor: pointer;
}

.gallery-modal__close:hover {
  background: rgba(255, 255, 255, .2);
}

.gallery-modal__nav {
  position: fixed;
  top: 50%;
  z-index: 2;
  width: 54px;
  height: 54px;
  transform: translateY(-50%);
  border: 1px solid rgba(255, 255, 255, .22);
  border-radius: 999px;
  background: rgba(255, 255, 255, .12);
  color: #fff;
  font-size: 44px;
  line-height: 46px;
  cursor: pointer;
}

.gallery-modal__nav:hover {
  background: rgba(255, 255, 255, .2);
}

.gallery-modal__nav--prev {
  left: max(18px, env(safe-area-inset-left));
}

.gallery-modal__nav--next {
  right: max(18px, env(safe-area-inset-right));
}

body.gallery-modal-open {
  overflow: hidden;
}

@media (max-width: 767px) {
  .gallery-modal {
    padding: 18px;
  }

  .gallery-modal__figure {
    max-height: calc(100vh - 120px);
  }

  .gallery-modal__img {
    max-height: calc(100vh - 170px);
    border-radius: 16px;
  }

  .gallery-modal__caption {
    max-width: calc(100vw - 36px);
    font-size: 13px;
  }

  .gallery-modal__close {
    width: 42px;
    height: 42px;
    font-size: 28px;
  }

  .gallery-modal__nav {
    top: auto;
    bottom: max(18px, env(safe-area-inset-bottom));
    width: 46px;
    height: 46px;
    transform: none;
    font-size: 36px;
    line-height: 38px;
  }

  .gallery-modal__nav--prev {
    left: 18px;
  }

  .gallery-modal__nav--next {
    right: 18px;
  }
}
 .portfolio-hero {
      padding: 72px 0 44px;
      background:
        radial-gradient(circle at 18% 12%, rgba(245, 123, 32, .14), transparent 34%),
        radial-gradient(circle at 86% 18%, rgba(20, 61, 123, .16), transparent 38%),
        linear-gradient(180deg, #f6f8fc 0%, #ffffff 100%);
      overflow: hidden;
    }

    .portfolio-hero__grid {
      display: grid;
      grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr);
      gap: 44px;
      align-items: center;
    }

    .portfolio-hero__copy h1 {
      margin: 18px 0 18px;
      max-width: 820px;
      color: #112746;
      font-size: clamp(42px, 6vw, 74px);
      line-height: .94;
      letter-spacing: -.055em;
      font-weight: 900;
    }

    .portfolio-hero__lead {
      max-width: 720px;
      margin: 0 0 18px;
      color: #40516a;
      font-size: clamp(18px, 2vw, 22px);
      line-height: 1.55;
      font-weight: 600;
    }

    .portfolio-hero__text {
      max-width: 700px;
      margin: 0;
      color: #62708a;
      font-size: 16px;
      line-height: 1.8;
    }

    .portfolio-hero__actions {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
      margin-top: 28px;
    }

    .portfolio-stats {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 12px;
      margin-top: 30px;
      max-width: 760px;
    }

    .portfolio-stat {
      padding: 16px 14px;
      border: 1px solid rgba(20, 61, 123, .12);
      border-radius: 18px;
      background: rgba(255, 255, 255, .76);
      box-shadow: 0 16px 34px rgba(17, 39, 70, .07);
    }

    .portfolio-stat strong {
      display: block;
      color: #143d7b;
      font-size: 26px;
      line-height: 1;
      font-weight: 900;
      letter-spacing: -.04em;
    }

    .portfolio-stat span {
      display: block;
      margin-top: 7px;
      color: #62708a;
      font-size: 12px;
      line-height: 1.3;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: .04em;
    }

    .portfolio-hero__visual {
      position: relative;
    }

    .portfolio-mosaic {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 14px;
      transform: rotate(-1deg);
    }

    .portfolio-mosaic__item {
      position: relative;
      min-height: 210px;
      border-radius: 28px;
      overflow: hidden;
      border: 8px solid #fff;
      box-shadow: 0 24px 60px rgba(17, 39, 70, .16);
      background: #e9eef6;
    }

    .portfolio-mosaic__item:first-child {
      grid-row: span 2;
      min-height: 440px;
    }

    .portfolio-mosaic__item img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .portfolio-mosaic__badge {
      position: absolute;
      left: 18px;
      bottom: 18px;
      padding: 10px 14px;
      border-radius: 999px;
      background: rgba(255, 255, 255, .92);
      color: #143d7b;
      font-size: 13px;
      font-weight: 900;
      box-shadow: 0 14px 34px rgba(17, 39, 70, .18);
    }

    .portfolio-section {
      padding: 72px 0;
    }

    .portfolio-section--soft {
      background: #f6f8fc;
    }

    .portfolio-head {
      max-width: 840px;
      margin: 0 auto 34px;
      text-align: center;
    }

    .portfolio-head h2 {
      margin: 16px 0 12px;
      color: #112746;
      font-size: clamp(34px, 4vw, 56px);
      line-height: 1;
      letter-spacing: -.05em;
      font-weight: 900;
    }

    .portfolio-head p {
      margin: 0 auto;
      max-width: 720px;
      color: #62708a;
      font-size: 17px;
      line-height: 1.7;
    }

    .portfolio-filter-row {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      gap: 10px;
      margin: 0 0 34px;
    }

    .portfolio-filter {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 42px;
      padding: 10px 16px;
      border: 1px solid rgba(20, 61, 123, .15);
      border-radius: 999px;
      background: #fff;
      color: #40516a;
      font-size: 13px;
      font-weight: 900;
      text-decoration: none;
      box-shadow: 0 12px 28px rgba(17, 39, 70, .06);
    }

    .portfolio-filter.is-active {
      background: #143d7b;
      color: #fff;
      border-color: #143d7b;
    }

    .portfolio-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 22px;
    }

    .portfolio-card {
      display: flex;
      flex-direction: column;
      min-height: 100%;
      border: 1px solid rgba(20, 61, 123, .12);
      border-radius: 28px;
      overflow: hidden;
      background: #fff;
      box-shadow: 0 22px 55px rgba(17, 39, 70, .09);
    }

    .portfolio-card__media {
      position: relative;
      display: block;
      aspect-ratio: 1.25 / 1;
      overflow: hidden;
      background: #dfe7f2;
    }

    .portfolio-card__media img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      transition: transform .45s ease;
    }

    .portfolio-card:hover .portfolio-card__media img {
      transform: scale(1.045);
    }

    .portfolio-card__tag {
      position: absolute;
      left: 14px;
      top: 14px;
      z-index: 1;
      padding: 8px 11px;
      border-radius: 999px;
      background: rgba(20, 61, 123, .92);
      color: #fff;
      font-size: 11px;
      line-height: 1;
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: .05em;
    }

    .portfolio-card__body {
      display: flex;
      flex-direction: column;
      flex: 1;
      padding: 22px;
    }

    .portfolio-card__location {
      color: #f57b20;
      font-size: 12px;
      line-height: 1.2;
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: .06em;
    }

    .portfolio-card h3 {
      margin: 10px 0 12px;
      color: #112746;
      font-size: 23px;
      line-height: 1.08;
      letter-spacing: -.03em;
      font-weight: 900;
    }

    .portfolio-card p {
      margin: 0;
      color: #62708a;
      font-size: 15px;
      line-height: 1.65;
    }

    .portfolio-card__features {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin: 18px 0 20px;
      padding: 0;
      list-style: none;
    }

    .portfolio-card__features li {
      padding: 7px 9px;
      border-radius: 999px;
      background: #f2f5fa;
      color: #40516a;
      font-size: 11px;
      font-weight: 900;
      text-transform: uppercase;
      letter-spacing: .04em;
    }

    .portfolio-card .btn {
      margin-top: auto;
    }

    .portfolio-proof-panel {
      display: grid;
      grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
      gap: 34px;
      align-items: center;
      padding: 36px;
      border-radius: 34px;
      background: #143d7b;
      color: #fff;
      overflow: hidden;
      position: relative;
    }

    .portfolio-proof-panel:before {
      content: "";
      position: absolute;
      inset: auto -120px -160px auto;
      width: 360px;
      height: 360px;
      border-radius: 50%;
      background: rgba(245, 123, 32, .22);
      filter: blur(12px);
    }

    .portfolio-proof-panel h2 {
      position: relative;
      margin: 0 0 12px;
      font-size: clamp(30px, 4vw, 52px);
      line-height: 1;
      letter-spacing: -.05em;
      font-weight: 900;
    }

    .portfolio-proof-panel p {
      position: relative;
      margin: 0;
      color: rgba(255, 255, 255, .78);
      font-size: 16px;
      line-height: 1.75;
    }

    .portfolio-proof-list {
      position: relative;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
      margin: 0;
      padding: 0;
      list-style: none;
    }

    .portfolio-proof-list li {
      padding: 16px;
      border: 1px solid rgba(255, 255, 255, .16);
      border-radius: 18px;
      background: rgba(255, 255, 255, .08);
      color: #fff;
      font-size: 14px;
      line-height: 1.4;
      font-weight: 800;
    }

    @media (max-width: 980px) {
      .portfolio-hero__grid,
      .portfolio-proof-panel {
        grid-template-columns: 1fr;
      }

      .portfolio-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .portfolio-mosaic__item:first-child {
        min-height: 320px;
      }
    }

    @media (max-width: 680px) {
      .portfolio-hero {
        padding: 44px 0 28px;
      }

      .portfolio-hero__grid {
        gap: 28px;
      }

      .portfolio-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .portfolio-mosaic {
        display: flex;
        gap: 12px;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        padding-bottom: 8px;
        transform: none;
      }

      .portfolio-mosaic__item,
      .portfolio-mosaic__item:first-child {
        flex: 0 0 78%;
        min-height: 260px;
        scroll-snap-align: start;
      }

      .portfolio-section {
        padding: 52px 0;
      }

      .portfolio-grid {
        grid-template-columns: 1fr;
      }

      .portfolio-proof-panel {
        padding: 24px;
        border-radius: 26px;
      }

      .portfolio-proof-list {
        grid-template-columns: 1fr;
      }
    }
