:root{
  --brand:#A52729;
  --brand-hover:#8F1F21;
  --brand-active:#7A191B;
  --bg:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --border:rgba(229,231,235,.9);
  --shadow:0 22px 60px rgba(17,24,39,.10);
  --shadow-soft:0 12px 34px rgba(17,24,39,.08);
  --radius:22px;
  --radius-sm:16px;
}

html,body{ height:100%; }

body{
  background:var(--bg);
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;
  font-size:13.5px;
  letter-spacing:.01em;
}

.ps-toast-stack{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:1200;
  display:grid;
  gap:10px;
  pointer-events:none;
}
.ps-toast{
  min-width:240px;
  max-width:320px;
  padding:12px 14px;
  border-radius:16px;
  color:#fff;
  background:#111827;
  box-shadow:0 18px 40px rgba(17,24,39,.24);
  opacity:0;
  transform:translateY(8px);
  transition:opacity .18s ease, transform .18s ease;
}
.ps-toast.is-visible{
  opacity:1;
  transform:translateY(0);
}
.ps-toast.is-error{ background:#8f1f21; }

a,
a:hover,
a:focus,
a:focus-visible{
  text-decoration:none;
}

/* Generic */
.link-brand{
  color:var(--brand);
  text-decoration:none;
  font-weight:700;
}
.link-brand:hover{
  color:var(--brand-hover);
  text-decoration:underline;
  text-underline-offset:4px;
}

.soft-card{
  border:1px solid var(--border);
  border-radius:calc(var(--radius) - 6px);
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78));
  box-shadow:0 14px 36px rgba(17,24,39,.08);
}

/* Buttons/Inputs */
.btn{
  border-radius:999px;
  padding:.56rem .82rem;
  font-weight:750;
  letter-spacing:.12px;
  text-decoration:none;
  transition:transform .06s ease, background-color .14s ease, border-color .14s ease, box-shadow .14s ease, color .14s ease;
  position:relative;
  overflow:hidden;
}
.btn:active{ transform:translateY(1px); }
.btn:hover,
.btn:focus,
.btn:focus-visible{
  text-decoration:none;
}
.btn.is-loading,
.sr-ic.is-loading,
.cart-remove.is-loading,
.asset-detail-pillbtn.is-loading{
  opacity:.7;
  pointer-events:none;
}

.btn-brand{
  background:var(--brand);
  border-color:var(--brand);
  color:#fff;
  box-shadow:0 10px 22px rgba(165,39,41,.18);
}
.btn-brand:hover{ background:var(--brand-hover); border-color:var(--brand-hover); color:#fff; }
.btn-brand:active{ background:var(--brand-active) !important; border-color:var(--brand-active) !important; }

.btn-outline-brand{
  background:transparent;
  border-color:rgba(165,39,41,.45);
  color:var(--brand);
}
.btn-outline-brand:hover{
  background:rgba(165,39,41,.08);
  border-color:rgba(165,39,41,.60);
  color:var(--brand-hover);
}

.btn-brand::after,
.btn-outline-brand::after{
  content:"";
  position:absolute;
  top:-45%;
  left:-140%;
  width:68%;
  height:190%;
  transform:skewX(-18deg);
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.42), transparent);
  opacity:0;
  pointer-events:none;
}
.btn-brand:hover::after,
.btn-outline-brand:hover::after{
  opacity:1;
  animation:btnShine .85s ease-out forwards;
}
@keyframes btnShine{ from{ left:-140%; } to{ left:140%; } }

.form-control, .form-select{
  border-color:var(--border);
  border-radius:var(--radius-sm);
  padding:.60rem .78rem;
  font-size:12.5px;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.form-control:focus, .form-select:focus{
  border-color:rgba(165,39,41,.55);
  box-shadow:0 0 0 .25rem rgba(165,39,41,.14);
}

.input-group-text{
  border-color:var(--border);
  border-radius:var(--radius-sm);
  background:#fff;
  padding:.60rem .72rem;
  color:#9ca3af;
}

.input-group > .input-group-text:first-child{
  border-top-left-radius:var(--radius-sm) !important;
  border-bottom-left-radius:var(--radius-sm) !important;
}
.input-group > .form-control{
  border-left:0;
  border-radius:0 !important;
}
.input-group > .form-control:last-child{
  border-top-right-radius:var(--radius-sm) !important;
  border-bottom-right-radius:var(--radius-sm) !important;
}
.input-group > :not(:first-child){ margin-left:0; }

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,.88);
  backdrop-filter:saturate(1.1) blur(10px);
  border-bottom:1px solid rgba(229,231,235,.75);
}

.nav-wrap{
  padding:10px 0;
}

.brand-logo{
  height:28px;
  width:auto;
  max-width:220px;
  object-fit:contain;
}

.nav-link{
  font-weight:750;
  color:#374151;
  padding:.45rem .6rem !important;
  border-radius:999px;
}
.nav-link:hover{
  background:rgba(165,39,41,.06);
  color:var(--brand-hover);
}

.nav-link.active{
  background:rgba(165,39,41,.10);
  color:var(--brand);
}

.icon-pill{
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid var(--border);
  background:#fff;
  display:grid;
  place-items:center;
  transition:box-shadow .14s ease, border-color .14s ease, transform .06s ease;
}
.icon-pill:hover{
  border-color:rgba(165,39,41,.30);
  box-shadow:0 12px 26px rgba(17,24,39,.08);
}
.icon-pill:active{ transform:translateY(1px); }
.icon-pill i{ color:var(--brand); font-size:14px; }

/* Hero */
.hero{
  position:relative;
  overflow:hidden;
  padding:28px 0 16px;
}
.hero::before{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(900px 420px at 12% 18%, rgba(165,39,41,.16), transparent 56%),
    radial-gradient(900px 420px at 88% 74%, rgba(165,39,41,.10), transparent 56%);
  animation:bgFloat 10s ease-in-out infinite alternate;
  pointer-events:none;
}
@keyframes bgFloat{ from{ transform:translate3d(0,0,0) scale(1);} to{ transform:translate3d(-1.2%, 1%, 0) scale(1.02);} }

.hero-inner{
  position:relative;
  z-index:1;
}

.hero-title{
  font-weight:820;
  letter-spacing:-.03em;
  font-size:clamp(20px, 2.4vw, 30px);
  margin:0;
}

.hero-sub{
  margin-top:8px;
  color:var(--muted);
  font-size:12.8px;
  line-height:1.55;
}

.search-card{
  margin-top:14px;
  padding:12px;
  border-radius:calc(var(--radius) - 2px);
}

.search-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}

.search-row .input-group{
  flex:1 1 520px;
  min-width:min(620px, 100%);
}

.search-row .form-select{
  width:160px;
}

@media (max-width: 575.98px){
  .search-row .input-group{ min-width:100%; }
  .search-row .form-select{ width:48%; }
  .search-row .btn{ width:100%; }
}

.hint-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin-top:10px;
  color:var(--muted);
  font-size:12px;
}

.chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(229,231,235,.9);
  background:rgba(255,255,255,.70);
  color:#374151;
  font-weight:750;
  font-size:12px;
}
.chip i{ color:var(--brand); }

/* Sections */
.section{
  padding:18px 0;
}
.section-title{
  font-weight:850;
  letter-spacing:-.02em;
  font-size:15px;
  margin:0;
  color:var(--brand);
}
.section-sub{
  margin-top:6px;
  color:var(--muted);
  font-size:12.6px;
}

/* Category tiles */
.cat-grid{
  margin-top:12px;
  display:grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap:10px;
}
@media (max-width: 1199.98px){ .cat-grid{ grid-template-columns: repeat(4, minmax(0, 1fr)); } }
@media (max-width: 767.98px){ .cat-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); } }

.cat-tile{
  border:1px solid var(--border);
  border-radius:18px;
  background:rgba(255,255,255,.85);
  padding:12px;
  text-decoration:none;
  color:#374151;
  display:flex;
  gap:10px;
  align-items:center;
  transition:transform .10s ease, box-shadow .14s ease, border-color .14s ease, background-color .14s ease;
}
.cat-tile:hover{
  border-color:rgba(165,39,41,.22);
  box-shadow:var(--shadow-soft);
  transform:translateY(-1px);
}
.cat-ic{
  width:34px;
  height:34px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:rgba(165,39,41,.10);
  color:var(--brand);
}
.cat-ic i{ font-size:14px; }
.cat-name{
  font-weight:850;
  font-size:12.8px;
}
.cat-meta{
  color:var(--muted);
  font-size:12px;
}

/* Asset grid */
.asset-grid{
  margin-top:12px;
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:12px;
}
@media (max-width: 1199.98px){ .asset-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 767.98px){ .asset-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 420px){ .asset-grid{ grid-template-columns: 1fr; } }

.asset-card{
  border:1px solid var(--border);
  border-radius:18px;
  background:#fff;
  overflow:hidden;
  text-decoration:none;
  color:inherit;
  box-shadow:0 10px 26px rgba(17,24,39,.06);
  transition:transform .10s ease, box-shadow .14s ease, border-color .14s ease;
}
.asset-card:hover{
  transform:translateY(-1px);
  border-color:rgba(165,39,41,.22);
  box-shadow:0 18px 44px rgba(17,24,39,.10);
}
.asset-img{
  aspect-ratio: 4 / 3;
  background:
    linear-gradient(180deg, rgba(255,255,255,.65), rgba(255,255,255,.10)),
    radial-gradient(520px 260px at 20% 30%, rgba(165,39,41,.18), transparent 60%),
    radial-gradient(520px 260px at 80% 80%, rgba(165,39,41,.10), transparent 60%);
  position:relative;
}
.asset-badge{
  position:absolute;
  left:10px;
  top:10px;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.74);
  font-size:11px;
  font-weight:850;
  color:var(--brand);
  backdrop-filter:saturate(1.1) blur(8px);
}
.asset-body{
  padding:10px 10px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.asset-title{
  font-weight:850;
  font-size:12.8px;
  margin:0;
}
.asset-sub{
  margin-top:4px;
  color:var(--muted);
  font-size:12px;
}
.asset-like{
  width:30px;
  height:30px;
  border-radius:999px;
  border:1px solid var(--border);
  display:grid;
  place-items:center;
  background:#fff;
  flex:0 0 auto;
}
.asset-like i{ color:var(--brand); font-size:12px; }

/* Pricing tease */
.price-grid{
  margin-top:12px;
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap:12px;
}
@media (max-width: 991.98px){ .price-grid{ grid-template-columns: 1fr; } }

.price-main{
  padding:14px;
  border-radius:calc(var(--radius) - 4px);
  background:
    radial-gradient(760px 320px at 10% 0%, rgba(165,39,41,.16), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78));
}
.price-main h3{
  margin:0;
  font-weight:900;
  letter-spacing:-.02em;
  font-size:15px;
  color:var(--brand);
}
.price-main p{
  margin:8px 0 0;
  color:var(--muted);
  font-size:12.6px;
  line-height:1.55;
}
.price-mini{
  padding:14px;
}
.price-mini .t{
  font-weight:900;
  color:#374151;
  font-size:13px;
}
.fa-brand{
  color:var(--brand);
}
.price-mini .s{
  margin-top:6px;
  color:var(--muted);
  font-size:12.4px;
  line-height:1.5;
}

/* Footer */
.site-footer{
  padding:18px 0 26px;
  border-top:1px solid rgba(229,231,235,.75);
  background:linear-gradient(180deg, rgba(165,39,41,.03), transparent);
}
.foot-note{
  color:var(--muted);
  font-size:12px;
}

@media (prefers-reduced-motion: reduce){
  .hero::before{ animation:none; }
  .asset-card, .cat-tile, .btn{ transition:none; }
}

/* ==========================================
   Shutterstock-like landing (images only)
   (Original implementation, inspired layout)
   ========================================== */
.ss-promo{
  display:none !important;
  background:linear-gradient(90deg, var(--brand), var(--brand-hover));
  color:#fff;
  font-size:12px;
}
.ss-promo .promo-inner{
  padding:10px 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.ss-promo .promo-inner span{
  opacity:.95;
  font-weight:650;
  flex:1 1 auto;
  text-align:center;
}
.ss-promo .promo-btn{
  background:#fff;
  border:1px solid rgba(255,255,255,.35);
  color:var(--brand);
  padding:.44rem .78rem;
  border-radius:999px;
  font-weight:850;
  font-size:12px;
  white-space:nowrap;
}

.ss-header{
  background:#0b0f14;
  color:#fff;
  position:sticky;
  top:0;
  z-index:110;
}

.ss-head-top{
  padding:10px 0;
}

.ss-head-grid{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  gap:10px;
}

.ss-burger{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#fff;
}
.ss-burger i{ font-size:14px; }

.ss-logo{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
}
.ss-logo img{
  height:34px;
  width:auto;
}

.ss-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}

.ss-action-link{
  color:rgba(255,255,255,.86);
  text-decoration:none;
  font-weight:750;
  font-size:12.6px;
}
.ss-action-link:hover{ color:#fff; }
.ss-action-link i{
  opacity:.9;
  font-size:11px;
  margin-left:6px;
}

.ss-social .ss-action-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  text-decoration:none;
}
.ss-social .ss-action-link i{
  margin-left:0;
  font-size:13px;
}
.ss-social .ss-action-link:hover{
  border-color:rgba(255,255,255,.22);
}

.ss-ic{
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  display:grid;
  place-items:center;
  text-decoration:none;
}
.ss-ic i{ color:#fff; font-size:13px; opacity:.95; }
.ss-ic:hover{ border-color:rgba(255,255,255,.26); }

.ss-login{
  appearance:none;
  border:1px solid rgba(255,255,255,.22);
  background:transparent;
  color:#fff;
  padding:.44rem .78rem;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:850;
  font-size:12px;
  line-height:1.2;
  text-decoration:none;
  cursor:pointer;
}
.ss-login:hover{
  background:rgba(255,255,255,.08);
  color:#fff;
}

.ss-navline{
  border-top:1px solid rgba(255,255,255,.08);
}

.ss-nav{
  display:flex;
  justify-content:center;
  gap:18px;
  flex-wrap:wrap;
  padding:10px 0;
}

.ss-nav a{
  color:rgba(255,255,255,.82);
  text-decoration:none;
  font-weight:780;
  font-size:12.6px;
  position:relative;
  padding:6px 2px;
}
.ss-nav a:hover{ color:#fff; }
.ss-nav a.active{
  color:#fff;
}
.ss-nav a.active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-10px;
  height:3px;
  border-radius:999px;
  background:var(--brand);
}

/* Hero */
.ss-hero{
  position:relative;
  overflow:hidden;
  background:#0b0f14;
  padding:56px 0 42px;
}
.ss-hero::before{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(900px 480px at 22% 45%, rgba(165,39,41,.92), transparent 58%),
    radial-gradient(900px 480px at 72% 42%, rgba(165,39,41,.48), transparent 62%),
    radial-gradient(820px 420px at 85% 30%, rgba(0,0,0,.65), transparent 60%),
    radial-gradient(620px 420px at 10% 90%, rgba(0,0,0,.55), transparent 64%);
  filter:saturate(1.05);
  animation:bgFloat 10s ease-in-out infinite alternate;
  pointer-events:none;
}
.ss-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(11,15,20,.10), rgba(11,15,20,.70));
  pointer-events:none;
}

.ss-hero .hero-inner{
  position:relative;
  z-index:1;
}

.ss-hero-title{
  text-align:center;
  color:#fff;
  margin:0;
  font-weight:900;
  letter-spacing:-.03em;
  font-size:clamp(26px, 3.6vw, 44px);
}

.ss-hero-tabs{
  margin-top:18px;
  display:flex;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
  max-width:980px;
  margin-left:auto;
  margin-right:auto;
}

.ss-hero-tab{
  color:rgba(255,255,255,.78);
  text-decoration:none;
  font-weight:780;
  font-size:12.6px;
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-bottom:2px solid transparent;
}
.ss-hero-tab i{ opacity:.95; }
.ss-hero-tab.active{
  color:#fff;
  border-color:rgba(255,255,255,.70);
}
.ss-hero-tab:hover{ color:#fff; }

.ss-search{
  margin-top:16px;
  display:flex;
  align-items:stretch;
  gap:10px;
  max-width:1100px;
  margin-left:auto;
  margin-right:auto;
}

.ss-searchbar{
  flex:1 1 auto;
  display:flex;
  align-items:stretch;
  background:#fff;
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 18px 50px rgba(0,0,0,.28);
}

.ss-dd{
  border:0;
  background:#fff;
  border-right:1px solid rgba(229,231,235,.9);
  padding:12px 14px;
  min-width:158px;
  font-size:12.6px;
  font-weight:880;
  color:#374151;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.ss-dd i{ color:#9ca3af; font-size:12px; }

.ss-q{
  border:0;
  outline:0;
  flex:1 1 auto;
  padding:12px 14px;
  font-size:13px;
}
.ss-q::placeholder{ color:#9ca3af; }

.ss-go{
  width:52px;
  border:0;
  background:var(--brand);
  color:#fff;
  display:grid;
  place-items:center;
}
.ss-go:hover{ background:var(--brand-hover); }
.ss-go i{ font-size:14px; }

.ss-imgbtn{
  border:1px solid rgba(229,231,235,.9);
  background:rgba(255,255,255,.94);
  color:#111827;
  border-radius:8px;
  padding:0 14px;
  font-weight:880;
  font-size:12.6px;
  display:flex;
  align-items:center;
  gap:10px;
  white-space:nowrap;
  text-decoration:none;
}
.ss-imgbtn i{ color:var(--brand); }
.ss-imgbtn:hover{
  border-color:rgba(165,39,41,.26);
  box-shadow:0 12px 30px rgba(0,0,0,.12);
  text-decoration:none;
}

.ss-trending{
  margin-top:12px;
  text-align:center;
  color:rgba(255,255,255,.78);
  font-size:12.4px;
  max-width:1100px;
  margin-left:auto;
  margin-right:auto;
}
.ss-trending a{
  color:rgba(255,255,255,.92);
  text-decoration:none;
  font-weight:800;
}
.ss-trending a:hover{ text-decoration:underline; text-underline-offset:4px; }

@media (max-width: 991.98px){
  .ss-actions .ss-action-link{ display:none; }
}

@media (max-width: 767.98px){
  .ss-search{ flex-wrap:wrap; }
  .ss-imgbtn{ width:100%; justify-content:center; height:44px; }
  .ss-searchbar{ width:100%; }
  .ss-dd{ min-width:132px; padding:10px 12px; }
  .ss-q{ padding:10px 12px; }
  .ss-go{ width:48px; }
}

/* Section headings */
.ss-section{
  padding:22px 0;
}
.ss-soft{
  background:#f6f7f8;
}
.ss-carousel{
  position:relative;
}
.ss-car-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:38px;
  height:38px;
  border-radius:999px;
  border:1px solid rgba(17,24,39,.10);
  background:rgba(255,255,255,.92);
  display:grid;
  place-items:center;
  box-shadow:0 14px 34px rgba(17,24,39,.14);
  z-index:2;
  transition:transform .14s ease, background-color .14s ease, border-color .14s ease;
}
.ss-car-btn:hover{
  transform:translateY(-50%) scale(1.03);
  border-color:rgba(165,39,41,.18);
}
.ss-car-btn i{ color:#111827; font-size:14px; }
.ss-car-btn.prev{ left:-8px; }
.ss-car-btn.next{ right:-8px; }
@media (max-width: 991.98px){
  .ss-car-btn{ display:none; }
}
.ss-h2{
  margin:0;
  font-weight:950;
  letter-spacing:-.02em;
  font-size:clamp(18px, 2.4vw, 30px);
  color:#111827;
}
.ss-headrow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.ss-headrow .btn{
  padding:.44rem .78rem;
  font-size:12px;
}

/* Content strip */
.ss-strip{
  margin-top:12px;
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns: minmax(320px, 1fr);
  gap:12px;
  overflow:auto;
  padding-bottom:6px;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
}
.ss-strip::-webkit-scrollbar{ height:10px; }
.ss-strip::-webkit-scrollbar-thumb{ background:rgba(17,24,39,.10); border-radius:999px; }

.ss-strip-card{
  scroll-snap-align:start;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--border);
  background:#fff;
  min-height:250px;
  position:relative;
  text-decoration:none;
  color:#fff;
  box-shadow:0 16px 44px rgba(17,24,39,.10);
  transform:translateZ(0);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.ss-strip-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(1.02);
}
.ss-strip-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.00), rgba(0,0,0,.55));
}
.ss-strip-label{
  position:absolute;
  left:14px;
  bottom:14px;
  z-index:1;
  font-weight:950;
  font-size:13px;
  letter-spacing:-.01em;
  display:flex;
  align-items:center;
  gap:10px;
}
.ss-strip-label i{ opacity:.95; }
.ss-strip-card:hover{
  transform:translateY(-2px);
  border-color:rgba(165,39,41,.20);
  box-shadow:0 18px 54px rgba(17,24,39,.14);
}
.ss-strip-card:active{ transform:translateY(0); }

/* One-brand tiles */
.ss-tilegrid{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:14px;
}
@media (max-width: 991.98px){ .ss-tilegrid{ grid-template-columns:repeat(2, minmax(0, 1fr)); } }
@media (max-width: 575.98px){ .ss-tilegrid{ grid-template-columns:1fr; } }
.ss-tile{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(17,24,39,.10);
  background:#fff;
  text-decoration:none;
  color:#111827;
  box-shadow:0 12px 30px rgba(17,24,39,.06);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.ss-tile:hover{
  transform:translateY(-1px);
  border-color:rgba(165,39,41,.18);
  box-shadow:0 14px 34px rgba(17,24,39,.08);
}
.ss-tile img{
  width:46px;
  height:46px;
  border-radius:12px;
  object-fit:cover;
  flex:0 0 auto;
}
.ss-tile b{
  font-size:12.6px;
  font-weight:900;
  letter-spacing:-.01em;
}
.ss-tile small{
  display:block;
  margin-top:3px;
  color:#6b7280;
  font-size:12px;
  font-weight:650;
}

/* Icon categories strip */
.ss-icongrid{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:12px;
}
@media (max-width: 991.98px){ .ss-icongrid{ grid-template-columns:repeat(3, minmax(0, 1fr)); } }
@media (max-width: 575.98px){ .ss-icongrid{ grid-template-columns:repeat(2, minmax(0, 1fr)); } }
.ss-iconcard{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(17,24,39,.10);
  background:#fff;
  text-decoration:none;
  color:#111827;
  box-shadow:0 10px 26px rgba(17,24,39,.06);
}
.ss-iconcard i{
  width:34px;
  height:34px;
  border-radius:12px;
  display:grid;
  place-items:center;
  border:1px solid rgba(165,39,41,.18);
  color:var(--brand);
  background:rgba(165,39,41,.06);
  font-size:14px;
}
.ss-iconcard span{
  font-weight:900;
  font-size:12.6px;
}

/* Explore section */
.ss-chiprow{
  margin-top:10px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
.ss-qchip{
  border:1px solid rgba(229,231,235,.9);
  background:#fff;
  border-radius:999px;
  padding:6px 10px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#374151;
  text-decoration:none;
  font-weight:780;
  font-size:12px;
}
.ss-qchip i{ color:#9ca3af; font-size:12px; }
.ss-qchip:hover{
  border-color:rgba(165,39,41,.22);
  box-shadow:0 12px 26px rgba(17,24,39,.08);
  color:var(--brand-hover);
}

.ss-tabs{
  margin-top:10px;
  display:flex;
  justify-content:flex-end;
  gap:18px;
  border-bottom:1px solid rgba(229,231,235,.9);
}
.ss-tab{
  border:0;
  background:transparent;
  padding:10px 2px;
  font-weight:900;
  font-size:12.6px;
  color:#6b7280;
  position:relative;
}
.ss-tab.active{ color:#111827; }
.ss-tab.active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:2px;
  border-radius:999px;
  background:var(--brand);
}

/* Masonry */
.ss-pane{ margin-top:12px; }
.ss-pane[hidden]{ display:none !important; }

.ss-masonry{
  column-count:3;
  column-gap:12px;
}
@media (max-width: 991.98px){ .ss-masonry{ column-count:2; } }
@media (max-width: 575.98px){ .ss-masonry{ column-count:1; } }

.ss-item{
  break-inside:avoid;
  margin:0 0 12px;
  display:inline-block;
  width:100%;
  position:relative;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.9);
  box-shadow:0 12px 28px rgba(17,24,39,.08);
}
.ss-item img{
  width:100%;
  height:auto;
  display:block;
}
.ss-item:hover{
  border-color:rgba(165,39,41,.22);
  box-shadow:0 18px 44px rgba(17,24,39,.12);
}
.ss-item::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.00), rgba(0,0,0,.35));
  opacity:.9;
  pointer-events:none;
}
.ss-tag{
  position:absolute;
  left:10px;
  top:10px;
  z-index:1;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.74);
  font-size:11px;
  font-weight:950;
  color:var(--brand);
  backdrop-filter:saturate(1.1) blur(8px);
}

.ss-more{
  margin-top:14px;
  display:flex;
  justify-content:center;
}

/* Collections */
.ss-collections{
  margin-top:12px;
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns: minmax(300px, 1fr);
  gap:12px;
  overflow:auto;
  padding-bottom:6px;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
}
.ss-collections::-webkit-scrollbar{ height:10px; }
.ss-collections::-webkit-scrollbar-thumb{ background:rgba(17,24,39,.10); border-radius:999px; }

.ss-col-card{
  scroll-snap-align:start;
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.9);
  min-height:290px;
  text-decoration:none;
  color:#fff;
  box-shadow:0 16px 44px rgba(17,24,39,.10);
}
.ss-col-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.ss-col-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.00), rgba(0,0,0,.60));
}
.ss-col-label{
  position:absolute;
  left:14px;
  bottom:14px;
  z-index:1;
  font-weight:950;
  font-size:13px;
  letter-spacing:-.01em;
}

/* Footer */
.ss-footer{
  background:#0b0f14;
  color:rgba(255,255,255,.82);
  padding:26px 0 34px;
  margin-top:26px;
}
.ss-foot-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:14px;
}
@media (max-width: 991.98px){ .ss-foot-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 575.98px){ .ss-foot-grid{ grid-template-columns: 1fr; } }

.ss-foot-title{
  color:#fff;
  font-weight:900;
  font-size:12.6px;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.ss-foot a{
  display:block;
  color:rgba(255,255,255,.78);
  text-decoration:none;
  padding:6px 0;
  font-weight:650;
  font-size:12.6px;
}
.ss-foot a:hover{ color:#fff; }
.ss-foot-bottom{
  margin-top:18px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.10);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  color:rgba(255,255,255,.62);
  font-size:12px;
}

/* ==========================================
   Search results (Shutterstock-like)
   ========================================== */
.btn.btn-sm{
  padding:.42rem .70rem;
  font-size:11.5px;
}

.sr-main{
  background:#fff;
}

.sr-searchline{
  background:#fff;
  border-bottom:1px solid rgba(229,231,235,.85);
}
.sr-search{
  padding:12px 0;
  margin:0;
}
.sr-searchbar{
  box-shadow:0 12px 34px rgba(17,24,39,.12);
}
.sr-dd{
  min-width:148px;
  padding:10px 12px;
  border-right:1px solid rgba(229,231,235,.95);
}
.sr-dd.dropdown-toggle::after{
  margin-left:10px;
  opacity:.8;
  transform:translateY(1px);
}
.sr-q{
  padding:10px 12px;
  font-size:12.8px;
}
.sr-imgbtn{
  height:44px;
  border-radius:8px;
  padding:0 12px;
  font-size:12.2px;
}
.sr-imgbtn i{ font-size:13px; }

.sr-top{
  padding:10px 0 2px;
}

.sr-breadcrumb ol{
  list-style:none;
  padding:0;
  margin:0 0 6px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  color:#6b7280;
  font-size:12px;
}
.sr-breadcrumb a{
  color:#6b7280;
  text-decoration:none;
  font-weight:750;
}
.sr-breadcrumb a:hover{ color:#111827; }
.sr-breadcrumb li+li::before{
  content:"/";
  margin-right:8px;
  opacity:.7;
}

.sr-title{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.sr-h1{
  margin:0;
  font-weight:950;
  letter-spacing:-.02em;
  font-size:clamp(18px, 2.2vw, 28px);
  color:#111827;
}
.sr-sub{
  color:#6b7280;
  font-size:12.4px;
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.sr-sub b{ color:#111827; }
.sr-dot{ opacity:.7; }

.sr-toolbar{
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid rgba(229,231,235,.85);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}

.sr-tools{
  display:flex;
  align-items:center;
  gap:8px;
  flex:1 1 auto;
  overflow:auto;
  padding-bottom:4px;
  scrollbar-width:thin;
}
.sr-tools::-webkit-scrollbar{ height:8px; }
.sr-tools::-webkit-scrollbar-thumb{ background:rgba(17,24,39,.10); border-radius:999px; }

.sr-toolbtn{
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  border-radius:999px;
  padding:7px 10px;
  font-weight:850;
  font-size:12px;
  color:#111827;
  display:inline-flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
  transition:box-shadow .14s ease, border-color .14s ease, transform .08s ease, background-color .14s ease;
}
.sr-toolbtn i{
  color:#6b7280;
  font-size:12px;
}
.sr-toolbtn:hover{
  border-color:rgba(165,39,41,.20);
  box-shadow:0 12px 26px rgba(17,24,39,.08);
}
.sr-toolbtn:active{ transform:translateY(1px); }
.sr-toolbtn.dropdown-toggle::after{
  margin-left:2px;
  opacity:.8;
}

.sr-menu{
  border-radius:14px;
  border:1px solid rgba(229,231,235,.95);
  box-shadow:0 18px 50px rgba(17,24,39,.14);
  padding:6px;
  min-width:220px;
  font-size:12.6px;
}
.sr-menu .dropdown-item{
  border-radius:10px;
  padding:8px 10px;
  font-weight:750;
  display:flex;
  align-items:center;
}
.sr-menu .dropdown-item i{ color:#6b7280; }
.sr-menu .dropdown-item:hover{
  background:rgba(165,39,41,.06);
  color:var(--brand-hover);
}
.sr-menu-pad{
  padding:10px;
  min-width:260px;
}
.sr-colors{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:8px;
}
.sr-swatch{
  width:34px;
  height:34px;
  border-radius:12px;
  border:1px solid rgba(229,231,235,.95);
  background:var(--sw, transparent);
  box-shadow:0 10px 22px rgba(17,24,39,.06);
}
.sr-swatch:first-child{
  background:linear-gradient(135deg, rgba(17,24,39,.18), rgba(229,231,235,.14));
}
.sr-swatch:hover{ border-color:rgba(165,39,41,.25); }
.sr-sw-black{ --sw:#111827; }
.sr-sw-white{ --sw:#ffffff; }
.sr-sw-amber{ --sw:#f59e0b; }
.sr-sw-green{ --sw:#22c55e; }
.sr-sw-blue{ --sw:#3b82f6; }
.sr-sw-purple{ --sw:#a855f7; }
.sr-sw-brand{ --sw:var(--brand); }
.sr-sw-white{ box-shadow:inset 0 0 0 1px rgba(17,24,39,.08), 0 10px 22px rgba(17,24,39,.06); }

.sr-menu-foot{
  margin-top:10px;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
}

.sr-switch{
  display:inline-flex;
  align-items:center;
  gap:10px;
  user-select:none;
  font-size:12.4px;
  font-weight:850;
  color:#374151;
  white-space:nowrap;
  position:relative;
}
.sr-switch input{
  position:absolute;
  opacity:0;
  pointer-events:none;
  width:1px;
  height:1px;
  overflow:hidden;
}
.sr-slider{
  width:36px;
  height:20px;
  border-radius:999px;
  border:1px solid rgba(229,231,235,.95);
  background:rgba(17,24,39,.08);
  position:relative;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.45);
  transition:background-color .14s ease, border-color .14s ease;
}
.sr-slider::after{
  content:"";
  position:absolute;
  top:2px;
  left:2px;
  width:14px;
  height:14px;
  border-radius:999px;
  background:#fff;
  box-shadow:0 8px 18px rgba(17,24,39,.16);
  transition:transform .14s ease;
}
.sr-switch input:checked + .sr-slider{
  background:rgba(165,39,41,.85);
  border-color:rgba(165,39,41,.65);
}
.sr-switch input:checked + .sr-slider::after{
  transform:translateX(16px);
}

.sr-results{
  padding:10px 0 8px;
}
.sr-results.is-loading{
  opacity:.66;
  transition:opacity .18s ease;
}

.sr-masonry{
  column-count:5;
  column-gap:10px;
}
@media (max-width: 1399.98px){ .sr-masonry{ column-count:4; } }
@media (max-width: 991.98px){ .sr-masonry{ column-count:3; } }
@media (max-width: 767.98px){ .sr-masonry{ column-count:2; } }
@media (max-width: 479.98px){ .sr-masonry{ column-count:1; } }

.sr-card{
  break-inside:avoid;
  margin:0 0 10px;
  display:inline-block;
  width:100%;
  border-radius:10px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  position:relative;
  text-decoration:none;
  transform:translateZ(0);
  transition:box-shadow .14s ease, border-color .14s ease, transform .14s ease;
}
.sr-card-link{
  display:block;
  text-decoration:none;
  color:inherit;
}
.sr-card img{
  width:100%;
  height:auto;
  display:block;
}
.sr-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.00), rgba(0,0,0,.32));
  opacity:0;
  transition:opacity .14s ease;
  pointer-events:none;
}
.sr-card:hover{
  border-color:rgba(165,39,41,.20);
  box-shadow:0 18px 54px rgba(17,24,39,.12);
  transform:translateY(-1px);
}
.sr-card:hover::after{ opacity:1; }

.sr-hover{
  position:absolute;
  top:10px;
  right:10px;
  display:flex;
  flex-direction:column;
  gap:8px;
  opacity:0;
  transform:translateY(-4px);
  transition:opacity .14s ease, transform .14s ease;
  z-index:2;
}
.sr-card:hover .sr-hover{
  opacity:1;
  transform:translateY(0);
}
.sr-ic{
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.90);
  display:grid;
  place-items:center;
  color:#111827;
  box-shadow:0 14px 30px rgba(17,24,39,.18);
  transition:transform .08s ease, border-color .14s ease, color .14s ease;
}
.sr-ic i{ font-size:14px; }
.sr-ic:hover{
  border-color:rgba(165,39,41,.30);
  color:var(--brand);
}
.sr-ic:active{ transform:translateY(1px); }

.sr-pagination{
  margin-top:14px;
  display:flex;
  justify-content:center;
  gap:6px;
  align-items:center;
  flex-wrap:wrap;
}
.sr-page{
  width:34px;
  height:34px;
  border-radius:10px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  display:grid;
  place-items:center;
  text-decoration:none;
  color:#374151;
  font-weight:900;
  font-size:12.4px;
  transition:box-shadow .14s ease, border-color .14s ease, background-color .14s ease, color .14s ease;
}
.sr-page:hover{
  border-color:rgba(165,39,41,.20);
  box-shadow:0 12px 26px rgba(17,24,39,.08);
  color:var(--brand-hover);
}
.sr-page.active{
  background:var(--brand);
  border-color:var(--brand);
  color:#fff;
}
.sr-ellipsis{
  color:#9ca3af;
  font-weight:900;
}

.sr-topics{
  padding:18px 0 26px;
  border-top:1px solid rgba(229,231,235,.85);
  background:linear-gradient(180deg, rgba(165,39,41,.02), transparent);
}
.sr-topics-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.sr-kicker{
  font-weight:950;
  letter-spacing:-.02em;
  font-size:14px;
  color:#111827;
}
.sr-mini{
  margin-top:3px;
  color:#6b7280;
  font-size:12.4px;
}
.sr-topicstrip{
  margin-top:10px;
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns: minmax(180px, 1fr);
  gap:10px;
  overflow:auto;
  padding-bottom:6px;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
}
.sr-topicstrip::-webkit-scrollbar{ height:10px; }
.sr-topicstrip::-webkit-scrollbar-thumb{ background:rgba(17,24,39,.10); border-radius:999px; }
.sr-topiccard{
  scroll-snap-align:start;
  display:block;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  box-shadow:0 14px 34px rgba(17,24,39,.08);
  transform:translateZ(0);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.sr-topiccard img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.sr-topiccard:hover{
  transform:translateY(-1px);
  border-color:rgba(165,39,41,.18);
  box-shadow:0 18px 44px rgba(17,24,39,.10);
}

/* ==========================================
   Asset details
   ========================================== */
.asset-detail-main{
  background:#fff;
}
.asset-detail-top{
  padding:10px 0 6px;
  border-bottom:1px solid rgba(229,231,235,.85);
}
.asset-detail-bc{ margin-bottom:8px; }

.asset-detail-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.asset-detail-h1{
  margin:0;
  font-weight:950;
  letter-spacing:-.02em;
  font-size:clamp(18px, 2.2vw, 28px);
  color:#111827;
}
.asset-detail-meta{
  margin-top:6px;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  color:#6b7280;
  font-size:12.4px;
}
.asset-detail-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  color:#374151;
  font-weight:850;
  font-size:12px;
}
.asset-detail-chip i{ color:#6b7280; }
.asset-detail-sep{ opacity:.7; }
.asset-detail-by a{
  color:var(--brand);
  font-weight:900;
  text-decoration:none;
}
.asset-detail-by a:hover{ text-decoration:underline; text-underline-offset:4px; }

.asset-detail-head-actions{
  display:flex;
  align-items:center;
  gap:8px;
}
.asset-detail-iconbtn{
  width:36px;
  height:36px;
  border-radius:999px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  display:grid;
  place-items:center;
  color:#374151;
  transition:box-shadow .14s ease, border-color .14s ease, transform .08s ease, color .14s ease;
}
.asset-detail-iconbtn:hover{
  border-color:rgba(165,39,41,.22);
  color:var(--brand-hover);
  box-shadow:0 12px 26px rgba(17,24,39,.08);
}
.asset-detail-iconbtn:active{ transform:translateY(1px); }

.asset-detail-body{
  padding:14px 0 18px;
}

.asset-detail-preview{}
.asset-detail-stage{
  position:relative;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.95);
  background:#0b0f14;
  box-shadow:0 20px 60px rgba(17,24,39,.12);
}
.asset-detail-img{
  width:100%;
  height:auto;
  display:block;
  object-fit:cover;
  max-height:min(66vh, 560px);
}
.asset-detail-wm{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  pointer-events:none;
}
.asset-detail-wm img{
  width:min(60%, 420px);
  height:auto;
  opacity:.16;
  filter:saturate(0) brightness(1.2);
  transform:rotate(-12deg);
}
.asset-detail-stage::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.30));
  pointer-events:none;
}

.asset-detail-stage-actions{
  position:absolute;
  right:10px;
  bottom:10px;
  display:flex;
  gap:8px;
  opacity:0;
  transform:translateY(6px);
  transition:opacity .14s ease, transform .14s ease;
  z-index:2;
}
.asset-detail-stage:hover .asset-detail-stage-actions{
  opacity:1;
  transform:translateY(0);
}
.asset-detail-fab{
  width:36px;
  height:36px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.90);
  display:grid;
  place-items:center;
  color:#111827;
  box-shadow:0 14px 30px rgba(17,24,39,.18);
  transition:transform .08s ease, border-color .14s ease, color .14s ease;
}
.asset-detail-fab i{ font-size:14px; }
.asset-detail-fab:hover{
  border-color:rgba(165,39,41,.30);
  color:var(--brand);
}
.asset-detail-fab:active{ transform:translateY(1px); }

.asset-detail-thumbs{
  margin-top:10px;
  display:flex;
  gap:10px;
  overflow:auto;
  padding-bottom:4px;
  scroll-behavior:smooth;
}
.asset-detail-thumbs::-webkit-scrollbar{ height:8px; }
.asset-detail-thumbs::-webkit-scrollbar-thumb{ background:rgba(17,24,39,.10); border-radius:999px; }
.asset-detail-thumb{
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  border-radius:12px;
  padding:0;
  overflow:hidden;
  width:92px;
  height:64px;
  flex:0 0 auto;
  transition:box-shadow .14s ease, border-color .14s ease, transform .08s ease;
}
.asset-detail-thumb img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.asset-detail-thumb:hover{
  border-color:rgba(165,39,41,.22);
  box-shadow:0 12px 26px rgba(17,24,39,.08);
}
.asset-detail-thumb.active{
  border-color:rgba(165,39,41,.55);
  box-shadow:0 0 0 .22rem rgba(165,39,41,.12);
}
.asset-detail-thumb:active{ transform:translateY(1px); }

.asset-detail-tabs{
  margin-top:14px;
  display:flex;
  gap:18px;
  border-bottom:1px solid rgba(229,231,235,.90);
}
.asset-detail-tab{
  border:0;
  background:transparent;
  padding:10px 2px;
  font-weight:950;
  font-size:12.6px;
  color:#6b7280;
  position:relative;
}
.asset-detail-tab.active{ color:#111827; }
.asset-detail-tab.active::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:2px;
  border-radius:999px;
  background:var(--brand);
}
.asset-detail-pane{ margin-top:12px; }
.asset-detail-pane[hidden]{ display:none !important; }

.asset-detail-card{
  border:1px solid rgba(229,231,235,.95);
  border-radius:14px;
  background:#fff;
  padding:12px;
  box-shadow:0 14px 34px rgba(17,24,39,.06);
}
.asset-detail-card-title{
  font-weight:950;
  font-size:12.6px;
  color:#111827;
  letter-spacing:-.01em;
  margin-bottom:10px;
}
.asset-detail-info{
  display:grid;
  gap:8px;
}
.asset-detail-info-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-size:12.6px;
  color:#6b7280;
}
.asset-detail-info-row b{
  color:#111827;
  font-weight:900;
}

.asset-detail-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.asset-detail-tag{
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  color:#374151;
  text-decoration:none;
  border-radius:999px;
  padding:6px 10px;
  font-weight:850;
  font-size:12px;
}
.asset-detail-tag:hover{
  border-color:rgba(165,39,41,.22);
  color:var(--brand-hover);
  box-shadow:0 12px 26px rgba(17,24,39,.08);
}

.asset-detail-note{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(229,231,235,.95);
  background:rgba(17,24,39,.02);
  color:#374151;
  font-size:12.6px;
  line-height:1.45;
}
.asset-detail-note i{
  margin-top:2px;
  color:var(--brand);
}
.asset-detail-note-soft{
  background:rgba(165,39,41,.04);
  border-color:rgba(165,39,41,.12);
}
.asset-detail-cols{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
}
@media (max-width: 575.98px){
  .asset-detail-cols{ grid-template-columns:1fr; }
}
.asset-detail-mini{
  border:1px solid rgba(229,231,235,.95);
  border-radius:14px;
  padding:10px 12px;
  background:#fff;
}
.asset-detail-mini-h{
  font-weight:950;
  font-size:12.6px;
  margin-bottom:8px;
}
.asset-detail-list{
  margin:0;
  padding-left:16px;
  color:#6b7280;
  font-size:12.4px;
}
.asset-detail-list li{ margin:6px 0; }

.asset-detail-side{
  position:sticky;
  top:98px;
}
@media (max-width: 991.98px){
  .asset-detail-side{ position:static; top:auto; }
}

.asset-detail-sidecard{
  border:1px solid rgba(229,231,235,.95);
  border-radius:16px;
  background:#fff;
  padding:12px;
  box-shadow:0 20px 60px rgba(17,24,39,.10);
}
.asset-detail-sidecard + .asset-detail-sidecard{ margin-top:12px; }

.asset-detail-side-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.asset-detail-price{
  font-size:22px;
  font-weight:950;
  letter-spacing:-.02em;
  color:#111827;
}
.asset-detail-subline{
  margin-top:3px;
  color:#6b7280;
  font-size:12.4px;
}
.asset-detail-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(165,39,41,.16);
  background:rgba(165,39,41,.06);
  color:var(--brand-hover);
  font-weight:900;
  font-size:12px;
  white-space:nowrap;
}
.asset-detail-pill i{ font-size:12px; }

.asset-detail-choices{
  margin-top:10px;
  display:grid;
  gap:10px;
}

/* Custom radio (project-wide pattern for user-side) */
.u-radio{
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  border-radius:14px;
  padding:10px 10px;
  display:flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
  transition:box-shadow .14s ease, border-color .14s ease, transform .08s ease;
  user-select:none;
}
.u-radio input{
  position:absolute;
  opacity:0;
  pointer-events:none;
  width:1px;
  height:1px;
  overflow:hidden;
}
.u-dot{
  width:16px;
  height:16px;
  border-radius:999px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  box-shadow:inset 0 0 0 2px rgba(17,24,39,.06);
  display:grid;
  place-items:center;
  flex:0 0 auto;
}
.u-dot::after{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--brand);
  transform:scale(0);
  transition:transform .12s ease;
}
.u-main{
  flex:1 1 auto;
  min-width:0;
}
.u-title{
  display:block;
  font-weight:950;
  font-size:12.6px;
  color:#111827;
  letter-spacing:-.01em;
}
.u-sub{
  display:block;
  margin-top:2px;
  color:#6b7280;
  font-size:12.2px;
  font-weight:650;
}
.u-price{
  font-weight:950;
  font-size:12.6px;
  color:#111827;
  white-space:nowrap;
}
.u-radio:hover{
  border-color:rgba(165,39,41,.18);
  box-shadow:0 14px 34px rgba(17,24,39,.08);
}
.u-radio:active{ transform:translateY(1px); }
.u-radio.is-checked{
  border-color:rgba(165,39,41,.50);
  box-shadow:0 0 0 .22rem rgba(165,39,41,.10);
}
.u-radio.is-checked .u-dot{
  border-color:rgba(165,39,41,.45);
}
.u-radio.is-checked .u-dot::after{
  transform:scale(1);
}
.u-radio.is-focus{
  box-shadow:0 0 0 .22rem rgba(165,39,41,.14);
  border-color:rgba(165,39,41,.55);
}
.u-radio input:checked + .u-dot::after{ transform:scale(1); }

.asset-detail-ctas{
  margin-top:10px;
  display:grid;
  gap:8px;
}
.asset-detail-ctas .btn{
  padding:.52rem .82rem;
  font-size:12.2px;
}

.asset-detail-minirow{
  margin-top:10px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.asset-detail-ghost{
  flex:1 1 auto;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  border-radius:12px;
  padding:8px 10px;
  font-weight:850;
  font-size:12px;
  color:#374151;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  transition:box-shadow .14s ease, border-color .14s ease, transform .08s ease, color .14s ease;
}
.asset-detail-ghost i{ color:#6b7280; }
.asset-detail-ghost:hover{
  border-color:rgba(165,39,41,.18);
  color:var(--brand-hover);
  box-shadow:0 12px 26px rgba(17,24,39,.08);
}
.asset-detail-ghost:active{ transform:translateY(1px); }

.asset-detail-similar{
  padding:18px 0 30px;
  border-top:1px solid rgba(229,231,235,.85);
  background:linear-gradient(180deg, rgba(165,39,41,.02), transparent);
}
.asset-detail-masonry{
  margin-top:12px;
}

/* Asset details (replica layout) */
.asset-detail-searchline .sr-search{ padding:10px 0; }

.asset-detail-shell{
  padding:12px 0 18px;
}

.asset-detail-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 360px;
  gap:22px;
  align-items:start;
}
@media (max-width: 991.98px){
  .asset-detail-grid{ grid-template-columns:1fr; }
}

.asset-detail-right{
  position:sticky;
  top:112px;
}
@media (max-width: 991.98px){
  .asset-detail-right{ position:static; top:auto; }
}

.asset-detail-stage{
  border-radius:10px;
  background:#fff;
  box-shadow:0 14px 34px rgba(17,24,39,.08);
}
.asset-detail-img{
  max-height:none;
}
.asset-detail-stage::after{
  background:linear-gradient(180deg, rgba(0,0,0,.00), rgba(0,0,0,.14));
}
.asset-detail-wm img{
  width:min(72%, 520px);
  opacity:.14;
  filter:saturate(0) contrast(1.05) brightness(1.15);
  transform:none;
}

.asset-detail-stagebar{
  position:absolute;
  right:12px;
  bottom:12px;
  display:flex;
  gap:8px;
  z-index:3;
}
.asset-detail-pillbtn{
  border:1px solid rgba(229,231,235,.95);
  background:rgba(255,255,255,.92);
  border-radius:999px;
  padding:7px 10px;
  font-weight:900;
  font-size:12px;
  color:#111827;
  display:inline-flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  box-shadow:0 14px 30px rgba(17,24,39,.14);
  transition:transform .08s ease, border-color .14s ease, box-shadow .14s ease, color .14s ease;
}
.asset-detail-pillbtn i{ color:#6b7280; font-size:12px; }
.asset-detail-pillbtn:hover{
  border-color:rgba(165,39,41,.22);
  color:var(--brand-hover);
  text-decoration:none;
  box-shadow:0 18px 44px rgba(17,24,39,.16);
}
.asset-detail-pillbtn:hover i{ color:var(--brand); }
.asset-detail-pillbtn:active{ transform:translateY(1px); }

.asset-detail-formats{
  margin-top:12px;
}
.asset-detail-sec-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}
.asset-detail-sec-title{
  font-weight:950;
  font-size:12.4px;
  color:#111827;
}
.asset-detail-formatrow{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.asset-detail-format{
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  border-radius:999px;
  padding:6px 10px;
  font-weight:850;
  font-size:12px;
  color:#374151;
  transition:box-shadow .14s ease, border-color .14s ease, transform .08s ease, color .14s ease, background-color .14s ease;
}
.asset-detail-format:hover{
  border-color:rgba(165,39,41,.20);
  box-shadow:0 12px 26px rgba(17,24,39,.08);
  color:var(--brand-hover);
}
.asset-detail-format:active{ transform:translateY(1px); }
.asset-detail-format.active{
  border-color:rgba(165,39,41,.45);
  background:rgba(165,39,41,.06);
  color:var(--brand-hover);
}

.asset-detail-buy{
  border:1px solid rgba(229,231,235,.95);
  border-radius:12px;
  background:#fff;
  box-shadow:0 18px 54px rgba(17,24,39,.10);
  padding:12px;
}
.asset-detail-buytop{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
}
.asset-detail-buytitle{
  font-weight:950;
  font-size:12.6px;
  color:#111827;
}
.asset-detail-buyprice{
  font-weight:950;
  letter-spacing:-.02em;
  color:#111827;
  font-size:18px;
}
.asset-detail-cur{
  font-size:12px;
  color:#6b7280;
  font-weight:900;
  margin-right:2px;
}
.asset-detail-buysub{
  margin-top:4px;
  color:#6b7280;
  font-size:12.4px;
}

.asset-detail-owned{
  margin-top:12px;
  padding:14px;
  border-radius:14px;
  border:1px solid rgba(165,39,41,.14);
  background:
    radial-gradient(180px 100px at 100% 0%, rgba(165,39,41,.08), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,249,249,.96));
  box-shadow:0 18px 38px rgba(165,39,41,.08);
}

.asset-detail-owned--error{
  background:linear-gradient(180deg, rgba(254,242,242,.96), rgba(255,255,255,.96));
  border-color:rgba(220,38,38,.18);
}

.asset-detail-owned__error{
  color:#991b1b;
  font-size:13px;
  font-weight:800;
  line-height:1.6;
}

.asset-detail-owned__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}

.asset-detail-owned__eyebrow{
  font-size:10.5px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:#8f3a3b;
  font-weight:900;
}

.asset-detail-owned__head strong{
  display:block;
  margin-top:4px;
  color:#111827;
  font-size:15px;
  font-weight:950;
}

.asset-detail-owned__badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(165,39,41,.10);
  color:var(--brand);
  font-size:11.5px;
  font-weight:900;
  white-space:nowrap;
}

.asset-detail-owned__sub{
  margin:10px 0 0;
  color:#6b7280;
  font-size:12.6px;
  line-height:1.55;
}

.asset-detail-owned__form{
  margin-top:12px;
  display:grid;
  gap:10px;
}

.asset-detail-owned__label{
  font-size:11px;
  color:#6b7280;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:900;
}

.asset-detail-owned__select{
  min-height:46px;
  border-radius:12px;
  border-color:rgba(229,231,235,.95);
  box-shadow:none;
  font-size:13px;
  font-weight:800;
}

.asset-detail-owned__select:focus{
  border-color:rgba(165,39,41,.32);
  box-shadow:0 0 0 .2rem rgba(165,39,41,.10);
}

.asset-detail-owned__meta{
  margin-top:12px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.asset-detail-owned__pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  color:#374151;
  font-size:11.5px;
  font-weight:900;
}

.asset-detail-radio{
  border-radius:12px;
  padding:10px;
}
.asset-detail-radio .u-sub{ line-height:1.35; }
.asset-detail-minilink{
  margin-top:6px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#6b7280;
  font-weight:850;
  font-size:12px;
}
.asset-detail-minilink i{
  color:var(--brand);
  font-size:12px;
}

.asset-detail-ctas .btn{
  padding:.54rem .82rem;
  font-size:12.4px;
}

.asset-detail-biz{
  margin-top:10px;
  width:100%;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  border-radius:12px;
  padding:10px 12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  text-align:left;
  transition:box-shadow .14s ease, border-color .14s ease, transform .08s ease;
}
.asset-detail-biz b{
  display:block;
  font-weight:950;
  font-size:12.6px;
  color:#111827;
}
.asset-detail-biz small{
  display:block;
  margin-top:2px;
  color:#6b7280;
  font-size:12.2px;
  font-weight:650;
}
.asset-detail-biz i{ color:#9ca3af; }
.asset-detail-biz:hover{
  border-color:rgba(165,39,41,.18);
  box-shadow:0 14px 34px rgba(17,24,39,.08);
}
.asset-detail-biz:active{ transform:translateY(1px); }

.asset-detail-details{
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid rgba(229,231,235,.85);
}
.asset-detail-dlist{
  display:grid;
  gap:8px;
}
.asset-detail-drow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-size:12.6px;
  color:#6b7280;
}
.asset-detail-drow b{
  color:#111827;
  font-weight:900;
}
.asset-detail-tagset{
  margin-top:10px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.asset-detail-tagset-inline{
  margin-top:0;
}

.asset-detail-block{
  padding:18px 0 22px;
  border-top:1px solid rgba(229,231,235,.85);
}
.asset-detail-soft{
  background:linear-gradient(180deg, rgba(165,39,41,.02), transparent);
}
.asset-detail-blockhead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.asset-detail-h2{
  margin:0;
  font-weight:950;
  letter-spacing:-.02em;
  font-size:clamp(16px, 2.0vw, 22px);
  color:#111827;
}

.asset-detail-simgrid{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  grid-auto-rows:118px;
  gap:10px;
}
.asset-detail-sim{
  border-radius:10px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  box-shadow:0 14px 34px rgba(17,24,39,.08);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.asset-detail-sim img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.asset-detail-sim:hover{
  transform:translateY(-1px);
  border-color:rgba(165,39,41,.18);
  box-shadow:0 18px 44px rgba(17,24,39,.10);
}
.asset-detail-sim-a{ grid-column:1; grid-row:1 / span 2; }
.asset-detail-sim-b{ grid-column:2; grid-row:1; }
.asset-detail-sim-c{ grid-column:3; grid-row:1; }
.asset-detail-sim-d{ grid-column:4; grid-row:1 / span 2; }
.asset-detail-sim-e{ grid-column:2 / span 2; grid-row:2; }
.asset-detail-sim-f{ grid-column:1 / span 2; grid-row:3; }
.asset-detail-sim-g{ grid-column:3 / span 2; grid-row:3; }
@media (max-width: 991.98px){
  .asset-detail-simgrid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    grid-auto-rows:128px;
  }
  .asset-detail-sim-a, .asset-detail-sim-d{ grid-row:auto; grid-column:auto; }
  .asset-detail-sim-e, .asset-detail-sim-f, .asset-detail-sim-g{ grid-row:auto; grid-column:auto; }
}

.asset-detail-recgrid{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  grid-auto-rows:128px;
  gap:10px;
}
.asset-detail-rec{
  border-radius:10px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  box-shadow:0 14px 34px rgba(17,24,39,.08);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.asset-detail-rec img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.asset-detail-rec:hover{
  transform:translateY(-1px);
  border-color:rgba(165,39,41,.18);
  box-shadow:0 18px 44px rgba(17,24,39,.10);
}
.asset-detail-rec-1{ grid-column:1; grid-row:1 / span 2; }
.asset-detail-rec-2{ grid-column:2; grid-row:1; }
.asset-detail-rec-3{ grid-column:3; grid-row:1; }
.asset-detail-rec-4{ grid-column:4; grid-row:1; }
.asset-detail-rec-5{ grid-column:2 / span 3; grid-row:2; }
.asset-detail-rec-6{ grid-column:1 / span 4; grid-row:3; }
@media (max-width: 991.98px){
  .asset-detail-recgrid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .asset-detail-rec-1, .asset-detail-rec-5, .asset-detail-rec-6{ grid-column:auto; grid-row:auto; }
}

.asset-detail-find{
  margin-top:14px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  padding-top:12px;
  border-top:1px solid rgba(229,231,235,.85);
}
.asset-detail-find-h{
  font-weight:950;
  font-size:12.8px;
  color:#111827;
}
.asset-detail-find-s{
  margin-top:3px;
  color:#6b7280;
  font-size:12.4px;
}

.asset-detail-artistgrid{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  grid-auto-rows:128px;
  gap:10px;
}
.asset-detail-art{
  border-radius:10px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  box-shadow:0 14px 34px rgba(17,24,39,.08);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.asset-detail-art img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.asset-detail-art:hover{
  transform:translateY(-1px);
  border-color:rgba(165,39,41,.18);
  box-shadow:0 18px 44px rgba(17,24,39,.10);
}
.asset-detail-art-1{ grid-column:1 / span 2; grid-row:1; }
.asset-detail-art-2{ grid-column:3; grid-row:1; }
.asset-detail-art-3{ grid-column:4; grid-row:1; }
.asset-detail-art-4{ grid-column:1; grid-row:2; }
.asset-detail-art-5{ grid-column:2; grid-row:2; }
.asset-detail-art-6{ grid-column:3 / span 2; grid-row:2; }
@media (max-width: 991.98px){
  .asset-detail-artistgrid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .asset-detail-art-1, .asset-detail-art-6{ grid-column:auto; grid-row:auto; }
}

/* ==========================================
   Pricing replica page
   ========================================== */
.prx-page{
  background:
    radial-gradient(1200px 420px at 50% 120px, rgba(165,39,41,.08), transparent 60%),
    linear-gradient(180deg, #f7f1e8 0%, #faf6ef 38%, #f6f1e8 100%);
  color:#111827;
}

.prx-header{
  position:sticky;
  top:0;
  z-index:120;
}

.prx-topbar,
.prx-navline{
  background:#111111;
}

.prx-topbar{
  border-bottom:1px solid rgba(255,255,255,.06);
}

.prx-topbar__inner{
  min-height:78px;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:12px;
}

.prx-topbar__spacer{
  min-height:1px;
}

.prx-wordmark{
  justify-self:center;
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:#fff;
  text-decoration:none;
  font-size:30px;
  font-weight:900;
  letter-spacing:-.04em;
}

.prx-wordmark:hover{
  color:#fff;
}

.prx-wordmark__dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:var(--brand);
  box-shadow:0 0 0 7px rgba(165,39,41,.18);
}

.prx-topbar__actions{
  justify-self:end;
  display:flex;
  align-items:center;
  gap:10px;
}

.prx-toplink{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#fff;
  text-decoration:none;
  font-size:13px;
  font-weight:700;
}

.prx-toplink:hover{
  color:#fff;
}

.prx-icon{
  width:34px;
  height:34px;
  border-radius:999px;
  display:grid;
  place-items:center;
  color:#fff;
  text-decoration:none;
  transition:background-color .15s ease, transform .08s ease;
}

.prx-icon:hover{
  color:#fff;
  background:rgba(255,255,255,.08);
}

.prx-icon:active{ transform:translateY(1px); }

.prx-login{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:78px;
  padding:10px 14px;
  border-radius:10px;
  background:#fff;
  color:#111111;
  text-decoration:none;
  font-size:14px;
  font-weight:800;
}

.prx-login:hover{
  color:#111111;
}

.prx-navline{
  padding:0 0 12px;
}

.prx-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:22px;
  flex-wrap:wrap;
}

.prx-nav a{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:#fff;
  text-decoration:none;
  font-size:13px;
  font-weight:650;
  opacity:.95;
}

.prx-nav a:hover{
  color:#fff;
  opacity:1;
}

.prx-main{
  padding-bottom:44px;
}

.prx-hero{
  padding:28px 0 24px;
}

.prx-title{
  margin:0;
  text-align:center;
  font-size:clamp(34px, 4vw, 54px);
  font-weight:900;
  letter-spacing:-.05em;
  color:#141414;
}

.prx-billing{
  margin:30px auto 0;
  width:max-content;
  max-width:100%;
  display:flex;
  align-items:center;
  border:1px solid rgba(17,17,17,.18);
  border-radius:12px;
  overflow:hidden;
  background:rgba(255,255,255,.55);
  box-shadow:0 8px 20px rgba(17,24,39,.05);
}

.prx-billing button{
  min-width:110px;
  border:0;
  border-right:1px solid rgba(17,17,17,.10);
  background:transparent;
  color:#4b5563;
  padding:13px 18px;
  font-size:15px;
  font-weight:700;
  transition:background-color .15s ease, color .15s ease;
}

.prx-billing button:last-child{
  border-right:0;
}

.prx-billing button.is-active{
  background:rgba(165,39,41,.09);
  color:#111111;
  box-shadow:inset 0 0 0 1px rgba(165,39,41,.30);
}

.prx-cardgrid{
  margin:32px auto 0;
  max-width:1120px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
}

.prx-plan{
  position:relative;
  border:1px solid rgba(17,17,17,.10);
  border-radius:18px;
  background:rgba(255,255,255,.88);
  box-shadow:0 16px 34px rgba(17,24,39,.08);
  min-height:520px;
}

.prx-plan--accent{
  border-color:rgba(165,39,41,.80);
  box-shadow:0 18px 38px rgba(165,39,41,.16);
}

.prx-plan__icon{
  position:absolute;
  top:18px;
  right:18px;
  color:#111111;
  font-size:14px;
}

.prx-plan__body{
  padding:40px 18px 20px;
}

.prx-plan__title{
  margin:0;
  font-size:24px;
  font-weight:900;
  letter-spacing:-.03em;
  color:#111111;
}

.prx-plan__copy{
  margin:10px 0 0;
  max-width:30ch;
  color:#374151;
  font-size:14px;
  line-height:1.45;
}

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

.prx-list li{
  display:flex;
  align-items:flex-start;
  gap:12px;
  color:#111111;
  font-size:14px;
  line-height:1.45;
}

.prx-list i{
  margin-top:2px;
  color:#111111;
  font-size:14px;
}

.prx-list--compact{
  margin-top:0;
  gap:11px;
}

.prx-control{
  margin-top:48px;
}

.prx-control--packs{
  margin-top:38px;
}

.prx-control__label{
  color:#111111;
  font-size:13px;
  font-weight:650;
}

.prx-chipset{
  margin-top:10px;
  display:inline-flex;
  align-items:center;
  border:1px solid rgba(17,17,17,.14);
  border-radius:10px;
  overflow:hidden;
  background:#fff;
}

.prx-chipset button{
  min-width:44px;
  border:0;
  border-right:1px solid rgba(17,17,17,.10);
  background:#fff;
  color:#6b7280;
  padding:8px 12px;
  font-size:16px;
  font-weight:700;
  line-height:1;
  transition:background-color .15s ease, color .15s ease, box-shadow .15s ease;
}

.prx-chipset button:last-child{
  border-right:0;
}

.prx-chipset button.is-active{
  color:#111111;
  box-shadow:inset 0 0 0 1.5px rgba(165,39,41,.85);
  background:rgba(165,39,41,.04);
}

.prx-price{
  margin-top:26px;
  display:flex;
  align-items:flex-end;
  gap:4px;
  color:#111111;
}

.prx-price--pack{
  margin-top:30px;
}

.prx-price__currency{
  margin-bottom:7px;
  font-size:26px;
  font-weight:900;
  line-height:1;
}

.prx-price__amount{
  font-size:58px;
  line-height:.9;
  font-weight:900;
  letter-spacing:-.06em;
}

.prx-price__term{
  margin-bottom:10px;
  font-size:17px;
  font-weight:700;
}

.prx-price__note{
  margin-top:10px;
  color:#374151;
  font-size:14px;
  font-weight:650;
}

.prx-btn{
  margin-top:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:56px;
  border-radius:10px;
  text-decoration:none;
  font-size:18px;
  font-weight:850;
  transition:transform .08s ease, box-shadow .15s ease, background-color .15s ease, border-color .15s ease, color .15s ease;
}

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

.prx-btn--solid{
  background:#111111;
  border:1px solid #111111;
  color:#fff;
}

.prx-btn--solid:hover{
  color:#fff;
  background:#1d1d1d;
}

.prx-btn--ghost{
  background:#fff;
  border:1px solid rgba(17,17,17,.14);
  color:#111111;
}

.prx-btn--ghost:hover{
  color:#111111;
  border-color:rgba(165,39,41,.55);
  box-shadow:0 12px 28px rgba(165,39,41,.10);
}

.prx-btn--small{
  width:auto;
  min-width:180px;
  min-height:48px;
  font-size:16px;
  padding:0 22px;
}

.prx-check{
  margin-top:16px;
  display:flex;
  align-items:center;
  gap:10px;
  color:#111111;
  font-size:14px;
  font-weight:650;
}

.prx-check input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.prx-check__box{
  width:18px;
  height:18px;
  border:1px solid rgba(17,17,17,.25);
  border-radius:4px;
  background:#fff;
  position:relative;
}

.prx-check input:checked + .prx-check__box{
  border-color:rgba(165,39,41,.75);
  background:rgba(165,39,41,.08);
}

.prx-check input:checked + .prx-check__box::after{
  content:"";
  position:absolute;
  left:5px;
  top:2px;
  width:5px;
  height:9px;
  border-right:2px solid var(--brand);
  border-bottom:2px solid var(--brand);
  transform:rotate(45deg);
}

.prx-learn{
  margin-top:8px;
  display:inline-flex;
  color:#111111;
  font-size:12px;
  font-weight:650;
  text-decoration:underline;
  text-underline-offset:3px;
}

.prx-fineprint{
  margin:20px 0 0;
  text-align:center;
  color:#4b5563;
  font-size:12px;
  font-weight:650;
}

.prx-enterprise{
  padding:22px 0 18px;
}

.prx-enterprise__card{
  border:1px solid rgba(17,17,17,.14);
  border-radius:16px;
  background:rgba(255,255,255,.82);
  box-shadow:0 14px 30px rgba(17,24,39,.06);
  display:grid;
  grid-template-columns:290px 1fr;
  gap:22px;
  padding:26px 24px;
}

.prx-enterprise__intro h2{
  margin:0;
  font-size:22px;
  font-weight:900;
  letter-spacing:-.03em;
}

.prx-enterprise__intro p{
  margin:12px 0 0;
  color:#374151;
  font-size:14px;
  line-height:1.55;
}

.prx-enterprise__content h3{
  margin:0;
  font-size:18px;
  font-weight:850;
  letter-spacing:-.02em;
}

.prx-enterprise__list{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:22px;
}

.prx-trusted{
  padding:32px 0 26px;
}

.prx-trusted h2{
  margin:0;
  text-align:center;
  font-size:17px;
  font-weight:850;
}

.prx-logos{
  margin-top:28px;
  display:grid;
  grid-template-columns:repeat(8, minmax(0, 1fr));
  gap:18px;
  align-items:center;
}

.prx-logos span{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  color:rgba(17,17,17,.62);
  font-size:15px;
  font-weight:900;
  letter-spacing:-.02em;
  text-align:center;
  filter:grayscale(1);
}

.prx-compare{
  padding:8px 0 24px;
}

.prx-tablewrap{
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 14px 30px rgba(17,24,39,.06);
}

.prx-table{
  width:100%;
  min-width:1020px;
  border-collapse:collapse;
  background:rgba(255,255,255,.72);
}

.prx-table th,
.prx-table td{
  padding:16px 18px;
  border-bottom:1px solid rgba(17,17,17,.08);
  color:#111111;
  font-size:14px;
  vertical-align:top;
}

.prx-table th{
  background:rgba(255,255,255,.50);
}

.prx-table th:nth-child(2),
.prx-table td:nth-child(2),
.prx-table th:nth-child(4),
.prx-table td:nth-child(4){
  background:rgba(255,255,255,.40);
}

.prx-table__lead{
  min-width:300px;
  text-align:left;
  font-size:22px !important;
  font-weight:900;
  letter-spacing:-.03em;
  line-height:1.1;
}

.prx-colhead{
  display:grid;
  gap:10px;
  justify-items:center;
  text-align:center;
}

.prx-colhead span{
  font-size:17px;
  font-weight:850;
}

.prx-colbtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:100px;
  min-height:34px;
  padding:0 12px;
  border-radius:10px;
  border:1px solid rgba(17,17,17,.18);
  background:#fff;
  color:#111111;
  text-decoration:none;
  font-size:13px;
  font-weight:750;
}

.prx-colbtn--dark{
  border-color:rgba(165,39,41,.40);
  background:rgba(165,39,41,.08);
}

.prx-table__section td{
  background:rgba(165,39,41,.04);
  color:#111111;
  font-size:18px;
  font-weight:850;
  border-bottom:1px solid rgba(165,39,41,.10);
}

.prx-table td:not(:first-child),
.prx-table th:not(:first-child){
  text-align:center;
}

.prx-table i{
  color:#111111;
}

.prx-table__muted{
  color:#9ca3af !important;
}

.prx-faq{
  padding:20px 0 36px;
}

.prx-faq h2{
  margin:0;
  text-align:center;
  font-size:44px;
  font-weight:900;
  letter-spacing:-.04em;
}

.prx-faq__acc{
  margin-top:24px;
}

.prx-faq__acc .accordion-item{
  border:0;
  border-bottom:1px solid rgba(17,17,17,.10);
  background:transparent;
}

.prx-faq__acc .accordion-button{
  padding:18px 0;
  background:transparent;
  color:#111111;
  font-size:18px;
  font-weight:800;
  box-shadow:none;
}

.prx-faq__acc .accordion-button:not(.collapsed){
  color:var(--brand);
}

.prx-faq__acc .accordion-button::after{
  filter:none;
}

.prx-faq__acc .accordion-body{
  padding:0 0 18px;
  max-width:72ch;
  color:#4b5563;
  font-size:14px;
  line-height:1.65;
}

/* ==========================================
   Cart page
   ========================================== */
.cart-page{
  background:
    radial-gradient(980px 340px at 50% 0, rgba(165,39,41,.10), transparent 60%),
    linear-gradient(180deg, #f8fafc 0%, #fff 26%);
}

.cart-main{
  min-height:calc(100vh - 260px);
}

.cart-hero{
  padding:20px 0 10px;
}

.cart-bc{
  margin-bottom:10px;
}

.cart-hero__row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}

.cart-title{
  margin:0;
  font-size:clamp(26px, 4vw, 42px);
  line-height:1.02;
  font-weight:900;
  letter-spacing:-.04em;
  color:#111827;
}

.cart-sub{
  margin:8px 0 0;
  color:#6b7280;
  font-size:13px;
  line-height:1.6;
}

.cart-continue{
  white-space:nowrap;
}

.cart-section{
  padding:12px 0 34px;
}

.cart-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.35fr) minmax(320px, .65fr);
  gap:18px;
  align-items:start;
}

.cart-col{
  display:grid;
  gap:14px;
}

.cart-summary{
  position:sticky;
  top:98px;
}

.cart-card{
  border:1px solid rgba(229,231,235,.95);
  border-radius:22px;
  background:rgba(255,255,255,.92);
  box-shadow:0 16px 40px rgba(17,24,39,.08);
}

.cart-status{
  padding:16px 18px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:14px;
  align-items:center;
}

.cart-status__icon{
  width:42px;
  height:42px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:rgba(165,39,41,.10);
  color:var(--brand);
  font-size:16px;
}

.cart-status__title{
  font-size:15px;
  font-weight:900;
  color:#111827;
}

.cart-status__copy{
  margin-top:4px;
  color:#6b7280;
  font-size:12.6px;
  line-height:1.5;
}

.cart-pill{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:11px;
  font-weight:850;
  white-space:nowrap;
}

.cart-items{
  display:grid;
  gap:14px;
}

.cart-item{
  display:grid;
  grid-template-columns:188px 1fr;
  gap:16px;
  padding:16px;
  border:1px solid rgba(229,231,235,.95);
  border-radius:22px;
  background:#fff;
  box-shadow:0 16px 38px rgba(17,24,39,.07);
}

.cart-item__media{
  position:relative;
  overflow:hidden;
  border-radius:18px;
  min-height:160px;
}

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

.cart-badge{
  position:absolute;
  top:12px;
  left:12px;
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(17,24,39,.82);
  color:#fff;
  font-size:11px;
  font-weight:800;
}

.cart-badge--soft{
  background:rgba(165,39,41,.88);
}

.cart-item__body{
  min-width:0;
}

.cart-item__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.cart-item__top h2{
  margin:0;
  font-size:20px;
  font-weight:900;
  letter-spacing:-.02em;
  color:#111827;
}

.cart-item__top p{
  margin:8px 0 0;
  color:#6b7280;
  font-size:12.8px;
  line-height:1.55;
}

.cart-remove{
  width:38px;
  height:38px;
  border-radius:12px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  color:#6b7280;
  display:grid;
  place-items:center;
  transition:border-color .15s ease, color .15s ease, box-shadow .15s ease;
}

.cart-remove:hover{
  color:var(--brand);
  border-color:rgba(165,39,41,.35);
  box-shadow:0 10px 22px rgba(165,39,41,.10);
}

.cart-meta{
  margin-top:12px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.cart-meta span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 11px;
  border-radius:999px;
  background:rgba(17,24,39,.04);
  color:#374151;
  font-size:11.5px;
  font-weight:750;
}

.cart-item__bottom{
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid rgba(229,231,235,.85);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.cart-qty{
  display:inline-flex;
  align-items:center;
  border:1px solid rgba(229,231,235,.95);
  border-radius:999px;
  overflow:hidden;
  background:#fff;
}

.cart-qty button{
  width:42px;
  height:42px;
  border:0;
  background:#fff;
  color:#374151;
}

.cart-qty button:hover{
  background:rgba(165,39,41,.06);
  color:var(--brand);
}

.cart-qty span{
  min-width:42px;
  text-align:center;
  font-size:14px;
  font-weight:850;
  color:#111827;
}

.cart-price{
  display:flex;
  align-items:flex-end;
  gap:4px;
  color:#111827;
}

.cart-price span{
  margin-bottom:6px;
  font-size:13px;
  font-weight:850;
}

.cart-price strong{
  font-size:32px;
  line-height:.95;
  font-weight:900;
  letter-spacing:-.04em;
}

.cart-empty{
  padding:38px 24px;
  border:1px dashed rgba(165,39,41,.28);
  border-radius:24px;
  background:rgba(255,255,255,.80);
  text-align:center;
}

.cart-empty__icon{
  width:68px;
  height:68px;
  margin:0 auto;
  border-radius:20px;
  display:grid;
  place-items:center;
  background:rgba(165,39,41,.10);
  color:var(--brand);
  font-size:26px;
}

.cart-empty h2{
  margin:16px 0 0;
  font-size:26px;
  font-weight:900;
  letter-spacing:-.03em;
}

.cart-empty p{
  margin:10px auto 0;
  max-width:42ch;
  color:#6b7280;
  font-size:13px;
  line-height:1.6;
}

.cart-empty__actions{
  margin-top:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
}

.cart-addons{
  padding:18px;
}

.cart-blockhead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.cart-blockhead h2{
  margin:0;
  font-size:20px;
  font-weight:900;
  letter-spacing:-.02em;
  color:#111827;
}

.cart-blockhead p{
  margin:6px 0 0;
  color:#6b7280;
  font-size:12.6px;
}

.cart-addonlist{
  margin-top:14px;
  display:grid;
  gap:12px;
}

.cart-addon{
  display:grid;
  grid-template-columns:auto auto 1fr auto;
  gap:12px;
  align-items:start;
  padding:14px;
  border:1px solid rgba(229,231,235,.95);
  border-radius:18px;
  background:#fff;
}

.cart-addon input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.cart-addon__box{
  width:20px;
  height:20px;
  border-radius:6px;
  border:1px solid rgba(17,24,39,.18);
  background:#fff;
  position:relative;
}

.cart-addon input:checked + .cart-addon__box{
  border-color:rgba(165,39,41,.60);
  background:rgba(165,39,41,.08);
}

.cart-addon input:checked + .cart-addon__box::after{
  content:"";
  position:absolute;
  left:6px;
  top:2px;
  width:6px;
  height:11px;
  border-right:2px solid var(--brand);
  border-bottom:2px solid var(--brand);
  transform:rotate(45deg);
}

.cart-addon__copy strong{
  display:block;
  color:#111827;
  font-size:14px;
  font-weight:850;
}

.cart-addon__copy small{
  display:block;
  margin-top:5px;
  color:#6b7280;
  font-size:12.4px;
  line-height:1.5;
}

.cart-addon__price{
  color:#111827;
  font-size:13px;
  font-weight:850;
  white-space:nowrap;
}

.cart-summary__card{
  padding:18px;
}

.cart-coupon{
  margin-top:16px;
  display:block;
}

.cart-coupon > span{
  display:block;
  margin-bottom:8px;
  color:#374151;
  font-size:12.4px;
  font-weight:800;
}

.cart-coupon__row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
}

.cart-totals{
  margin-top:16px;
  padding:16px 0;
  border-top:1px solid rgba(229,231,235,.85);
  border-bottom:1px solid rgba(229,231,235,.85);
  display:grid;
  gap:12px;
}

.cart-totals div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:#374151;
  font-size:13px;
  font-weight:700;
}

.cart-totals strong{
  color:#111827;
  font-weight:850;
}

.cart-total{
  padding-top:8px;
  border-top:1px dashed rgba(229,231,235,.95);
}

.cart-total span,
.cart-total strong{
  font-size:16px !important;
  font-weight:900 !important;
}

.cart-trust{
  margin-top:16px;
  display:grid;
  gap:10px;
}

.cart-trust div{
  display:flex;
  align-items:center;
  gap:10px;
  color:#374151;
  font-size:12.4px;
  font-weight:750;
}

.cart-trust i{
  width:18px;
  color:var(--brand);
}

.cart-help{
  margin-top:14px;
  padding:16px 18px;
}

.cart-help h3{
  margin:0;
  font-size:18px;
  font-weight:900;
  letter-spacing:-.02em;
  color:#111827;
}

.cart-help p{
  margin:8px 0 0;
  color:#6b7280;
  font-size:12.6px;
  line-height:1.55;
}

/* ==========================================
   Checkout page
   ========================================== */
.checkout-page{
  background:
    radial-gradient(1100px 460px at 12% 0%, rgba(165,39,41,.14), transparent 62%),
    radial-gradient(900px 420px at 100% 18%, rgba(17,24,39,.05), transparent 58%),
    linear-gradient(180deg, #faf8f6 0%, #ffffff 28%);
}

.checkout-main{
  min-height:calc(100vh - 260px);
}

.checkout-hero{
  padding:22px 0 12px;
}

.checkout-bc{
  margin-bottom:14px;
}

.checkout-hero__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
}

.checkout-copy{
  max-width:780px;
}

.checkout-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.checkout-title{
  margin:12px 0 0;
  font-size:clamp(34px, 5vw, 58px);
  line-height:.96;
  font-weight:900;
  letter-spacing:-.04em;
  color:#111827;
}

.checkout-sub{
  max-width:760px;
  margin:12px 0 0;
  color:#6b7280;
  font-size:14px;
  line-height:1.6;
}

.checkout-hero__trust{
  display:grid;
  gap:8px;
  justify-items:end;
  text-align:right;
}

.checkout-trustpill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:11px 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(229,231,235,.92);
  color:#111827;
  font-size:12px;
  font-weight:900;
  box-shadow:0 16px 36px rgba(17,24,39,.06);
}

.checkout-trustpill i{
  color:var(--brand);
}

.checkout-trustnote{
  color:#6b7280;
  font-size:12px;
  font-weight:700;
}

.checkout-steps{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
}

.checkout-step{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border:1px solid rgba(229,231,235,.92);
  border-radius:18px;
  background:rgba(255,255,255,.84);
  box-shadow:0 14px 34px rgba(17,24,39,.04);
}

.checkout-step__dot{
  width:34px;
  height:34px;
  border-radius:999px;
  display:grid;
  place-items:center;
  font-size:13px;
  font-weight:900;
  color:#6b7280;
  background:rgba(17,24,39,.05);
  flex:0 0 auto;
}

.checkout-step strong{
  display:block;
  font-size:13px;
  font-weight:900;
  color:#111827;
}

.checkout-step span:last-child{
  display:block;
  margin-top:2px;
  font-size:12px;
  color:#6b7280;
}

.checkout-step.is-active{
  border-color:rgba(165,39,41,.24);
  box-shadow:0 18px 44px rgba(165,39,41,.10);
}

.checkout-step.is-active .checkout-step__dot,
.checkout-step.is-complete .checkout-step__dot{
  background:rgba(165,39,41,.10);
  color:var(--brand);
}

.checkout-section{
  padding:14px 0 40px;
}

.checkout-layout{
  display:grid;
  grid-template-columns:minmax(0, 1.18fr) minmax(340px, .82fr);
  gap:22px;
  align-items:start;
}

.checkout-primary{
  display:grid;
  gap:18px;
}

.checkout-sidebar{
  position:sticky;
  top:104px;
}

.checkout-card{
  border:1px solid rgba(229,231,235,.95);
  border-radius:24px;
  background:rgba(255,255,255,.92);
  box-shadow:0 18px 46px rgba(17,24,39,.06);
  padding:22px;
  margin-bottom:18px;
}

.checkout-card--spotlight{
  background:
    radial-gradient(420px 180px at 0% 0%, rgba(165,39,41,.10), transparent 65%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.88));
}

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

.checkout-spotlight__metric{
  border:1px solid rgba(229,231,235,.92);
  border-radius:18px;
  background:rgba(255,255,255,.72);
  padding:14px 16px;
}

.checkout-spotlight__metric span{
  display:block;
  font-size:11px;
  color:#6b7280;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:800;
}

.checkout-spotlight__metric strong{
  display:block;
  margin-top:8px;
  font-size:18px;
  line-height:1.25;
  font-weight:950;
  color:#111827;
  word-break:break-word;
}

.checkout-card__head{
  display:flex;
  align-items:flex-start;
  gap:14px;
  margin-bottom:18px;
}

.checkout-card__icon{
  width:48px;
  height:48px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:rgba(165,39,41,.10);
  color:var(--brand);
  font-size:18px;
  flex:0 0 auto;
}

.checkout-card__head h2{
  margin:0;
  font-size:24px;
  font-weight:900;
  letter-spacing:-.02em;
  color:#111827;
}

.checkout-card__head p{
  margin:6px 0 0;
  color:#6b7280;
  font-size:13px;
  line-height:1.55;
}

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

.checkout-fieldgrid--single{
  grid-template-columns:1fr;
}

.checkout-field{
  display:grid;
  gap:8px;
}

.checkout-field__label{
  font-size:11px;
  color:#6b7280;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:800;
}

.checkout-readonly{
  min-height:58px;
  display:flex;
  align-items:center;
  padding:0 16px;
  border-radius:18px;
  border:1px solid rgba(229,231,235,.95);
  background:linear-gradient(180deg, rgba(249,250,251,.96), rgba(255,255,255,.94));
  color:#111827;
  font-weight:800;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9);
}

.checkout-input{
  width:100%;
  min-height:58px;
  padding:0 16px;
  border-radius:18px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  color:#111827;
  font-size:14px;
  font-weight:800;
  transition:border-color .15s ease, box-shadow .15s ease;
}

.checkout-input:focus{
  outline:none;
  border-color:rgba(165,39,41,.34);
  box-shadow:0 0 0 4px rgba(165,39,41,.10);
}

.checkout-meta{
  margin-top:14px;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.checkout-meta__chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:850;
}

.checkout-meta__chip.is-ok{
  background:rgba(16,185,129,.10);
  color:#047857;
}

.checkout-meta__chip.is-warn{
  background:rgba(245,158,11,.10);
  color:#b45309;
}

.checkout-meta__link{
  color:var(--brand);
  font-size:12.5px;
  font-weight:850;
}

.checkout-methods{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
  margin-bottom:18px;
}

.checkout-methods__head{
  margin-bottom:12px;
}

.checkout-methods__eyebrow{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(17,24,39,.05);
  color:#374151;
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.checkout-methods button{
  border:1px solid rgba(229,231,235,.95);
  border-radius:18px;
  background:#fff;
  color:#374151;
  min-height:66px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  font-size:14px;
  font-weight:900;
  transition:border-color .15s ease, box-shadow .15s ease, color .15s ease, background-color .15s ease, transform .08s ease;
}

.checkout-methods button.is-active{
  color:var(--brand);
  border-color:rgba(165,39,41,.34);
  background:rgba(165,39,41,.05);
  box-shadow:0 16px 36px rgba(165,39,41,.08);
}

.checkout-panel{
  margin-top:18px;
}

.checkout-stripe{
  display:grid;
  gap:16px;
}

.checkout-stripe__hero{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:18px 20px;
  border-radius:24px;
  background:linear-gradient(135deg, rgba(165,39,41,.96), rgba(86,19,22,.92));
  color:#fff;
  box-shadow:0 24px 50px rgba(165,39,41,.16);
}

.checkout-stripe__hero strong{
  display:block;
  margin-top:4px;
  font-size:20px;
  font-weight:900;
}

.checkout-stripe__eyebrow{
  font-size:11px;
  letter-spacing:.1em;
  text-transform:uppercase;
  font-weight:800;
  opacity:.78;
}

.checkout-stripe__fields{
  gap:14px;
}

.checkout-stripe__mount{
  position:relative;
  border:1px solid rgba(229,231,235,.95);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(249,250,251,.92));
  padding:18px;
  min-height:108px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.95);
}

.checkout-stripe__loader{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:72px;
  color:#6b7280;
  font-size:13px;
  font-weight:700;
}

.checkout-stripe__spinner{
  width:18px;
  height:18px;
  border:2px solid rgba(165,39,41,.18);
  border-top-color:var(--brand);
  border-radius:50%;
  animation:checkout-spin .7s linear infinite;
}

.checkout-stripe__element{
  min-height:72px;
}

.checkout-stripe__status{
  font-size:12.5px;
  color:#6b7280;
  font-weight:700;
}

.checkout-stripe__status.is-ready{
  color:#0f766e;
}

.checkout-stripe__status.is-error{
  color:#b42318;
}

.checkout-stripe__error{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:14px 16px;
  border-radius:16px;
  background:rgba(180,35,24,.08);
  color:#8a1c13;
  font-size:13px;
  font-weight:700;
  line-height:1.5;
}

.checkout-stripe__error i{
  margin-top:2px;
}

.checkout-stripe__error.is-server{
  background:rgba(165,39,41,.08);
  color:#7f1d1d;
}

.checkout-cardui{
  padding:18px;
  border-radius:24px;
  background:
    linear-gradient(135deg, rgba(165,39,41,.95), rgba(84,18,20,.92));
  color:#fff;
  box-shadow:0 24px 48px rgba(165,39,41,.18);
}

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

.checkout-cardui__label{
  font-size:11px;
  letter-spacing:.1em;
  text-transform:uppercase;
  font-weight:800;
  opacity:.84;
}

.checkout-cardui__brands{
  display:flex;
  align-items:center;
  gap:10px;
}

.checkout-cardui__brands i{
  font-size:24px;
}

.checkout-cardui__number{
  margin-top:26px;
  font-size:clamp(22px, 3vw, 34px);
  font-weight:900;
  letter-spacing:.14em;
}

.checkout-cardui__meta{
  margin-top:24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  font-size:13px;
  font-weight:800;
}

.checkout-mockfields{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
}

.checkout-mockinput{
  border:1px solid rgba(229,231,235,.95);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(249,250,251,.9));
  padding:14px 15px;
}

.checkout-mockinput span{
  display:block;
  font-size:11px;
  color:#6b7280;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:800;
}

.checkout-mockinput strong{
  display:block;
  margin-top:8px;
  font-size:13px;
  color:#111827;
  font-weight:900;
}

.checkout-paymentnote{
  margin-top:16px;
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:15px 16px;
  border-radius:18px;
  background:rgba(17,24,39,.04);
  color:#374151;
  font-size:12.5px;
  font-weight:700;
  line-height:1.5;
}

.checkout-paymentnote i{
  margin-top:2px;
  color:var(--brand);
}

.checkout-submit.is-loading{
  opacity:.92;
  cursor:wait;
}

.checkout-invoicebox{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:18px;
  border:1px solid rgba(229,231,235,.95);
  border-radius:20px;
  background:linear-gradient(180deg, rgba(249,250,251,.94), rgba(255,255,255,.92));
}

.checkout-invoicebox__icon{
  width:50px;
  height:50px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:rgba(165,39,41,.10);
  color:var(--brand);
  font-size:18px;
  flex:0 0 auto;
}

.checkout-invoicebox strong{
  display:block;
  color:#111827;
  font-size:16px;
  font-weight:900;
}

.checkout-invoicebox p{
  margin:8px 0 0;
  color:#6b7280;
  font-size:13px;
  line-height:1.6;
}

.checkout-confirmlist{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}

.checkout-confirmlist li{
  display:grid;
  gap:12px;
  grid-template-columns:18px 1fr;
  color:#374151;
  font-size:13px;
  font-weight:750;
  line-height:1.5;
}

.checkout-confirmlist i{
  color:var(--brand);
  margin-top:2px;
}

.checkout-review{
  margin-top:18px;
}

.checkout-check{
  display:flex;
  align-items:flex-start;
  gap:12px;
  color:#374151;
  font-size:13px;
  line-height:1.6;
  font-weight:750;
}

.checkout-check input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.checkout-check__box{
  width:20px;
  height:20px;
  border-radius:6px;
  border:1px solid rgba(17,24,39,.18);
  background:#fff;
  position:relative;
  flex:0 0 auto;
}

.checkout-check input:checked + .checkout-check__box{
  border-color:rgba(165,39,41,.60);
  background:rgba(165,39,41,.08);
}

.checkout-check input:checked + .checkout-check__box::after{
  content:"";
  position:absolute;
  left:6px;
  top:2px;
  width:6px;
  height:11px;
  border-right:2px solid var(--brand);
  border-bottom:2px solid var(--brand);
  transform:rotate(45deg);
}

.checkout-alert{
  margin-top:18px;
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:16px;
  border-radius:18px;
  border:1px solid rgba(245,158,11,.26);
  background:rgba(245,158,11,.08);
  color:#92400e;
  font-size:12.8px;
  font-weight:800;
  line-height:1.55;
}

.checkout-alert i{
  margin-top:2px;
}

.checkout-cta{
  margin-top:18px;
}

.checkout-submit{
  min-height:58px;
  font-size:16px;
  font-weight:900;
  letter-spacing:-.01em;
}

.checkout-summarycard{
  border:1px solid rgba(229,231,235,.95);
  border-radius:28px;
  background:
    radial-gradient(420px 220px at 100% 0%, rgba(165,39,41,.10), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.90));
  box-shadow:0 22px 54px rgba(17,24,39,.08);
  padding:22px;
}

.checkout-summarycard__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}

.checkout-summarycard__eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(17,24,39,.05);
  color:#374151;
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.1em;
}

.checkout-summarycard h2{
  margin:12px 0 0;
  font-size:30px;
  line-height:.98;
  font-weight:950;
  color:#111827;
}

.checkout-summarycard p{
  margin:10px 0 0;
  color:#6b7280;
  font-size:13px;
  line-height:1.55;
}

.checkout-summarybadge{
  display:inline-flex;
  align-items:center;
  padding:9px 12px;
  border-radius:999px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:11.5px;
  font-weight:900;
}

.checkout-summaryitems{
  margin-top:18px;
  display:grid;
  gap:12px;
}

.checkout-summaryitem{
  display:grid;
  grid-template-columns:78px 1fr auto;
  align-items:center;
  gap:12px;
  padding:12px 0;
  border-bottom:1px solid rgba(229,231,235,.8);
}

.checkout-summaryitem:last-child{
  border-bottom:0;
}

.checkout-summaryitem__media{
  border-radius:18px;
  overflow:hidden;
  height:74px;
  background:#f3f4f6;
}

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

.checkout-summaryitem__title{
  font-size:14px;
  font-weight:900;
  color:#111827;
}

.checkout-summaryitem__meta{
  margin-top:6px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.checkout-summaryitem__meta span{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(17,24,39,.05);
  color:#6b7280;
  font-size:11px;
  font-weight:800;
}

.checkout-summaryitem__license{
  background:rgba(165,39,41,.08) !important;
  color:var(--brand) !important;
}

.checkout-summaryitem__price{
  color:#111827;
  font-size:16px;
  font-weight:950;
  white-space:nowrap;
}

.checkout-summarytotals{
  margin-top:16px;
  padding:18px 0;
  border-top:1px solid rgba(229,231,235,.82);
  border-bottom:1px solid rgba(229,231,235,.82);
  display:grid;
  gap:12px;
}

.checkout-summarytotals div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  color:#374151;
  font-size:13px;
  font-weight:800;
}

.checkout-summarytotals strong{
  color:#111827;
  font-weight:950;
}

.checkout-summarytotals__main{
  padding-top:12px;
  border-top:1px dashed rgba(229,231,235,.95);
}

.checkout-summarytotals__main span,
.checkout-summarytotals__main strong{
  font-size:18px !important;
  font-weight:950 !important;
}

.checkout-assurance{
  margin-top:16px;
  display:grid;
  gap:10px;
}

.checkout-assurance div{
  display:flex;
  align-items:center;
  gap:10px;
  color:#374151;
  font-size:12.5px;
  font-weight:800;
}

.checkout-assurance i{
  width:18px;
  color:var(--brand);
}

.checkout-summaryactions{
  margin-top:18px;
  display:grid;
  gap:12px;
}

.checkout-help{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--brand);
  font-size:12.5px;
  font-weight:900;
}

.checkout-empty{
  border:1px solid rgba(229,231,235,.92);
  border-radius:28px;
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.92));
  box-shadow:0 22px 56px rgba(17,24,39,.06);
  padding:42px 28px;
  text-align:center;
}

.checkout-empty__icon{
  width:74px;
  height:74px;
  margin:0 auto 18px;
  border-radius:22px;
  display:grid;
  place-items:center;
  background:rgba(165,39,41,.10);
  color:var(--brand);
  font-size:26px;
}

.checkout-empty h2{
  margin:0;
  font-size:30px;
  font-weight:950;
  color:#111827;
}

.checkout-empty p{
  max-width:520px;
  margin:12px auto 0;
  color:#6b7280;
  font-size:14px;
  line-height:1.6;
}

.checkout-empty__actions{
  margin-top:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
}

@keyframes checkout-spin{
  to{
    transform:rotate(360deg);
  }
}

@media (max-width: 1199.98px){
  .checkout-layout{
    grid-template-columns:1fr;
  }

  .checkout-sidebar{
    position:static;
    top:auto;
  }
}

@media (max-width: 991.98px){
  .checkout-steps,
  .checkout-spotlight,
  .checkout-fieldgrid,
  .checkout-mockfields{
    grid-template-columns:1fr;
  }

  .checkout-hero__trust{
    justify-items:start;
    text-align:left;
  }

  .checkout-methods{
    grid-template-columns:1fr;
  }

  .checkout-summaryitem{
    grid-template-columns:72px 1fr;
  }

  .checkout-summaryitem__price{
    grid-column:2;
  }

  .checkout-stripe__hero{
    align-items:flex-start;
    flex-direction:column;
  }
}

@media (max-width: 767.98px){
  .checkout-card,
  .checkout-summarycard,
  .checkout-empty{
    padding:18px;
    border-radius:22px;
  }

  .checkout-title{
    font-size:40px;
  }

  .checkout-card__head h2{
    font-size:22px;
  }

  .checkout-summarycard h2{
    font-size:26px;
  }
}

/* ==========================================
   Pricing page
   ========================================== */
.pr-main{
  background:#fff;
}
.pr-searchline .sr-search{
  padding:10px 0;
}
.pr-hero{
  position:relative;
  overflow:hidden;
  padding:22px 0 20px;
  background:
    radial-gradient(900px 420px at 14% 18%, rgba(165,39,41,.18), transparent 56%),
    radial-gradient(900px 420px at 86% 74%, rgba(17,24,39,.06), transparent 56%),
    linear-gradient(180deg, rgba(165,39,41,.03), rgba(165,39,41,0));
  border-bottom:1px solid rgba(229,231,235,.85);
}
.pr-bc{ margin-bottom:10px; }
.pr-shell{
  display:grid;
  grid-template-columns:minmax(0, 1.1fr) minmax(320px, .9fr);
  gap:16px;
  align-items:start;
}
@media (max-width: 991.98px){
  .pr-shell{ grid-template-columns:1fr; }
}
.pr-copy{
  padding:10px 2px 8px;
}
.pr-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-weight:850;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-size:11px;
}
.pr-h1{
  margin:12px 0 0;
  font-weight:950;
  letter-spacing:-.03em;
  font-size:clamp(24px, 4vw, 42px);
  line-height:1.02;
  color:#111827;
}
.pr-lead{
  margin:12px 0 0;
  max-width:62ch;
  color:#6b7280;
  font-size:13.2px;
  line-height:1.65;
}
.pr-actions{
  margin-top:16px;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.pr-switch{
  margin-top:18px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px;
  border-radius:999px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  box-shadow:0 14px 34px rgba(17,24,39,.08);
}
.pr-switch button{
  border:0;
  background:transparent;
  color:#6b7280;
  font-size:12px;
  font-weight:850;
  padding:8px 14px;
  border-radius:999px;
  transition:background-color .14s ease, color .14s ease, transform .06s ease, box-shadow .14s ease;
}
.pr-switch button.is-active{
  background:rgba(165,39,41,.10);
  color:var(--brand);
  box-shadow:inset 0 0 0 1px rgba(165,39,41,.12);
}
.pr-switch button:active{ transform:translateY(1px); }
.pr-note{
  margin-top:10px;
  color:#6b7280;
  font-size:12.2px;
  font-weight:700;
}
.pr-overview{
  display:grid;
  gap:12px;
}
.pr-mini{
  border:1px solid rgba(229,231,235,.95);
  border-radius:20px;
  background:#fff;
  padding:16px;
  box-shadow:0 16px 38px rgba(17,24,39,.08);
}
.pr-mini-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.pr-mini-tag{
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:11px;
  font-weight:850;
}
.pr-mini h3{
  margin:12px 0 0;
  font-size:18px;
  font-weight:950;
  color:#111827;
}
.pr-mini p{
  margin:8px 0 0;
  color:#6b7280;
  font-size:12.6px;
  line-height:1.55;
}
.pr-metrics{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}
@media (max-width: 575.98px){
  .pr-metrics{ grid-template-columns:1fr; }
}
.pr-metric{
  border:1px solid rgba(229,231,235,.9);
  border-radius:16px;
  padding:12px;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.90));
}
.pr-metric b{
  display:block;
  font-size:20px;
  font-weight:950;
  line-height:1;
  color:#111827;
}
.pr-metric span{
  display:block;
  margin-top:6px;
  color:#6b7280;
  font-size:12px;
  font-weight:700;
}

.pr-section{
  padding:22px 0;
}
.pr-soft{
  background:linear-gradient(180deg, rgba(165,39,41,.03), rgba(165,39,41,0));
}
.pr-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.pr-head h2{
  margin:0;
  font-weight:950;
  letter-spacing:-.02em;
  font-size:clamp(18px, 2.2vw, 26px);
  color:#111827;
}
.pr-head p{
  margin:6px 0 0;
  color:#6b7280;
  font-size:12.8px;
}

.pr-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
}
@media (max-width: 991.98px){
  .pr-grid{ grid-template-columns:1fr; }
}
.pr-card{
  position:relative;
  border:1px solid rgba(229,231,235,.95);
  border-radius:22px;
  background:#fff;
  padding:16px;
  box-shadow:0 16px 38px rgba(17,24,39,.08);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.pr-card:hover{
  transform:translateY(-2px);
  border-color:rgba(165,39,41,.22);
  box-shadow:0 22px 48px rgba(17,24,39,.10);
}
.pr-card.is-featured{
  border-color:rgba(165,39,41,.30);
  box-shadow:0 24px 54px rgba(165,39,41,.12);
}
.pr-ribbon{
  position:absolute;
  top:14px;
  right:14px;
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:7px 10px;
  border-radius:999px;
  background:#111827;
  color:#fff;
  font-size:11px;
  font-weight:850;
}
.pr-tier{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--brand);
  font-size:11px;
  font-weight:850;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.pr-title{
  margin-top:12px;
  font-size:22px;
  font-weight:950;
  color:#111827;
  letter-spacing:-.02em;
}
.pr-sub{
  margin-top:8px;
  color:#6b7280;
  font-size:12.8px;
  line-height:1.55;
}
.pr-price{
  margin-top:16px;
  display:flex;
  align-items:flex-end;
  gap:8px;
}
.pr-price .cur{
  margin-bottom:7px;
  color:#6b7280;
  font-size:12px;
  font-weight:850;
}
.pr-price .amt{
  font-size:42px;
  line-height:.95;
  font-weight:950;
  letter-spacing:-.04em;
  color:#111827;
}
.pr-price .per{
  margin-bottom:8px;
  color:#6b7280;
  font-size:12px;
  font-weight:750;
}
.pr-save{
  margin-top:8px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(17,24,39,.05);
  color:#374151;
  font-size:11px;
  font-weight:850;
}
.pr-list{
  margin:14px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.pr-list li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:#374151;
  font-size:12.6px;
  line-height:1.5;
}
.pr-list i{
  margin-top:2px;
  color:var(--brand);
}
.pr-card .btn{
  margin-top:16px;
  width:100%;
}
.pr-minirow{
  margin-top:10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  color:#6b7280;
  font-size:12px;
  font-weight:700;
}

.pr-creditgrid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:12px;
}
@media (max-width: 991.98px){
  .pr-creditgrid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 575.98px){
  .pr-creditgrid{ grid-template-columns:1fr; }
}
.pr-pack{
  border:1px solid rgba(229,231,235,.95);
  border-radius:20px;
  background:#fff;
  padding:14px;
  box-shadow:0 16px 38px rgba(17,24,39,.07);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.pr-pack:hover{
  transform:translateY(-1px);
  border-color:rgba(165,39,41,.22);
  box-shadow:0 20px 44px rgba(17,24,39,.09);
}
.pr-pack h3{
  margin:10px 0 0;
  font-size:22px;
  line-height:1;
  font-weight:950;
  color:#111827;
}
.pr-pack p{
  margin:8px 0 0;
  color:#6b7280;
  font-size:12.6px;
  line-height:1.5;
}
.pr-pack-price{
  margin-top:14px;
  display:flex;
  align-items:flex-end;
  gap:7px;
}
.pr-pack-price b{
  font-size:30px;
  line-height:1;
  font-weight:950;
  letter-spacing:-.03em;
  color:#111827;
}
.pr-pack-price span{
  margin-bottom:4px;
  color:#6b7280;
  font-size:12px;
  font-weight:700;
}
.pr-pack .btn{
  margin-top:14px;
  width:100%;
}

.pr-compare{
  margin-top:14px;
  border:1px solid rgba(229,231,235,.95);
  border-radius:22px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 18px 44px rgba(17,24,39,.08);
}
.pr-table{
  width:100%;
  min-width:760px;
  border-collapse:collapse;
}
.pr-table th,
.pr-table td{
  padding:14px 16px;
  border-bottom:1px solid rgba(229,231,235,.85);
  font-size:12.8px;
  vertical-align:top;
}
.pr-table th{
  background:rgba(17,24,39,.03);
  color:#111827;
  font-weight:900;
  text-align:left;
}
.pr-table td{
  color:#374151;
  font-weight:650;
}
.pr-table tr:last-child td{ border-bottom:0; }
.pr-ok{
  color:var(--brand);
  font-weight:900;
}
.pr-muted{
  color:#9ca3af;
}

.pr-trust{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
}
@media (max-width: 991.98px){
  .pr-trust{ grid-template-columns:1fr; }
}
.pr-trustcard{
  border:1px solid rgba(229,231,235,.95);
  border-radius:20px;
  background:#fff;
  padding:16px;
  box-shadow:0 16px 38px rgba(17,24,39,.07);
}
.pr-trustcard i{
  color:var(--brand);
  font-size:16px;
}
.pr-trustcard h3{
  margin:12px 0 0;
  font-size:16px;
  font-weight:900;
  color:#111827;
}
.pr-trustcard p{
  margin:8px 0 0;
  color:#6b7280;
  font-size:12.6px;
  line-height:1.55;
}

.pr-faq{
  margin-top:14px;
}
.pr-acc .accordion-item{
  border:1px solid rgba(229,231,235,.95);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 12px 30px rgba(17,24,39,.06);
}
.pr-acc .accordion-item + .accordion-item{ margin-top:10px; }
.pr-acc .accordion-button{
  font-weight:850;
  color:#111827;
  padding:14px 16px;
}
.pr-acc .accordion-button:focus{
  box-shadow:0 0 0 .25rem rgba(165,39,41,.12);
}
.pr-acc .accordion-button:not(.collapsed){
  color:var(--brand);
  background:rgba(165,39,41,.05);
}
.pr-acc .accordion-body{
  color:#6b7280;
  font-size:12.8px;
  line-height:1.65;
}

.pr-cta{
  margin-top:14px;
  position:relative;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.95);
  border-radius:24px;
  padding:24px;
  background:
    radial-gradient(860px 280px at 10% 12%, rgba(165,39,41,.16), transparent 56%),
    radial-gradient(760px 260px at 100% 100%, rgba(17,24,39,.06), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.90));
  box-shadow:0 20px 44px rgba(17,24,39,.08);
}
.pr-cta h3{
  margin:0;
  font-size:30px;
  font-weight:950;
  letter-spacing:-.03em;
  color:#111827;
}
.pr-cta p{
  margin:10px 0 0;
  max-width:62ch;
  color:#6b7280;
  font-size:13px;
  line-height:1.65;
}

/* ==========================================
   Collections page
   ========================================== */
.cl-main{
  background:#fff;
}
.cl-searchline .sr-search{
  padding:10px 0;
}

.cl-hero{
  position:relative;
  overflow:hidden;
  padding:22px 0 18px;
  background:
    radial-gradient(900px 420px at 12% 18%, rgba(165,39,41,.18), transparent 56%),
    radial-gradient(900px 420px at 88% 74%, rgba(17,24,39,.06), transparent 56%),
    linear-gradient(180deg, rgba(165,39,41,.03), rgba(165,39,41,0));
  border-bottom:1px solid rgba(229,231,235,.85);
}
.cl-bc{ margin-bottom:10px; }
.cl-shell{
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) minmax(320px, .8fr);
  gap:16px;
  align-items:stretch;
}
@media (max-width: 991.98px){
  .cl-shell{ grid-template-columns:1fr; }
}
.cl-copy{
  padding:14px 2px 8px;
}
.cl-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-weight:850;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-size:11px;
}
.cl-h1{
  margin:12px 0 0;
  font-weight:950;
  letter-spacing:-.03em;
  font-size:clamp(24px, 4vw, 42px);
  line-height:1.02;
  color:#111827;
}
.cl-lead{
  margin:12px 0 0;
  max-width:62ch;
  color:#6b7280;
  font-size:13.2px;
  line-height:1.65;
}
.cl-actions{
  margin-top:16px;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.cl-meta{
  margin-top:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.cl-meta-card{
  min-width:150px;
  border:1px solid rgba(229,231,235,.9);
  border-radius:16px;
  background:rgba(255,255,255,.82);
  padding:12px 14px;
  box-shadow:0 14px 34px rgba(17,24,39,.06);
}
.cl-meta-card b{
  display:block;
  font-size:20px;
  line-height:1;
  color:#111827;
  font-weight:950;
}
.cl-meta-card span{
  display:block;
  margin-top:6px;
  color:#6b7280;
  font-size:12.2px;
  font-weight:700;
}
.cl-spotlight{
  position:relative;
  min-height:380px;
  border:1px solid rgba(229,231,235,.9);
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 22px 50px rgba(17,24,39,.10);
}
.cl-spotlight img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.cl-spotlight::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(17,24,39,.04), rgba(17,24,39,.72));
}
.cl-spot-copy{
  position:absolute;
  inset:auto 18px 18px 18px;
  z-index:1;
  color:#fff;
}
.cl-spot-tag{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(6px);
  font-size:11px;
  font-weight:850;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.cl-spot-title{
  margin-top:10px;
  font-size:24px;
  line-height:1.05;
  font-weight:950;
  letter-spacing:-.03em;
}
.cl-spot-sub{
  margin-top:8px;
  max-width:34ch;
  color:rgba(255,255,255,.82);
  font-size:12.8px;
  line-height:1.55;
}
.cl-spot-link{
  margin-top:12px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#fff;
  text-decoration:none;
  font-weight:850;
}
.cl-spot-link:hover{
  color:#fff;
  text-decoration:underline;
  text-underline-offset:4px;
}

.cl-section{
  padding:22px 0;
}
.cl-soft{
  background:linear-gradient(180deg, rgba(165,39,41,.03), rgba(165,39,41,0));
}
.cl-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.cl-head h2{
  margin:0;
  font-weight:950;
  letter-spacing:-.02em;
  font-size:clamp(18px, 2.2vw, 26px);
  color:#111827;
}
.cl-head p{
  margin:6px 0 0;
  color:#6b7280;
  font-size:12.8px;
}

.cl-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
}
@media (max-width: 991.98px){
  .cl-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 575.98px){
  .cl-grid{ grid-template-columns:1fr; }
}
.cl-card{
  display:block;
  text-decoration:none;
  color:inherit;
  border:1px solid rgba(229,231,235,.9);
  border-radius:20px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 16px 38px rgba(17,24,39,.08);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.cl-card:hover{
  transform:translateY(-2px);
  border-color:rgba(165,39,41,.22);
  box-shadow:0 22px 48px rgba(17,24,39,.11);
}
.cl-card:active{ transform:translateY(0); }
.cl-cover{
  position:relative;
  aspect-ratio:1.25 / 1;
  overflow:hidden;
}
.cl-cover img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.cl-cover::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(17,24,39,0), rgba(17,24,39,.52));
}
.cl-badge{
  position:absolute;
  top:12px;
  left:12px;
  z-index:1;
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.90);
  color:#111827;
  font-size:11px;
  font-weight:850;
}
.cl-body{
  padding:14px;
}
.cl-title{
  font-weight:900;
  font-size:15px;
  color:#111827;
}
.cl-desc{
  margin-top:7px;
  color:#6b7280;
  font-size:12.6px;
  line-height:1.55;
}
.cl-row{
  margin-top:12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.cl-tags{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.cl-tags span,
.cl-row b{
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:11px;
  font-weight:850;
}

.cl-editorial{
  margin-top:14px;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:12px;
}
@media (max-width: 991.98px){
  .cl-editorial{ grid-template-columns:1fr; }
}
.cl-story{
  position:relative;
  min-height:420px;
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.9);
  box-shadow:0 18px 46px rgba(17,24,39,.09);
}
.cl-story img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.cl-story::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(17,24,39,.05), rgba(17,24,39,.72));
}
.cl-storycopy{
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  z-index:1;
  color:#fff;
}
.cl-storycopy h3{
  margin:0;
  font-size:26px;
  line-height:1.04;
  font-weight:950;
  letter-spacing:-.03em;
}
.cl-storycopy p{
  margin:10px 0 0;
  color:rgba(255,255,255,.82);
  font-size:12.8px;
  line-height:1.6;
}
.cl-list{
  display:grid;
  gap:12px;
}
.cl-mini{
  display:grid;
  grid-template-columns:112px 1fr;
  gap:12px;
  align-items:center;
  text-decoration:none;
  color:inherit;
  border:1px solid rgba(229,231,235,.9);
  border-radius:18px;
  padding:10px;
  background:#fff;
  box-shadow:0 16px 38px rgba(17,24,39,.07);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.cl-mini:hover{
  transform:translateY(-1px);
  border-color:rgba(165,39,41,.22);
  box-shadow:0 20px 44px rgba(17,24,39,.09);
}
.cl-mini img{
  width:100%;
  aspect-ratio:1 / 1;
  object-fit:cover;
  border-radius:14px;
  display:block;
}
.cl-mini b{
  display:block;
  font-size:14px;
  font-weight:900;
  color:#111827;
}
.cl-mini p{
  margin:6px 0 0;
  color:#6b7280;
  font-size:12.4px;
  line-height:1.5;
}
.cl-mini span{
  display:inline-flex;
  align-items:center;
  gap:7px;
  margin-top:9px;
  color:var(--brand);
  font-size:11.5px;
  font-weight:850;
}

.cl-mosaic{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  grid-auto-rows:138px;
  gap:10px;
}
@media (max-width: 991.98px){
  .cl-mosaic{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    grid-auto-rows:148px;
  }
}
@media (max-width: 575.98px){
  .cl-mosaic{ grid-template-columns:1fr; }
}
.cl-shot{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.9);
  box-shadow:0 16px 38px rgba(17,24,39,.08);
}
.cl-shot img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.cl-shot:hover{
  transform:translateY(-1px);
  box-shadow:0 20px 44px rgba(17,24,39,.10);
}
.cl-shot-a{ grid-column:1 / span 2; grid-row:1 / span 2; }
.cl-shot-b{ grid-column:3; grid-row:1; }
.cl-shot-c{ grid-column:4; grid-row:1; }
.cl-shot-d{ grid-column:3 / span 2; grid-row:2; }
.cl-shot-e{ grid-column:1; grid-row:3; }
.cl-shot-f{ grid-column:2; grid-row:3; }
.cl-shot-g{ grid-column:3 / span 2; grid-row:3; }
@media (max-width: 991.98px){
  .cl-shot-a, .cl-shot-d, .cl-shot-g{
    grid-column:auto;
    grid-row:auto;
  }
}
@media (max-width: 575.98px){
  .cl-shot-a, .cl-shot-b, .cl-shot-c, .cl-shot-d, .cl-shot-e, .cl-shot-f, .cl-shot-g{
    grid-column:auto;
    grid-row:auto;
  }
}

.cl-cta{
  margin-top:16px;
  position:relative;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.9);
  border-radius:24px;
  padding:22px;
  background:
    radial-gradient(860px 280px at 10% 12%, rgba(165,39,41,.16), transparent 56%),
    radial-gradient(760px 260px at 100% 100%, rgba(17,24,39,.06), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.90));
  box-shadow:0 20px 44px rgba(17,24,39,.08);
}
.cl-cta h3{
  margin:0;
  font-size:28px;
  font-weight:950;
  letter-spacing:-.03em;
  color:#111827;
}
.cl-cta p{
  margin:10px 0 0;
  max-width:62ch;
  color:#6b7280;
  font-size:13px;
  line-height:1.65;
}
.cl-cta .cl-actions{
  margin-top:14px;
}

/* ==========================================
   Categories page
   ========================================== */
.cg-main{
  background:#fff;
}
.cg-searchline .sr-search{
  padding:10px 0;
}

.cg-hero{
  position:relative;
  background:#0b0f14;
  background-image:url("https://picsum.photos/seed/cg-hero/2200/900");
  background-size:cover;
  background-position:center;
  padding:10px 0 22px;
  overflow:hidden;
}
.cg-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(1000px 520px at 20% 30%, rgba(165,39,41,.55), rgba(0,0,0,0) 60%),
    linear-gradient(90deg, rgba(0,0,0,.62), rgba(0,0,0,.25) 55%, rgba(0,0,0,.55));
}
.cg-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.55));
}
.cg-hero .container{
  position:relative;
  z-index:1;
}
.cg-bc{
  margin:2px 0 12px;
}
.cg-bc ol{
  color:rgba(255,255,255,.78);
}
.cg-bc a{
  color:rgba(255,255,255,.78);
}
.cg-bc a:hover{ color:#fff; }
.cg-bc li+li::before{ color:rgba(255,255,255,.60); }

.cg-hero-inner{
  max-width:760px;
  padding:14px 0 6px;
}
.cg-h1{
  margin:0;
  color:#fff;
  font-weight:950;
  letter-spacing:-.03em;
  font-size:clamp(18px, 2.6vw, 32px);
}
.cg-lead{
  margin:8px 0 0;
  color:rgba(255,255,255,.84);
  font-size:12.8px;
  line-height:1.55;
  max-width:680px;
}
.cg-cta{
  margin-top:10px;
  padding:.52rem .92rem;
  font-size:12.4px;
}

.cg-intro{
  padding:18px 0 12px;
}
.cg-intro-inner{
  text-align:center;
  max-width:860px;
  margin:0 auto;
}
.cg-kicker{
  font-weight:950;
  letter-spacing:-.02em;
  font-size:13.5px;
  color:#111827;
}
.cg-copy{
  margin:8px auto 0;
  color:#6b7280;
  font-size:12.6px;
  line-height:1.6;
}

.cg-section{
  padding:10px 0 18px;
}
.cg-head{
  margin-bottom:10px;
}
.cg-h2{
  margin:0;
  font-weight:950;
  letter-spacing:-.02em;
  font-size:clamp(16px, 2.0vw, 22px);
  color:#111827;
}

.cg-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}
@media (max-width: 991.98px){ .cg-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); } }
@media (max-width: 575.98px){ .cg-grid{ grid-template-columns:1fr; } }

.cg-card{
  position:relative;
  border-radius:10px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  box-shadow:0 14px 34px rgba(17,24,39,.08);
  min-height:96px;
  aspect-ratio: 16 / 9;
  text-decoration:none;
  transform:translateZ(0);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.cg-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.cg-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.45));
  opacity:.9;
  pointer-events:none;
}
.cg-label{
  position:absolute;
  inset:auto 12px 12px 12px;
  z-index:1;
  color:#fff;
  font-weight:950;
  font-size:12.4px;
  letter-spacing:-.01em;
  text-shadow:0 10px 30px rgba(0,0,0,.28);
}
.cg-card:hover{
  transform:translateY(-1px);
  border-color:rgba(165,39,41,.18);
  box-shadow:0 18px 44px rgba(17,24,39,.10);
}
.cg-card:active{ transform:translateY(0); }

.cg-faq{
  padding:10px 0 18px;
}
.cg-faqgrid{
  display:grid;
  grid-template-columns: 1fr;
  gap:10px;
}
.cg-faqtitle{
  font-weight:950;
  letter-spacing:-.02em;
  font-size:13.5px;
  color:#111827;
  margin:0 0 4px;
}
.cg-acc .accordion-item{
  border:1px solid rgba(229,231,235,.95);
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 14px 34px rgba(17,24,39,.06);
}
.cg-acc .accordion-item + .accordion-item{ margin-top:10px; }
.cg-acc .accordion-button{
  font-weight:900;
  font-size:12.6px;
  padding:12px 12px;
}
.cg-acc .accordion-button:focus{
  box-shadow:0 0 0 .25rem rgba(165,39,41,.12);
}
.cg-acc .accordion-button:not(.collapsed){
  color:#111827;
  background:rgba(165,39,41,.04);
}
.cg-acc .accordion-body{
  font-size:12.6px;
  color:#6b7280;
  line-height:1.6;
  padding:10px 12px 12px;
}

.cg-best{}
.cg-bestgrid{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
}
@media (max-width: 991.98px){ .cg-bestgrid{ grid-template-columns:repeat(2, minmax(0, 1fr)); } }
@media (max-width: 575.98px){ .cg-bestgrid{ grid-template-columns:1fr; } }
.cg-bestcard{
  border-radius:10px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  box-shadow:0 14px 34px rgba(17,24,39,.08);
  text-decoration:none;
  aspect-ratio: 16 / 10;
  transform:translateZ(0);
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.cg-bestcard img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.cg-bestcard:hover{
  transform:translateY(-1px);
  border-color:rgba(165,39,41,.18);
  box-shadow:0 18px 44px rgba(17,24,39,.10);
}
.cg-bestcta{
  margin-top:12px;
  display:flex;
  justify-content:center;
}

.cg-social{
  padding:16px 0 26px;
  border-top:1px solid rgba(229,231,235,.85);
}
.cg-socialhead{
  font-weight:950;
  letter-spacing:-.02em;
  font-size:13.5px;
  color:#111827;
  margin-bottom:10px;
}
.cg-banner{
  border-radius:10px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.95);
  background:#0b0f14;
  background-image:url("https://picsum.photos/seed/cg-banner/2200/650");
  background-size:cover;
  background-position:center;
  min-height:160px;
  position:relative;
  box-shadow:0 18px 54px rgba(17,24,39,.10);
}
.cg-banner::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,.60), rgba(0,0,0,.25) 55%, rgba(0,0,0,.55));
}
.cg-bannerinner{
  position:relative;
  z-index:1;
  padding:16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.cg-bannerh{
  color:#fff;
  font-weight:950;
  letter-spacing:-.02em;
  font-size:clamp(14px, 2.0vw, 20px);
}

/* ==========================================
   Order success page
   ========================================== */
.success-page{
  background:
    radial-gradient(980px 360px at 50% 0, rgba(165,39,41,.10), transparent 62%),
    linear-gradient(180deg, #f8fafc 0%, #fff 28%);
}

.success-main{
  min-height:calc(100vh - 260px);
}

.success-hero{
  padding:20px 0 12px;
}

.success-bc{
  margin-bottom:12px;
}

.success-card{
  display:grid;
  grid-template-columns:auto minmax(0, 1fr) auto;
  gap:20px;
  align-items:center;
  padding:26px;
  border:1px solid rgba(229,231,235,.95);
  border-radius:28px;
  background:rgba(255,255,255,.94);
  box-shadow:0 18px 46px rgba(17,24,39,.08);
}

.success-mark{
  width:72px;
  height:72px;
  border-radius:24px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, rgba(165,39,41,.16), rgba(165,39,41,.06));
  color:var(--brand);
  font-size:28px;
  box-shadow:inset 0 0 0 1px rgba(165,39,41,.14);
}

.success-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.12em;
}

.success-copy h1{
  margin:12px 0 0;
  font-size:clamp(24px, 3.2vw, 36px);
  line-height:1.02;
  font-weight:950;
  letter-spacing:-.045em;
  color:#111827;
}

.success-copy p{
  margin:12px 0 0;
  max-width:760px;
  color:#6b7280;
  font-size:14px;
  line-height:1.7;
}

.success-meta{
  display:grid;
  gap:12px;
  min-width:190px;
}

.success-meta div{
  padding:12px 14px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(229,231,235,.95);
}

.success-meta span{
  display:block;
  color:#6b7280;
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.success-meta strong{
  display:block;
  margin-top:6px;
  color:#111827;
  font-size:15px;
  font-weight:900;
}

.success-section{
  padding:12px 0 42px;
}

.success-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) minmax(310px, .8fr);
  gap:18px;
  align-items:start;
}

.success-col{
  display:grid;
  gap:16px;
}

.success-aside{
  display:grid;
  gap:16px;
  position:sticky;
  top:98px;
}

.success-panel{
  border:1px solid rgba(229,231,235,.95);
  border-radius:24px;
  background:rgba(255,255,255,.94);
  box-shadow:0 16px 40px rgba(17,24,39,.08);
  padding:20px;
}

.success-head h2{
  margin:0;
  color:#111827;
  font-size:22px;
  font-weight:900;
  letter-spacing:-.03em;
}

.success-head p{
  margin:7px 0 0;
  color:#6b7280;
  font-size:12.8px;
  line-height:1.6;
}

.success-items{
  margin-top:18px;
  display:grid;
  gap:14px;
}

.success-item{
  display:grid;
  grid-template-columns:180px minmax(0, 1fr);
  gap:16px;
  align-items:stretch;
  padding:14px;
  border-radius:22px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
}

.success-item__media{
  min-height:132px;
  overflow:hidden;
  border-radius:18px;
}

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

.success-item__body{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:14px;
}

.success-item__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.success-item__top h3{
  margin:0;
  color:#111827;
  font-size:18px;
  font-weight:900;
  letter-spacing:-.02em;
}

.success-item__top p{
  margin:6px 0 0;
  color:#6b7280;
  font-size:12.6px;
  line-height:1.6;
}

.success-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(165,39,41,.10);
  color:var(--brand);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  white-space:nowrap;
}

.success-pill--soft{
  background:rgba(17,24,39,.06);
  color:#111827;
}

.success-item__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.success-steps{
  margin-top:18px;
  display:grid;
  gap:14px;
}

.success-step{
  display:grid;
  grid-template-columns:46px minmax(0, 1fr);
  gap:14px;
  align-items:flex-start;
  padding:14px 0;
  border-bottom:1px solid rgba(229,231,235,.82);
}

.success-step:last-child{
  border-bottom:0;
  padding-bottom:0;
}

.success-step__icon{
  width:46px;
  height:46px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:18px;
}

.success-step strong{
  display:block;
  color:#111827;
  font-size:15px;
  font-weight:900;
}

.success-step p{
  margin:6px 0 0;
  color:#6b7280;
  font-size:12.8px;
  line-height:1.6;
}

.success-panel--receipt{
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,250,252,.94) 100%);
}

.success-receipt{
  margin-top:16px;
  display:grid;
  gap:12px;
}

.success-receipt div,
.success-totals div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.success-receipt span,
.success-totals span{
  color:#6b7280;
  font-size:12.6px;
  font-weight:700;
}

.success-receipt strong,
.success-totals strong{
  color:#111827;
  font-size:13px;
  font-weight:850;
}

.success-status{
  color:var(--brand) !important;
}

.success-totals{
  margin-top:18px;
  padding:16px 0;
  border-top:1px solid rgba(229,231,235,.9);
  border-bottom:1px solid rgba(229,231,235,.9);
  display:grid;
  gap:12px;
}

.success-totals__main{
  padding-top:8px;
  border-top:1px dashed rgba(229,231,235,.95);
}

.success-totals__main span,
.success-totals__main strong{
  font-size:16px !important;
  font-weight:900 !important;
}

.success-actions{
  margin-top:18px;
  display:grid;
  gap:10px;
}

.success-help{
  margin-top:12px;
  display:grid;
  gap:10px;
}

.success-help a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:13px 14px;
  border-radius:16px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  color:#111827;
  font-size:13px;
  font-weight:800;
  text-decoration:none;
}

.success-help a span{
  display:block;
}

.success-help a i{
  color:var(--brand);
  font-size:16px;
}

@media (max-width: 991.98px){
  .success-card{
    grid-template-columns:1fr;
  }

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

  .success-aside{
    position:static;
    top:auto;
  }

  .success-item{
    grid-template-columns:1fr;
  }
}

@media (max-width: 767.98px){
  .success-card{
    padding:20px;
  }

  .success-copy h1{
    font-size:28px;
  }

  .success-item__top{
    flex-direction:column;
  }

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

/* ==========================================
   Favorites / Lightboxes page
   ========================================== */
.fav-page{
  background:
    radial-gradient(1080px 420px at 50% 0, rgba(165,39,41,.12), transparent 60%),
    linear-gradient(180deg, #f7f2ec 0%, #fcfbf8 32%, #fff 100%);
}

.fav-main{
  min-height:calc(100vh - 260px);
}

.fav-hero{
  padding:22px 0 18px;
}

.fav-bc{
  margin-bottom:12px;
}

.fav-splash{
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(340px, .95fr);
  gap:22px;
  align-items:start;
  padding:24px;
  border:1px solid rgba(229,231,235,.92);
  border-radius:32px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.96) 0%, rgba(255,247,244,.92) 100%);
  box-shadow:0 22px 60px rgba(17,24,39,.08);
}

.fav-kicker{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:6px 12px;
  border-radius:999px;
  background:#111827;
  color:#fff;
  font-size:10.5px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.fav-copy{
  padding:10px 4px 0 4px;
}

.fav-title{
  margin:16px 0 0;
  max-width:680px;
  color:#111827;
  font-size:clamp(34px, 4.3vw, 62px);
  line-height:.98;
  font-weight:950;
  letter-spacing:-.055em;
}

.fav-sub{
  margin:14px 0 0;
  max-width:620px;
  color:#5b6472;
  font-size:14px;
  line-height:1.82;
}

.fav-actions{
  margin-top:22px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.fav-stats{
  margin-top:24px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
  max-width:620px;
}

.fav-stat{
  padding:16px 16px 14px;
  border-radius:20px;
  border:1px solid rgba(17,24,39,.08);
  background:rgba(255,255,255,.78);
}

.fav-stat strong{
  display:block;
  color:#111827;
  font-size:30px;
  line-height:1;
  font-weight:950;
  letter-spacing:-.05em;
}

.fav-stat span{
  display:block;
  margin-top:7px;
  color:var(--brand);
  font-size:11px;
  font-weight:850;
  text-transform:uppercase;
  letter-spacing:.1em;
}

.fav-stage{
  position:relative;
  min-height:100%;
  display:grid;
  grid-template-columns:minmax(0, 1.02fr) 160px;
  gap:14px;
}

.fav-stage__lead{
  padding:22px;
  border-radius:30px;
  background:
    linear-gradient(160deg, #161921 0%, #252a36 40%, #3a1d1e 100%);
  color:#fff;
  box-shadow:0 24px 58px rgba(17,24,39,.20);
  position:relative;
  overflow:hidden;
}

.fav-stage__lead::before{
  content:"";
  position:absolute;
  right:-70px;
  top:-80px;
  width:220px;
  height:220px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.18), transparent 68%);
}

.fav-stage__eyebrow{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:6px 11px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  color:#fdd8d9;
  font-size:10px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.fav-stage__lead h2{
  margin:14px 0 0;
  font-size:36px;
  line-height:1;
  font-weight:950;
  letter-spacing:-.05em;
}

.fav-stage__lead p{
  margin:12px 0 0;
  max-width:340px;
  color:rgba(255,255,255,.76);
  font-size:13px;
  line-height:1.7;
}

.fav-stage__meta{
  margin-top:18px;
  display:grid;
  gap:10px;
  color:rgba(255,255,255,.82);
  font-size:12px;
  font-weight:750;
}

.fav-stage__meta span{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.fav-stage__meta i{
  width:16px;
  color:#ffb0b4;
}

.fav-stage__avatars{
  margin-top:20px;
  display:flex;
  align-items:center;
}

.fav-stage__avatars span,
.fav-stage__avatars b{
  width:36px;
  height:36px;
  border-radius:50%;
  display:grid;
  place-items:center;
  margin-left:-8px;
  border:2px solid rgba(22,25,33,.95);
  background:#f2d9d9;
  color:#111827;
  font-size:11px;
  font-weight:900;
}

.fav-stage__avatars span:first-child{
  margin-left:0;
}

.fav-stage__avatars b{
  background:#fff;
}

.fav-stage__stack{
  display:grid;
  gap:12px;
}

.fav-mini{
  position:relative;
  overflow:hidden;
  min-height:148px;
  border-radius:24px;
  box-shadow:0 14px 36px rgba(17,24,39,.12);
}

.fav-mini--tall{
  min-height:248px;
}

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

.fav-mini::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 35%, rgba(17,24,39,.74) 100%);
}

.fav-mini__label{
  position:absolute;
  left:14px;
  bottom:14px;
  z-index:1;
  color:#fff;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.12em;
}

.fav-section{
  padding:6px 0 44px;
}

.fav-layout{
  display:grid;
  grid-template-columns:320px minmax(0, 1fr);
  gap:18px;
  align-items:start;
}

.fav-side{
  display:grid;
  gap:18px;
}

.fav-content{
  min-width:0;
}

.fav-panel{
  border:1px solid rgba(229,231,235,.95);
  border-radius:28px;
  background:rgba(255,255,255,.95);
  box-shadow:0 18px 44px rgba(17,24,39,.08);
  padding:22px;
}

.fav-panel--accent{
  background:
    linear-gradient(160deg, rgba(165,39,41,.95) 0%, rgba(123,29,31,.98) 100%);
  border-color:rgba(123,29,31,.70);
  color:#fff;
}

.fav-panel--gallery{
  background:rgba(255,255,255,.92);
}

.fav-panel__head,
.fav-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}

.fav-panel__kicker{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:5px 10px;
  border-radius:999px;
  background:rgba(17,24,39,.06);
  color:var(--brand);
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.14em;
}

.fav-panel--accent .fav-panel__kicker{
  background:rgba(255,255,255,.14);
  color:#ffe8e9;
}

.fav-panel__head h2,
.fav-head h2{
  margin:0;
  color:#111827;
  font-size:22px;
  font-weight:900;
  letter-spacing:-.03em;
}

.fav-panel--accent .fav-panel__head h2{
  color:#fff;
}

.fav-panel__copy,
.fav-head p{
  margin:10px 0 0;
  color:#6b7280;
  font-size:12.8px;
  line-height:1.7;
}

.fav-panel--accent .fav-panel__copy{
  color:rgba(255,255,255,.78);
}

.fav-panel__link{
  color:var(--brand);
  font-size:12px;
  font-weight:850;
  text-decoration:none;
}

.fav-accentstats{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}

.fav-accentstats div{
  padding:14px;
  border-radius:18px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.10);
}

.fav-accentstats strong{
  display:block;
  font-size:28px;
  line-height:1;
  font-weight:950;
  letter-spacing:-.05em;
}

.fav-accentstats span{
  display:block;
  margin-top:6px;
  color:rgba(255,255,255,.74);
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.fav-panel__cta{
  margin-top:18px;
  min-height:50px;
  font-weight:850;
}

.fav-boardlist{
  margin-top:18px;
  display:grid;
  gap:10px;
}

.fav-board{
  display:grid;
  grid-template-columns:14px minmax(0, 1fr);
  gap:12px;
  align-items:start;
  padding:14px 0;
  border-top:1px solid rgba(229,231,235,.90);
  text-decoration:none;
}

.fav-board:first-child{
  border-top:0;
  padding-top:0;
}

.fav-board__swatch{
  width:14px;
  height:14px;
  border-radius:50%;
  background:linear-gradient(135deg, #a52729, #ff8d70);
  margin-top:4px;
  box-shadow:0 0 0 4px rgba(165,39,41,.10);
}

.fav-board__swatch--amber{
  background:linear-gradient(135deg, #f59e0b, #fcd34d);
  box-shadow:0 0 0 4px rgba(245,158,11,.10);
}

.fav-board__swatch--ink{
  background:linear-gradient(135deg, #111827, #475569);
  box-shadow:0 0 0 4px rgba(17,24,39,.08);
}

.fav-board strong{
  display:block;
  color:#111827;
  font-size:14px;
  font-weight:900;
}

.fav-board span{
  display:block;
  margin-top:5px;
  color:#6b7280;
  font-size:12px;
  line-height:1.5;
}

.fav-board--active strong{
  color:var(--brand);
}

.fav-filter{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px;
  border:1px solid rgba(229,231,235,.95);
  border-radius:18px;
  background:#f8fafc;
  flex-wrap:wrap;
}

.fav-filter button{
  border:0;
  background:transparent;
  color:#6b7280;
  min-height:40px;
  padding:0 16px;
  border-radius:13px;
  font-size:12.5px;
  font-weight:850;
  transition:background-color .15s ease, color .15s ease, box-shadow .15s ease;
}

.fav-filter button.is-active{
  background:#fff;
  color:var(--brand);
  box-shadow:0 10px 20px rgba(17,24,39,.06);
}

.fav-grid{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
}

.fav-tile{
  display:flex;
  flex-direction:column;
  min-width:0;
  border-radius:28px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  box-shadow:0 16px 36px rgba(17,24,39,.06);
}

.fav-tile--wide{
  grid-column:span 2;
}

.fav-tile[hidden]{
  display:none !important;
}

.fav-tile__media{
  display:block;
  min-height:236px;
  background:#f3f4f6;
}

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

.fav-tile__body{
  padding:18px;
}

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

.fav-badge{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(165,39,41,.09);
  color:var(--brand);
  font-size:10.5px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.12em;
}

.fav-badge--soft{
  background:rgba(17,24,39,.06);
  color:#111827;
}

.fav-save{
  width:40px;
  height:40px;
  border:1px solid rgba(229,231,235,.95);
  border-radius:14px;
  background:#fff;
  color:var(--brand);
  display:grid;
  place-items:center;
  font-size:15px;
}

.fav-tile h3{
  margin:14px 0 0;
  font-size:22px;
  line-height:1.1;
  font-weight:900;
  letter-spacing:-.03em;
}

.fav-tile h3 a{
  color:#111827;
  text-decoration:none;
}

.fav-tile p{
  margin:10px 0 0;
  color:#6b7280;
  font-size:13px;
  line-height:1.72;
}

.fav-tile__meta{
  margin-top:14px;
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  color:#374151;
  font-size:12px;
  font-weight:750;
}

.fav-tile__meta span{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.fav-tile__meta i{
  color:var(--brand);
}

.fav-notes{
  margin-top:18px;
  display:grid;
  gap:12px;
}

.fav-note{
  display:grid;
  grid-template-columns:44px minmax(0, 1fr);
  gap:12px;
  align-items:flex-start;
  padding:14px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(229,231,235,.95);
}

.fav-note i{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:17px;
}

.fav-note strong{
  display:block;
  color:#111827;
  font-size:14px;
  font-weight:900;
}

.fav-note p{
  margin:5px 0 0;
  color:#6b7280;
  font-size:12.6px;
  line-height:1.65;
}

@media (max-width: 991.98px){
  .fav-splash,
  .fav-layout{
    grid-template-columns:1fr;
  }

  .fav-stage{
    grid-template-columns:1fr 160px;
  }

  .fav-head,
  .fav-panel__head{
    flex-direction:column;
  }

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

  .fav-tile--wide{
    grid-column:auto;
  }
}

@media (max-width: 767.98px){
  .fav-title{
    font-size:40px;
  }

  .fav-splash{
    padding:18px;
  }

  .fav-stats{
    grid-template-columns:1fr;
  }

  .fav-stage{
    grid-template-columns:1fr;
  }

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

  .fav-mini--tall{
    min-height:170px;
  }

  .fav-filter{
    width:100%;
    justify-content:space-between;
  }

  .fav-filter button{
    flex:1 1 0;
    min-width:0;
  }

  .fav-tile__media{
    min-height:190px;
  }
}

/* ==========================================
   Account page
   ========================================== */
.account-page{
  background:
    radial-gradient(980px 360px at 50% 0, rgba(165,39,41,.11), transparent 60%),
    linear-gradient(180deg, #f8fafc 0%, #fff 28%);
}

.account-main{
  min-height:calc(100vh - 260px);
}

.account-hero{
  padding:20px 0 14px;
}

.account-bc{
  margin-bottom:12px;
}

.account-hero__card{
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(300px, .95fr);
  gap:18px;
  align-items:stretch;
}

.account-hero__main{
  padding:28px;
  border-radius:32px;
  background:
    radial-gradient(260px 180px at 85% 18%, rgba(255,255,255,.10), transparent 65%),
    linear-gradient(145deg, #171b23 0%, #1d2330 48%, #431d20 100%);
  box-shadow:0 24px 62px rgba(17,24,39,.18);
  color:#fff;
}

.account-hero__side{
  display:grid;
  gap:14px;
}

.account-profile{
  display:flex;
  align-items:flex-start;
  gap:18px;
}

.account-avatar{
  width:84px;
  height:84px;
  border-radius:28px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, rgba(165,39,41,.98), rgba(235,120,97,.92));
  color:#fff;
  font-size:28px;
  font-weight:950;
  letter-spacing:-.05em;
  box-shadow:0 18px 42px rgba(165,39,41,.22);
  flex:0 0 auto;
}

.account-avatarwrap{
  display:grid;
  gap:10px;
  flex:0 0 auto;
}

.account-avatarbadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.08);
  color:#fff;
  font-size:10.5px;
  font-weight:900;
  letter-spacing:.1em;
  text-transform:uppercase;
}

.account-kicker{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:6px 11px;
  border-radius:999px;
  background:rgba(255,255,255,.11);
  color:#ffe7e8;
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.16em;
}

.account-profile__copy h1{
  margin:14px 0 0;
  color:#fff;
  font-size:clamp(34px, 4vw, 54px);
  line-height:1;
  font-weight:950;
  letter-spacing:-.05em;
}

.account-profile__copy p{
  margin:12px 0 0;
  max-width:650px;
  color:rgba(255,255,255,.74);
  font-size:14px;
  line-height:1.75;
}

.account-tags{
  margin-top:18px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.account-tags span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.08);
  color:#fff;
  font-size:12px;
  font-weight:750;
}

.account-tags i{
  color:#ffb7ba;
}

.account-hero__actions{
  margin-top:24px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.account-hero__actions .btn{
  min-height:40px;
  padding-inline:14px;
  border-radius:13px;
  font-size:12px;
  font-weight:850;
}

.account-summary{
  padding:22px;
  border-radius:28px;
  border:1px solid rgba(229,231,235,.95);
  background:
    linear-gradient(135deg, rgba(255,255,255,.98) 0%, rgba(249,250,251,.95) 100%);
  box-shadow:0 18px 40px rgba(17,24,39,.08);
}

.account-summary__kicker{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:5px 10px;
  border-radius:999px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.14em;
}

.account-summary h2{
  margin:12px 0 0;
  color:#111827;
  font-size:30px;
  line-height:1;
  font-weight:950;
  letter-spacing:-.04em;
}

.account-summary p{
  margin:10px 0 0;
  color:#6b7280;
  font-size:13px;
  line-height:1.7;
}

.account-summary__rows{
  margin-top:18px;
  display:grid;
  gap:10px;
}

.account-summary__rows div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 0;
  border-top:1px solid rgba(229,231,235,.9);
}

.account-summary__rows div:first-child{
  border-top:0;
  padding-top:0;
}

.account-summary__rows span{
  color:#6b7280;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.account-summary__rows strong{
  color:#111827;
  font-size:13px;
  font-weight:900;
  text-align:right;
}

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

.account-metric{
  padding:18px;
  border-radius:24px;
  border:1px solid rgba(229,231,235,.95);
  background:rgba(255,255,255,.94);
  box-shadow:0 14px 34px rgba(17,24,39,.06);
}

.account-metric span{
  display:block;
  color:#6b7280;
  font-size:11px;
  font-weight:850;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.account-metric strong{
  display:block;
  margin-top:8px;
  color:#111827;
  font-size:34px;
  line-height:1;
  font-weight:950;
  letter-spacing:-.05em;
}

.account-metric small{
  display:block;
  margin-top:7px;
  color:#6b7280;
  font-size:12px;
}

.account-section{
  padding:8px 0 42px;
}

.account-layout{
  display:grid;
  grid-template-columns:310px minmax(0, 1fr);
  gap:18px;
  align-items:start;
}

.account-side{
  display:grid;
  gap:18px;
  position:sticky;
  top:98px;
}

.account-content{
  display:grid;
  gap:18px;
}

.account-panel{
  border:1px solid rgba(229,231,235,.95);
  border-radius:28px;
  background:rgba(255,255,255,.94);
  box-shadow:0 18px 44px rgba(17,24,39,.08);
  padding:22px;
}

.account-panel--nav{
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,250,252,.96) 100%);
}

.account-panel--support{
  background:
    linear-gradient(160deg, rgba(165,39,41,.95) 0%, rgba(124,29,31,.98) 100%);
  border-color:rgba(124,29,31,.72);
  color:#fff;
}

.account-panel__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}

.account-panel__kicker{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:5px 10px;
  border-radius:999px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.14em;
}

.account-panel--support .account-panel__kicker{
  background:rgba(255,255,255,.14);
  color:#ffe7e8;
}

.account-panel__head h2{
  margin:10px 0 0;
  color:#111827;
  font-size:24px;
  font-weight:900;
  letter-spacing:-.03em;
}

.account-panel--support .account-panel__head h2{
  color:#fff;
}

.account-panel__copy{
  margin:10px 0 0;
  color:#6b7280;
  font-size:12.8px;
  line-height:1.7;
}

.account-panel--support .account-panel__copy{
  color:rgba(255,255,255,.78);
}

.account-nav{
  margin-top:18px;
  display:grid;
  gap:10px;
}

.account-nav a{
  display:flex;
  align-items:center;
  gap:12px;
  min-height:52px;
  padding:0 14px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(229,231,235,.95);
  color:#111827;
  text-decoration:none;
  font-size:13px;
  font-weight:850;
}

.account-nav a.is-active{
  border-color:rgba(165,39,41,.30);
  background:rgba(165,39,41,.07);
  color:var(--brand);
  box-shadow:0 12px 28px rgba(165,39,41,.08);
}

.account-nav i{
  width:18px;
  color:var(--brand);
}

.account-help{
  margin-top:18px;
  display:grid;
  gap:10px;
}

.account-help a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:13px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.08);
  color:#fff;
  text-decoration:none;
  font-size:13px;
  font-weight:800;
}

.account-overview{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}

.account-overview__card{
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
}

.account-overview__icon{
  width:48px;
  height:48px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:rgba(165,39,41,.09);
  color:var(--brand);
  font-size:20px;
}

.account-overview__card strong{
  display:block;
  margin-top:14px;
  color:#111827;
  font-size:16px;
  font-weight:900;
}

.account-overview__card p{
  margin:8px 0 0;
  color:#6b7280;
  font-size:12.8px;
  line-height:1.7;
}

.account-list{
  margin-top:18px;
  display:grid;
  gap:12px;
}

.account-download{
  display:grid;
  grid-template-columns:84px minmax(0, 1fr) auto auto;
  gap:14px;
  align-items:center;
  padding:14px;
  border-radius:22px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
}

.account-download__thumb{
  height:72px;
  overflow:hidden;
  border-radius:16px;
}

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

.account-download__copy h3{
  margin:0;
  color:#111827;
  font-size:17px;
  font-weight:900;
  letter-spacing:-.02em;
}

.account-download__copy p{
  margin:6px 0 0;
  color:#6b7280;
  font-size:12.6px;
  line-height:1.65;
}

.account-download__status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(165,39,41,.09);
  color:var(--brand);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.account-download__status--soft{
  background:rgba(17,24,39,.06);
  color:#111827;
}

.account-download__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.account-licensegrid{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}

.account-license{
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
}

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

.account-license__top strong{
  color:#111827;
  font-size:16px;
  font-weight:900;
}

.account-license__top span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:0 10px;
  border-radius:999px;
  background:rgba(165,39,41,.09);
  color:var(--brand);
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.1em;
}

.account-license__warn{
  background:rgba(245,158,11,.12) !important;
  color:#b45309 !important;
}

.account-license p{
  margin:12px 0 0;
  color:#6b7280;
  font-size:12.8px;
  line-height:1.7;
}

.account-license__meta{
  margin-top:14px;
  display:grid;
  gap:8px;
  color:#374151;
  font-size:12px;
  font-weight:750;
}

.account-billing{
  margin-top:18px;
  display:grid;
  grid-template-columns:minmax(0, 1fr) 280px;
  gap:16px;
}

.account-methods{
  display:grid;
  gap:12px;
}

.account-method{
  display:grid;
  grid-template-columns:54px minmax(0, 1fr) auto;
  gap:14px;
  align-items:center;
  padding:16px;
  border-radius:22px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
}

.account-method--active{
  border-color:rgba(165,39,41,.32);
  box-shadow:0 14px 34px rgba(165,39,41,.08);
}

.account-method__brand{
  width:54px;
  height:54px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:rgba(17,24,39,.05);
  color:var(--brand);
  font-size:28px;
}

.account-method strong{
  display:block;
  color:#111827;
  font-size:15px;
  font-weight:900;
}

.account-method p{
  margin:5px 0 0;
  color:#6b7280;
  font-size:12.6px;
}

.account-method span{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 11px;
  border-radius:999px;
  background:rgba(17,24,39,.06);
  color:#111827;
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.1em;
}

.account-address{
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
}

.account-address strong{
  display:block;
  color:#111827;
  font-size:16px;
  font-weight:900;
}

.account-address p{
  margin:12px 0 0;
  color:#6b7280;
  font-size:12.8px;
  line-height:1.75;
}

.account-address .btn{
  margin-top:14px;
}

.account-table{
  margin-top:18px;
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
}

.account-table__row{
  display:grid;
  grid-template-columns:1.1fr .9fr .8fr .8fr .9fr;
  gap:12px;
  align-items:center;
  padding:15px 16px;
  border-top:1px solid rgba(229,231,235,.95);
  color:#374151;
  font-size:12.8px;
  font-weight:750;
}

.account-table__row:first-child{
  border-top:0;
}

.account-table__row--head{
  background:#f8fafc;
  color:#111827;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.account-table__status{
  color:var(--brand);
  font-weight:900;
}

.account-alert{
  margin:0 0 18px;
  border-radius:18px;
}

.account-details{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}

.account-forms{
  margin-top:18px;
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:18px;
}

.account-formcard{
  padding:24px;
  border-radius:24px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  box-shadow:0 24px 60px rgba(15,23,42,.06);
}

.account-formcard__head{
  margin-bottom:18px;
}

.account-formcard__head strong{
  display:block;
  color:#111827;
  font-size:18px;
  font-weight:900;
}

.account-formcard__head p{
  margin:8px 0 0;
  color:#6b7280;
  font-size:13px;
  line-height:1.7;
}

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

.account-field{
  display:flex;
  flex-direction:column;
  gap:8px;
}

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

.account-field span{
  color:#111827;
  font-size:12px;
  font-weight:800;
}

.account-field input,
.account-field textarea{
  width:100%;
  border:1px solid rgba(209,213,219,.95);
  border-radius:18px;
  background:#fff;
  color:#111827;
  padding:14px 16px;
  font-size:14px;
  font-weight:600;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease;
}

.account-field input:focus,
.account-field textarea:focus{
  border-color:rgba(179,38,45,.45);
  box-shadow:0 0 0 4px rgba(179,38,45,.08);
}

.account-field textarea{
  resize:vertical;
  min-height:120px;
}

.account-field small{
  color:#6b7280;
  font-size:12px;
}

.account-formcard__actions{
  margin-top:18px;
}

.account-detailcard{
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
}

.account-detailcard strong{
  display:block;
  color:#111827;
  font-size:16px;
  font-weight:900;
}

.account-detailcard p{
  margin:10px 0 0;
  color:#6b7280;
  font-size:12.8px;
  line-height:1.7;
}

.account-detailcard .btn{
  margin-top:14px;
}

@media (max-width: 1199.98px){
  .account-download{
    grid-template-columns:84px minmax(0, 1fr);
  }

  .account-download__status,
  .account-download__actions{
    grid-column:2;
  }
}

@media (max-width: 991.98px){
  .account-hero__card,
  .account-layout,
  .account-overview,
  .account-licensegrid,
  .account-billing,
  .account-details,
  .account-forms,
  .account-formgrid{
    grid-template-columns:1fr;
  }

  .account-metrics{
    grid-template-columns:1fr;
  }

  .account-side{
    position:static;
    top:auto;
  }

  .account-panel__head{
    flex-direction:column;
  }
}

@media (max-width: 767.98px){
  .account-profile{
    flex-direction:column;
  }

  .account-hero__main{
    padding:20px;
  }

  .account-profile__copy h1{
    font-size:38px;
  }

  .account-summary{
    padding:18px;
  }

  .account-summary__rows div{
    flex-direction:column;
    align-items:flex-start;
  }

  .account-summary__rows strong{
    text-align:left;
  }

  .account-nav a{
    min-height:48px;
  }

  .account-download{
    grid-template-columns:1fr;
  }

  .account-download__thumb{
    height:180px;
  }

  .account-download__status,
  .account-download__actions{
    grid-column:auto;
  }

  .account-download__actions{
    justify-content:flex-start;
  }

  .account-method{
    grid-template-columns:1fr;
  }

  .account-table__row{
    grid-template-columns:1fr;
  }

.account-table__row--head{
  display:none;
}
}

/* ==========================================
   Live support widget
   ========================================== */
.support-chat{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:1200;
  pointer-events:none;
}

.support-chat__launcher,
.support-chat__panel{
  pointer-events:auto;
}

.support-chat__launcher{
  width:68px;
  height:68px;
  display:grid;
  place-items:center;
  gap:5px;
  padding:8px;
  border:0;
  border-radius:22px;
  background:linear-gradient(135deg, var(--brand) 0%, #e86854 100%);
  color:#fff;
  box-shadow:0 22px 50px rgba(165,39,41,.28);
  transition:opacity .18s ease, transform .18s ease, box-shadow .18s ease;
}

.support-chat__launcher-icon{
  width:30px;
  height:30px;
  border-radius:10px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.16);
  font-size:14px;
}

.support-chat__launcher-copy{
  display:grid;
  text-align:center;
}

.support-chat__launcher-copy strong{
  max-width:48px;
  font-size:9px;
  line-height:1.08;
  font-weight:900;
  letter-spacing:-.02em;
}

.support-chat__launcher-copy small{
  display:none;
}

.support-chat__panel{
  position:absolute;
  right:0;
  bottom:0;
  width:min(418px, calc(100vw - 24px));
  height:min(680px, calc(100vh - 90px));
  border-radius:28px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 28px 70px rgba(17,24,39,.18);
  border:1px solid rgba(229,231,235,.95);
  opacity:0;
  visibility:hidden;
  transform:translateY(16px) scale(.98);
  transition:opacity .2s ease, transform .2s ease, visibility .2s ease;
  display:flex;
  flex-direction:column;
}

.support-chat.is-open .support-chat__panel{
  opacity:1;
  visibility:visible;
  transform:translateY(0) scale(1);
}

.support-chat.is-open .support-chat__launcher{
  opacity:0;
  transform:translateY(10px) scale(.92);
  pointer-events:none;
}

.support-chat__confirm{
  position:absolute;
  inset:0;
  padding:18px;
  display:grid;
  place-items:center;
  background:rgba(17,24,39,.40);
  backdrop-filter:blur(6px);
}

.support-chat__confirm-card{
  width:100%;
  max-width:300px;
  padding:18px;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(229,231,235,.95);
  box-shadow:0 22px 52px rgba(17,24,39,.18);
}

.support-chat__confirm-card strong{
  display:block;
  color:#111827;
  font-size:18px;
  line-height:1.1;
  font-weight:900;
  letter-spacing:-.03em;
}

.support-chat__confirm-card p{
  margin:10px 0 0;
  color:#6b7280;
  font-size:12.5px;
  line-height:1.68;
}

.support-chat__confirm-actions{
  margin-top:16px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.support-chat__confirm-actions .btn{
  min-height:38px;
  padding-inline:14px;
  border-radius:14px;
  font-weight:850;
}

.support-chat__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  background:var(--brand);
  color:#fff;
}

.support-chat__header-copy{
  display:grid;
}

.support-chat__eyebrow{
  display:none;
  align-items:center;
  width:max-content;
  min-height:24px;
  padding:4px 9px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  color:#ffe3e5;
  font-size:9px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.14em;
}

.support-chat__header-copy strong{
  margin-top:0;
  font-size:15px;
  line-height:1;
  font-weight:800;
  letter-spacing:-.02em;
}

.support-chat__header-copy small{
  margin-top:4px;
  color:rgba(255,255,255,.72);
  font-size:10px;
  font-weight:650;
}

.support-chat__header-actions{
  display:flex;
  align-items:center;
  gap:6px;
}

.support-chat__header-btn{
  width:28px;
  height:28px;
  margin:0;
  padding:0;
  border-radius:9px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.08);
  color:#fff;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  font-size:11px;
  line-height:1;
  appearance:none;
}

.support-chat__body{
  flex:1 1 auto;
  min-height:0;
  height:100%;
  background:linear-gradient(180deg, #fff 0%, #f8fafc 100%);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.support-chat__intro,
.support-chat__conversation{
  flex:1 1 auto;
  min-height:0;
}

.support-chat__intro{
  padding:14px;
  overflow:auto;
  scrollbar-width:thin;
  scrollbar-color:rgba(17,24,39,.22) transparent;
}

.support-chat__intro-card{
  height:auto;
  min-height:100%;
  border-radius:22px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  box-shadow:0 18px 38px rgba(17,24,39,.06);
  padding:16px;
}

.support-chat__intro-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.14em;
}

.support-chat__intro-card h3{
  margin:14px 0 0;
  color:#111827;
  font-size:22px;
  line-height:1.05;
  font-weight:900;
  letter-spacing:-.04em;
}

.support-chat__intro-card p{
  margin:8px 0 0;
  color:#6b7280;
  font-size:12.5px;
  line-height:1.68;
}

.support-chat__form{
  margin-top:18px;
  display:grid;
  gap:14px;
}

.support-chat__field{
  display:grid;
  gap:7px;
}

.support-chat__field span{
  color:#111827;
  font-size:12px;
  font-weight:850;
}

.support-chat__field input,
.support-chat__field textarea{
  width:100%;
  border:1px solid rgba(209,213,219,.95);
  border-radius:16px;
  background:#fff;
  color:#111827;
  padding:12px 14px;
  font-size:13px;
  line-height:1.5;
  outline:0;
  resize:none;
}

.support-chat__field input:focus,
.support-chat__field textarea:focus{
  border-color:rgba(165,39,41,.32);
  box-shadow:0 0 0 4px rgba(165,39,41,.08);
}

.support-chat__form-row{
  display:grid;
  gap:12px;
}

.support-chat__form-row small{
  color:#6b7280;
  font-size:11px;
  line-height:1.6;
}

.support-chat__form-row .btn{
  justify-self:start;
  min-height:40px;
  padding-inline:14px;
  border-radius:14px;
  font-weight:850;
}

.support-chat__conversation{
  display:flex;
  flex-direction:column;
}

.support-chat__thread{
  flex:1 1 auto;
  min-height:0;
  overflow:auto;
  padding:12px 14px 8px;
  display:flex;
  flex-direction:column;
  gap:8px;
  scrollbar-width:thin;
  scrollbar-color:rgba(17,24,39,.22) transparent;
}

.support-chat__message{
  display:grid;
  gap:3px;
}

.support-chat__message.is-user{
  justify-items:end;
}

.support-chat__bubble{
  max-width:92%;
  padding:10px 13px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(229,231,235,.95);
  color:#111827;
  font-size:12.8px;
  line-height:1.58;
  white-space:pre-line;
  word-break:break-word;
  box-shadow:0 10px 22px rgba(17,24,39,.05);
}

.support-chat__message.is-user .support-chat__bubble{
  max-width:78%;
  background:linear-gradient(135deg, rgba(165,39,41,.98), #e86854);
  border-color:transparent;
  color:#fff;
}

.support-chat__bubble a{
  color:#a52729;
  font-weight:700;
  text-decoration:none;
  border-bottom:1px solid rgba(165,39,41,.22);
}

.support-chat__bubble a:hover{
  color:#8d1d20;
  border-bottom-color:rgba(141,29,32,.38);
}

.support-chat__message.is-user .support-chat__bubble a{
  color:#fff;
  border-bottom-color:rgba(255,255,255,.35);
}

.support-chat__bubble--typing{
  display:flex;
  align-items:center;
  gap:5px;
  min-height:46px;
}

.support-chat__bubble--typing span{
  width:8px;
  height:8px;
  border-radius:50%;
  background:rgba(17,24,39,.35);
  animation:support-typing 1s ease-in-out infinite;
}

.support-chat__bubble--typing span:nth-child(2){
  animation-delay:.15s;
}

.support-chat__bubble--typing span:nth-child(3){
  animation-delay:.3s;
}

.support-chat__meta{
  color:#6b7280;
  font-size:9px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.06em;
  padding:0 2px;
  opacity:.82;
}

.support-chat__composer{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 42px;
  align-items:end;
  gap:9px;
  padding:10px 12px 12px;
  border-top:1px solid rgba(229,231,235,.95);
  background:linear-gradient(180deg, rgba(248,250,252,.78) 0%, rgba(255,255,255,.98) 55%);
}

.support-chat__composer textarea{
  width:100%;
  border:1px solid rgba(209,213,219,.95);
  border-radius:15px;
  background:rgba(255,255,255,.94);
  padding:11px 14px;
  font-size:13px;
  line-height:1.45;
  color:#111827;
  outline:0;
  resize:none;
  min-height:52px;
  max-height:120px;
  overflow-y:auto;
}

.support-chat__composer textarea:focus{
  border-color:rgba(165,39,41,.32);
  box-shadow:0 0 0 4px rgba(165,39,41,.08);
}

.support-chat__composer button{
  border:0;
  border-radius:15px;
  background:linear-gradient(135deg, rgba(165,39,41,.98), #e86854);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:14px;
  box-shadow:0 14px 30px rgba(165,39,41,.18);
}

.support-chat__intro::-webkit-scrollbar,
.support-chat__thread::-webkit-scrollbar{
  width:8px;
}

.support-chat__intro::-webkit-scrollbar-track,
.support-chat__thread::-webkit-scrollbar-track{
  background:transparent;
}

.support-chat__intro::-webkit-scrollbar-thumb,
.support-chat__thread::-webkit-scrollbar-thumb{
  background:rgba(17,24,39,.18);
  border-radius:999px;
}

@keyframes support-typing{
  0%, 80%, 100%{
    transform:translateY(0);
    opacity:.35;
  }
  40%{
    transform:translateY(-4px);
    opacity:1;
  }
}

@media (max-width: 767.98px){
  .support-chat{
    right:12px;
    bottom:12px;
  }

  .support-chat__launcher{
    width:62px;
    height:62px;
    border-radius:20px;
  }

  .support-chat__launcher-copy strong{
    max-width:42px;
    font-size:8px;
  }

  .support-chat__panel{
    bottom:0;
    width:min(100vw - 18px, 402px);
    height:min(74vh, 640px);
  }

  .support-chat__intro-card h3{
    font-size:20px;
  }
}

/* ==========================================
   Help and legal pages
   ========================================== */
.help-page,
.legal-page{
  background:
    radial-gradient(980px 360px at 50% 0, rgba(165,39,41,.09), transparent 60%),
    linear-gradient(180deg, #f8fafc 0%, #fff 28%);
}

.help-main,
.legal-main{
  min-height:calc(100vh - 240px);
}

.help-hero,
.legal-hero{
  padding:20px 0 14px;
}

.help-bc,
.legal-bc{
  margin-bottom:12px;
}

.help-hero__card,
.legal-hero__card{
  padding:26px;
  border-radius:30px;
  border:1px solid rgba(229,231,235,.95);
  background:
    linear-gradient(135deg, rgba(255,255,255,.98) 0%, rgba(251,243,240,.94) 100%);
  box-shadow:0 20px 52px rgba(17,24,39,.08);
}

.help-kicker,
.legal-kicker,
.help-card__kicker,
.legal-card__kicker{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:5px 10px;
  border-radius:999px;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.14em;
}

.help-hero__card h1,
.legal-hero__card h1{
  margin:14px 0 0;
  color:#111827;
  font-size:clamp(34px, 4vw, 56px);
  line-height:1;
  font-weight:950;
  letter-spacing:-.05em;
}

.help-hero__card p,
.legal-hero__card p{
  margin:12px 0 0;
  max-width:780px;
  color:#6b7280;
  font-size:14px;
  line-height:1.78;
}

.help-search{
  margin-top:22px;
  display:grid;
  gap:12px;
}

.help-search__box{
  display:grid;
  grid-template-columns:18px minmax(0, 1fr);
  gap:12px;
  align-items:center;
  padding:0 16px;
  min-height:54px;
  border-radius:18px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
}

.help-search__box i{
  color:#6b7280;
}

.help-search__box input{
  border:0;
  outline:0;
  background:transparent;
  color:#111827;
  font-size:13px;
}

.help-chipbar{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.help-chipbar a{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:0 13px;
  border-radius:999px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  color:#111827;
  text-decoration:none;
  font-size:12px;
  font-weight:800;
}

.help-chipbar--stack{
  margin-top:18px;
}

.help-section,
.legal-section{
  padding:8px 0 42px;
}

.help-layout,
.legal-layout{
  display:grid;
  grid-template-columns:300px minmax(0, 1fr);
  gap:18px;
  align-items:start;
}

.help-layout--contact{
  margin-top:18px;
}

.help-side{
  display:grid;
  gap:18px;
}

.help-content{
  display:grid;
  gap:18px;
}

.help-card,
.legal-card,
.legal-article{
  padding:22px;
  border-radius:28px;
  border:1px solid rgba(229,231,235,.95);
  background:rgba(255,255,255,.94);
  box-shadow:0 18px 44px rgba(17,24,39,.08);
}

.help-card h2,
.legal-card h2,
.legal-article h2{
  margin:12px 0 0;
  color:#111827;
  font-size:24px;
  font-weight:900;
  letter-spacing:-.03em;
}

.help-card p,
.legal-card p{
  margin:10px 0 0;
  color:#6b7280;
  font-size:12.8px;
  line-height:1.72;
}

.help-card__lead{
  max-width:760px;
}

.help-topics{
  margin-top:18px;
  display:grid;
  gap:10px;
}

.help-topics a{
  display:flex;
  align-items:center;
  gap:12px;
  min-height:52px;
  padding:0 14px;
  border-radius:18px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  color:#111827;
  text-decoration:none;
  font-size:13px;
  font-weight:800;
}

.help-topics i{
  width:18px;
  color:var(--brand);
}

.help-card--accent{
  background:linear-gradient(160deg, rgba(165,39,41,.95) 0%, rgba(123,29,31,.98) 100%);
  border-color:rgba(123,29,31,.72);
  color:#fff;
}

.help-card--accent h2,
.help-card--accent p,
.help-card--accent .help-card__kicker{
  color:#fff;
}

.help-card--accent .help-card__kicker{
  background:rgba(255,255,255,.12);
}

.help-actions{
  margin-top:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.help-accordion{
  margin-top:18px;
}

.help-accordion .accordion-item{
  border:1px solid rgba(229,231,235,.95);
  border-radius:18px !important;
  overflow:hidden;
  margin-bottom:10px;
}

.help-accordion .accordion-button{
  font-size:14px;
  font-weight:850;
  color:#111827;
  box-shadow:none !important;
}

.help-accordion .accordion-button:not(.collapsed){
  background:rgba(165,39,41,.06);
  color:var(--brand);
}

.help-accordion .accordion-body{
  color:#6b7280;
  font-size:12.8px;
  line-height:1.75;
}

.help-access{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}

.help-access div{
  padding:18px;
  border-radius:20px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
}

.help-access strong{
  display:block;
  color:#111827;
  font-size:15px;
  font-weight:900;
}

.help-access p{
  margin:8px 0 0;
}

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

.help-channel{
  display:grid;
  gap:14px;
}

.help-channel__icon{
  width:50px;
  height:50px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:rgba(165,39,41,.08);
  color:var(--brand);
  font-size:20px;
}

.help-form{
  margin-top:18px;
}

.help-statlist{
  margin-top:18px;
  display:grid;
  gap:10px;
}

.help-statlist div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 0;
  border-top:1px solid rgba(229,231,235,.9);
}

.help-statlist div:first-child{
  border-top:0;
  padding-top:0;
}

.help-statlist span{
  color:#6b7280;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.help-statlist strong{
  color:#111827;
  font-size:13px;
  font-weight:900;
  text-align:right;
}

.help-list,
.legal-list{
  margin:16px 0 0;
  padding-left:18px;
  color:#374151;
  display:grid;
  gap:8px;
  font-size:13px;
  line-height:1.65;
}

.legal-meta{
  margin-top:18px;
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.legal-meta span,
.legal-meta a{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:0 14px;
  border-radius:999px;
  border:1px solid rgba(229,231,235,.95);
  background:#fff;
  color:#374151;
  text-decoration:none;
  font-size:12px;
  font-weight:800;
}

.legal-article{
  display:grid;
  gap:22px;
}

.legal-article section{
  border-top:1px solid rgba(229,231,235,.9);
  padding-top:18px;
}

.legal-article section:first-child{
  border-top:0;
  padding-top:0;
}

.legal-article p{
  margin:10px 0 0;
  color:#6b7280;
  font-size:13px;
  line-height:1.78;
}

@media (max-width: 991.98px){
  .help-layout,
  .legal-layout,
  .help-contactgrid,
  .help-access{
    grid-template-columns:1fr;
  }
}

@media (max-width: 767.98px){
  .help-hero__card,
  .legal-hero__card,
  .help-card,
  .legal-card,
  .legal-article{
    padding:18px;
  }

  .help-hero__card h1,
  .legal-hero__card h1{
    font-size:38px;
  }

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

  .help-statlist div{
    flex-direction:column;
    align-items:flex-start;
  }

  .help-statlist strong{
    text-align:left;
  }
}

/* ==========================================
   Pricing page redesign
   ========================================== */
.prxv2-page{
  background:
    radial-gradient(1200px 520px at 10% 0%, rgba(179,38,45,.11), transparent 60%),
    radial-gradient(900px 460px at 100% 10%, rgba(17,24,39,.08), transparent 58%),
    linear-gradient(180deg, #f8f4ee 0%, #fcfaf6 36%, #f5f7fb 100%);
  color:#111827;
}

.prxv2-main{
  padding-bottom:44px;
}

.prxv2-breadcrumb{
  margin-bottom:24px;
}

.prxv2-hero{
  padding:26px 0 14px;
}

.prxv2-hero__layout{
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) minmax(300px, .8fr);
  gap:26px;
  align-items:start;
}

.prxv2-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(179,38,45,.10);
  color:var(--brand);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.prxv2-hero__copy h1{
  margin:18px 0 0;
  max-width:13ch;
  font-size:clamp(40px, 5.6vw, 72px);
  line-height:.94;
  letter-spacing:-.06em;
  font-weight:950;
  color:#111827;
}

.prxv2-hero__copy p{
  margin:18px 0 0;
  max-width:62ch;
  color:#475569;
  font-size:16px;
  line-height:1.8;
}

.prxv2-stats{
  margin-top:26px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}

.prxv2-stat{
  padding:18px 18px 16px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.8);
  background:rgba(255,255,255,.68);
  box-shadow:0 22px 46px rgba(15,23,42,.08);
  backdrop-filter:blur(10px);
}

.prxv2-stat span{
  display:block;
  color:#64748b;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.prxv2-stat strong{
  display:block;
  margin-top:8px;
  color:#111827;
  font-size:18px;
  font-weight:900;
  line-height:1.35;
}

.prxv2-glance{
  padding:24px;
  border-radius:28px;
  background:#111827;
  color:#fff;
  box-shadow:0 28px 70px rgba(15,23,42,.20);
}

.prxv2-glance__badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.prxv2-glance h2{
  margin:18px 0 0;
  font-size:26px;
  line-height:1.1;
  letter-spacing:-.04em;
  font-weight:900;
}

.prxv2-glance p{
  margin:14px 0 0;
  color:rgba(255,255,255,.74);
  font-size:14px;
  line-height:1.8;
}

.prxv2-mini{
  margin:18px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:12px;
}

.prxv2-mini li{
  display:flex;
  gap:12px;
  align-items:flex-start;
  color:#fff;
  font-size:14px;
  line-height:1.6;
}

.prxv2-mini i{
  margin-top:4px;
  color:#fca5a5;
}

.prxv2-billing{
  margin-top:28px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px;
  border-radius:24px;
  background:rgba(255,255,255,.76);
  border:1px solid rgba(226,232,240,.92);
  box-shadow:0 18px 40px rgba(15,23,42,.08);
}

.prxv2-billing button{
  min-height:48px;
  padding:0 20px;
  border:0;
  border-radius:18px;
  background:transparent;
  color:#64748b;
  font-size:14px;
  font-weight:800;
  transition:background-color .18s ease, color .18s ease, transform .08s ease, box-shadow .18s ease;
}

.prxv2-billing button.is-active{
  background:#111827;
  color:#fff;
  box-shadow:0 16px 28px rgba(15,23,42,.18);
}

.prxv2-billing button:active{
  transform:translateY(1px);
}

.prxv2-plans{
  padding:18px 0 18px;
}

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

.prxv2-card{
  position:relative;
  overflow:hidden;
  border-radius:32px;
  border:1px solid rgba(226,232,240,.9);
  background:rgba(255,255,255,.88);
  box-shadow:0 26px 60px rgba(15,23,42,.08);
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

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

.prxv2-card.is-highlighted{
  border-color:rgba(179,38,45,.40);
  box-shadow:0 28px 70px rgba(179,38,45,.14);
}

.prxv2-card__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:24px 24px 0;
}

.prxv2-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(179,38,45,.11);
  color:var(--brand);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.prxv2-pill--soft{
  background:rgba(15,23,42,.08);
  color:#0f172a;
}

.prxv2-icon{
  width:46px;
  height:46px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:#fff;
  color:#111827;
  box-shadow:inset 0 0 0 1px rgba(226,232,240,.9);
  font-size:18px;
}

.prxv2-card__body{
  padding:18px 24px 24px;
}

.prxv2-headline h2{
  margin:0;
  font-size:30px;
  line-height:1.05;
  letter-spacing:-.04em;
  font-weight:900;
}

.prxv2-headline p{
  margin:12px 0 0;
  color:#475569;
  font-size:15px;
  line-height:1.8;
}

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

.prxv2-list li{
  display:flex;
  gap:12px;
  align-items:flex-start;
  color:#0f172a;
  font-size:14px;
  line-height:1.65;
}

.prxv2-list i{
  margin-top:4px;
  color:var(--brand);
}

.prxv2-control{
  margin-top:28px;
  padding:18px;
  border-radius:22px;
  background:linear-gradient(180deg, rgba(248,250,252,.98), rgba(255,255,255,.94));
  border:1px solid rgba(226,232,240,.95);
}

.prxv2-label{
  color:#334155;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.prxv2-chipset{
  margin-top:14px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.prxv2-chipset button{
  min-width:58px;
  min-height:46px;
  padding:0 16px;
  border:1px solid rgba(203,213,225,.95);
  border-radius:16px;
  background:#fff;
  color:#475569;
  font-size:15px;
  font-weight:900;
  transition:border-color .18s ease, color .18s ease, box-shadow .18s ease, transform .08s ease;
}

.prxv2-chipset button.is-active{
  border-color:rgba(179,38,45,.58);
  color:#111827;
  box-shadow:0 14px 28px rgba(179,38,45,.10);
}

.prxv2-chipset button:active{
  transform:translateY(1px);
}

.prxv2-check{
  margin-top:16px;
  display:flex;
  gap:10px;
  align-items:center;
  color:#0f172a;
  font-size:14px;
  font-weight:700;
}

.prxv2-check input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.prxv2-check__box{
  width:18px;
  height:18px;
  border-radius:5px;
  border:1px solid rgba(148,163,184,.9);
  background:#fff;
  position:relative;
  flex:0 0 auto;
}

.prxv2-check input:checked + .prxv2-check__box{
  border-color:rgba(179,38,45,.58);
  background:rgba(179,38,45,.10);
}

.prxv2-check input:checked + .prxv2-check__box::after{
  content:"";
  position:absolute;
  left:5px;
  top:1px;
  width:6px;
  height:10px;
  border:2px solid var(--brand);
  border-left:0;
  border-top:0;
  transform:rotate(45deg);
}

.prxv2-link{
  display:inline-flex;
  margin-top:14px;
  color:var(--brand);
  font-size:13px;
  font-weight:800;
}

.prxv2-link:hover{
  color:var(--brand-dark);
}

.prxv2-price{
  margin-top:24px;
}

.prxv2-price__main{
  display:flex;
  align-items:flex-end;
  gap:6px;
  color:#111827;
}

.prxv2-price__currency{
  margin-bottom:8px;
  font-size:28px;
  font-weight:900;
  line-height:1;
}

.prxv2-price__amount{
  font-size:64px;
  line-height:.88;
  font-weight:950;
  letter-spacing:-.06em;
}

.prxv2-price__term{
  margin-bottom:10px;
  color:#334155;
  font-size:18px;
  font-weight:800;
}

.prxv2-price__note{
  margin-top:10px;
  color:#475569;
  font-size:14px;
  line-height:1.7;
}

.prxv2-actions{
  margin-top:22px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}

.prxv2-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:0 20px;
  border-radius:18px;
  text-decoration:none;
  font-size:15px;
  font-weight:900;
  transition:transform .08s ease, box-shadow .18s ease, background-color .18s ease, border-color .18s ease, color .18s ease;
}

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

.prxv2-btn--solid{
  background:#111827;
  border:1px solid #111827;
  color:#fff;
  box-shadow:0 18px 34px rgba(15,23,42,.16);
}

.prxv2-btn--solid:hover{
  color:#fff;
  background:#1e293b;
  border-color:#1e293b;
}

.prxv2-btn--ghost{
  background:#fff;
  border:1px solid rgba(203,213,225,.95);
  color:#111827;
}

.prxv2-btn--ghost:hover{
  color:#111827;
  border-color:rgba(179,38,45,.44);
  box-shadow:0 18px 34px rgba(179,38,45,.10);
}

.prxv2-footnotes{
  margin-top:20px;
  padding-top:18px;
  border-top:1px solid rgba(226,232,240,.92);
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}

.prxv2-footnotes span{
  display:block;
  color:#64748b;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.prxv2-footnotes strong{
  display:block;
  margin-top:8px;
  color:#111827;
  font-size:15px;
  line-height:1.45;
  font-weight:900;
}

.prxv2-workflows,
.prxv2-compare,
.prxv2-enterprise,
.prxv2-faq{
  padding:18px 0 22px;
}

.prxv2-sectionhead{
  margin-bottom:18px;
}

.prxv2-sectionhead span{
  display:inline-block;
  color:var(--brand);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.1em;
}

.prxv2-sectionhead h2{
  margin:10px 0 0;
  font-size:clamp(28px, 3.6vw, 44px);
  line-height:1;
  letter-spacing:-.05em;
  font-weight:950;
}

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

.prxv2-workcard{
  padding:24px;
  border-radius:26px;
  border:1px solid rgba(226,232,240,.9);
  background:rgba(255,255,255,.84);
  box-shadow:0 24px 48px rgba(15,23,42,.06);
}

.prxv2-workcard__icon{
  width:52px;
  height:52px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:rgba(179,38,45,.10);
  color:var(--brand);
  font-size:20px;
}

.prxv2-workcard h3{
  margin:18px 0 0;
  font-size:22px;
  line-height:1.1;
  letter-spacing:-.03em;
  font-weight:900;
}

.prxv2-workcard p{
  margin:12px 0 0;
  color:#475569;
  font-size:14px;
  line-height:1.8;
}

.prxv2-workcard strong,
.prxv2-workcard strong a{
  display:inline-block;
  margin-top:18px;
  color:#111827;
  font-size:15px;
  font-weight:900;
}

.prxv2-mobilecompare{
  display:none;
}

.prxv2-tablewrap{
  overflow:hidden;
  border-radius:28px;
  border:1px solid rgba(226,232,240,.9);
  background:rgba(255,255,255,.88);
  box-shadow:0 28px 60px rgba(15,23,42,.08);
}

.prxv2-table{
  width:100%;
  border-collapse:collapse;
}

.prxv2-table th,
.prxv2-table td{
  padding:18px 16px;
  border-bottom:1px solid rgba(226,232,240,.9);
  color:#0f172a;
  font-size:14px;
}

.prxv2-table th{
  background:#f8fafc;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.prxv2-table th:not(:first-child),
.prxv2-table td:not(:first-child){
  text-align:center;
}

.prxv2-table .is-section td{
  background:rgba(179,38,45,.08);
  color:var(--brand);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.prxv2-table i{
  color:var(--brand);
}

.prxv2-enterprise__card{
  padding:28px;
  border-radius:30px;
  background:#111827;
  color:#fff;
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:22px;
  align-items:center;
  box-shadow:0 28px 70px rgba(15,23,42,.18);
}

.prxv2-enterprise__copy span{
  display:inline-block;
  color:#fca5a5;
  font-size:12px;
  font-weight:900;
  letter-spacing:.1em;
  text-transform:uppercase;
}

.prxv2-enterprise__copy h2{
  margin:12px 0 0;
  font-size:34px;
  line-height:1.05;
  letter-spacing:-.04em;
  font-weight:950;
}

.prxv2-enterprise__copy p{
  margin:14px 0 0;
  max-width:60ch;
  color:rgba(255,255,255,.74);
  font-size:15px;
  line-height:1.8;
}

.prxv2-enterprise__actions{
  display:grid;
  gap:12px;
  min-width:220px;
}

.prxv2-enterprise .prxv2-btn--solid{
  background:var(--brand);
  border-color:var(--brand);
}

.prxv2-enterprise .prxv2-btn--solid:hover{
  background:var(--brand-dark);
  border-color:var(--brand-dark);
}

.prxv2-enterprise .prxv2-btn--ghost{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.14);
  color:#fff;
}

.prxv2-enterprise .prxv2-btn--ghost:hover{
  color:#fff;
  border-color:rgba(255,255,255,.24);
}

.prxv2-faq__acc{
  display:grid;
  gap:14px;
}

.prxv2-faq__acc .accordion-item{
  border:1px solid rgba(226,232,240,.9);
  border-radius:22px;
  overflow:hidden;
  background:rgba(255,255,255,.86);
  box-shadow:0 18px 40px rgba(15,23,42,.05);
}

.prxv2-faq__acc .accordion-button{
  padding:20px 22px;
  font-size:16px;
  font-weight:900;
  color:#111827;
  background:transparent;
  box-shadow:none;
}

.prxv2-faq__acc .accordion-button:not(.collapsed){
  color:#111827;
  background:rgba(179,38,45,.05);
}

.prxv2-faq__acc .accordion-body{
  padding:0 22px 22px;
  color:#475569;
  font-size:15px;
  line-height:1.8;
}

@media (max-width: 1199.98px){
  .prxv2-hero__layout,
  .prxv2-grid,
  .prxv2-workgrid,
  .prxv2-enterprise__card{
    grid-template-columns:1fr;
  }

  .prxv2-enterprise__actions{
    min-width:0;
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991.98px){
  .prxv2-stats,
  .prxv2-actions,
  .prxv2-footnotes{
    grid-template-columns:1fr;
  }

  .prxv2-price__amount{
    font-size:54px;
  }

  .prxv2-mobilecompare{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:14px;
    margin-bottom:16px;
  }

  .prxv2-mobilecard{
    padding:20px;
    border-radius:24px;
    border:1px solid rgba(226,232,240,.9);
    background:rgba(255,255,255,.88);
    box-shadow:0 18px 40px rgba(15,23,42,.05);
  }

  .prxv2-mobilecard h3{
    margin:0;
    font-size:20px;
    font-weight:900;
  }

  .prxv2-mobilecard p{
    margin:10px 0 0;
    color:#475569;
    font-size:14px;
    line-height:1.7;
  }

  .prxv2-mobilecard ul{
    margin:14px 0 0;
    padding-left:18px;
    color:#0f172a;
    display:grid;
    gap:8px;
    font-size:14px;
    line-height:1.6;
  }

  .prxv2-tablewrap{
    display:none;
  }
}

@media (max-width: 767.98px){
  .prxv2-hero{
    padding-top:18px;
  }

  .prxv2-hero__copy h1{
    max-width:none;
    font-size:clamp(34px, 12vw, 52px);
  }

  .prxv2-hero__copy p{
    font-size:15px;
  }

  .prxv2-billing{
    width:100%;
    display:grid;
    grid-template-columns:1fr;
  }

  .prxv2-billing button{
    width:100%;
  }

  .prxv2-card__top,
  .prxv2-card__body,
  .prxv2-glance,
  .prxv2-workcard,
  .prxv2-enterprise__card{
    padding-left:18px;
    padding-right:18px;
  }

  .prxv2-card__top{
    padding-top:18px;
  }

  .prxv2-card__body{
    padding-top:14px;
    padding-bottom:18px;
  }

  .prxv2-headline h2{
    font-size:26px;
  }

  .prxv2-chipset{
    gap:8px;
  }

  .prxv2-chipset button{
    min-width:unset;
    flex:1 1 calc(50% - 8px);
  }

  .prxv2-price__currency{
    font-size:24px;
    margin-bottom:7px;
  }

  .prxv2-price__amount{
    font-size:48px;
  }

  .prxv2-price__term{
    font-size:16px;
  }

  .prxv2-mobilecompare{
    grid-template-columns:1fr;
  }

  .prxv2-enterprise__copy h2{
    font-size:28px;
  }

  .prxv2-enterprise__actions{
    grid-template-columns:1fr;
  }
}

/* ==========================================
   Custom 404 page
   ========================================== */
.error404-page{
  margin:0;
  min-height:100vh;
  font-family:'Inter', sans-serif;
  background:
    radial-gradient(1000px 500px at 14% 10%, rgba(179,38,45,.18), transparent 60%),
    radial-gradient(900px 480px at 88% 0%, rgba(15,23,42,.18), transparent 58%),
    linear-gradient(180deg, #0f172a 0%, #111827 42%, #0b1220 100%);
  color:#fff;
  overflow:hidden;
}

.error404-shell{
  position:relative;
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:28px;
  isolation:isolate;
}

.error404-grid{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:44px 44px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.55), transparent 88%);
  opacity:.25;
  z-index:-3;
}

.error404-orb{
  position:absolute;
  border-radius:999px;
  filter:blur(18px);
  opacity:.75;
  z-index:-2;
  animation:error404Float 10s ease-in-out infinite;
}

.error404-orb--one{
  top:9%;
  left:7%;
  width:220px;
  height:220px;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.25), rgba(179,38,45,.42));
}

.error404-orb--two{
  right:9%;
  bottom:8%;
  width:280px;
  height:280px;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.20), rgba(59,130,246,.22));
  animation-duration:12s;
}

.error404-card{
  position:relative;
  width:min(100%, 980px);
  padding:34px;
  border-radius:34px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  box-shadow:0 40px 90px rgba(0,0,0,.34);
  backdrop-filter:blur(18px);
}

.error404-card::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg, rgba(255,255,255,.25), rgba(255,255,255,0));
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  pointer-events:none;
}

.error404-brand{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:auto;
}

.error404-brand img{
  width:190px;
  max-width:100%;
  display:block;
}

.error404-code{
  margin-top:26px;
  display:flex;
  align-items:center;
  gap:12px;
  font-size:clamp(88px, 15vw, 180px);
  line-height:.82;
  font-weight:950;
  letter-spacing:-.12em;
  color:rgba(255,255,255,.16);
  text-shadow:0 16px 40px rgba(0,0,0,.18);
  user-select:none;
}

.error404-code span:nth-child(2){
  color:rgba(255,255,255,.30);
  transform:translateY(10px);
}

.error404-copy{
  position:relative;
  z-index:1;
  margin-top:-8px;
  max-width:640px;
}

.error404-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:#fca5a5;
  font-size:12px;
  font-weight:900;
  letter-spacing:.1em;
  text-transform:uppercase;
}

.error404-copy h1{
  margin:16px 0 0;
  font-size:clamp(40px, 6vw, 68px);
  line-height:.94;
  letter-spacing:-.06em;
  font-weight:950;
  color:#fff;
}

.error404-copy p{
  margin:16px 0 0;
  max-width:56ch;
  color:rgba(255,255,255,.76);
  font-size:16px;
  line-height:1.85;
}

.error404-actions{
  margin-top:30px;
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.error404-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:54px;
  padding:0 20px;
  border-radius:18px;
  border:1px solid transparent;
  text-decoration:none;
  font-size:14px;
  font-weight:900;
  cursor:pointer;
  transition:transform .08s ease, box-shadow .18s ease, border-color .18s ease, background-color .18s ease, color .18s ease;
}

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

.error404-btn--solid{
  background:var(--brand);
  border-color:var(--brand);
  color:#fff;
  box-shadow:0 18px 36px rgba(179,38,45,.26);
}

.error404-btn--solid:hover{
  color:#fff;
  background:var(--brand-dark);
  border-color:var(--brand-dark);
}

.error404-btn--ghost{
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.14);
  color:#fff;
}

.error404-btn--ghost:hover{
  color:#fff;
  border-color:rgba(255,255,255,.26);
  background:rgba(255,255,255,.09);
}

.error404-quicklinks{
  margin-top:26px;
  display:flex;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}

.error404-quicklinks a{
  color:rgba(255,255,255,.72);
  font-size:13px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.error404-quicklinks a:hover{
  color:#fff;
}

@keyframes error404Float{
  0%, 100%{
    transform:translate3d(0, 0, 0) scale(1);
  }
  50%{
    transform:translate3d(0, -18px, 0) scale(1.04);
  }
}

@media (max-width: 767.98px){
  .error404-shell{
    padding:18px;
  }

  .error404-card{
    padding:24px 18px;
    border-radius:28px;
  }

  .error404-brand img{
    width:150px;
  }

  .error404-code{
    margin-top:18px;
    gap:6px;
    font-size:clamp(72px, 24vw, 118px);
  }

  .error404-copy{
    margin-top:8px;
  }

  .error404-copy p{
    font-size:15px;
    line-height:1.78;
  }

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

  .error404-btn{
    width:100%;
  }

  .error404-quicklinks{
    gap:12px;
  }
}

/* ==========================================
   Blog pages
   ========================================== */
.blog-page{
  background:
    radial-gradient(1200px 420px at 15% 0%, rgba(179,38,45,.10), transparent 58%),
    linear-gradient(180deg, #faf7f2 0%, #fcfbf8 34%, #f5f7fb 100%);
}

.blog-main{
  padding-bottom:36px;
}

.blog-breadcrumb{
  margin-bottom:22px;
}

.blog-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(179,38,45,.10);
  color:var(--brand);
  font-size:12px;
  font-weight:900;
  letter-spacing:.1em;
  text-transform:uppercase;
}

.blog-hero{
  padding:26px 0 12px;
}

.blog-hero__layout{
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) minmax(260px, .8fr);
  gap:22px;
  align-items:end;
}

.blog-hero__copy h1{
  margin:16px 0 0;
  max-width:12ch;
  font-size:clamp(38px, 5vw, 68px);
  line-height:.94;
  letter-spacing:-.06em;
  font-weight:950;
  color:#111827;
}

.blog-hero__copy p{
  margin:16px 0 0;
  max-width:60ch;
  color:#475569;
  font-size:16px;
  line-height:1.8;
}

.blog-hero__panel{
  display:grid;
  gap:12px;
  padding:22px;
  border-radius:26px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(226,232,240,.92);
  box-shadow:0 20px 48px rgba(15,23,42,.08);
}

.blog-hero__panel div{
  padding-bottom:12px;
  border-bottom:1px solid rgba(226,232,240,.8);
}

.blog-hero__panel div:last-child{
  padding-bottom:0;
  border-bottom:0;
}

.blog-hero__panel span{
  display:block;
  color:#64748b;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.blog-hero__panel strong{
  display:block;
  margin-top:8px;
  color:#111827;
  font-size:18px;
  line-height:1.4;
  font-weight:900;
}

.blog-featured,
.blog-listing,
.blog-detail-body{
  padding:18px 0;
}

.blog-featured__card{
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(0, .95fr);
  gap:24px;
  padding:24px;
  border-radius:30px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(226,232,240,.94);
  box-shadow:0 26px 64px rgba(15,23,42,.08);
}

.blog-featured__media,
.blog-card__media,
.blog-home-card__cover,
.blog-article__cover{
  display:block;
  overflow:hidden;
  border-radius:24px;
  background:linear-gradient(135deg, rgba(179,38,45,.18), rgba(248,250,252,.96));
}

.blog-featured__media{
  min-height:320px;
}

.blog-featured__media img,
.blog-card__media img,
.blog-home-card__cover img,
.blog-article__cover img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.blog-featured__media span,
.blog-card__media span,
.blog-home-card__cover span,
.blog-article__cover span{
  width:100%;
  height:100%;
  min-height:inherit;
  display:grid;
  place-items:center;
  color:var(--brand);
  font-size:2rem;
}

.blog-featured__copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.blog-featured__pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  min-height:34px;
  padding:0 14px;
  border-radius:999px;
  background:#111827;
  color:#fff;
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.blog-featured__copy h2{
  margin:16px 0 0;
  font-size:clamp(30px, 4vw, 48px);
  line-height:1;
  letter-spacing:-.05em;
  font-weight:950;
}

.blog-featured__copy h2 a,
.blog-card h3 a,
.blog-home-card h3 a{
  color:#111827;
  text-decoration:none;
}

.blog-featured__copy p{
  margin:16px 0 0;
  color:#475569;
  font-size:15px;
  line-height:1.85;
}

.blog-meta{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:18px;
  color:#64748b;
  font-size:12px;
  font-weight:800;
}

.blog-meta span{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.blog-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}

.blog-tags--compact{
  margin-top:14px;
}

.blog-tags--detail{
  margin-top:18px;
}

.blog-tag{
  display:inline-flex;
  align-items:center;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(226,232,240,.94);
  color:#334155;
  font-size:12px;
  font-weight:800;
  line-height:1;
}

.blog-readmore{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:18px;
  color:var(--brand);
  font-size:14px;
  font-weight:900;
  text-decoration:none;
}

.blog-readmore:hover{
  color:var(--brand-dark);
}

.blog-sectionhead{
  margin-bottom:18px;
}

.blog-sectionhead span{
  display:inline-block;
  color:var(--brand);
  font-size:12px;
  font-weight:900;
  letter-spacing:.1em;
  text-transform:uppercase;
}

.blog-sectionhead h2{
  margin:10px 0 0;
  font-size:clamp(28px, 3.8vw, 42px);
  line-height:1;
  letter-spacing:-.05em;
  font-weight:950;
}

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

.blog-card,
.blog-home-card{
  overflow:hidden;
  border-radius:26px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(226,232,240,.94);
  box-shadow:0 22px 48px rgba(15,23,42,.06);
}

.blog-card__media,
.blog-home-card__cover{
  aspect-ratio:1.25 / 1;
}

.blog-card__body,
.blog-home-card__body{
  padding:18px;
}

.blog-card h3,
.blog-home-card h3{
  margin:14px 0 0;
  font-size:24px;
  line-height:1.12;
  letter-spacing:-.03em;
  font-weight:900;
}

.blog-card p,
.blog-home-card p{
  margin:12px 0 0;
  color:#475569;
  font-size:14px;
  line-height:1.8;
}

.blog-home-card__link{
  display:inline-flex;
  margin-top:16px;
  color:var(--brand);
  font-size:14px;
  font-weight:900;
  text-decoration:none;
}

.blog-detail-hero{
  padding:26px 0 8px;
}

.blog-detail-head{
  max-width:920px;
}

.blog-detail-head h1{
  margin:16px 0 0;
  font-size:clamp(40px, 5.4vw, 76px);
  line-height:.94;
  letter-spacing:-.06em;
  font-weight:950;
  color:#111827;
}

.blog-detail-head p{
  margin:16px 0 0;
  max-width:62ch;
  color:#475569;
  font-size:16px;
  line-height:1.85;
}

.blog-meta--detail{
  margin-top:20px;
}

.blog-detail-layout{
  display:grid;
  grid-template-columns:minmax(0, 1.15fr) minmax(280px, .6fr);
  gap:22px;
  align-items:start;
}

.blog-article,
.blog-side__card{
  border-radius:30px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(226,232,240,.94);
  box-shadow:0 24px 56px rgba(15,23,42,.06);
}

.blog-article__cover{
  margin:18px;
  min-height:360px;
}

.blog-article__content{
  padding:0 22px 24px;
}

.blog-article__content p{
  margin:18px 0 0;
  color:#334155;
  font-size:16px;
  line-height:1.95;
}

.blog-article__content > :first-child{
  margin-top:0;
}

.blog-article__content h2,
.blog-article__content h3,
.blog-article__content h4{
  margin:28px 0 0;
  color:#111827;
  line-height:1.15;
  letter-spacing:-.04em;
  font-weight:950;
}

.blog-article__content h2{
  font-size:34px;
}

.blog-article__content h3{
  font-size:28px;
}

.blog-article__content h4{
  font-size:22px;
}

.blog-article__content ul,
.blog-article__content ol{
  margin:18px 0 0;
  padding-left:1.35rem;
  color:#334155;
}

.blog-article__content li{
  margin-top:10px;
  font-size:16px;
  line-height:1.85;
}

.blog-article__content blockquote{
  margin:22px 0 0;
  padding:18px 20px;
  border-left:4px solid var(--brand);
  border-radius:20px;
  background:rgba(179,38,45,.05);
  color:#1f2937;
  font-size:18px;
  line-height:1.8;
  font-weight:700;
}

.blog-article__content a{
  color:var(--brand);
  text-decoration:none;
  font-weight:800;
}

.blog-article__content a:hover{
  color:var(--brand-dark);
}

.blog-side{
  display:grid;
  gap:18px;
}

.blog-side__card{
  padding:22px;
}

.blog-side__card span{
  display:inline-block;
  color:var(--brand);
  font-size:12px;
  font-weight:900;
  letter-spacing:.1em;
  text-transform:uppercase;
}

.blog-side__card h2{
  margin:12px 0 0;
  font-size:28px;
  line-height:1.08;
  letter-spacing:-.04em;
  font-weight:950;
}

.blog-side__card p{
  margin:14px 0 0;
  color:#475569;
  font-size:14px;
  line-height:1.8;
}

.blog-related{
  display:grid;
  gap:12px;
  margin-top:16px;
}

.blog-related__item{
  display:block;
  padding:14px 16px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(226,232,240,.94);
  text-decoration:none;
}

.blog-related__item strong{
  display:block;
  color:#111827;
  font-size:15px;
  line-height:1.5;
  font-weight:900;
}

.blog-related__item small{
  display:block;
  margin-top:8px;
  color:#64748b;
  font-size:12px;
  font-weight:800;
}

@media (max-width: 1199.98px){
  .blog-hero__layout,
  .blog-featured__card,
  .blog-detail-layout{
    grid-template-columns:1fr;
  }
}

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

@media (max-width: 767.98px){
  .blog-hero{
    padding-top:18px;
  }

  .blog-hero__copy h1,
  .blog-detail-head h1{
    max-width:none;
    font-size:clamp(34px, 12vw, 52px);
  }

  .blog-hero__copy p,
  .blog-detail-head p,
  .blog-article__content p{
    font-size:15px;
    line-height:1.8;
  }

  .blog-grid,
  .blog-home-grid{
    grid-template-columns:1fr;
  }

  .blog-featured__card,
  .blog-card__body,
  .blog-home-card__body,
  .blog-side__card,
  .blog-article__content{
    padding-left:18px;
    padding-right:18px;
  }

  .blog-featured__card{
    padding:18px;
  }

  .blog-article__cover{
    margin:14px;
    min-height:260px;
  }
}

