/* ============================================================
   McDowell South RV — Inventory listing + Product detail
   Loaded AFTER styles.css + pages.css. Reuses their tokens
   and the .unit-card component from styles.css.
   ============================================================ */

/* ===========================================================
   LISTING (Search Results) PAGE
   =========================================================== */
.inv-toolbar{
  display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  padding:18px 0;border-bottom:1px solid var(--line);
}
.inv-count{font-family:var(--sans);color:var(--muted);font-size:.98rem;}
.inv-count b{font-family:var(--serif);font-weight:800;color:var(--blue);font-size:1.25rem;}
.inv-toolbar-right{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.inv-sort{position:relative;}
.inv-sort label{font-family:var(--cond);text-transform:uppercase;letter-spacing:.07em;font-size:.72rem;color:var(--muted);font-weight:600;margin-right:8px;}
.inv-sort select{
  font-family:var(--sans);font-weight:600;font-size:.92rem;color:var(--ink);background:#fff;
  border:1.5px solid var(--line);border-radius:10px;padding:10px 36px 10px 14px;appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236A7180' stroke-width='2.5'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
}
.inv-sort select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,35,153,.12);}
.filter-open-btn{display:none;}

.inv-layout{display:grid;grid-template-columns:286px 1fr;gap:clamp(24px,3vw,40px);align-items:start;margin-top:28px;}

/* ---- filter rail ---- */
.filters{position:sticky;top:96px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;}
.filters-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line);}
.filters-head h3{font-size:1.1rem;}
.filters-head button{font-family:var(--cond);text-transform:uppercase;letter-spacing:.05em;font-size:.74rem;font-weight:600;color:var(--blue);}
.filters-head button:hover{color:var(--blue-dark);text-decoration:underline;}
.filters-close{display:none;}
.filter-group{padding:18px 20px;border-bottom:1px solid var(--line);}
.filter-group:last-child{border-bottom:none;}
.filter-group > h4{font-family:var(--cond);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;color:var(--ink);font-weight:600;margin-bottom:14px;}
.cond-seg{display:flex;gap:6px;}
.cond-seg button{flex:1;padding:9px 0;border-radius:9px;border:1.5px solid var(--line);background:#fff;font-family:var(--cond);font-weight:600;font-size:.82rem;color:var(--ink);transition:.14s;text-transform:uppercase;letter-spacing:.03em;}
.cond-seg button:hover{border-color:var(--blue);color:var(--blue);}
.cond-seg button.on{background:var(--blue);border-color:var(--blue);color:#fff;}
.fcheck{display:flex;align-items:center;gap:11px;padding:7px 0;cursor:pointer;font-size:.94rem;color:var(--ink);font-weight:500;}
.fcheck input{width:18px;height:18px;accent-color:var(--blue);flex-shrink:0;cursor:pointer;}
.fcheck .ct{margin-left:auto;font-family:var(--cond);font-size:.78rem;color:var(--muted);font-weight:600;}
.fcheck:hover{color:var(--blue);}
.range-val{font-family:var(--serif);font-weight:800;color:var(--blue);font-size:1.05rem;float:right;}
.frange{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:var(--tint);outline:none;margin:6px 0 2px;}
.frange::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:var(--blue);border:3px solid #fff;box-shadow:0 2px 6px rgba(0,17,74,.35);cursor:pointer;}
.frange::-moz-range-thumb{width:20px;height:20px;border:3px solid #fff;border-radius:50%;background:var(--blue);box-shadow:0 2px 6px rgba(0,17,74,.35);cursor:pointer;}
.frange-scale{display:flex;justify-content:space-between;font-size:.72rem;color:var(--muted);margin-top:6px;}
.sleeps-seg{display:flex;gap:6px;}
.sleeps-seg button{flex:1;padding:9px 0;border-radius:9px;border:1.5px solid var(--line);background:#fff;font-family:var(--cond);font-weight:600;font-size:.86rem;color:var(--ink);transition:.14s;}
.sleeps-seg button:hover{border-color:var(--blue);color:var(--blue);}
.sleeps-seg button.on{background:var(--blue);border-color:var(--blue);color:#fff;}

/* ---- results grid (reuses .unit-card from styles.css) ---- */
.inv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.inv-grid .unit-card{flex:initial;width:auto;}
.filter-scrim{display:none;}
.save-badge{white-space:nowrap;}
.inv-empty{grid-column:1/-1;text-align:center;padding:70px 20px;color:var(--muted);}
.inv-empty svg{width:54px;height:54px;color:var(--line);margin-bottom:16px;}
.inv-empty h3{font-size:1.4rem;color:var(--ink);margin-bottom:8px;}
.inv-empty p{max-width:42ch;margin:0 auto 20px;}

@media(max-width:1100px){
  .inv-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:980px){
  .inv-layout{grid-template-columns:1fr;}
  .filter-open-btn{display:inline-flex;}
  .filters{
    position:fixed;inset:0 auto 0 0;width:min(86vw,360px);z-index:120;border-radius:0;
    transform:translateX(-100%);transition:transform .25s ease;box-shadow:10px 0 40px rgba(0,0,0,.25);
    max-height:100vh;overflow-y:auto;
  }
  .filters.open{transform:translateX(0);}
  .filters-close{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:8px;color:var(--muted);}
  .filters-close:hover{background:var(--tint-2);color:var(--ink);}
  .filter-scrim{display:block;position:fixed;inset:0;background:rgba(8,12,28,.45);z-index:110;opacity:0;visibility:hidden;transition:.2s;}
  .filter-scrim.show{opacity:1;visibility:visible;}
}
@media(max-width:560px){
  .inv-grid{grid-template-columns:1fr;}
}

/* ===========================================================
   PRODUCT DETAIL PAGE
   =========================================================== */
.pd-resultnav{background:var(--tint-2);border-bottom:1px solid var(--line);}
.pd-resultnav .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:54px;flex-wrap:wrap;}
.pd-back{display:inline-flex;align-items:center;gap:8px;font-family:var(--cond);text-transform:uppercase;letter-spacing:.05em;font-weight:600;font-size:.82rem;color:var(--blue);}
.pd-back svg{width:16px;height:16px;}
.pd-back:hover{color:var(--blue-dark);}
.pd-pager{display:flex;align-items:center;gap:6px;}
.pd-pager a{display:inline-flex;align-items:center;gap:6px;font-family:var(--cond);text-transform:uppercase;letter-spacing:.04em;font-weight:600;font-size:.78rem;color:var(--muted);padding:7px 13px;border-radius:8px;border:1.5px solid var(--line);background:#fff;transition:.14s;}
.pd-pager a:hover{border-color:var(--blue);color:var(--blue);}
.pd-pager a.disabled{opacity:.4;pointer-events:none;}
.pd-pager svg{width:14px;height:14px;}

/* title block */
.pd-head{padding:26px 0 8px;}
.pd-head .breadcrumb a,.pd-head .breadcrumb .sep{color:var(--muted);}
.pd-head .breadcrumb a:hover{color:var(--blue);}
.pd-head .breadcrumb{margin-bottom:14px;}
.pd-titlerow{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.pd-type{font-family:var(--cond);text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;color:var(--accent-dark);font-weight:600;}
.pd-title{font-family:var(--serif);font-weight:800;font-size:clamp(1.7rem,3vw,2.5rem);line-height:1.08;color:var(--ink);margin-top:6px;letter-spacing:-.01em;}
.pd-meta{display:flex;flex-wrap:wrap;gap:10px 20px;margin-top:12px;font-size:.92rem;color:var(--muted);}
.pd-meta span{display:inline-flex;align-items:center;gap:7px;}
.pd-meta svg{width:16px;height:16px;color:var(--blue);}
.pd-meta .stocknum{font-weight:700;color:var(--ink);}
.pd-share{display:flex;gap:8px;flex-shrink:0;}
.pd-iconbtn{width:42px;height:42px;border-radius:11px;border:1.5px solid var(--line);background:#fff;display:grid;place-items:center;color:var(--muted);transition:.15s;}
.pd-iconbtn svg{width:20px;height:20px;}
.pd-iconbtn:hover{border-color:var(--blue);color:var(--blue);}
.pd-iconbtn.fav.on{background:#fdeef0;border-color:#e3577a;color:#e3577a;}
.pd-iconbtn.fav.on svg{fill:#e3577a;}
.pd-sharewrap{position:relative;}
.pd-sharemenu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:7px;min-width:188px;z-index:30;display:none;}
.pd-sharemenu.open{display:block;animation:ddPop .15s ease;}
.pd-sharemenu a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;font-size:.92rem;font-weight:500;color:var(--ink);}
.pd-sharemenu a:hover{background:var(--tint-2);color:var(--blue);}
.pd-sharemenu svg{width:17px;height:17px;color:var(--muted);}
.pd-sharemenu a:hover svg{color:var(--blue);}

/* anchor nav */
.pd-anchornav{position:sticky;top:74px;z-index:40;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:18px;}
.pd-anchornav .wrap{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;}
.pd-anchornav .wrap::-webkit-scrollbar{display:none;}
.pd-anchornav a{font-family:var(--cond);text-transform:uppercase;letter-spacing:.05em;font-weight:600;font-size:.82rem;color:var(--muted);padding:15px 16px;border-bottom:3px solid transparent;white-space:nowrap;transition:.14s;}
.pd-anchornav a:hover{color:var(--blue);}
.pd-anchornav a.active{color:var(--blue);border-bottom-color:var(--accent);}

/* main two-column grid */
.pd-main{padding:30px 0 10px;}
.pd-grid{display:grid;grid-template-columns:1.55fr 1fr;gap:clamp(26px,3.5vw,52px);align-items:start;}
@media(max-width:980px){.pd-grid{grid-template-columns:1fr;}}

/* gallery */
.pd-gallery{position:relative;}
.pd-stage{position:relative;border-radius:var(--radius);overflow:hidden;background:#16235a;aspect-ratio:4/3;box-shadow:var(--shadow-sm);cursor:zoom-in;}
.pd-stage img,.pd-stage .ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.pd-stage .badge-row{position:absolute;top:14px;left:14px;right:14px;display:flex;justify-content:space-between;align-items:flex-start;gap:10px;z-index:3;}
.pd-stage .count-pill{position:absolute;bottom:14px;left:14px;background:rgba(0,0,0,.6);color:#fff;font-size:.8rem;font-weight:600;padding:6px 12px;border-radius:7px;display:inline-flex;align-items:center;gap:6px;z-index:3;}
.pd-stage .count-pill svg{width:15px;height:15px;}
.pd-stage .tour-pill{position:absolute;bottom:14px;right:14px;background:rgba(255,255,255,.94);color:var(--blue);font-family:var(--cond);font-weight:700;font-size:.78rem;letter-spacing:.03em;padding:7px 13px;border-radius:7px;z-index:3;display:inline-flex;align-items:center;gap:7px;}
.pd-stage .tour-pill svg{width:15px;height:15px;}
.pd-stage .gnav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.92);box-shadow:var(--shadow-sm);display:grid;place-items:center;color:var(--blue);z-index:4;transition:.14s;}
.pd-stage .gnav:hover{background:#fff;}
.pd-stage .gnav.prev{left:12px;}
.pd-stage .gnav.next{right:12px;}
.pd-stage .gnav svg{width:22px;height:22px;}
.pd-thumbs{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-top:10px;}
.pd-thumb{position:relative;aspect-ratio:4/3;border-radius:8px;overflow:hidden;background:#16235a;cursor:pointer;border:2px solid transparent;transition:.14s;}
.pd-thumb img,.pd-thumb .ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.pd-thumb.on{border-color:var(--blue);}
.pd-thumb .more{position:absolute;inset:0;background:rgba(0,17,74,.72);color:#fff;display:grid;place-items:center;font-family:var(--cond);font-weight:700;font-size:.92rem;}
.pd-thumb .ph .ph-label{font-size:.56rem;padding:3px 5px;}

/* lightbox */
.pd-lightbox{position:fixed;inset:0;background:rgba(6,10,22,.92);z-index:200;display:none;align-items:center;justify-content:center;flex-direction:column;padding:30px;}
.pd-lightbox.open{display:flex;}
.pd-lightbox img{max-width:92vw;max-height:80vh;border-radius:10px;object-fit:contain;}
.pd-lightbox .lb-ph{width:min(92vw,1024px);aspect-ratio:4/3;border-radius:10px;}
.pd-lightbox .lb-close{position:absolute;top:22px;right:26px;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;display:grid;place-items:center;}
.pd-lightbox .lb-close:hover{background:rgba(255,255,255,.26);}
.pd-lightbox .lb-close svg{width:24px;height:24px;}
.pd-lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;display:grid;place-items:center;}
.pd-lightbox .lb-nav:hover{background:rgba(255,255,255,.26);}
.pd-lightbox .lb-nav.prev{left:24px;}
.pd-lightbox .lb-nav.next{right:24px;}
.pd-lightbox .lb-nav svg{width:26px;height:26px;}
.pd-lightbox .lb-count{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.85);font-size:.9rem;font-weight:600;}

/* ---- buy box (right column) ---- */
.pd-buybox{position:sticky;top:140px;display:flex;flex-direction:column;gap:16px;}
.buy-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:24px;}
.buy-price .lbl{font-family:var(--cond);text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;color:var(--muted);font-weight:600;}
.buy-price .sale{font-family:var(--serif);font-weight:800;font-size:2.6rem;color:var(--blue);line-height:1;margin-top:2px;}
.buy-price .callprice{font-family:var(--serif);font-weight:800;font-size:1.9rem;color:var(--blue);line-height:1.1;margin-top:2px;}
.buy-price .msrp-row{display:flex;align-items:baseline;gap:12px;margin-top:10px;flex-wrap:wrap;}
.buy-price .msrp-row s{color:var(--muted);font-size:1rem;}
.buy-price .save-tag{background:var(--accent);color:#3a2600;font-family:var(--cond);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;padding:5px 11px;border-radius:7px;white-space:nowrap;}
.buy-finance{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);font-size:.92rem;color:var(--muted);}
.buy-finance b{color:var(--ink);font-family:var(--serif);font-size:1.15rem;}
.buy-cta{display:flex;flex-direction:column;gap:10px;margin-top:18px;}
.buy-cta .btn{width:100%;}
.buy-disclaimer{font-size:.74rem;color:var(--muted);line-height:1.5;margin-top:14px;}

.quickspec{background:var(--tint-2);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;}
.quickspec h4{font-family:var(--cond);text-transform:uppercase;letter-spacing:.08em;font-size:.76rem;color:var(--ink);font-weight:600;margin-bottom:14px;}
.quickspec-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.quickspec-grid .qs{display:flex;align-items:center;gap:11px;}
.qs .qs-ic{width:38px;height:38px;border-radius:10px;background:#fff;border:1px solid var(--line);color:var(--blue);display:grid;place-items:center;flex-shrink:0;}
.qs .qs-ic svg{width:19px;height:19px;}
.qs .qs-v{font-family:var(--serif);font-weight:800;font-size:1.05rem;color:var(--ink);line-height:1;}
.qs .qs-k{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600;margin-top:3px;}

.expert-card{background:var(--blue);color:#fff;border-radius:var(--radius);padding:22px 24px;}
.expert-card h4{color:#fff;font-family:var(--serif);font-size:1.2rem;margin-bottom:6px;}
.expert-card p{color:rgba(255,255,255,.82);font-size:.9rem;line-height:1.55;margin-bottom:16px;}
.expert-card .ec-contact{display:flex;flex-direction:column;gap:10px;}
.expert-card .ec-contact a{display:inline-flex;align-items:center;gap:10px;color:#fff;font-weight:600;font-size:.98rem;}
.expert-card .ec-contact a svg{width:18px;height:18px;color:var(--accent);}

/* ---- content sections ---- */
.pd-section{padding:34px 0;border-top:1px solid var(--line);scroll-margin-top:130px;}
.pd-section > h2{font-size:clamp(1.5rem,2.4vw,2rem);margin-bottom:6px;}
.pd-section .sec-sub{color:var(--muted);margin-bottom:24px;}

/* floorplan */
.fp-wrap{display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:center;}
@media(max-width:760px){.fp-wrap{grid-template-columns:1fr;}}
.fp-img{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);}
.fp-img img{width:100%;height:auto;}
.fp-side .brandlogo{height:42px;width:auto;margin-bottom:18px;}
.fp-side h3{margin-bottom:8px;}
.fp-side p{color:var(--muted);margin-bottom:20px;}
.fp-actions{display:flex;flex-direction:column;gap:10px;align-items:flex-start;}

/* specs table */
.spec-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);}
.spec-table td{padding:13px 18px;border-bottom:1px solid var(--line);font-size:.95rem;}
.spec-table tr td:first-child{font-family:var(--cond);text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;color:var(--muted);font-weight:600;width:46%;background:var(--tint-2);}
.spec-table tr td:last-child{font-weight:600;color:var(--ink);}
.spec-cols{columns:2;column-gap:24px;}
@media(max-width:680px){.spec-cols{columns:1;}}
.spec-cols .spec-table{break-inside:avoid;margin-bottom:0;}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 24px;}
@media(max-width:680px){.spec-grid{grid-template-columns:1fr;}}
.spec-grid .srow{display:flex;justify-content:space-between;gap:16px;padding:12px 2px;border-bottom:1px solid var(--line);}
.spec-grid .srow .sk{font-family:var(--cond);text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;color:var(--muted);font-weight:600;}
.spec-grid .srow .sv{font-weight:600;color:var(--ink);font-size:.95rem;text-align:right;}
.spec-note{background:var(--tint);border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:10px;padding:16px 20px;color:var(--muted);font-size:.92rem;line-height:1.6;}

/* description */
.desc-highlights{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 24px;margin-bottom:26px;}
@media(max-width:560px){.desc-highlights{grid-template-columns:1fr;}}
.desc-highlights .dh{display:flex;align-items:center;gap:12px;font-weight:600;color:var(--ink);}
.desc-highlights .dh .check{width:26px;height:26px;border-radius:8px;background:var(--tint);color:var(--blue);display:grid;place-items:center;flex-shrink:0;}
.desc-highlights .dh .check svg{width:15px;height:15px;}
.desc-prose p{color:var(--ink);font-size:1.04rem;line-height:1.75;margin-bottom:16px;}
.desc-prose.clamped p:nth-child(n+2){display:none;}
.readmore-btn{font-family:var(--cond);text-transform:uppercase;letter-spacing:.05em;font-weight:600;font-size:.82rem;color:var(--blue);display:inline-flex;align-items:center;gap:7px;}
.readmore-btn svg{width:15px;height:15px;transition:transform .18s;}
.readmore-btn.open svg{transform:rotate(180deg);}

/* features & options */
.feat-cats{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
@media(max-width:760px){.feat-cats{grid-template-columns:1fr;}}
.feat-cat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;}
.feat-cat summary{list-style:none;cursor:pointer;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:14px;font-family:var(--serif);font-weight:700;font-size:1.05rem;color:var(--ink);}
.feat-cat summary::-webkit-details-marker{display:none;}
.feat-cat summary .badge{margin-left:auto;font-family:var(--cond);font-size:.72rem;color:var(--muted);font-weight:600;background:var(--tint-2);padding:3px 9px;border-radius:999px;}
.feat-cat summary .chev{width:20px;height:20px;color:var(--muted);transition:transform .2s;flex-shrink:0;}
.feat-cat[open] summary .chev{transform:rotate(180deg);}
.feat-cat .fc-body{padding:0 20px 18px;}
.feat-cat ul{list-style:none;padding:0;margin:0;columns:1;}
.feat-cat li{position:relative;padding:6px 0 6px 22px;font-size:.92rem;color:var(--ink);line-height:1.5;}
.feat-cat li::before{content:"";position:absolute;left:2px;top:13px;width:7px;height:7px;border-radius:50%;background:var(--accent);}
.pkg-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:16px;}
@media(max-width:760px){.pkg-grid{grid-template-columns:1fr;}}
.pkg-card{border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;background:linear-gradient(180deg,#fff,var(--tint-2));}
.pkg-card h4{font-family:var(--serif);font-size:1.08rem;color:var(--blue-dark);margin-bottom:6px;}
.pkg-card p{font-size:.9rem;color:var(--muted);line-height:1.55;}
.pkg-card .req{display:inline-block;font-family:var(--cond);text-transform:uppercase;letter-spacing:.05em;font-size:.68rem;font-weight:600;color:var(--accent-dark);background:#fdf2e0;padding:2px 8px;border-radius:999px;margin-left:8px;vertical-align:middle;}

/* payment calculator */
.calc-wrap{display:grid;grid-template-columns:1fr 360px;gap:32px;align-items:start;}
@media(max-width:840px){.calc-wrap{grid-template-columns:1fr;}}
.calc-fields{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
@media(max-width:560px){.calc-fields{grid-template-columns:1fr;}}
.calc-field label{font-family:var(--cond);text-transform:uppercase;letter-spacing:.06em;font-size:.74rem;color:var(--muted);font-weight:600;display:flex;justify-content:space-between;margin-bottom:7px;}
.calc-field label .v{font-family:var(--serif);color:var(--blue);font-weight:800;letter-spacing:0;text-transform:none;font-size:1.02rem;}
.calc-field input[type=number],.calc-field input[type=text]{font-family:var(--sans);font-size:1rem;color:var(--ink);background:var(--tint-2);border:1.5px solid var(--line);border-radius:10px;padding:11px 14px;width:100%;outline:none;transition:.15s;}
.calc-field input:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(0,35,153,.12);}
.calc-field .frange{margin-top:8px;}
.calc-result{background:var(--blue);color:#fff;border-radius:var(--radius);padding:28px 26px;text-align:center;box-shadow:var(--shadow-md);}
.calc-result .lbl{font-family:var(--cond);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;color:rgba(255,255,255,.75);font-weight:600;}
.calc-result .mo{font-family:var(--serif);font-weight:800;font-size:3.2rem;line-height:1;margin:6px 0;}
.calc-result .mo small{font-size:1.1rem;font-weight:600;opacity:.8;}
.calc-result .terms{font-size:.84rem;color:rgba(255,255,255,.8);margin-top:8px;line-height:1.5;}
.calc-result .btn{margin-top:18px;width:100%;}
.calc-result .calc-disc{font-size:.72rem;color:rgba(255,255,255,.6);margin-top:14px;line-height:1.5;}

/* similar */
.similar-track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:12px;scrollbar-width:none;}
.similar-track::-webkit-scrollbar{display:none;}

/* ---- modal (lead-gen) ---- */
.pd-modal{position:fixed;inset:0;background:rgba(8,12,28,.55);z-index:210;display:none;align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(3px);}
.pd-modal.open{display:flex;animation:fsIn .2s ease;}
.pd-modal .modal-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);width:min(520px,100%);max-height:90vh;overflow-y:auto;}
.pd-modal .modal-head{padding:24px 28px 0;position:relative;}
.pd-modal .modal-head .eyebrow{display:block;margin-bottom:6px;}
.pd-modal .modal-head h3{font-size:1.5rem;}
.pd-modal .modal-head p{color:var(--muted);font-size:.94rem;margin-top:8px;}
.pd-modal .modal-close{position:absolute;top:18px;right:20px;width:36px;height:36px;border-radius:9px;color:var(--muted);display:grid;place-items:center;}
.pd-modal .modal-close:hover{background:var(--tint-2);color:var(--ink);}
.pd-modal .modal-close svg{width:22px;height:22px;}
.pd-modal .modal-body{padding:22px 28px 28px;}
.pd-modal .modal-unit{display:flex;align-items:center;gap:13px;background:var(--tint-2);border:1px solid var(--line);border-radius:11px;padding:12px 14px;margin-bottom:20px;}
.pd-modal .modal-unit .mu-ph{width:64px;height:48px;border-radius:7px;overflow:hidden;background:#16235a;flex-shrink:0;}
.pd-modal .modal-unit .mu-ph img,.pd-modal .modal-unit .mu-ph .ph{width:100%;height:100%;object-fit:cover;}
.pd-modal .modal-unit .mu-t{font-family:var(--serif);font-weight:700;font-size:.98rem;line-height:1.2;}
.pd-modal .modal-unit .mu-s{font-size:.8rem;color:var(--muted);margin-top:3px;}

@media(max-width:980px){
  .pd-buybox{position:static;}
}
