
:root{--red:#e72b31;--black:#050505;--white:#f7f7f7;--muted:#cfcfcf;--blue:#1877f2;--google-blue:#4285f4;--google-red:#ea4335;--google-yellow:#fbbc05;--google-green:#34a853;--display:"Arial Black",Impact,system-ui,sans-serif;--body:Arial,Helvetica,sans-serif}*{box-sizing:border-box}html,body{margin:0;height:100%;overflow:hidden;background:#000;color:#fff;font-family:var(--body)}button,a{font:inherit}button{cursor:pointer}a{text-decoration:none;color:inherit}.site{height:100dvh;display:grid;grid-template-rows:auto 1fr auto;background:#000}.top{background:#020202;border-bottom:1px solid rgba(255,255,255,.12);z-index:5}.topline{height:18px;display:flex;justify-content:center;gap:clamp(28px,24vw,560px);align-items:center;text-transform:uppercase;font:900 clamp(9px,.65vw,12px)/1 var(--display)}.nav{height:70px;width:min(1220px,92vw);margin:auto;display:flex;align-items:center;justify-content:space-between;gap:20px}.logoBtn{border:0;background:transparent;padding:0;overflow:visible}.navLogo{display:block;width:clamp(220px,23vw,380px);height:auto;max-height:58px;object-fit:contain;object-position:center;background:transparent}.navlinks{display:flex;gap:clamp(8px,1vw,18px);align-items:center}.navlinks button,.footer button{border:0;background:transparent;color:#fff;font-weight:900}.navlinks button{font-size:clamp(13px,.9vw,17px)}.pill,.primary{background:linear-gradient(135deg,#ff343b,#bb1119)!important;border:0!important;border-radius:999px;color:#fff!important;padding:13px 21px!important;font-weight:1000!important;box-shadow:0 12px 26px rgba(231,43,49,.28)}.ghost{display:inline-flex;align-items:center;border:1px solid rgba(255,255,255,.34);background:rgba(0,0,0,.38);border-radius:999px;color:#fff;padding:12px 19px;font-weight:1000}.hero{position:relative;overflow:hidden}.heroBg{position:absolute;inset:0;background:url('Images/whitcomb-vehicle-001.webp') center/cover no-repeat;filter:saturate(.86) contrast(1.08);transform:scale(1.015)}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(15,0,0,.84),rgba(0,0,0,.52) 46%,rgba(5,20,35,.62))}.hero:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 35% 52%,rgba(0,0,0,.04),rgba(0,0,0,.78) 85%)}.heroContent{position:relative;z-index:1;height:100%;width:min(1220px,92vw);margin:auto;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding-bottom:2vh}.eyebrow{padding:8px 12px;border-radius:999px;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.22);font:900 clamp(10px,.7vw,13px)/1 var(--display);text-transform:uppercase;letter-spacing:.08em}.hero h1{font-family:var(--display);text-transform:uppercase;font-size:clamp(54px,7.4vw,126px);line-height:.83;margin:14px 0 8px;max-width:760px;text-shadow:0 10px 32px rgba(0,0,0,.72)}.hero h1 span{color:#ff3339}.hero p{font-weight:900;font-size:clamp(17px,1.18vw,23px);line-height:1.35;max-width:760px;margin:0 0 20px}.cta{display:flex;gap:12px;flex-wrap:wrap}.heroBadge{display:block;margin-top:22px;width:clamp(290px,30vw,520px);height:auto;max-height:130px;object-fit:contain;background:transparent;filter:drop-shadow(0 14px 22px rgba(0,0,0,.6))}.footer{min-height:128px;background:linear-gradient(120deg,#050505,#151515 38%,#070707);border-top:1px solid rgba(255,255,255,.12);display:grid;grid-template-columns:1.1fr .75fr 1fr auto;gap:clamp(18px,4vw,72px);align-items:start;padding:17px max(26px,calc((100vw - 1220px)/2));position:relative}.footer h3{margin:0 0 8px;font:900 16px/1 var(--display);text-transform:uppercase}.footer p{margin:0;color:#eee;line-height:1.45;font-size:14px}.footer button{display:block;padding:0 0 6px}.footerLogo{display:block;width:clamp(260px,24vw,420px);height:auto;max-height:92px;object-fit:contain;object-position:center;background:transparent;filter:drop-shadow(0 0 12px rgba(255,255,255,.13))}.legal{grid-column:1/-1;border-top:1px solid rgba(255,255,255,.12);padding-top:7px;display:flex;justify-content:space-between;color:#aaa;font-size:12px}.modal{width:min(1580px,95vw);height:auto;max-height:92dvh;border:1px solid rgba(255,255,255,.24);border-radius:28px;background:linear-gradient(135deg,rgba(22,22,22,.72),rgba(69,28,32,.66));color:#fff;padding:0;overflow:hidden;box-shadow:0 26px 90px rgba(0,0,0,.65),inset 0 1px 0 rgba(255,255,255,.18),inset 0 -1px 0 rgba(255,255,255,.05);backdrop-filter:blur(18px) saturate(1.28);-webkit-backdrop-filter:blur(18px) saturate(1.28);position:relative}.modal:before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(115deg,rgba(255,255,255,.22) 0%,rgba(255,255,255,.08) 18%,rgba(255,255,255,0) 42%),radial-gradient(circle at 18% 8%,rgba(255,255,255,.16),transparent 30%),radial-gradient(circle at 82% 14%,rgba(231,43,49,.18),transparent 34%);mix-blend-mode:screen;opacity:.72}.modal::backdrop{background:rgba(0,0,0,.64);backdrop-filter:blur(8px)}.modal.wide{width:min(1880px,97vw);height:auto;max-height:94dvh}.close{position:absolute;right:22px;top:22px;z-index:5;width:56px;height:56px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.12);color:#fff;font-size:32px}.modalHead{height:106px;display:flex;align-items:center;justify-content:space-between;padding:20px 94px 16px 28px;border-bottom:1px solid rgba(255,255,255,.16);background:linear-gradient(100deg,rgba(20,20,20,.62),rgba(92,37,42,.44));box-shadow:inset 0 1px 0 rgba(255,255,255,.14);position:relative;z-index:1}.kicker{font:900 13px/1 var(--display);color:#ff3b41;text-transform:uppercase;letter-spacing:.08em}.modal h2{font:900 clamp(28px,2vw,46px)/1 var(--display);text-transform:uppercase;margin:6px 0 0}.modalLogo{display:block;width:clamp(270px,24vw,450px);height:auto;max-height:82px;object-fit:contain;background:transparent}.modalBody{max-height:calc(94dvh - 106px);overflow:auto;padding:24px;position:relative;z-index:1}.serviceGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.serviceCard{min-height:200px;border:1px solid rgba(255,255,255,.16);border-radius:22px;background:linear-gradient(rgba(0,0,0,.64),rgba(0,0,0,.83)),var(--bg);background-size:cover;background-position:center;color:#fff;padding:24px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}.serviceCard strong{font:900 23px/1.05 var(--display);text-transform:uppercase}.serviceCard p{font-size:17px;line-height:1.35;color:#e2e2e2;margin:0}.serviceIcon{width:52px;height:52px;border-radius:15px;display:grid;place-items:center;background:rgba(231,43,49,.4);border:1px solid rgba(255,255,255,.2)}.modalActions{position:sticky;bottom:-24px;margin:18px -24px -24px;padding:16px 28px;background:rgba(5,5,5,.78);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:flex-end;gap:14px}.aboutLayout,.contactGrid,.detailLayout{display:grid;grid-template-columns:1fr 1fr;gap:24px}.imageStack{display:grid;gap:18px}.imagePanel{border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.18);background:rgba(0,0,0,.38);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}.imagePanel img,.photo img{display:block;width:100%;height:100%;object-fit:cover}.family{height:420px}.founder{height:280px}.story{background:linear-gradient(135deg,rgba(255,255,255,.10),rgba(255,255,255,.045));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:26px;font-size:18px;line-height:1.62}.communityTabs{display:grid;grid-template-columns:1fr 1fr;overflow:hidden;border-radius:24px;border:1px solid rgba(30,136,255,.55);background:#fff;margin-bottom:18px}.communityTabs a{min-height:66px;display:grid;place-items:center;font-weight:1000;font-size:21px}.communityTabs .fb{background:var(--blue);color:#fff}.communityTabs .gr{background:#fff;color:#111}.googleWord span:nth-child(1){color:var(--google-blue)}.googleWord span:nth-child(2){color:var(--google-red)}.googleWord span:nth-child(3){color:var(--google-yellow)}.googleWord span:nth-child(4){color:var(--google-blue)}.googleWord span:nth-child(5){color:var(--google-green)}.googleWord span:nth-child(6){color:var(--google-red)}.featureCards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:16px}.feature{height:180px;position:relative;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.18);background:#111}.feature img{width:100%;height:100%;object-fit:cover;filter:brightness(.55)}.feature div{position:absolute;left:18px;right:18px;bottom:14px}.feature h3{font:900 24px/1 var(--display);margin:0;text-transform:uppercase}.feature p{margin:4px 0 0;color:#eee;font-weight:700}.filterBtns{display:flex;gap:12px;margin:8px 0 16px}.filterBtns button{border:1px solid rgba(255,255,255,.18);background:#292929;color:#fff;border-radius:999px;padding:12px 18px;font-weight:1000}.filterBtns button.active{background:var(--red)}.gallery{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}.photo{height:190px;border-radius:16px;overflow:hidden;background:#111;border:1px solid rgba(255,255,255,.12);position:relative}.photo .cap{position:absolute;left:12px;right:12px;bottom:12px;background:rgba(0,0,0,.72);border-radius:999px;padding:8px 11px;font-weight:900;color:#fff;font-size:13px}.vehicleText{margin:0 0 16px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:16px;font-size:17px;line-height:1.45}.contactCard{background:linear-gradient(135deg,rgba(255,255,255,.10),rgba(255,255,255,.045));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:26px;font-size:20px;line-height:1.55}.mapShell{border-radius:24px;min-height:300px;background:linear-gradient(135deg,#141414,#222);border:1px solid rgba(255,255,255,.14);display:grid;place-items:center;text-align:center;padding:30px}.mapShell p{color:#ddd}.formGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.full{grid-column:1/-1}label{font-weight:900;display:flex;flex-direction:column;gap:8px}input,select,textarea{border:1px solid rgba(255,255,255,.18);border-radius:14px;background:#fff;color:#111;padding:14px 16px;font-size:17px}.smsBox{margin:18px 0;padding:18px;border-radius:18px;background:rgba(14,79,145,.22);border:1px solid rgba(30,136,255,.25)}@media(max-width:1200px){html,body{overflow:auto}.site{min-height:100dvh;height:auto}.serviceGrid{grid-template-columns:repeat(2,1fr)}.featureCards,.gallery{grid-template-columns:repeat(3,1fr)}.aboutLayout,.contactGrid,.detailLayout{grid-template-columns:1fr}.footer{grid-template-columns:1fr 1fr}.footerLogo{width:300px}}@media(max-width:720px){.topline{height:auto;padding:6px;flex-direction:column;gap:4px}.nav{height:auto;padding:12px 0;flex-direction:column}.navlinks{flex-wrap:wrap;justify-content:center}.heroContent{padding:50px 0}.modal,.modal.wide{width:96vw;height:93dvh}.modalHead{height:auto;min-height:112px}.modalLogo{display:none}.serviceGrid,.featureCards,.gallery,.formGrid,.footer{grid-template-columns:1fr}.photo{height:220px}.legal{flex-direction:column;gap:8px}}


/* FINAL STABLE PATCH - logos, about image, community captions, mobile lightbox */
.navLogo,.heroBadge,.modalLogo,.footerLogo{display:block!important;width:auto!important;height:auto!important;object-fit:contain!important;object-position:center!important;background:transparent!important;overflow:visible!important;}
.footerLogo{content:url('Brand/whitcomb-contact-badge.png');width:clamp(250px,22vw,390px)!important;max-height:110px!important;filter:drop-shadow(0 0 12px rgba(255,255,255,.18)) drop-shadow(0 0 20px rgba(185,28,34,.16))!important;}
.heroBadge,.modalLogo{content:url('Brand/whitcomb-capsule-logo.png');}
.navLogo{content:url('Brand/whitcomb-main-logo.png');}
.imagePanel.founder img,.founder img{object-fit:contain!important;background:#080808!important;padding:8px!important;}
.imagePanel.family img,.family img{object-fit:cover!important;}
.photo{cursor:pointer;touch-action:manipulation;border:1px solid rgba(255,255,255,.12);}
.photo .cap,.gallery .cap{display:none!important;}
.lightboxDialog{border:0;background:rgba(0,0,0,.92);padding:0;max-width:96vw;max-height:96dvh;overflow:hidden;border-radius:18px;}
.lightboxDialog::backdrop{background:rgba(0,0,0,.84);backdrop-filter:blur(6px);}
.lightboxDialog img{display:block;max-width:94vw;max-height:94dvh;object-fit:contain;background:#050505;}
.lightboxClose{position:fixed;right:24px;top:24px;z-index:9999;width:52px;height:52px;border-radius:50%;border:1px solid rgba(255,255,255,.35);background:rgba(0,0,0,.65);color:#fff;font-size:32px;}
.googleWord{font-weight:1000;}
.communityTabs .gr{background:#fff!important;color:#111!important;}
@media(max-width:720px){.footerLogo{width:min(330px,78vw)!important}.photo{height:230px}.imagePanel.founder{height:260px}.lightboxClose{right:14px;top:14px}}

/* === URGENT FINAL REPAIR PASS === */
.modalLogo{max-width:340px!important;max-height:92px!important;object-fit:contain!important;background:transparent!important}
.modal.serviceCenterModal .modalLogo{content:url('Brand/Whitcomb_Sales_Service_Badge.png')}
.modal.serviceCenterModal .modalBody{padding-top:14px!important}
.mapLive{padding:0!important;overflow:hidden!important;position:relative!important;min-height:420px!important}
.mapLive iframe{display:block;width:100%;height:420px;border:0;filter:saturate(.9) contrast(.95)}
.mapLive .mapBtn{position:absolute;left:24px;bottom:24px;z-index:2}
.wizardSteps{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:0 0 18px}
.wizardSteps span{border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:10px 12px;text-align:center;background:rgba(255,255,255,.06);font-weight:900}
.wizardSteps span.active{background:#ed1c24;color:white;border-color:#ed1c24;box-shadow:0 0 24px rgba(237,28,36,.25)}
.wizardPane{display:none}.wizardPane.active{display:block}
.concernGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px}
.concernChoice{min-height:132px;border-radius:20px;border:1px solid rgba(255,255,255,.16);background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.02));color:white;padding:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-align:center}
.concernChoice span{font-size:28px}.concernChoice strong{font-size:18px;text-transform:uppercase}.concernChoice em{font-style:normal;color:rgba(255,255,255,.76)}
.concernChoice.active,.concernChoice:hover{border-color:#ed1c24;box-shadow:0 0 0 2px rgba(237,28,36,.25)}
.wizardNav{display:flex;justify-content:space-between;align-items:center;margin-top:20px;border-top:1px solid rgba(255,255,255,.12);padding-top:18px}
.repairWizard input,.repairWizard select,.repairWizard textarea{background:#fff!important;color:#111!important;border:0!important}
.repairWizard label{color:#fff!important;font-weight:900}.repairWizard .smsBox{margin-top:15px}
.gallery .galleryCard,.galleryItem,.gallery-card{background-size:cover!important;background-position:center!important}
.gallery span,.gallery em,.galleryCaption,.gallery-caption{display:none!important}
@media(max-width:760px){.concernGrid{grid-template-columns:1fr}.wizardSteps{grid-template-columns:1fr 1fr}.modalLogo{max-width:230px!important}.mapLive,.mapLive iframe{min-height:320px;height:320px}}


/* === CLEAN LOGO / SCALE / GALLERY PATCH === */
.modalLogo{
  content:url('Brand/whitcomb-swoosh-icon.png')!important;
  width:clamp(180px,16vw,290px)!important;
  max-width:290px!important;
  max-height:78px!important;
  object-fit:contain!important;
  background:transparent!important;
  padding:0!important;
}
.modal.serviceCenterModal .modalLogo{content:url('Brand/whitcomb-swoosh-icon.png')!important;}
.heroBadge{
  content:url('Brand/whitcomb-capsule-logo.png')!important;
  width:clamp(280px,38vw,560px)!important;
  max-width:560px!important;
  max-height:115px!important;
  object-fit:contain!important;
}
.footerLogo{
  content:url('Brand/whitcomb-swoosh-icon.png')!important;
  width:clamp(220px,20vw,330px)!important;
  max-width:330px!important;
  max-height:95px!important;
  object-fit:contain!important;
}
.modalHead{gap:18px!important;}
.wizardSteps span.active{background:#ed1c24!important;color:#fff!important;border-color:#ed1c24!important;}
.wizardSteps span:not(.active){background:rgba(255,255,255,.06)!important;color:#fff!important;border-color:rgba(255,255,255,.14)!important;box-shadow:none!important;}
.gallery{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))!important;}
.photo{height:clamp(160px,16vh,210px)!important;}
.photo .cap,.gallery .cap{display:none!important;}
@media(max-width:720px){
  .modalLogo{width:min(235px,48vw)!important;max-height:62px!important;}
  .heroBadge{width:min(360px,86vw)!important;max-height:90px!important;}
  .footerLogo{width:min(300px,76vw)!important;max-height:86px!important;}
  .heroContent h1{font-size:clamp(64px,21vw,120px)!important;}
  .gallery{grid-template-columns:1fr!important;}
  .photo{height:225px!important;}
}

/* SEO fallback content for no-JavaScript users */
.noScriptSeo{max-width:1100px;margin:2rem auto;padding:1rem 1.25rem;color:#fff;background:#151515;border:1px solid rgba(255,255,255,.18);border-radius:18px;font-family:system-ui,sans-serif}.noScriptSeo h1{font-size:2rem;margin:0 0 .75rem}.noScriptSeo p{line-height:1.55}

/* Glass / tighter modal polish */
.aboutLayout,.contactGrid,.detailLayout{align-items:start}
.contactGrid{grid-template-columns:minmax(320px,.9fr) minmax(420px,1fr)}
.imagePanel.founder img{object-fit:contain;background:#050505}
.modal .serviceGrid,.modal .aboutLayout,.modal .contactGrid,.modal .detailLayout,.modal .communityTabs,.modal .featureCards,.modal .filterBtns,.modal .gallery,.modal .vehicleText,.modal form{position:relative;z-index:1}
@media(min-width:1201px){.modalBody:has(.aboutLayout),.modalBody:has(.contactGrid){overflow:visible}.modal.wide:has(.aboutLayout),.modal.wide:has(.contactGrid){max-height:88dvh}.family{height:360px}.founder{height:240px}.story{font-size:17px;line-height:1.52}.contactCard{min-height:300px}.mapShell{min-height:300px}.gallery{grid-template-columns:repeat(5,1fr)}.photo{height:175px}}
@media(max-width:720px){.modal,.modal.wide{height:auto;max-height:94dvh}.modalBody{max-height:calc(94dvh - 112px)}.contactGrid{grid-template-columns:1fr}.family{height:280px}.founder{height:190px}}

/* === OPAQUE SHINY GLASS + SUBJECT-SIZED MODALS + GALLERY CAROUSEL PATCH === */
.modal{
  background:
    linear-gradient(135deg, rgba(19,19,20,.96) 0%, rgba(58,21,26,.94) 48%, rgba(23,10,12,.97) 100%) !important;
  border:1px solid rgba(255,255,255,.34) !important;
  box-shadow:
    0 30px 90px rgba(0,0,0,.72),
    0 0 0 1px rgba(255,255,255,.08) inset,
    0 1px 0 rgba(255,255,255,.32) inset,
    0 -80px 160px rgba(130,18,25,.18) inset !important;
  backdrop-filter:blur(14px) saturate(1.18) !important;
  -webkit-backdrop-filter:blur(14px) saturate(1.18) !important;
}
.modal:before{
  background:
    linear-gradient(118deg, rgba(255,255,255,.42) 0%, rgba(255,255,255,.16) 13%, rgba(255,255,255,.035) 29%, rgba(255,255,255,0) 52%),
    radial-gradient(circle at 18% 0%, rgba(255,255,255,.26), transparent 28%),
    radial-gradient(circle at 90% 10%, rgba(255,65,72,.22), transparent 34%) !important;
  opacity:.9 !important;
  mix-blend-mode:screen !important;
}
.modal:after{
  content:"";
  pointer-events:none;
  position:absolute;
  inset:0;
  z-index:0;
  border-radius:28px;
  background:linear-gradient(72deg, transparent 0 42%, rgba(255,255,255,.12) 49%, rgba(255,255,255,.035) 56%, transparent 66%);
}
.modalHead{
  background:linear-gradient(105deg, rgba(8,8,9,.94), rgba(75,27,32,.88), rgba(26,10,12,.94)) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.28), inset 0 -1px 0 rgba(255,255,255,.10) !important;
}
.story,.contactCard,.vehicleText,.imagePanel,.mapShell,.feature,.serviceCard,.concernChoice{
  background-color:rgba(255,255,255,.075) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.20), inset 0 -1px 0 rgba(255,255,255,.06) !important;
}

/* Make the modal size fit the subject instead of always going huge. */
.modal.wide{width:min(1420px,96vw)!important;max-height:92dvh!important;}
.modal-services{width:min(1500px,96vw)!important;}
.modal-about{width:min(1370px,94vw)!important;}
.modal-contact{width:min(1220px,94vw)!important;}
.modal-community{width:min(1520px,96vw)!important;}
.modal-serviceCenter{width:min(1450px,96vw)!important;}
.modal-legal{width:min(920px,92vw)!important;}
.modalBody{max-height:calc(92dvh - 106px)!important;}
@media(min-width:1201px){
  .modalBody:has(.aboutLayout),.modalBody:has(.contactGrid){overflow:auto!important;}
  .modal-about .aboutLayout{grid-template-columns:minmax(480px,.95fr) minmax(520px,1fr)!important;}
  .modal-contact .contactGrid{grid-template-columns:minmax(360px,.85fr) minmax(470px,1fr)!important;}
  .modal-about .family{height:330px!important;}
  .modal-about .founder{height:220px!important;}
  .modal-about .story{font-size:16.5px!important;line-height:1.48!important;padding:24px!important;}
}

/* Gallery buttons now open a carousel/lightbox. */
.photo{appearance:none;-webkit-appearance:none;border:1px solid rgba(255,255,255,.14)!important;padding:0!important;text-align:left;color:inherit;cursor:pointer;}
.lightboxDialog{
  width:min(1200px,96vw);
  height:min(860px,94dvh);
  background:rgba(5,5,6,.96)!important;
  border:1px solid rgba(255,255,255,.24)!important;
  border-radius:22px!important;
  display:none;
  place-items:center;
  position:relative;
}
.lightboxDialog[open]{display:grid;}
.lightboxDialog img{max-width:100%;max-height:100%;width:100%;height:100%;object-fit:contain!important;background:#050505!important;}
.lightboxNav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:58px;height:72px;border-radius:18px;border:1px solid rgba(255,255,255,.22);background:rgba(0,0,0,.58);color:#fff;font-size:58px;line-height:1;display:grid;place-items:center;}
.lightboxPrev{left:18px}.lightboxNext{right:18px}
.lightboxCount{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);background:rgba(0,0,0,.68);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:8px 14px;font-weight:900;color:#fff;}
.lightboxClose{background:rgba(35,35,35,.78)!important;}
@media(max-width:720px){
  .modal.wide,.modal-services,.modal-about,.modal-contact,.modal-community,.modal-serviceCenter{width:96vw!important;height:auto!important;max-height:94dvh!important;}
  .modalBody{max-height:calc(94dvh - 112px)!important;}
  .lightboxDialog{width:96vw;height:88dvh;}
  .lightboxNav{width:48px;height:62px;font-size:46px;}
  .lightboxPrev{left:8px}.lightboxNext{right:8px}
}


/* === AERO GLASS MODAL PATCH ===
   Goal: Windows Aero-style translucent glass, less dead space, subject-sized popups. */
.modal{
  width:min(1320px,94vw) !important;
  height:auto !important;
  max-height:92dvh !important;
  border:1px solid rgba(255,255,255,.34) !important;
  border-radius:26px !important;
  background:
    linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,.045) 38%,rgba(95,12,18,.18) 100%) !important;
  color:#fff !important;
  overflow:hidden !important;
  box-shadow:
    0 28px 90px rgba(0,0,0,.72),
    inset 0 1px 0 rgba(255,255,255,.55),
    inset 0 -1px 0 rgba(255,255,255,.14) !important;
  backdrop-filter:blur(26px) saturate(1.55) contrast(1.08) !important;
  -webkit-backdrop-filter:blur(26px) saturate(1.55) contrast(1.08) !important;
}
.modal.wide{width:min(1660px,96vw) !important;max-height:92dvh !important;}
.modal-serviceCenter{width:min(1540px,96vw) !important;}
.modal-about{width:min(1480px,95vw) !important;}
.modal-contact{width:min(1320px,94vw) !important;}
.modal-services{width:min(1580px,96vw) !important;}
.modal-community{width:min(1760px,97vw) !important;}
.modal:before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  pointer-events:none !important;
  background:
    linear-gradient(112deg,rgba(255,255,255,.55) 0%,rgba(255,255,255,.22) 10%,rgba(255,255,255,.06) 24%,rgba(255,255,255,0) 42%),
    radial-gradient(circle at 18% 0%,rgba(255,255,255,.38),transparent 24%),
    radial-gradient(circle at 88% 14%,rgba(255,64,72,.18),transparent 38%),
    linear-gradient(180deg,rgba(255,255,255,.13),rgba(255,255,255,0) 31%) !important;
  opacity:.82 !important;
  mix-blend-mode:screen !important;
}
.modal:after{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:25px;
  pointer-events:none;
  background:linear-gradient(100deg,transparent 0%,rgba(255,255,255,.16) 46%,rgba(255,255,255,.38) 50%,rgba(255,255,255,.08) 54%,transparent 70%);
  transform:translateX(-72%) skewX(-14deg);
  opacity:.38;
}
.modal::backdrop{
  background:rgba(0,0,0,.46) !important;
  backdrop-filter:blur(10px) saturate(1.15) !important;
  -webkit-backdrop-filter:blur(10px) saturate(1.15) !important;
}
.modalHead{
  height:auto !important;
  min-height:92px !important;
  padding:18px 90px 16px 28px !important;
  background:linear-gradient(180deg,rgba(45,8,12,.46),rgba(15,15,15,.18)) !important;
  border-bottom:1px solid rgba(255,255,255,.24) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.32),0 1px 0 rgba(0,0,0,.28) !important;
}
.modalLogo{width:clamp(190px,18vw,330px) !important;max-height:70px !important;object-fit:contain !important;}
.close{background:rgba(255,255,255,.16) !important;border:1px solid rgba(255,255,255,.42) !important;box-shadow:inset 0 1px 0 rgba(255,255,255,.35),0 8px 20px rgba(0,0,0,.35) !important;}
.modalBody{
  padding:24px 28px 28px !important;
  max-height:calc(92dvh - 92px) !important;
  overflow:auto !important;
  background:linear-gradient(135deg,rgba(60,0,8,.08),rgba(255,255,255,.025)) !important;
}
.story,.contactCard,.mapShell,.imagePanel,.vehicleText,.smsBox,.serviceCard,.feature,.photo{
  background-color:rgba(255,255,255,.075) !important;
  backdrop-filter:blur(18px) saturate(1.28) !important;
  -webkit-backdrop-filter:blur(18px) saturate(1.28) !important;
  border-color:rgba(255,255,255,.24) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 12px 28px rgba(0,0,0,.18) !important;
}
.story,.contactCard{background:linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,.055)) !important;}
.aboutLayout{align-items:start !important;}
.family{height:clamp(285px,34vh,420px) !important;}
.founder{height:clamp(170px,23vh,280px) !important;}
.contactGrid{align-items:start !important;}
.mapShell{min-height:clamp(260px,36vh,380px) !important;}
.serviceGrid{grid-template-columns:repeat(4,minmax(0,1fr)) !important;gap:18px !important;}
.serviceCard{min-height:clamp(150px,20vh,205px) !important;}
.gallery{grid-template-columns:repeat(5,minmax(0,1fr)) !important;gap:14px !important;}
.photo{height:clamp(135px,18vh,190px) !important;}
.feature{height:clamp(140px,20vh,180px) !important;}
@media (max-width:900px){
  .modal,.modal.wide,.modal-about,.modal-contact,.modal-services,.modal-community,.modal-serviceCenter{width:96vw !important;max-height:94dvh !important;border-radius:20px !important;}
  .modalHead{min-height:78px !important;padding:14px 68px 12px 18px !important;}
  .modalLogo{width:clamp(150px,38vw,240px) !important;max-height:56px !important;}
  .modalBody{padding:16px !important;max-height:calc(94dvh - 78px) !important;}
  .aboutLayout,.contactGrid,.detailLayout{grid-template-columns:1fr !important;}
  .serviceGrid,.gallery{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .featureCards{grid-template-columns:1fr !important;}
  .family{height:260px !important}.founder{height:180px !important}.photo{height:150px !important}
}
@media (max-width:560px){.serviceGrid,.gallery{grid-template-columns:1fr !important}.modal h2{font-size:30px !important}.photo{height:210px !important}}

/* === SUBJECT-SIZED POPUP PATCH ===
   Keeps the Aero glass look, but stops content-light popups from stretching tall.
   Service/About/Contact now shrink to their content; large galleries still scroll when needed. */
.modal[open]{
  height:fit-content !important;
  min-height:0 !important;
  max-height:calc(100dvh - 38px) !important;
  margin:auto !important;
}
.modalBody{
  height:auto !important;
  min-height:0 !important;
  max-height:calc(100dvh - 132px) !important;
}
.modal-services,
.modal-about,
.modal-contact,
.modal-legal{
  height:fit-content !important;
  min-height:0 !important;
}
.modal-services .modalBody,
.modal-about .modalBody,
.modal-contact .modalBody,
.modal-legal .modalBody{
  max-height:none !important;
  overflow:visible !important;
}
.modal-services .modalActions,
.modal-contact .modalActions,
.modal-about .modalActions{
  position:static !important;
  bottom:auto !important;
  margin:18px -28px -28px !important;
}
.modal-services .serviceGrid{
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:16px !important;
}
.modal-services .serviceCard{
  min-height:165px !important;
  padding:20px !important;
}
.modal-services .serviceCard strong{font-size:21px !important;}
.modal-services .serviceCard p{font-size:15.5px !important;}
.modal-about .aboutLayout,
.modal-contact .contactGrid{
  align-items:start !important;
}
.modal-about .family{height:320px !important;}
.modal-about .founder{height:210px !important;}
.modal-about .story{padding:23px !important;line-height:1.46 !important;}
.modal-contact .mapShell{min-height:300px !important;}
.modal-community,
.modal-serviceCenter{
  height:fit-content !important;
  min-height:0 !important;
  max-height:calc(100dvh - 26px) !important;
}
.modal-community .modalBody,
.modal-serviceCenter .modalBody{
  max-height:calc(100dvh - 132px) !important;
  overflow:auto !important;
}
@media(max-width:900px){
  .modal-services .modalBody,
  .modal-about .modalBody,
  .modal-contact .modalBody,
  .modal-legal .modalBody{
    max-height:calc(94dvh - 78px) !important;
    overflow:auto !important;
  }
  .modal-services .serviceGrid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .modal-services .serviceCard{min-height:150px !important;}
}
@media(max-width:560px){
  .modal-services .serviceGrid{grid-template-columns:1fr !important;}
}

/* === COMMUNITY BUTTON + ABOUT EMPHASIS PATCH === */
.categoryCards .feature{
  appearance:none;
  -webkit-appearance:none;
  padding:0;
  text-align:left;
  color:#fff;
  cursor:pointer;
}
.categoryCards .feature.active{
  border-color:rgba(255,255,255,.62) !important;
  box-shadow:0 0 0 2px rgba(231,43,49,.72), 0 18px 38px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.22) !important;
}
.categoryCards .feature:focus-visible{
  outline:3px solid #fff;
  outline-offset:4px;
}
.filterBtns{display:none !important;}
.modal-about{
  width:min(1660px,97vw) !important;
}
.modal-about .modalBody{
  padding:28px 32px 34px !important;
}
.modal-about .aboutLayout{
  grid-template-columns:minmax(560px,1.05fr) minmax(560px,.95fr) !important;
  gap:28px !important;
}
.modal-about .imagePanel.family{
  height:clamp(430px,48vh,560px) !important;
  background:#050505 !important;
}
.modal-about .imagePanel.family img{
  object-fit:contain !important;
  background:#050505 !important;
}
.modal-about .imagePanel.founder{
  height:clamp(230px,28vh,330px) !important;
}
.modal-about .story{
  font-size:18px !important;
  line-height:1.58 !important;
  padding:30px !important;
}
@media(max-width:900px){
  .modal-about .aboutLayout{grid-template-columns:1fr !important;}
  .modal-about .imagePanel.family{height:auto !important;}
  .modal-about .imagePanel.family img{height:auto !important;}
  .modal-about .story{font-size:16px !important;line-height:1.5 !important;padding:20px !important;}
}

/* === REVIEW PASS: MOBILE FLOW + HERO ROTATION FADE === */
.heroBg{transition:background-image .8s ease-in-out, opacity .8s ease-in-out;}
@media(max-width:720px){
  html,body{overflow:auto!important;}
  .site{height:auto!important;min-height:100dvh!important;grid-template-rows:auto auto auto!important;}
  .nav{gap:10px!important;padding:9px 0!important;}
  .navLogo{width:min(270px,82vw)!important;max-height:54px!important;}
  .navlinks{gap:8px!important;}
  .navlinks button{font-size:13px!important;padding:8px 10px!important;}
  .hero{min-height:calc(100dvh - 250px)!important;}
  .heroContent{justify-content:flex-start!important;padding-top:28px!important;padding-bottom:26px!important;}
  .heroContent h1{font-size:clamp(48px,17vw,82px)!important;line-height:.86!important;margin:10px 0 8px!important;}
  .heroContent p{font-size:clamp(16px,4.8vw,20px)!important;line-height:1.25!important;margin-bottom:14px!important;}
  .cta{gap:10px!important;}
  .primary,.ghost{padding:11px 15px!important;font-size:15px!important;}
  .heroBadge{margin-top:18px!important;width:min(330px,86vw)!important;max-height:86px!important;}
  .footer{padding:24px 24px 28px!important;gap:18px!important;}
  .footerLogo{justify-self:start!important;}
}

/* === CONVERSION POLISH PASS: hero life, trust, deeper services, final CTA === */
.site{grid-template-rows:auto 1fr auto auto!important;}
.heroBg{transition:background-image .8s ease, transform 9s ease;animation:heroDrift 18s ease-in-out infinite alternate;}
@keyframes heroDrift{from{transform:scale(1.015) translate3d(0,0,0)}to{transform:scale(1.055) translate3d(-1.2%,.8%,0)}}
.heroContent{animation:heroFloat 8s ease-in-out infinite alternate;}
@keyframes heroFloat{from{transform:translateY(0)}to{transform:translateY(-8px)}}
.primary{position:relative;overflow:hidden;}
.primary:after{content:"";position:absolute;inset:-30% -80%;background:linear-gradient(110deg,transparent 35%,rgba(255,255,255,.42) 50%,transparent 65%);transform:translateX(-80%);animation:btnSheen 4.8s ease-in-out infinite;pointer-events:none;}
@keyframes btnSheen{0%,58%{transform:translateX(-90%)}74%,100%{transform:translateX(90%)}}
.trustStrip{margin-top:16px;display:flex;gap:9px;flex-wrap:wrap;max-width:900px;}
.trustStrip span{display:inline-flex;align-items:center;gap:7px;padding:8px 11px;border-radius:999px;background:rgba(0,0,0,.46);border:1px solid rgba(255,255,255,.22);font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.02em;box-shadow:inset 0 1px 0 rgba(255,255,255,.13)}
.trustStrip span:before{content:"✓";color:#38d56a;font-weight:1000;}
.heroRotator{margin-top:10px;min-height:24px;font:900 clamp(15px,1vw,19px)/1.25 var(--display);letter-spacing:.04em;text-transform:uppercase;color:#fff;text-shadow:0 4px 12px rgba(0,0,0,.7);transition:opacity .18s ease;}
.finalCta{display:flex;align-items:center;justify-content:center;gap:18px;min-height:54px;padding:9px 20px;background:linear-gradient(90deg,#060606,#19090b 38%,#060606);border-top:1px solid rgba(255,255,255,.11);border-bottom:1px solid rgba(255,255,255,.08);text-align:center;}
.finalCta strong{font:900 18px/1 var(--display);text-transform:uppercase;letter-spacing:.03em;}
.finalCta span{color:#e8e8e8;font-weight:800;}
.finalCta .primary{padding:10px 18px!important;font-size:14px!important;}
.miniReviews{margin-top:10px;display:grid;gap:4px;color:#e9e9e9;font-size:13px;font-weight:800;opacity:.92;}
.mobileCall{display:none;position:fixed;right:16px;bottom:16px;z-index:20;background:linear-gradient(135deg,#ff343b,#bb1119);color:#fff;border-radius:999px;padding:13px 18px;font-weight:1000;box-shadow:0 10px 28px rgba(0,0,0,.45),0 0 24px rgba(231,43,49,.28);}
.serviceDetailDeep .imagePanel{min-height:360px;}
.serviceBullets{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 18px;margin:16px 0 20px;padding:0;list-style:none;}
.serviceBullets li{padding:10px 12px;border-radius:13px;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.13);font-weight:900;}
.serviceBullets li:before{content:"✓ ";color:#ff454b;font-weight:1000;}

/* Make service and contact popups fit their content better. */
.modal-services .modalBody{padding-bottom:0!important;}
.modal-services .modalActions{margin-top:14px!important;}
.modal-contact .modalBody,.modal-about .modalBody{padding-bottom:22px!important;}
.modal-services{max-height:86dvh!important;}
.modal-contact{max-height:78dvh!important;}
.modal-legal{max-height:78dvh!important;}

@media(max-width:900px){
  html,body{overflow:auto!important;}
  .site{min-height:100dvh;height:auto!important;grid-template-rows:auto auto auto auto!important;}
  .topline{height:auto;min-height:24px;padding:5px 10px;gap:12px;flex-wrap:wrap;}
  .nav{height:auto;min-height:68px;align-items:center;gap:10px;}
  .navlinks{gap:6px;overflow-x:auto;padding-bottom:4px;}
  .navlinks button{white-space:nowrap;}
  .hero{min-height:calc(100dvh - 220px);}
  .heroContent{justify-content:flex-start;padding-top:28px;padding-bottom:24px;animation:none;}
  .hero h1{font-size:clamp(48px,16vw,82px)!important;line-height:.86!important;}
  .trustStrip span{font-size:11px;padding:7px 9px;}
  .heroRotator{font-size:14px;}
  .finalCta{flex-direction:column;gap:8px;padding:13px 14px;}
  .footer{grid-template-columns:1fr!important;gap:18px!important;padding:24px!important;}
  .legal{display:grid!important;gap:10px!important;}
  .mobileCall{display:inline-flex;}
  .serviceBullets{grid-template-columns:1fr;}
  .serviceDetailDeep .imagePanel{min-height:240px;}
}
@media(max-width:640px){
  .trustStrip{display:grid;grid-template-columns:1fr 1fr;}
  .finalCta strong{font-size:15px;}
  .miniReviews{display:none;}
}

/* === PLATE + CROP + CTA FIX PASS === */
.modal-services .modalBody{overflow:visible!important;max-height:none!important;padding-bottom:0!important;}
.modal-services .modalActions{position:relative!important;bottom:auto!important;margin:18px -24px 0!important;padding:18px 28px 24px!important;border-radius:0 0 24px 24px!important;transform:none!important;overflow:visible!important;}
.modal-services{height:fit-content!important;max-height:calc(100dvh - 44px)!important;overflow:hidden!important;}
.modal-services .serviceGrid{margin-bottom:0!important;}
.modal-services .primary,.modal-services .ghost{margin-bottom:0!important;align-self:center!important;}
.gallery .photo{background:#060606!important;}
.gallery .photo img{object-fit:contain!important;object-position:center center!important;background:#060606!important;filter:saturate(.98) contrast(1.02)!important;}
.categoryCards .feature img,.serviceCard img{object-fit:cover!important;}
.lightboxDialog img{object-fit:contain!important;}
@media(max-width:900px){.modal-services .modalBody{max-height:calc(94dvh - 78px)!important;overflow:auto!important;padding-bottom:0!important;}.modal-services .modalActions{margin:16px -16px 0!important;padding:16px 16px 22px!important;flex-wrap:wrap!important;}}

/* === AUTOMOTIVE GALLERY REBUILD: no letterbox cards, focal crops, vehicle-first lightbox === */
.gallery{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(255px,1fr))!important;
  gap:16px!important;
  align-items:start!important;
}
.gallery .photo{
  display:block!important;
  width:100%!important;
  height:auto!important;
  aspect-ratio:4/3!important;
  border-radius:16px!important;
  overflow:hidden!important;
  background:#080808!important;
  border:1px solid rgba(255,255,255,.22)!important;
  box-shadow:0 14px 34px rgba(0,0,0,.32)!important;
  padding:0!important;
  cursor:pointer!important;
}
.gallery .photo img{
  width:100%!important;
  height:100%!important;
  display:block!important;
  object-fit:cover!important;
  object-position:var(--focus, center center)!important;
  background:#080808!important;
  filter:saturate(1.02) contrast(1.03) brightness(.92)!important;
  transition:transform .18s ease, filter .18s ease!important;
}
.gallery .photo:hover img{transform:scale(1.035)!important;filter:saturate(1.04) contrast(1.05) brightness(1)!important;}
.vehicleText{
  padding:12px 16px!important;
  margin:0 0 14px!important;
  font-size:16px!important;
  line-height:1.4!important;
}
.lightboxDialog{
  width:min(1500px,96vw)!important;
  height:min(900px,92dvh)!important;
  max-width:96vw!important;
  max-height:92dvh!important;
  background:rgba(0,0,0,.82)!important;
  border:1px solid rgba(255,255,255,.24)!important;
  border-radius:22px!important;
  overflow:hidden!important;
  padding:0!important;
  box-shadow:0 28px 80px rgba(0,0,0,.75)!important;
}
.lightboxDialog::backdrop{background:rgba(0,0,0,.72)!important;backdrop-filter:blur(8px)!important;-webkit-backdrop-filter:blur(8px)!important;}
.lightboxDialog[open]{display:grid!important;place-items:center!important;}
.lightboxDialog img{
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  max-height:none!important;
  object-fit:cover!important;
  object-position:center center;
  background:#050505!important;
}
.categoryCards .feature.active{border-color:#ff333b!important;box-shadow:0 0 0 2px rgba(255,45,55,.45),0 18px 45px rgba(0,0,0,.28)!important;}
.categoryCards .feature{cursor:pointer!important;}
@media(max-width:900px){
  .gallery{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important;}
  .gallery .photo{aspect-ratio:1/1!important;border-radius:14px!important;}
  .vehicleText{font-size:14px!important;padding:10px 12px!important;}
  .lightboxDialog{width:96vw!important;height:84dvh!important;border-radius:18px!important;}
}
@media(max-width:560px){
  .gallery{grid-template-columns:1fr 1fr!important;gap:10px!important;}
  .gallery .photo{aspect-ratio:1/1!important;}
  .featureCards{grid-template-columns:1fr!important;}
  .feature{height:142px!important;}
  .lightboxDialog{width:96vw!important;height:80dvh!important;}
}

/* === FINAL LIGHTBOX FIX: no crop, no ceiling-only zoom, close stays inside overlay === */
.lightboxDialog,
.lightboxDialog[open]{
  width:auto!important;
  height:auto!important;
  max-width:96vw!important;
  max-height:92dvh!important;
  padding:0!important;
  margin:auto!important;
  border:0!important;
  border-radius:18px!important;
  background:rgba(0,0,0,.72)!important;
  overflow:visible!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  box-shadow:0 24px 90px rgba(0,0,0,.75)!important;
}
.lightboxDialog::backdrop{
  background:rgba(0,0,0,.78)!important;
  backdrop-filter:blur(10px)!important;
  -webkit-backdrop-filter:blur(10px)!important;
}
.lightboxDialog img,
#lightboxImg{
  display:block!important;
  width:auto!important;
  height:auto!important;
  max-width:94vw!important;
  max-height:88dvh!important;
  object-fit:contain!important;
  object-position:center center!important;
  background:transparent!important;
  border-radius:16px!important;
  filter:none!important;
}
.lightboxClose{
  position:absolute!important;
  top:10px!important;
  right:10px!important;
  left:auto!important;
  z-index:99999!important;
  width:44px!important;
  height:44px!important;
  border-radius:999px!important;
  border:1px solid rgba(255,255,255,.48)!important;
  background:rgba(25,25,25,.72)!important;
  color:#fff!important;
  font-size:30px!important;
  line-height:38px!important;
  display:grid!important;
  place-items:center!important;
  box-shadow:0 10px 28px rgba(0,0,0,.45)!important;
}
.lightboxPrev{left:12px!important}.lightboxNext{right:12px!important}
.lightboxNav{z-index:99998!important;}
@media(max-width:720px){
  .lightboxDialog,.lightboxDialog[open]{max-width:96vw!important;max-height:86dvh!important;}
  .lightboxDialog img,#lightboxImg{max-width:94vw!important;max-height:82dvh!important;}
  .lightboxClose{top:8px!important;right:8px!important;width:40px!important;height:40px!important;font-size:27px!important;}
  .lightboxNav{width:42px!important;height:54px!important;font-size:40px!important;}
  .lightboxPrev{left:6px!important}.lightboxNext{right:6px!important}
}


/* =========================================================
   FORENSIC FINAL FIX - MODAL CLOSE RIGHT + ABOUT SINGLE SCREEN
   This block intentionally lives at the very end of the stylesheet.
   ========================================================= */

/* Normalize dialog behavior and kill accidental left-position close inheritance */
dialog.modal{
  position:fixed !important;
  inset:50% auto auto 50% !important;
  transform:translate(-50%,-50%) !important;
  margin:0 !important;
  padding:0 !important;
  overflow:hidden !important;
}

dialog.modal > button.close,
dialog.modal button.close,
#modal > .close{
  position:absolute !important;
  top:14px !important;
  right:14px !important;
  left:auto !important;
  bottom:auto !important;
  z-index:99999 !important;
  width:38px !important;
  height:38px !important;
  min-width:38px !important;
  min-height:38px !important;
  display:grid !important;
  place-items:center !important;
  padding:0 !important;
  border-radius:999px !important;
  border:1px solid rgba(255,255,255,.38) !important;
  background:rgba(18,18,18,.48) !important;
  color:#fff !important;
  font-size:24px !important;
  line-height:1 !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.32), 0 8px 22px rgba(0,0,0,.38) !important;
  backdrop-filter:blur(12px) saturate(1.25) !important;
  -webkit-backdrop-filter:blur(12px) saturate(1.25) !important;
}

dialog.modal > button.close:hover,
dialog.modal button.close:hover{
  transform:translateY(-1px) scale(1.04) !important;
  background:rgba(185,28,34,.55) !important;
  box-shadow:0 0 10px rgba(255,255,255,.22), 0 0 18px rgba(231,43,49,.34), 0 8px 22px rgba(0,0,0,.38) !important;
}

/* Keep header clear of the smaller close button */
.modalHead{
  padding-right:70px !important;
}

/* General modal sizing should be content-aware, not full empty boxes */
.modal{
  height:auto !important;
  min-height:0 !important;
  max-height:calc(100dvh - 28px) !important;
}

.modalBody{
  min-height:0 !important;
  height:auto !important;
  overflow:visible !important;
  scrollbar-width:none !important;
}

.modalBody::-webkit-scrollbar{
  display:none !important;
}

/* About is important: bigger than normal, but deliberately one-screen */
.modal.modal-about,
dialog.modal.modal-about{
  width:min(1660px,96vw) !important;
  max-height:calc(100dvh - 26px) !important;
}

.modal-about .modalBody{
  padding:22px 26px 26px !important;
  overflow:hidden !important;
  max-height:none !important;
}

.aboutNoScroll{
  display:grid !important;
  grid-template-columns:minmax(520px,1.12fr) minmax(480px,.88fr) !important;
  gap:24px !important;
  align-items:stretch !important;
  max-height:calc(100dvh - 150px) !important;
  min-height:0 !important;
  overflow:hidden !important;
}

.aboutPhotoGrid{
  display:grid !important;
  grid-template-rows:minmax(300px,1fr) minmax(170px,.48fr) !important;
  gap:16px !important;
  min-height:0 !important;
  overflow:hidden !important;
}

.aboutNoScroll .imagePanel{
  border-radius:22px !important;
  overflow:hidden !important;
  min-height:0 !important;
  background:rgba(0,0,0,.38) !important;
  border:1px solid rgba(255,255,255,.18) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12), 0 18px 45px rgba(0,0,0,.32) !important;
}

.aboutNoScroll .imagePanel img,
.aboutFamily img,
.aboutFounder img{
  width:100% !important;
  height:100% !important;
  display:block !important;
  object-fit:contain !important;
  object-position:center !important;
  background:rgba(0,0,0,.45) !important;
}

.aboutFamily{
  height:auto !important;
}

.aboutFounder{
  height:auto !important;
}

.aboutStoryCard{
  align-self:stretch !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  overflow:hidden !important;
  padding:clamp(22px,2.2vw,34px) !important;
  border-radius:24px !important;
  background:linear-gradient(135deg,rgba(255,255,255,.14),rgba(255,255,255,.055)), rgba(20,20,20,.58) !important;
  border:1px solid rgba(255,255,255,.20) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22), 0 22px 60px rgba(0,0,0,.34) !important;
  backdrop-filter:blur(18px) saturate(1.28) !important;
  -webkit-backdrop-filter:blur(18px) saturate(1.28) !important;
}

.aboutStoryCard h3{
  margin:0 0 14px !important;
  font-family:var(--display, Oswald, sans-serif) !important;
  text-transform:uppercase !important;
  letter-spacing:.03em !important;
  font-size:clamp(28px,2.2vw,42px) !important;
  line-height:1.02 !important;
}

.aboutStoryCard p{
  margin:0 0 13px !important;
  font-size:clamp(15px,1vw,18px) !important;
  line-height:1.5 !important;
  color:rgba(255,255,255,.9) !important;
}

.aboutStoryCard p:last-child{
  margin-bottom:0 !important;
}

/* Preserve the glow/button feel after responsive stabilization */
button,
.primary,
.ghost,
.serviceCard,
.feature,
.photo,
.mobileCall{
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease, background .18s ease !important;
}

button:hover,
.primary:hover,
.ghost:hover,
.serviceCard:hover,
.feature:hover,
.photo:hover,
.mobileCall:hover{
  transform:translateY(-2px) !important;
  filter:brightness(1.08) !important;
  box-shadow:0 0 8px rgba(255,255,255,.16), 0 0 18px rgba(231,43,49,.28), 0 16px 34px rgba(0,0,0,.32) !important;
}

/* Mobile: About can scroll as page content, but not double-scroll inside nested containers */
@media(max-width:900px){
  dialog.modal{
    width:96vw !important;
    max-height:94dvh !important;
  }

  .modalBody{
    overflow:auto !important;
    max-height:calc(94dvh - 84px) !important;
    scrollbar-width:thin !important;
  }

  .modal-about .modalBody{
    overflow:auto !important;
    max-height:calc(94dvh - 84px) !important;
    padding:16px !important;
  }

  .aboutNoScroll{
    grid-template-columns:1fr !important;
    max-height:none !important;
    overflow:visible !important;
    gap:16px !important;
  }

  .aboutPhotoGrid{
    grid-template-rows:auto auto !important;
    overflow:visible !important;
  }

  .aboutNoScroll .imagePanel{
    height:auto !important;
  }

  .aboutNoScroll .imagePanel img{
    width:100% !important;
    height:auto !important;
    max-height:48vh !important;
  }

  .aboutStoryCard{
    overflow:visible !important;
    justify-content:flex-start !important;
  }
}


/* =========================================================
   ABOUT NEWSPAPER ARTICLE EFFECT
   Family photo stays strong left. Right side becomes a visible
   newspaper-style article layered over Curtis clipping.
   ========================================================= */

.modal.modal-about,
dialog.modal.modal-about{
  width:min(1740px,96vw) !important;
  max-height:calc(100dvh - 26px) !important;
  overflow:hidden !important;
}

.modal-about .modalBody{
  padding:22px 26px 26px !important;
  overflow:hidden !important;
  max-height:none !important;
}

.aboutNewspaperLayout{
  display:grid !important;
  grid-template-columns:minmax(520px,1.03fr) minmax(600px,.97fr) !important;
  gap:24px !important;
  align-items:stretch !important;
  max-height:calc(100dvh - 150px) !important;
  min-height:0 !important;
  overflow:hidden !important;
}

.aboutNewspaperLayout .aboutFamily{
  height:auto !important;
  min-height:0 !important;
  border-radius:24px !important;
  overflow:hidden !important;
  background:#050505 !important;
  border:1px solid rgba(255,255,255,.18) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12), 0 22px 58px rgba(0,0,0,.38) !important;
}

.aboutNewspaperLayout .aboutFamily img{
  width:100% !important;
  height:100% !important;
  display:block !important;
  object-fit:contain !important;
  object-position:center !important;
  background:#050505 !important;
}

.newspaperStory{
  position:relative !important;
  overflow:hidden !important;
  border-radius:24px !important;
  padding:0 !important;
  min-height:0 !important;
  align-self:stretch !important;
  background:#d8d0bd !important;
  border:1px solid rgba(255,255,255,.28) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.42), 0 24px 64px rgba(0,0,0,.42) !important;
}

.newspaperClipLayer{
  position:absolute !important;
  inset:0 !important;
  z-index:0 !important;
  opacity:.55 !important;
  filter:sepia(.35) contrast(1.08) brightness(.92) saturate(.82) !important;
  pointer-events:none !important;
  background:#d6ccb7 !important;
}

.newspaperClipLayer img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center !important;
  mix-blend-mode:multiply !important;
}

.newspaperStory::before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  z-index:1 !important;
  pointer-events:none !important;
  background:
    linear-gradient(90deg,rgba(238,232,211,.94),rgba(232,225,202,.88) 55%,rgba(225,216,190,.76)),
    repeating-linear-gradient(0deg,rgba(0,0,0,.035) 0px,rgba(0,0,0,.035) 1px,transparent 1px,transparent 4px) !important;
  mix-blend-mode:normal !important;
}

.newspaperStory::after{
  content:"" !important;
  position:absolute !important;
  inset:16px !important;
  z-index:2 !important;
  pointer-events:none !important;
  border:1px solid rgba(55,42,25,.25) !important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.24) !important;
}

.newspaperArticleText{
  position:relative !important;
  z-index:3 !important;
  height:100% !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  padding:clamp(26px,2.1vw,38px) !important;
  color:#17120c !important;
  font-family:Georgia, "Times New Roman", serif !important;
  text-shadow:0 1px 0 rgba(255,255,255,.28) !important;
}

.newspaperMasthead{
  font-family:Georgia, "Times New Roman", serif !important;
  text-transform:uppercase !important;
  letter-spacing:.09em !important;
  font-size:clamp(10px,.75vw,13px) !important;
  font-weight:800 !important;
  color:#4a1d1f !important;
  border-top:2px solid rgba(60,42,22,.65) !important;
  border-bottom:1px solid rgba(60,42,22,.45) !important;
  padding:6px 0 5px !important;
  margin:0 0 10px !important;
}

.newspaperArticleText h3{
  margin:0 0 10px !important;
  font-family:Georgia, "Times New Roman", serif !important;
  font-size:clamp(30px,2.5vw,48px) !important;
  line-height:.98 !important;
  color:#130f09 !important;
  font-weight:900 !important;
  letter-spacing:-.035em !important;
  text-transform:none !important;
  border-bottom:2px solid rgba(35,24,15,.45) !important;
  padding-bottom:8px !important;
}

.newspaperArticleText p{
  margin:0 0 clamp(7px,.7vw,11px) !important;
  color:#18130d !important;
  font-size:clamp(13px,.86vw,16px) !important;
  line-height:1.36 !important;
  font-weight:600 !important;
}

.newspaperArticleText p:first-of-type::first-letter{
  float:left !important;
  font-size:3.05em !important;
  line-height:.82 !important;
  padding-right:6px !important;
  font-weight:900 !important;
  color:#4a1d1f !important;
}

@media(max-width:1180px){
  .aboutNewspaperLayout{
    grid-template-columns:minmax(420px,.95fr) minmax(460px,1.05fr) !important;
  }
  .newspaperArticleText p{
    font-size:13.25px !important;
    line-height:1.31 !important;
  }
}

@media(max-width:900px){
  .modal-about .modalBody{
    overflow:auto !important;
    max-height:calc(94dvh - 84px) !important;
    padding:16px !important;
  }
  .aboutNewspaperLayout{
    grid-template-columns:1fr !important;
    max-height:none !important;
    overflow:visible !important;
    gap:16px !important;
  }
  .aboutNewspaperLayout .aboutFamily{
    height:auto !important;
  }
  .aboutNewspaperLayout .aboutFamily img{
    width:100% !important;
    height:auto !important;
    max-height:46vh !important;
  }
  .newspaperStory{
    min-height:620px !important;
  }
  .newspaperArticleText{
    justify-content:flex-start !important;
  }
  .newspaperArticleText p{
    font-size:14px !important;
    line-height:1.42 !important;
  }
}

/* =========================================================
   SERVICE ICON REMOVAL / CLEAN CARD ALIGNMENT
   ========================================================= */
.serviceIcon{display:none !important;}
.serviceCard{
  justify-content:flex-end !important;
  padding:clamp(1rem,1.5vw,1.5rem) !important;
}
.serviceCard strong{
  display:block !important;
  margin:0 0 .35rem !important;
  font-size:clamp(1.05rem,1.15vw,1.45rem) !important;
  line-height:1.05 !important;
}
.serviceCard p{margin:0 0 .45rem !important;}
.serviceCard em{margin-top:.2rem !important;}


/* =========================================================
   HOME 1080 CLEANUP + ABOUT TWO-IMAGE GALLERY FIX
   ========================================================= */

/* Homepage must advertise the hero, not let footer dominate the screen */
body,
.site{
  min-height:100dvh !important;
  height:auto !important;
  overflow-x:hidden !important;
}

.top{
  flex:0 0 auto !important;
}

.hero{
  min-height:calc(100dvh - 16.25rem) !important;
  height:auto !important;
  padding-block:clamp(1rem,2.2dvh,2.4rem) !important;
  display:flex !important;
  align-items:center !important;
}

.heroInner{
  width:min(100% - 2rem, 92rem) !important;
  display:grid !important;
  grid-template-columns:minmax(30rem, 44rem) minmax(16rem, 1fr) !important;
  align-items:center !important;
  gap:clamp(1rem,2vw,2.5rem) !important;
}

.heroCopy{
  max-width:44rem !important;
}

.heroCopy h1,
.hero h1{
  font-size:clamp(4.25rem,6.4vw,7.15rem) !important;
  line-height:.86 !important;
  max-width:10.5ch !important;
  margin-bottom:clamp(.55rem,1dvh,.9rem) !important;
}

.heroCopy p,
.hero p{
  font-size:clamp(1rem,1.15vw,1.28rem) !important;
  line-height:1.32 !important;
  max-width:43rem !important;
  margin-bottom:clamp(.7rem,1.1dvh,1rem) !important;
}

.heroActions,
.actions{
  gap:.75rem !important;
  margin-block:clamp(.4rem,.8dvh,.75rem) !important;
}

.heroTrust,
.trustStrip,
.trustGrid{
  margin-top:clamp(.6rem,1dvh,.9rem) !important;
}

.heroBadge,
.heroCard{
  max-width:min(100%,28rem) !important;
  justify-self:end !important;
}

/* Make the mid CTA tighter */
.closingCta{
  min-height:0 !important;
  height:auto !important;
  padding:clamp(.55rem,1dvh,.85rem) 0 !important;
}

.closingCta h2,
.closingCta strong,
.closingCta .lead{
  font-size:clamp(1rem,1.25vw,1.45rem) !important;
  line-height:1.05 !important;
  margin:0 !important;
}

/* Compact footer so 1080p does not waste the page */
.footer,
.siteFooter{
  min-height:0 !important;
  height:auto !important;
  padding-block:clamp(.75rem,1.4dvh,1.1rem) !important;
}

.footer{
  display:grid !important;
  grid-template-columns:minmax(14rem,1.15fr) minmax(10rem,.75fr) minmax(14rem,1fr) minmax(14rem,.95fr) !important;
  align-items:start !important;
  gap:clamp(.9rem,1.4vw,1.7rem) !important;
}

.footer h3,
.footer h4{
  font-size:clamp(.98rem,1.05vw,1.22rem) !important;
  line-height:1.05 !important;
  margin:0 0 .45rem !important;
}

.footer p,
.footer a,
.footer li{
  font-size:clamp(.78rem,.86vw,.98rem) !important;
  line-height:1.32 !important;
  margin-bottom:.25rem !important;
}

.footerLogo,
.footer img{
  max-width:min(100%,17rem) !important;
  height:auto !important;
  object-fit:contain !important;
}

.footerBottom,
.copyright{
  padding-top:.55rem !important;
  margin-top:.55rem !important;
  font-size:.78rem !important;
}

/* About: no more buried newspaper overlay. Make both images features. */
.modal-about,
dialog.modal.modal-about{
  width:min(96vw,104rem) !important;
  max-height:calc(100dvh - 1.25rem) !important;
  overflow:hidden !important;
}

.modal-about .modalBody{
  padding:clamp(.9rem,1.4vw,1.4rem) !important;
  overflow:hidden !important;
}

.aboutCleanLayout{
  display:grid !important;
  grid-template-columns:minmax(34rem,1.05fr) minmax(30rem,.95fr) !important;
  gap:clamp(1rem,1.5vw,1.5rem) !important;
  align-items:stretch !important;
  max-height:calc(100dvh - 9rem) !important;
  overflow:hidden !important;
  min-height:0 !important;
}

.aboutShowcase{
  display:grid !important;
  grid-template-rows:minmax(18rem,1.1fr) minmax(13rem,.9fr) !important;
  gap:clamp(.75rem,1.1vw,1rem) !important;
  min-height:0 !important;
  overflow:hidden !important;
}

.aboutFeatureShot{
  appearance:none !important;
  border:1px solid rgba(255,255,255,.24) !important;
  border-radius:clamp(1rem,1.4vw,1.35rem) !important;
  background:#050505 !important;
  padding:0 !important;
  overflow:hidden !important;
  cursor:pointer !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16), 0 1.2rem 3rem rgba(0,0,0,.35) !important;
  min-height:0 !important;
}

.aboutFeatureShot img{
  width:100% !important;
  height:100% !important;
  display:block !important;
  object-fit:contain !important;
  object-position:center !important;
  background:#050505 !important;
}

.fatherShot{
  background:#0a0a0a !important;
}

.fatherShot img{
  object-fit:contain !important;
  background:#0a0a0a !important;
}

.aboutCleanStory{
  align-self:stretch !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  overflow:hidden !important;
  padding:clamp(1.15rem,1.7vw,1.9rem) !important;
  border-radius:clamp(1rem,1.4vw,1.35rem) !important;
  background:linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,.045)),rgba(20,20,20,.52) !important;
  border:1px solid rgba(255,255,255,.24) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.24),0 1.2rem 3rem rgba(0,0,0,.34) !important;
  backdrop-filter:blur(18px) saturate(1.28) !important;
  -webkit-backdrop-filter:blur(18px) saturate(1.28) !important;
}

.aboutCleanStory h3{
  margin:0 0 .7rem !important;
  font-size:clamp(1.6rem,2vw,2.7rem) !important;
  line-height:1.02 !important;
  text-transform:uppercase !important;
  letter-spacing:.03em !important;
}

.aboutCleanStory p{
  margin:0 0 clamp(.45rem,.7vw,.75rem) !important;
  font-size:clamp(.82rem,.89vw,1rem) !important;
  line-height:1.38 !important;
  color:rgba(255,255,255,.91) !important;
}

.aboutCleanStory p:last-child{
  margin-bottom:0 !important;
}

/* Keep action effects alive */
button,
.primary,
.ghost,
.serviceCard,
.feature,
.photo,
.mobileCall,
.aboutFeatureShot{
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease, background .18s ease !important;
}

button:hover,
.primary:hover,
.ghost:hover,
.serviceCard:hover,
.feature:hover,
.photo:hover,
.mobileCall:hover,
.aboutFeatureShot:hover{
  transform:translateY(-2px) !important;
  filter:brightness(1.08) !important;
  box-shadow:0 0 .5rem rgba(255,255,255,.16), 0 0 1.15rem rgba(231,43,49,.30), 0 1rem 2.2rem rgba(0,0,0,.32) !important;
}

/* 1080-ish and browser zoom reflow */
@media(max-height:850px) and (min-width:1000px){
  .hero{
    min-height:calc(100dvh - 14.5rem) !important;
    padding-block:.9rem !important;
  }

  .heroCopy h1,
  .hero h1{
    font-size:clamp(3.7rem,5.7vw,6.2rem) !important;
  }

  .footer{
    padding-block:.65rem !important;
  }

  .footerLogo,
  .footer img{
    max-width:14.5rem !important;
  }

  .aboutCleanLayout{
    grid-template-columns:minmax(31rem,1.05fr) minmax(29rem,.95fr) !important;
  }

  .aboutCleanStory p{
    font-size:clamp(.75rem,.8vw,.92rem) !important;
    line-height:1.31 !important;
  }
}

@media(max-width:1180px){
  .heroInner{
    grid-template-columns:1fr !important;
    align-items:start !important;
  }

  .heroBadge,
  .heroCard{
    justify-self:start !important;
  }

  .footer{
    grid-template-columns:repeat(2,minmax(12rem,1fr)) !important;
  }

  .aboutCleanLayout{
    grid-template-columns:1fr !important;
    max-height:none !important;
    overflow:visible !important;
  }

  .modal-about .modalBody{
    overflow:auto !important;
    max-height:calc(94dvh - 5.5rem) !important;
  }

  .aboutShowcase{
    grid-template-rows:auto auto !important;
  }

  .aboutFeatureShot img{
    height:auto !important;
    max-height:45dvh !important;
  }

  .aboutCleanStory{
    overflow:visible !important;
    justify-content:flex-start !important;
  }
}

@media(max-width:760px){
  .hero{
    min-height:auto !important;
  }

  .heroCopy h1,
  .hero h1{
    font-size:clamp(3rem,17vw,5rem) !important;
  }

  .footer{
    grid-template-columns:1fr !important;
  }

  .aboutCleanStory p{
    font-size:.94rem !important;
    line-height:1.45 !important;
  }
}


/* =========================================================
   FINAL POLISH PASS
   ========================================================= */

/* Auto hide footer tray */
.footer,
.siteFooter{
  position:fixed !important;
  left:0 !important;
  right:0 !important;
  bottom:0 !important;
  z-index:70 !important;
  transform:translateY(calc(100% - 2.5rem)) !important;
  transition:transform .32s ease !important;
  cursor:pointer !important;
}

.footer:hover,
.siteFooter:hover,
body.footer-reveal .footer,
body.footer-reveal .siteFooter{
  transform:translateY(0) !important;
}

.footer::before,
.siteFooter::before{
  content:'WHITCOMB INFO BAR ▲';
  position:absolute;
  top:-2rem;
  left:50%;
  transform:translateX(-50%);
  background:rgba(15,15,15,.92);
  color:#fff;
  padding:.35rem 1rem;
  border-radius:.8rem .8rem 0 0;
  font-weight:800;
  font-size:.8rem;
  letter-spacing:.06em;
  border:1px solid rgba(255,255,255,.12);
}

/* leave room for hidden tray lip */
body,.site{
  padding-bottom:2.6rem !important;
}

/* About final arrangement */
.modal-about,
dialog.modal.modal-about{
  width:min(96vw,104rem) !important;
  max-height:calc(100dvh - 1rem) !important;
}

.modal-about .modalBody{
  overflow:hidden !important;
}

.aboutFinalLayout{
  display:grid !important;
  grid-template-columns:minmax(34rem,1.1fr) minmax(28rem,.9fr) !important;
  gap:1rem !important;
  max-height:calc(100dvh - 8rem) !important;
  min-height:34rem !important;
}

.aboutFamilyLeft,
.aboutRightColumn{
  min-height:0 !important;
}

.aboutFamilyLeft .aboutFeatureShot,
.aboutRightColumn .aboutFeatureShot{
  width:100% !important;
}

.aboutFamilyLeft .aboutFeatureShot{
  height:100% !important;
}

.aboutRightColumn{
  display:grid !important;
  grid-template-rows:minmax(12rem,15rem) minmax(0,1fr) !important;
  gap:.85rem !important;
}

.aboutFeatureShot{
  appearance:none !important;
  border:1px solid rgba(255,255,255,.22) !important;
  border-radius:1.15rem !important;
  background:#050505 !important;
  overflow:hidden !important;
  padding:0 !important;
  cursor:pointer !important;
}

.aboutFeatureShot img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  object-position:center !important;
  display:block !important;
}

.aboutScrollStory{
  overflow:auto !important;
  scrollbar-width:none !important;
  -ms-overflow-style:none !important;
  padding:1.2rem !important;
  border-radius:1.1rem !important;
  background:linear-gradient(135deg,rgba(255,255,255,.14),rgba(255,255,255,.05)),rgba(20,20,20,.52) !important;
  border:1px solid rgba(255,255,255,.2) !important;
  backdrop-filter:blur(16px) saturate(1.2) !important;
  -webkit-backdrop-filter:blur(16px) saturate(1.2) !important;
}

.aboutScrollStory::-webkit-scrollbar{
  width:0 !important;
  height:0 !important;
}

.aboutScrollStory h3{
  margin:0 0 .65rem !important;
  font-size:2rem !important;
}

.aboutScrollStory p{
  font-size:.92rem !important;
  line-height:1.42 !important;
  margin:0 0 .7rem !important;
}

@media(max-width:1180px){
  .footer,
  .siteFooter{
    position:relative !important;
    transform:none !important;
  }

  .footer::before,
  .siteFooter::before{
    display:none !important;
  }

  body,.site{
    padding-bottom:0 !important;
  }

  .aboutFinalLayout{
    grid-template-columns:1fr !important;
    max-height:none !important;
  }

  .modal-about .modalBody{
    overflow:auto !important;
  }

  .aboutRightColumn{
    grid-template-rows:auto auto !important;
  }

  .aboutFeatureShot img{
    height:auto !important;
  }

  .aboutScrollStory{
    max-height:none !important;
  }
}


/* =========================================================
   ABOUT CLEAN FINAL: NO BLACK TOP BAR + UNIFIED RIGHT CARD
   ========================================================= */

.modal-about,
dialog.modal.modal-about{
  width:min(96vw,104rem) !important;
  max-height:calc(100dvh - 1rem) !important;
}

.modal-about .modalBody{
  overflow:hidden !important;
  padding:clamp(.9rem,1.35vw,1.35rem) !important;
}

.aboutCleanedLayout{
  display:grid !important;
  grid-template-columns:minmax(34rem,1.05fr) minmax(30rem,.95fr) !important;
  gap:clamp(.9rem,1.4vw,1.35rem) !important;
  align-items:stretch !important;
  max-height:calc(100dvh - 8rem) !important;
  min-height:0 !important;
  overflow:hidden !important;
}

.aboutFamilyLeft{
  min-height:0 !important;
  height:100% !important;
  display:block !important;
}

.familyCleanShot{
  width:100% !important;
  height:100% !important;
  min-height:0 !important;
  display:block !important;
  background:#050505 !important;
  border-radius:1.2rem !important;
  overflow:hidden !important;
  padding:0 !important;
  border:1px solid rgba(255,255,255,.22) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14), 0 1.2rem 3rem rgba(0,0,0,.34) !important;
}

.familyCleanShot img{
  width:100% !important;
  height:100% !important;
  display:block !important;
  object-fit:cover !important;
  object-position:center top !important;
  background:#050505 !important;
}

/* Right side is now ONE bubble/card containing the clipping and scroll text */
.aboutRightUnifiedCard{
  min-height:0 !important;
  height:100% !important;
  display:grid !important;
  grid-template-rows:auto minmax(0,1fr) !important;
  gap:.85rem !important;
  overflow:hidden !important;
  padding:clamp(1rem,1.45vw,1.45rem) !important;
  border-radius:1.2rem !important;
  background:linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,.05)),rgba(20,20,20,.52) !important;
  border:1px solid rgba(255,255,255,.24) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.24),0 1.2rem 3rem rgba(0,0,0,.34) !important;
  backdrop-filter:blur(18px) saturate(1.28) !important;
  -webkit-backdrop-filter:blur(18px) saturate(1.28) !important;
}

.fatherInlineShot{
  width:100% !important;
  height:clamp(10rem,22dvh,15rem) !important;
  min-height:0 !important;
  display:block !important;
  background:#050505 !important;
  border-radius:.9rem !important;
  overflow:hidden !important;
  padding:0 !important;
  border:1px solid rgba(255,255,255,.18) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12), 0 .75rem 1.7rem rgba(0,0,0,.25) !important;
}

.fatherInlineShot img{
  width:100% !important;
  height:100% !important;
  display:block !important;
  object-fit:contain !important;
  object-position:center !important;
  background:#050505 !important;
}

.aboutUnifiedText{
  min-height:0 !important;
  height:100% !important;
  overflow:auto !important;
  scrollbar-width:none !important;
  -ms-overflow-style:none !important;
  padding:.1rem .2rem .25rem !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}

.aboutUnifiedText::-webkit-scrollbar{
  width:0 !important;
  height:0 !important;
}

.aboutUnifiedText h3{
  margin:0 0 .65rem !important;
  font-size:clamp(1.8rem,2.2vw,2.65rem) !important;
  line-height:1.03 !important;
}

.aboutUnifiedText p{
  margin:0 0 .75rem !important;
  font-size:clamp(.9rem,.92vw,1.02rem) !important;
  line-height:1.43 !important;
}

@media(max-height:850px) and (min-width:1000px){
  .aboutCleanedLayout{
    max-height:calc(100dvh - 7.2rem) !important;
  }

  .fatherInlineShot{
    height:clamp(8.5rem,19dvh,12rem) !important;
  }

  .aboutUnifiedText h3{
    font-size:clamp(1.55rem,1.9vw,2.2rem) !important;
  }

  .aboutUnifiedText p{
    font-size:clamp(.78rem,.82vw,.92rem) !important;
    line-height:1.34 !important;
    margin-bottom:.58rem !important;
  }
}

@media(max-width:1180px){
  .aboutCleanedLayout{
    grid-template-columns:1fr !important;
    max-height:none !important;
    overflow:visible !important;
  }

  .modal-about .modalBody{
    overflow:auto !important;
    max-height:calc(94dvh - 5.25rem) !important;
  }

  .familyCleanShot{
    height:auto !important;
  }

  .familyCleanShot img{
    height:auto !important;
    max-height:48dvh !important;
    object-fit:contain !important;
  }

  .aboutRightUnifiedCard{
    height:auto !important;
    overflow:visible !important;
  }

  .fatherInlineShot{
    height:auto !important;
  }

  .fatherInlineShot img{
    height:auto !important;
    max-height:18rem !important;
  }

  .aboutUnifiedText{
    overflow:visible !important;
  }
}


/* =========================================================
   ABOUT FINAL IMAGE EXPANSION - REMOVE BLACK / ENLARGE CURTIS
   ========================================================= */

.fatherInlineShot{
  width:100% !important;
  height:clamp(13rem,26dvh,18rem) !important;
  background:transparent !important;
  border-radius:.9rem !important;
  overflow:hidden !important;
  padding:0 !important;
  border:1px solid rgba(255,255,255,.14) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 .75rem 1.5rem rgba(0,0,0,.20) !important;
}

.fatherInlineShot img{
  width:100% !important;
  height:100% !important;
  display:block !important;
  object-fit:cover !important;
  object-position:center center !important;
  background:transparent !important;
}

.aboutRightUnifiedCard{
  padding:clamp(.8rem,1.2vw,1.15rem) !important;
  gap:.7rem !important;
}

@media(max-height:850px) and (min-width:1000px){
  .fatherInlineShot{
    height:clamp(11rem,22dvh,14rem) !important;
  }
}

/* =========================================================
   ABOUT TIMED GALLERY + TEXT RIGHT
   ========================================================= */
.aboutGalleryStoryLayout{
  display:grid !important;
  grid-template-columns:minmax(35rem,1.08fr) minmax(30rem,.92fr) !important;
  gap:clamp(1rem,1.45vw,1.5rem) !important;
  align-items:stretch !important;
  max-height:calc(100dvh - 8rem) !important;
  min-height:0 !important;
  overflow:hidden !important;
}

.aboutTimedGallery{
  position:relative !important;
  min-height:0 !important;
  height:100% !important;
  overflow:hidden !important;
  border-radius:1.25rem !important;
  background:#050505 !important;
  border:1px solid rgba(255,255,255,.22) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 1.2rem 3rem rgba(0,0,0,.36) !important;
}

.aboutGalleryImage{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  border:0 !important;
  padding:0 !important;
  margin:0 !important;
  opacity:0 !important;
  pointer-events:none !important;
  transform:scale(1.015) !important;
  transition:opacity .55s ease, transform 1.1s ease !important;
  background:#050505 !important;
  cursor:pointer !important;
}

.aboutGalleryImage.active{
  opacity:1 !important;
  pointer-events:auto !important;
  transform:scale(1) !important;
}

.aboutGalleryImage img{
  width:100% !important;
  height:100% !important;
  display:block !important;
  object-fit:contain !important;
  object-position:center !important;
  background:#050505 !important;
}

.aboutGalleryDots{
  position:absolute !important;
  left:50% !important;
  bottom:.8rem !important;
  transform:translateX(-50%) !important;
  z-index:5 !important;
  display:flex !important;
  gap:.45rem !important;
  padding:.35rem .55rem !important;
  border-radius:999px !important;
  background:rgba(0,0,0,.48) !important;
  border:1px solid rgba(255,255,255,.16) !important;
  backdrop-filter:blur(8px) !important;
  -webkit-backdrop-filter:blur(8px) !important;
}

.aboutGalleryDots button{
  width:.65rem !important;
  height:.65rem !important;
  min-width:.65rem !important;
  min-height:.65rem !important;
  border-radius:999px !important;
  border:1px solid rgba(255,255,255,.35) !important;
  background:rgba(255,255,255,.35) !important;
  padding:0 !important;
}

.aboutGalleryDots button.active{
  background:#ff3035 !important;
  border-color:#ff3035 !important;
  box-shadow:0 0 .75rem rgba(255,48,53,.55) !important;
}

.aboutStoryRight{
  height:100% !important;
  min-height:0 !important;
  overflow:hidden !important;
  display:flex !important;
  flex-direction:column !important;
  padding:clamp(1.15rem,1.65vw,1.85rem) !important;
  border-radius:1.25rem !important;
  background:
    linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,.05)),
    rgba(20,20,20,.55) !important;
  border:1px solid rgba(255,255,255,.24) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.24),0 1.2rem 3rem rgba(0,0,0,.34) !important;
  backdrop-filter:blur(18px) saturate(1.25) !important;
  -webkit-backdrop-filter:blur(18px) saturate(1.25) !important;
}

.aboutStoryRight .articleKicker{
  width:max-content !important;
  max-width:100% !important;
  margin:0 0 .6rem !important;
  padding:.28rem .58rem !important;
  border-radius:999px !important;
  background:rgba(231,43,49,.18) !important;
  border:1px solid rgba(231,43,49,.36) !important;
  color:#ff454b !important;
  font-size:.72rem !important;
  line-height:1 !important;
  font-weight:900 !important;
  letter-spacing:.11em !important;
  text-transform:uppercase !important;
}

.aboutStoryRight h3{
  margin:0 0 .7rem !important;
  font-family:Georgia,"Times New Roman",serif !important;
  font-size:clamp(1.9rem,2.3vw,3rem) !important;
  line-height:1.02 !important;
  letter-spacing:-.035em !important;
  color:#fff !important;
  border-bottom:1px solid rgba(255,255,255,.18) !important;
  padding-bottom:.55rem !important;
}

.aboutStoryScroll{
  min-height:0 !important;
  overflow:auto !important;
  scrollbar-width:none !important;
  -ms-overflow-style:none !important;
  padding-right:.25rem !important;
}

.aboutStoryScroll::-webkit-scrollbar{
  width:0 !important;
  height:0 !important;
}

.aboutStoryScroll p{
  font-family:Georgia,"Times New Roman",serif !important;
  font-size:clamp(.9rem,.92vw,1.02rem) !important;
  line-height:1.48 !important;
  margin:0 0 .78rem !important;
  color:rgba(255,255,255,.91) !important;
}

.aboutStoryScroll p:first-child::first-letter{
  float:left !important;
  font-size:2.9em !important;
  line-height:.82 !important;
  padding-right:.35rem !important;
  font-weight:900 !important;
  color:#ff3b40 !important;
}

@media(max-height:850px) and (min-width:1000px){
  .aboutGalleryStoryLayout{max-height:calc(100dvh - 7.2rem) !important;}
  .aboutStoryRight{padding:1rem !important;}
  .aboutStoryRight h3{font-size:clamp(1.55rem,1.9vw,2.25rem) !important;margin-bottom:.5rem !important;}
  .aboutStoryScroll p{font-size:clamp(.78rem,.82vw,.92rem) !important;line-height:1.36 !important;margin-bottom:.55rem !important;}
}

@media(max-width:1180px){
  .aboutGalleryStoryLayout{
    grid-template-columns:1fr !important;
    max-height:none !important;
    overflow:visible !important;
  }
  .modal-about .modalBody{
    overflow:auto !important;
    max-height:calc(94dvh - 5.25rem) !important;
  }
  .aboutTimedGallery{
    height:clamp(20rem,48dvh,34rem) !important;
  }
  .aboutStoryRight{
    height:auto !important;
    overflow:visible !important;
  }
  .aboutStoryScroll{
    overflow:visible !important;
  }
}
