/* Catalog */
body{
  background-color: var(--gp-cream);
  background-image: none;
}

main,
section,
.hero{
  background: transparent;
}

.catalogLayout{
  grid-template-columns:minmax(220px, 270px) minmax(0, 1fr);
  gap:16px;
}

.catalogResultsPane .searchResultsHead{
  margin-top:0;
}

.catalogHeroGrid{
  align-items:stretch;
}

.catalogHeroMainCard,
.catalogHeroLeadCard{
  height:100%;
}

.catalogHeroSegmentsCard{
  grid-column:1 / -1;
}

.catalogHeroLeadCard{
  border:1px solid rgba(32,39,66,.18);
  background:
    radial-gradient(140% 130% at 100% 0%, rgba(179,138,100,.18), rgba(179,138,100,0) 58%),
    linear-gradient(160deg, rgba(255,255,255,.93), rgba(246,244,240,.98));
  box-shadow:0 18px 38px rgba(16,22,39,.12);
}

.catalogHeroLeadEyebrow{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(179,138,100,.4);
  background:rgba(255,255,255,.84);
  color:rgba(32,39,66,.8);
  font-size:12px;
  font-weight:600;
  letter-spacing:.02em;
}

.catalogHeroLeadCard h3{
  margin-top:10px;
  color:var(--gp-ocean);
  font-size:clamp(28px, 2vw, 36px);
  line-height:1.18;
}

.catalogHeroLeadCard .muted{
  color:rgba(32,39,66,.82);
  font-size:clamp(16px, 1.06vw, 19px);
  line-height:1.45;
}

.catalogHeroLeadList{
  margin:12px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:8px;
}

.catalogHeroLeadList li{
  position:relative;
  padding-left:20px;
  color:rgba(32,39,66,.86);
  font-size:15px;
  line-height:1.38;
}

.catalogHeroLeadList li::before{
  content:"";
  position:absolute;
  left:0;
  top:.42em;
  width:8px;
  height:8px;
  border-radius:50%;
  background:rgba(179,138,100,.95);
  box-shadow:0 0 0 3px rgba(179,138,100,.2);
}

.catalogHeroLeadActions .btn{
  min-height:46px;
  padding:12px 18px;
  font-size:16px;
}

.catalogHeroLeadNote{
  margin:10px 0 0;
  color:rgba(32,39,66,.65);
  font-size:13px;
  line-height:1.35;
}

.catalogFiltersPane.searchWrap{
  position:static;
  top:auto;
}

.catalogMobileStickyBar{
  display:none;
}

.catalogMobileSheetBackdrop{
  display:none;
}

.catalogMobileSheetHead{
  display:none;
}

.catalogMobileSheetCta{
  display:none;
}

.catalogMobileFiltersBtn,
.catalogMobileQuickBtn{
  appearance:none;
  border:1px solid rgba(32,39,66,.2);
  background:rgba(255,255,255,.92);
  color:rgba(32,39,66,.94);
  border-radius:12px;
  min-height:40px;
  padding:8px 10px;
  font:inherit;
  font-size:14px;
  font-weight:600;
  line-height:1.2;
}

.catalogMobileQuickBtn{
  width:100%;
  text-align:left;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.catalogMobileFiltersBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}

.catalogMobileFiltersIcon{
  width:14px;
  height:14px;
  stroke:currentColor;
  fill:none;
  stroke-width:1.8;
  stroke-linecap:round;
}

.catalogResultsList .listingPrice{
  font-size:clamp(24px, 1.8vw, 34px);
  line-height:1.02;
}

.catalogResultsList .listingPriceHint{
  font-size:14px;
}

.catalogResultsList .listingMortgage{
  font-size:13px;
}

.catalogResultsList .listingFacts{
  font-size:14px;
}

.catalogResultsList .listingAddress{
  font-size:15px;
}

.catalogResultsList[data-view="catalog_grid"]{
  grid-template-columns:repeat(4, minmax(0, 1fr));
}

.catalogResultsList[data-view="catalog_grid"] .listing{
  padding:8px;
}

.catalogResultsList[data-view="catalog_grid"] .listingTopRow{
  gap:8px;
  align-items:flex-start;
}

.catalogResultsList[data-view="catalog_grid"] .listingTopRow .favBtn{
  align-self:flex-start;
  margin-top:2px;
  background:transparent;
}

.catalogResultsList[data-view="catalog_grid"] .listingTopRow .favBtn[aria-pressed="true"]{
  background:#282D46;
}

.catalogResultsList[data-view="catalog_grid"] .listingPrice{
  font-size:clamp(18px, 1.25vw, 26px);
  white-space:nowrap;
}

.catalogResultsList[data-view="catalog_grid"] .listingPriceHint{
  font-size:12px;
}

.catalogResultsList[data-view="catalog_grid"] .listingMortgage{
  font-size:12px;
}

.catalogResultsList[data-view="catalog_grid"] .listingFacts{
  font-size:12px;
  gap:4px;
}

.catalogResultsList[data-view="catalog_grid"] .listingAddress{
  font-size:13px;
}

.catalogResultsList[data-view="catalog_grid"] .listingPhoneBtn{
  min-height:36px;
  padding:8px 10px;
  font-size:14px;
}

.catalogResultsList .listing{
  background:transparent;
  border:none !important;
  box-shadow:none;
}

.catalogResultsList[data-view="catalog_list"] .listing{
  align-items:start;
}

.catalogResultsList[data-view="catalog_list"] .listingThumb{
  aspect-ratio:1 / 1;
}

.catalogResultsList[data-view="catalog_list"] .listingBodyCompact,
.catalogResultsList[data-view="catalog_list"] .listingBodyList{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(180px, 36%) auto;
  grid-template-areas:
    "main preview fav";
  column-gap:10px;
  row-gap:10px;
  align-items:start;
}

.catalogResultsList[data-view="catalog_list"] .listingPrice{
  font-size:clamp(22px, 1.45vw, 30px);
  line-height:1.04;
}

.catalogResultsList[data-view="catalog_list"] .listingMainColumn{
  grid-area:main;
  min-width:0;
  display:grid;
  gap:10px;
}

.catalogResultsList[data-view="catalog_list"] .listingAddress{
  min-height:0;
  -webkit-line-clamp:2;
}

.catalogResultsList[data-view="catalog_list"] .listingPreviewText,
.catalogResultsList[data-view="catalog_list"] .listingPreviewCol{
  grid-area:preview;
  margin:0;
  color:rgba(32,39,66,.64);
  font-size:14px;
  line-height:1.42;
  display:-webkit-box;
  -webkit-line-clamp:6;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.catalogResultsList[data-view="catalog_list"] .listingFavCol{
  grid-area:fav;
  align-self:start;
}

.catalogResultsList[data-view="catalog_list"] .listingFavCol .favBtn{
  margin-top:2px;
}

.catalogResultsList[data-view="catalog_list"] .listingContactRow{
  display:none;
}

.catalogResultsList[data-view="catalog_list"] .listingPhoneBtn{
  display:none;
}

.catalogSplit.catalogSplit--listOnly{
  grid-template-columns:minmax(0, 1fr);
}

.catalogStateCard{
  padding:20px;
}

.catalogConversionCardWrap{
  margin:12px 0 0;
}

.catalogConversionCard{
  border:1px solid rgba(32,39,66,.14);
  background:
    radial-gradient(120% 120% at 100% 0%, rgba(179,138,100,.14), rgba(179,138,100,0) 62%),
    rgba(255,255,255,.9);
}

.catalogConversionCardMain{
  display:grid;
  gap:12px;
}

.catalogConversionCardMain b{
  color:var(--gp-ocean);
  font-size:17px;
  line-height:1.3;
}

.catalogConversionCardMain p{
  color:rgba(32,39,66,.74);
}

.catalogRecoveryActions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.catalogResultsList{
  align-items:start;
}

.catalogResultsList .listingContactRow,
.catalogResultsList .listingPhoneBtn{
  display:none;
}

.catalogResultsList .listing{
  min-height:100%;
}

.catalogFiltersForm{
  gap:8px;
}

.catalogFiltersForm .field.field--advanced{
  display:none;
}

.catalogFiltersForm.catalogFiltersForm--advancedOpen .field.field--advanced{
  display:grid;
}

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

.catalogFiltersGrid .field{
  gap:4px;
}

.catalogFiltersGrid .field--full{
  grid-column:1 / -1;
}

.catalogChoiceSelect{
  display:none;
}

.catalogChoiceField{
  gap:6px;
}

.catalogChoiceField[data-filter-field="marketSegment"]{
  margin-top:6px;
}

.catalogTopSelectField{
  position:relative;
  gap:4px;
  margin-bottom:6px;
}

.catalogTopSelectField > label{
  position:absolute;
  width:1px;
  height:1px;
  margin:-1px;
  padding:0;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap;
  border:0;
}

.catalogTopSelect{
  width:100%;
  min-height:40px;
  border-radius:12px;
  border:1px solid rgba(32,39,66,.2);
  background:rgba(255,255,255,.86);
  padding:9px 40px 9px 10px;
  font-size:14px;
  line-height:1.2;
  font-weight:500;
  color:rgba(32,39,66,.92);
}

.catalogTopSelect:focus{
  border-color:rgba(179,138,100,.72);
  box-shadow:0 0 0 4px var(--focus);
}

.catalogChoiceField[data-filter-field="marketSegment"] > label{
  position:absolute;
  width:1px;
  height:1px;
  margin:-1px;
  padding:0;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap;
  border:0;
}

.catalogChoiceGroup{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.catalogChoiceBtn{
  appearance:none;
  border:1px solid rgba(32,39,66,.2);
  background:rgba(255,255,255,.86);
  color:rgba(32,39,66,.92);
  border-radius:12px;
  min-height:38px;
  padding:8px 12px;
  font:inherit;
  font-size:14px;
  font-weight:600;
  line-height:1.2;
  cursor:pointer;
  transition:background .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease;
}

.catalogChoiceBtn:hover{
  background:rgba(255,255,255,.98);
  border-color:rgba(32,39,66,.28);
}

.catalogChoiceBtn.is-active{
  background:rgba(32,39,66,.08);
  border-color:rgba(32,39,66,.28);
  color:var(--gp-ocean);
  box-shadow:none;
}

.catalogChoiceBtn:focus-visible{
  outline:2px solid rgba(179,138,100,.7);
  outline-offset:2px;
}

.catalogChoiceGroup--rooms{
  display:grid;
  grid-template-columns:minmax(0, 1fr);
  gap:6px;
}

.catalogChoiceGroup--rooms .catalogChoiceBtn{
  width:100%;
  justify-content:flex-start;
  display:inline-flex;
  align-items:center;
  gap:10px;
  border-radius:10px;
  min-height:40px;
  padding:8px 10px;
  font-size:15px;
  font-weight:500;
}

.catalogChoiceGroup--rooms .catalogChoiceBtn::before{
  content:"";
  width:16px;
  height:16px;
  border-radius:5px;
  border:1px solid rgba(32,39,66,.26);
  background:rgba(255,255,255,.95);
  flex:0 0 16px;
  transition:background .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.catalogChoiceGroup--rooms .catalogChoiceBtn.is-active::before{
  background:var(--gp-ocean);
  border-color:var(--gp-ocean);
  box-shadow:inset 0 0 0 3px rgba(255,255,255,.95);
}

.catalogFiltersGrid .field label{
  font-size:11px;
  letter-spacing:.03em;
}

.catalogFiltersGrid .field input{
  min-height:40px;
  padding:9px 10px;
  border-radius:12px;
}

.catalogFiltersGrid .field select{
  min-height:40px;
  padding:9px 40px 9px 10px;
  border-radius:12px;
}

.catalogFiltersGrid .field .fieldRange{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:8px;
}

.catalogFiltersGrid .field .fieldRangeCell{
  display:grid;
  gap:4px;
}

.catalogFiltersGrid .field .fieldRangeHint{
  font-size:11px;
  line-height:1;
  color:rgba(32,39,66,.6);
  text-transform:uppercase;
  letter-spacing:.04em;
}

.catalogFilterActions{
  margin-top:0;
}

.catalogFilterActions .btn{
  min-height:40px;
  padding:10px 12px;
}

.catalogAdvancedToggle{
  margin-top:2px;
}

.catalogAdvancedBtn{
  appearance:none;
  border:1px solid rgba(32,39,66,.18);
  background:rgba(255,255,255,.8);
  color:rgba(32,39,66,.88);
  border-radius:12px;
  min-height:38px;
  padding:8px 11px;
  font:inherit;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  width:100%;
  text-align:left;
}

.catalogAdvancedBtn:hover{
  border-color:rgba(32,39,66,.32);
  background:rgba(255,255,255,.95);
}

.catalogAdvancedBtn:focus-visible{
  outline:2px solid rgba(32,39,66,.36);
  outline-offset:2px;
}

.catalogQuickFilters{
  margin-top:10px;
  margin-bottom:2px;
}

.catalogQuickFilters .catalogQuickChip{
  min-height:34px;
  padding:7px 11px;
  border-radius:999px;
  transition:background .18s ease, border-color .18s ease, color .18s ease;
}

.catalogQuickFilters .catalogQuickChip.is-active{
  border-color:rgba(32,39,66,.3);
  background:rgba(32,39,66,.12);
  color:rgba(32,39,66,.96);
}

.catalogSplit.catalogSplit--mapMode .catalogMapPane{
  display:block;
}

/* Partners: keep accent benefit card contrast after shared card styles */
.partnerBenefitsGrid .partnerBenefitCard.partnerBenefitCard--accent{
  border-color:rgba(161,123,90,.35);
  background:linear-gradient(155deg, rgba(41,53,90,.97), rgba(33,45,80,.95));
  box-shadow:0 18px 34px rgba(18,24,42,.24);
}

.partnerBenefitsGrid .partnerBenefitCard.partnerBenefitCard--accent h3{
  color:rgba(255,255,255,.98);
}

.partnerBenefitsGrid .partnerBenefitCard.partnerBenefitCard--accent .partnerBenefitIcon{
  border-color:rgba(237,243,255,.42);
  background:rgba(255,255,255,.1);
  color:rgba(248,252,255,.96);
}

.partnerBenefitsGrid .partnerBenefitCard.partnerBenefitCard--accent p{
  color:rgba(238,243,255,.88);
}

.partnerHeroHeadingBreak{
  display:block;
}

@media (max-width: 980px){
  .partnerHeroHeadingBreak{
    display:none;
  }

  .catalogHeroLeadCard h3{
    font-size:clamp(22px, 6vw, 30px);
  }

  .catalogResultsList[data-view="catalog_list"] .listingBodyCompact,
  .catalogResultsList[data-view="catalog_list"] .listingBodyList{
    grid-template-columns:1fr;
    grid-template-areas:
      "fav"
      "main"
      "preview";
    row-gap:8px;
  }

  .catalogResultsList[data-view="catalog_list"] .listingPreviewText,
  .catalogResultsList[data-view="catalog_list"] .listingPreviewCol{
    -webkit-line-clamp:4;
  }

  .catalogResultsList[data-view="catalog_list"] .listingFavCol{
    justify-self:end;
  }

  .catalogResultsList[data-view="catalog_grid"]{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .catalogMobileStickyBar{
    display:grid;
    grid-template-columns:auto repeat(3, minmax(0, 1fr));
    gap:6px;
    position:sticky;
    top:88px;
    z-index:48;
    margin-bottom:10px;
    padding:8px;
    border:1px solid rgba(32,39,66,.12);
    border-radius:14px;
    background:rgba(248,246,241,.95);
    backdrop-filter:blur(6px);
    box-shadow:0 10px 22px rgba(18,24,42,.12);
  }

  .catalogMobileSheetBackdrop{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(17,20,32,.4);
    opacity:0;
    pointer-events:none;
    transition:opacity .22s ease;
    z-index:86;
  }

  .catalogMobileSheetBackdrop.is-open{
    opacity:1;
    pointer-events:auto;
  }

  .catalogFiltersPane.searchWrap{
    position:fixed;
    left:8px;
    right:8px;
    bottom:0;
    top:auto;
    z-index:90;
    max-height:min(88dvh, 760px);
    border:1px solid rgba(32,39,66,.18);
    border-bottom:0;
    border-radius:18px 18px 0 0;
    background:linear-gradient(180deg, rgba(247,245,240,.98), rgba(247,245,240,.99));
    box-shadow:0 -14px 34px rgba(12,17,31,.24);
    transform:translateY(calc(100% + 20px));
    transition:transform .26s ease;
    overflow:hidden;
    padding:0;
  }

  .catalogFiltersPane.searchWrap.catalogFiltersPane--mobileOpen{
    transform:translateY(0);
  }

  body.catalogMobileSheetOpen{
    overflow:hidden;
    touch-action:none;
  }

  .catalogMobileSheetHead{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    padding:12px 14px 10px;
    border-bottom:1px solid rgba(32,39,66,.12);
    background:rgba(247,245,240,.97);
    position:sticky;
    top:0;
    z-index:2;
  }

  .catalogMobileSheetHead h3{
    margin:0;
    font-size:19px;
    line-height:1.15;
    color:var(--gp-ocean);
  }

  .catalogFiltersPane .catalogFiltersForm{
    overflow:auto;
    max-height:calc(min(88dvh, 760px) - 62px);
    padding:12px 14px calc(104px + env(safe-area-inset-bottom));
    gap:10px;
  }

  .catalogFiltersPane .catalogFilterActions{
    display:none;
  }

  .catalogMobileSheetCta{
    display:block;
    position:sticky;
    bottom:0;
    z-index:3;
    margin-top:6px;
    padding:10px 0 calc(8px + env(safe-area-inset-bottom));
    background:linear-gradient(180deg, rgba(247,245,240,.15), rgba(247,245,240,.98) 24%);
  }

  .catalogMobileSheetCta .btn{
    width:100%;
    min-height:46px;
    justify-content:center;
  }

  .catalogConversionCardWrap{
    margin-top:10px;
  }

  .catalogRecoveryActions{
    display:grid;
    grid-template-columns:1fr;
  }
}

@media (max-width: 680px){
  .catalogFiltersGrid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .catalogFiltersGrid .field{
    grid-column:1 / -1;
  }

  .catalogFiltersGrid .catalogTopSelectField{
    grid-column:auto;
    margin-bottom:2px;
  }

  .catalogChoiceField[data-filter-field="marketSegment"]{
    margin-top:2px;
  }

  .catalogHeroLeadCard{
    padding:14px;
  }

  .catalogHeroLeadList li{
    font-size:14px;
  }

  .catalogResultsList[data-view="catalog_grid"]{
    grid-template-columns:1fr;
  }
}

/* Item page */
.itemCardsGrid .listing{
  min-height:unset;
}

.itemCardsGrid .listingContactRow,
.itemCardsGrid .listingPhoneBtn{
  display:none;
}

.itemCardsGrid .listingCompact .listingPrice{
  font-size:clamp(18px, 1.25vw, 23px);
  line-height:1.08;
}

#similarGrid .listingCompact .listingPrice,
#recentGrid .listingCompact .listingPrice{
  font-size:clamp(18px, 1.1vw, 22px);
}

.itemMainImage{
  border-radius:16px;
}

.btns.itemCtaGroup{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  align-items:stretch;
  gap:10px;
  margin-top:12px;
  flex-wrap:nowrap;
  width:100%;
  align-self:stretch;
}

.btns.itemCtaGroup .btn{
  width:100%;
  min-width:0;
}

.btns.itemCtaGroup .btn:nth-child(3){
  grid-column:1 / -1;
}

@media (max-width: 760px){
  .btns.itemCtaGroup{
    grid-template-columns:1fr;
  }
}

/* Content pages */
.article .lead,
.article p,
.article ul{
  max-width:78ch;
}

.card.soft{
  border:1px solid rgba(32,39,66,.13);
}

/* Articles */
#list .card + #articlesGrid{
  margin-top:18px;
}

#articlesGrid{
  align-items:stretch;
}

#articlesGrid .articleCard{
  display:flex;
  flex-direction:column;
  min-height:100%;
  gap:0;
}

#articlesGrid .articleCard h3{
  margin:0 0 10px;
  line-height:1.25;
}

#articlesGrid .articleCard p{
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
  min-height:64px;
}

.articlesPage .heroRight{
  display:flex;
  align-items:stretch;
}

.articlesPage .articlesHeroGuide{
  width:100%;
  height:100%;
  display:flex;
  flex-direction:column;
  gap:0;
}

.articlesPage .heroLeft .h1{
  font-size:clamp(32px, 3.2vw, 56px);
}

.articlesPage .articlesHeroGuide > .divider{
  margin:12px 0;
}

.articlesHeroSchemes{
  display:grid;
  gap:10px;
  flex:1 1 auto;
}

.articlesHeroScheme{
  border:1px solid rgba(32,39,66,.14);
  border-radius:14px;
  background:rgba(255,255,255,.72);
  padding:12px;
  display:grid;
  gap:8px;
}

.articlesHeroSchemeHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.articlesHeroSchemeHead b{
  color:var(--gp-ocean);
  font-size:16px;
  line-height:1.25;
}

.articlesHeroScheme p{
  margin:0;
  color:rgba(32,39,66,.74);
  font-size:14px;
  line-height:1.45;
}

.articlesHeroScheme .chipRow{
  margin-top:0;
}

.articlesHeroScheme .chip{
  font-size:11px;
}

.articleTagCount{
  font-size:11px;
  color:rgba(32,39,66,.66);
}

.articlePagination{
  margin-top:16px;
}

.articlePagerWrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.articlePagerLabel{
  font-size:13px;
  color:rgba(32,39,66,.72);
  font-weight:600;
}

.articlePagerControls{
  display:flex;
  align-items:center;
  gap:8px;
}

.articlePageBtn[disabled]{
  opacity:.45;
  cursor:not-allowed;
}

.articleToc{
  margin:24px 0 20px;
  padding:12px 14px;
  border:1px solid rgba(32,39,66,.14);
  border-radius:14px;
  background:rgba(255,255,255,.65);
}

.articleToc b{
  display:block;
  margin-bottom:8px;
  color:var(--gp-ocean);
}

.articleTocList{
  display:grid;
  gap:6px;
}

.articleTocLink{
  color:rgba(32,39,66,.86);
  font-size:14px;
}

.articleTocLink--sub{
  padding-left:14px;
  font-size:13px;
  color:rgba(32,39,66,.7);
}

.articleMetaLine{
  margin:10px 0 16px;
  display:grid;
  gap:8px;
}

.card.article .breadcrumbs{
  padding-right:132px;
}

.articleBackRow{
  position:absolute;
  top:18px;
  right:18px;
  margin:0;
  z-index:3;
}

.articleBackLink{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:12px;
  font-weight:700;
  color:rgba(32,39,66,.82);
  min-height:30px;
  padding:6px 10px;
  border:1px solid rgba(32,39,66,.16);
  border-radius:999px;
  background:rgba(255,255,255,.88);
}

.articleBackLink:hover{
  color:var(--gp-ocean);
  border-color:rgba(32,39,66,.3);
  background:rgba(255,255,255,.96);
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-color:rgba(32,39,66,.34);
}

.articleShell{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(280px, 330px);
  gap:20px;
  align-items:start;
}

.articleShellMain{
  min-width:0;
}

.articleShellSidebar{
  min-width:0;
}

.articlePageSidebar{
  display:grid;
  gap:12px;
  align-content:start;
  position:sticky;
  top:108px;
}

.articleSidebarCard{
  border-radius:18px;
}

.articleSidebarCard h3{
  margin:0;
  color:var(--gp-ocean);
  font-size:16px;
  line-height:1.3;
}

.articleSidebarCard p{
  margin:0;
  color:rgba(32,39,66,.72);
  font-size:14px;
  line-height:1.5;
}

.articleSidebarCard .chipRow{
  margin-top:10px;
}

.articleSidebarSearchForm{
  display:grid;
  gap:10px;
}

.articleSidebarSearchRow{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:8px;
  align-items:center;
}

.articleSidebarSearchRow .btn{
  white-space:nowrap;
}

body.articleSidebarSearchModalOpen{
  overflow:hidden;
}

.articleSidebarSearchModal{
  position:fixed;
  inset:0;
  z-index:1200;
}

.articleSidebarSearchModal[hidden]{
  display:none;
}

.articleSidebarSearchOverlay{
  position:absolute;
  inset:0;
  border:0;
  padding:0;
  background:rgba(11,16,29,.42);
  cursor:pointer;
}

.articleSidebarSearchDialog{
  position:relative;
  z-index:1;
  width:min(560px, calc(100vw - 24px));
  margin:8vh auto 0;
  padding:14px;
  border:1px solid rgba(32,39,66,.2);
  border-radius:18px;
  background:rgba(255,255,255,.97);
  box-shadow:0 28px 60px rgba(13,17,30,.28);
  display:grid;
  gap:10px;
}

.articleSidebarSearchDialogHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.articleSidebarSearchDialogHead b{
  font-size:17px;
  color:var(--gp-ocean);
}

.articleSidebarSearchDialogHint{
  margin:0;
  font-size:13px;
  color:rgba(32,39,66,.72);
}

.articleSidebarSearchResults{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:8px;
}

.articleSidebarSearchResult a{
  display:grid;
  gap:4px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(32,39,66,.14);
  background:rgba(255,255,255,.82);
  color:rgba(32,39,66,.88);
  text-decoration:none;
}

.articleSidebarSearchResult a:hover{
  border-color:rgba(32,39,66,.24);
  background:rgba(255,255,255,.95);
}

.articleSidebarSearchResult b{
  font-size:14px;
  line-height:1.35;
}

.articleSidebarSearchResult span{
  color:rgba(32,39,66,.66);
  font-size:12px;
  line-height:1.35;
}

.articleSidebarSearchEmpty{
  color:rgba(32,39,66,.66);
  font-size:13px;
}

.articleSidebarSearchResultEmpty{
  border:1px dashed rgba(32,39,66,.22);
  border-radius:12px;
  padding:12px;
  background:rgba(247,245,240,.62);
}

.articleSidebarSearchDialogActions{
  display:flex;
  justify-content:flex-end;
}

.article .callout{
  margin:18px 0;
}

.article .callout + .callout{
  margin-top:16px;
}

.articleFaq{
  margin:14px 0 0;
  display:grid;
  gap:10px;
}

.articleFaqItem{
  margin:0;
}

.articleFaqItem > summary{
  margin:0;
}

.articleFaqItem > p{
  margin:0;
  padding:10px 4px 0;
  color:rgba(32,39,66,.74);
  line-height:1.5;
}

.articleMetaStats{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  font-size:13px;
  color:rgba(32,39,66,.66);
  font-weight:600;
}

.articleMetaStats .sep{
  color:rgba(32,39,66,.42);
  font-size:12px;
}

.articleMetaTags{
  margin-top:0;
}

.articleRelatedWrap h2{
  margin:0;
  font-size:18px;
}

.articleRelatedWrap .articleRelatedGrid{
  margin-top:10px;
  display:grid;
  gap:10px;
  grid-template-columns:1fr;
}

.articlePageSidebar .articleRelatedCard{
  padding:12px;
  border-radius:14px;
  background:rgba(247,245,240,.84);
}

.articleRelatedCard p{
  margin:6px 0 8px;
  font-size:13px;
  line-height:1.4;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

@media (max-width: 1120px){
  .articleShell{
    grid-template-columns:minmax(0, 1fr) minmax(260px, 300px);
    gap:16px;
  }
}

@media (max-width: 860px){
  .articlesPage .heroRight{
    display:block;
  }
  .articlesPage .articlesHeroGuide{
    height:auto;
  }
  .articlesHeroSchemeHead{
    align-items:flex-start;
    flex-direction:column;
  }
  .card.article .breadcrumbs{
    padding-right:114px;
  }
  .articleShell{
    grid-template-columns:1fr;
    gap:16px;
  }
  .articlePageSidebar{
    position:static;
    top:auto;
  }
  .articlePagination{
    margin-top:12px;
  }
  .articlePagerWrap{
    align-items:flex-start;
  }
  .articleSidebarSearchDialog{
    width:calc(100vw - 20px);
    margin:6vh auto 0;
  }
}

/* Shared premium consult block for catalog + articles pages */
.consultPromoSection{
  padding-top: 56px;
  padding-bottom: 58px;
}

.consultPromoCard{
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(0, .82fr);
  grid-template-areas:
    "top media"
    "bottom media";
  gap: 22px 24px;
  padding: clamp(28px, 3vw, 50px);
  border-radius: 34px;
  border: 1px solid rgba(244,241,234,.22);
  background:
    radial-gradient(900px 360px at 115% -22%, rgba(196,155,114,.2), transparent 58%),
    linear-gradient(150deg, rgba(32,39,66,.98), rgba(43,52,90,.96));
  box-shadow: 0 24px 64px rgba(13,17,30,.24);
  overflow: hidden;
}

.consultPromoCard::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,.04), transparent 24%);
  pointer-events: none;
}

.consultPromoTop{
  grid-area: top;
  display: grid;
  align-content: start;
  gap: 14px;
  position: relative;
  z-index: 1;
}

.consultPromoEyebrow{
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 36px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid rgba(244,241,234,.24);
  background: rgba(255,255,255,.04);
  color: rgba(244,241,234,.88);
  font-size: 13px;
  line-height: 1.25;
  letter-spacing: .07em;
  font-weight: 700;
  text-transform: uppercase;
}

.consultPromoTop h2{
  margin: 0;
  max-width: 16ch;
  color: #fff;
  font-size: clamp(34px, 3.3vw, 52px);
  line-height: 1.05;
  letter-spacing: .01em;
  text-wrap: balance;
}

.consultPromoTop p{
  margin: 0;
  max-width: 56ch;
  color: rgba(244,241,234,.86);
  font-size: clamp(17px, 1.55vw, 20px);
  line-height: 1.58;
}

.consultPromoBenefits{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 6px;
}

.consultPromoBenefit{
  margin: 0;
  display: grid;
  gap: 5px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(244,241,234,.18);
  background: rgba(255,255,255,.05);
}

.consultPromoBenefit b{
  color: #fff;
  font-size: 16px;
  line-height: 1.25;
}

.consultPromoBenefit span{
  color: rgba(244,241,234,.74);
  font-size: 14px;
  line-height: 1.42;
}

.consultPromoMedia{
  grid-area: media;
  position: relative;
  border-radius: 24px;
  border: 1px solid rgba(244,241,234,.22);
  overflow: hidden;
  background: rgba(255,255,255,.04);
}

.consultPromoMedia img{
  width: 100%;
  height: 100%;
  min-height: 430px;
  display: block;
  object-fit: cover;
}

.consultPromoVisualTag{
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.consultPromoVisualTag span{
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  padding: 6px 11px;
  border-radius: 999px;
  border: 1px solid rgba(244,241,234,.2);
  background: rgba(32,39,66,.72);
  color: rgba(244,241,234,.92);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
}

.consultPromoBottom{
  grid-area: bottom;
  display: grid;
  gap: 10px;
  position: relative;
  z-index: 1;
}

.consultPromoActions{
  margin-top: 0;
  align-items: center;
}

.consultPromoActions .consultPromoCtaPrimary{
  min-height: 52px;
  padding: 14px 22px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.22);
  background: linear-gradient(135deg, rgba(249,243,233,.98), rgba(243,232,216,.96));
  color: var(--gp-ocean);
  box-shadow: 0 14px 28px rgba(10,14,26,.26);
}

.consultPromoActions .consultPromoCtaPrimary:hover{
  background: linear-gradient(135deg, rgba(252,247,240,1), rgba(247,238,227,1));
  box-shadow: 0 18px 36px rgba(10,14,26,.34);
}

.consultPromoActions .consultPromoCtaSecondary{
  min-height: 52px;
  padding: 14px 20px;
  border-radius: 16px;
  border-color: rgba(244,241,234,.26);
  color: #fff;
  background: rgba(255,255,255,.04);
}

.consultPromoActions .consultPromoCtaSecondary:hover{
  border-color: rgba(244,241,234,.44);
  background: rgba(255,255,255,.08);
}

.consultPromoNote{
  margin: 0;
  color: rgba(244,241,234,.72);
  font-size: 16px;
  line-height: 1.45;
}

@media (max-width: 1100px){
  .consultPromoCard{
    grid-template-columns: 1fr;
    grid-template-areas:
      "top"
      "media"
      "bottom";
    gap: 18px;
    padding: 24px;
  }
  .consultPromoTop h2{
    max-width: 18ch;
  }
  .consultPromoBenefits{
    grid-template-columns: 1fr 1fr;
  }
  .consultPromoMedia img{
    min-height: 320px;
  }
}

@media (max-width: 760px){
  .consultPromoSection{
    padding-top: 46px;
    padding-bottom: 46px;
  }
  .consultPromoCard{
    padding: 20px;
    border-radius: 26px;
  }
  .consultPromoEyebrow{
    font-size: 12px;
    letter-spacing: .05em;
  }
  .consultPromoTop h2{
    max-width: none;
    font-size: clamp(30px, 8vw, 42px);
    line-height: 1.06;
  }
  .consultPromoTop p{
    font-size: 17px;
  }
  .consultPromoBenefits{
    grid-template-columns: 1fr;
  }
  .consultPromoActions{
    flex-direction: column;
    align-items: stretch;
  }
  .consultPromoActions .btn{
    width: 100%;
  }
  .consultPromoMedia{
    border-radius: 18px;
  }
  .consultPromoMedia img{
    min-height: 260px;
  }
  .consultPromoVisualTag{
    left: 10px;
    right: 10px;
    bottom: 10px;
  }
}
