:root{
  --red:#d11414;
  --red2:#b90f0f;

  --ink:#0b1324;
  --text:#1f2937;
  --muted:#6b7280;

  --bg:#ffffff;
  --soft:#f6f7fb;
  --soft2:#eef1f7;

  --line:rgba(15,23,42,.12);

  --shadow:0 18px 60px rgba(15,23,42,.10);
  --shadow2:0 26px 90px rgba(15,23,42,.14);

  --r:18px;
  --r2:14px;

  --fontH:"Chakra Petch", system-ui, sans-serif;
  --fontB:"Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--fontB);
  color:var(--text);
  background:var(--bg);
  overflow-x:hidden;
}
img{max-width:100%; display:block; height:auto}
a{text-decoration:none; color:inherit}
button{font-family:inherit}

.material-symbols-rounded{
  font-variation-settings: "FILL" 0, "wght" 650, "GRAD" 0, "opsz" 48;
}

.bl-container{
  width:min(1180px, calc(100% - 32px));
  margin-inline:auto;
}
@media (max-width:560px){
  .bl-container{ width:min(1180px, calc(100% - 20px)); }
}

.bl-page{ overflow-x:hidden; }

/* progress */
.bl-progress{
  position:fixed; left:0; top:0; height:3px; width:100%;
  background: transparent;
  z-index: 9999;
}
.bl-progress span{
  display:block; height:100%; width:0%;
  background: linear-gradient(90deg, var(--red), #38bdf8);
}

/* reveal animation */
.bl-reveal{
  opacity:0;
  transform: translateY(18px);
  transition: opacity .6s ease, transform .6s ease;
}
.bl-reveal.is-in{
  opacity:1;
  transform:none;
}
@media (prefers-reduced-motion: reduce){
  .bl-reveal{ opacity:1; transform:none; transition:none; }
}

/* HERO */
.bl-hero{
  position:relative;
  padding: 0 0 18px;
}
.bl-hero__media{
  position:relative;
  height: clamp(320px, 44vw, 560px);
  overflow:hidden;
  border-bottom: 1px solid var(--line);
  background: #0b1324;
}
.bl-hero__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform: scale(1.02);
}
.bl-hero__shade{
  position:absolute; inset:0;
  background:
    radial-gradient(700px 420px at 20% 25%, rgba(209,20,20,.28), transparent 60%),
    radial-gradient(760px 520px at 90% 15%, rgba(56,189,248,.22), transparent 55%),
    linear-gradient(90deg, rgba(11,19,36,.75) 0%, rgba(11,19,36,.25) 55%, rgba(11,19,36,.10) 100%),
    linear-gradient(180deg, rgba(11,19,36,.20) 0%, rgba(255,255,255,.65) 100%);
}
.bl-hero__grain{
  position:absolute; inset:0;
  opacity:.20;
  mix-blend-mode: overlay;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  background-size: 240px 240px;
  pointer-events:none;
}

.bl-hero__wrap{
  position:relative;
  margin-top: -120px;
  display:grid;
  gap: 18px;
  z-index:2;
}
@media (min-width: 980px){
  .bl-hero__wrap{
    grid-template-columns: 1.2fr .8fr;
    gap: 22px;
    margin-top: -150px;
  }
}
@media (max-width: 560px){
  .bl-hero__wrap{ margin-top: -84px; }
}

.bl-hero__card,
.bl-quick{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.35);
  border-radius: var(--r);
  padding: 18px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}

.bl-kicker{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-weight: 700;
  letter-spacing:.12em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(17,24,39,.78);
}
.bl-kicker__dot{
  width:10px; height:10px; border-radius:999px;
  background: var(--red);
  box-shadow: 0 0 0 6px rgba(209,20,20,.12);
}

.bl-h1{
  margin: 10px 0 10px;
  font-family: var(--fontH);
  font-weight: 700;
  color: var(--ink);
  text-transform: uppercase;
  letter-spacing:.02em;
  line-height: 1.05;
  font-size: clamp(30px, 4.2vw, 56px);
}
.bl-h1 span{
  display:block;
  margin-top: 10px;
  font-size: clamp(16px, 2.2vw, 24px);
  color: rgba(11,19,36,.72);
  text-transform:none;
  letter-spacing:.01em;
}

.bl-lead{
  margin: 0 0 14px;
  color: rgba(31,41,55,.78);
  line-height: 1.6;
  max-width: 66ch;
}

.bl-hero__actions{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
  margin-bottom: 12px;
}
@media (max-width: 560px){
  .bl-hero__actions{ flex-direction:column; }
}

.bl-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 999px;
  font-weight: 800;
  border: 1px solid transparent;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, filter .18s ease;
  white-space:nowrap;
}
.bl-btn:hover{ transform: translateY(-2px); }
.bl-btn--primary{
  background: linear-gradient(180deg, var(--red), var(--red2));
  color:#fff;
  box-shadow: 0 16px 50px rgba(209,20,20,.22);
}
.bl-btn--primary:hover{ box-shadow: 0 20px 70px rgba(209,20,20,.26); filter: saturate(1.05); }

.bl-btn--soft{
  background: linear-gradient(180deg, #ffffff, #f4f6fb);
  border-color: rgba(15,23,42,.14);
  color: rgba(11,19,36,.90);
  box-shadow: 0 16px 40px rgba(15,23,42,.08);
}
.bl-btn--soft:hover{ box-shadow: var(--shadow); }

.bl-btn--sm{ padding: 10px 14px; font-size: 14px; }
.bl-btn--block{ width:100%; border-radius: var(--r2); }

.bl-proof{
  display:grid;
  gap: 10px;
  margin-top: 12px;
}
@media (min-width: 720px){
  .bl-proof{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.bl-proof__item{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  padding: 12px 12px;
  border-radius: var(--r2);
  border: 1px solid rgba(15,23,42,.10);
  background: #fff;
}
.bl-proof__item .material-symbols-rounded{ color: var(--red); margin-top: 1px; }
.bl-proof__item strong{ display:block; color: rgba(11,19,36,.90); font-weight:700; }
.bl-proof__item span{ display:block; color: rgba(31,41,55,.65); font-size: 13px; margin-top: 2px; }

.bl-quick__title{
  margin:0;
  font-family: var(--fontH);
  text-transform: uppercase;
  letter-spacing:.08em;
  font-weight:700;
  color: var(--ink);
}
.bl-quick__sub{
  margin: 6px 0 12px;
  color: rgba(31,41,55,.70);
}
.bl-quick__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
@media (max-width: 560px){
  .bl-quick__grid{ grid-template-columns: 1fr; }
}
.bl-quick__chip{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 12px 12px;
  border-radius: var(--r2);
  border: 1px solid rgba(15,23,42,.10);
  background: linear-gradient(180deg, #ffffff, #f4f6fb);
  font-weight: 700;
  color: rgba(11,19,36,.82);
}
.bl-quick__cta{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 12px;
}
@media (max-width: 560px){
  .bl-quick__cta{ grid-template-columns: 1fr; }
}
.bl-mini{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: var(--r2);
  border: 1px solid rgba(15,23,42,.12);
  font-weight: 800;
  box-shadow: 0 16px 40px rgba(15,23,42,.08);
  transition: transform .18s ease, box-shadow .18s ease;
}
.bl-mini:hover{ transform: translateY(-2px); box-shadow: var(--shadow); }
.bl-mini--call{
  background: linear-gradient(180deg, rgba(209,20,20,.12), rgba(209,20,20,.06));
  border-color: rgba(209,20,20,.20);
}
.bl-mini--mail{
  background: linear-gradient(180deg, rgba(56,189,248,.14), rgba(56,189,248,.07));
  border-color: rgba(56,189,248,.22);
}
.bl-quick__note{
  display:flex;
  align-items:center;
  gap: 10px;
  margin-top: 12px;
  padding: 12px 12px;
  border-radius: var(--r2);
  border: 1px dashed rgba(15,23,42,.18);
  color: rgba(31,41,55,.74);
  background: rgba(255,255,255,.65);
}
.bl-quick__note .material-symbols-rounded{ color: var(--red); }

/* Nav filter */
.bl-nav{
  margin-top: 16px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
}
.bl-nav__btn{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background:#fff;
  font-weight: 800;
  color: rgba(11,19,36,.82);
  cursor:pointer;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease, border-color .16s ease;
}
.bl-nav__btn:hover{ transform: translateY(-1px); box-shadow: 0 16px 40px rgba(15,23,42,.08); }
.bl-nav__btn.is-active{
  background: linear-gradient(180deg, rgba(209,20,20,.14), rgba(209,20,20,.08));
  border-color: rgba(209,20,20,.25);
}
.bl-nav__btn .material-symbols-rounded{ color: var(--red); }

/* Mobile sticky CTA */
.bl-stickyCta{ display:none; }
@media (max-width: 720px){
  .bl-stickyCta{
    position: sticky;
    bottom: 10px;
    z-index: 5;
    display:flex;
    gap: 10px;
    width: min(720px, calc(100% - 20px));
    margin: 14px auto 0;
    padding: 10px;
    border-radius: 18px;
    background: rgba(255,255,255,.80);
    border: 1px solid rgba(15,23,42,.12);
    box-shadow: 0 18px 60px rgba(15,23,42,.14);
    backdrop-filter: blur(10px);
  }
  .bl-stickyCta__btn{
    flex:1;
    display:flex;
    align-items:center;
    justify-content:center;
    gap: 8px;
    padding: 12px 12px;
    border-radius: 14px;
    font-weight: 800;
    border: 1px solid rgba(15,23,42,.12);
  }
  .bl-stickyCta__btn--ghost{ background:#fff; }
  .bl-stickyCta__btn--primary{
    background: linear-gradient(180deg, var(--red), var(--red2));
    color:#fff;
    border-color: rgba(255,255,255,.18);
  }
}

/* Sections */
.bl-section{ padding: 64px 0; background: var(--bg); }
.bl-section--alt{
  background: linear-gradient(180deg, #ffffff 0%, #f6f7fb 100%);
  border-top: 1px solid rgba(15,23,42,.08);
  border-bottom: 1px solid rgba(15,23,42,.08);
}

.bl-subtitle{
  margin:0 0 8px;
  font-family: var(--fontH);
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:700;
  font-size: 12px;
  color: var(--red);
}
.b1-section. elite-exclusive {
  font-size: clamp(0.9rem, 2.5vw, 1.1rem);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #c1121f; /* elite red */
  background: linear-gradient(90deg, #c1121f, #ff4d4d);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-align: center;
  margin: 20px auto;
  width: fit-content;
  position: relative;
}

.bl-h2{
  margin:0 0 10px;
  font-family: var(--fontH);
  text-transform: uppercase;
  letter-spacing:.02em;
  color: var(--ink);
  font-weight:700;
  font-size: clamp(24px, 2.8vw, 40px);
}
.bl-text{
  margin:0;
  color: rgba(31,41,55,.72);
  line-height:1.6;
  max-width: 80ch;
}
.bl-head--split{
  display:flex;
  align-items:flex-end;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

/* MARKETPLACE GRID */
.bl-serviceGrid{
  margin-top: 16px;
  display:grid;
  gap: 14px;
}
@media (min-width: 720px){
  .bl-serviceGrid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (min-width: 1100px){
  .bl-serviceGrid{ grid-template-columns: repeat(3, minmax(0,1fr)); }
}

.bl-svc{
  border-radius: var(--r);
  overflow:hidden;
  background:#fff;
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 18px 55px rgba(15,23,42,.08);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  cursor:pointer;
}
.bl-svc:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow2);
  border-color: rgba(209,20,20,.22);
}
.bl-svc__img{
  position:relative;
  height: 210px;
  background: #0b1324;
}
.bl-svc__img img{
  width:100%; height:100%;
  object-fit: cover;
}
.bl-svc__img::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(11,19,36,.15) 0%, rgba(11,19,36,.55) 100%);
}
.bl-svc__tagRow{
  position:absolute;
  left: 12px; right:12px; bottom: 12px;
  display:flex; gap: 8px; flex-wrap:wrap;
  z-index:2;
}
.bl-svc__tag{
  padding: 8px 10px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 12px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(255,255,255,.30);
  color: rgba(11,19,36,.88);
}
.bl-svc__tag--hot{
  background: rgba(209,20,20,.18);
  border-color: rgba(209,20,20,.22);
  color: rgba(209,20,20,.98);
}

.bl-svc__body{
  padding: 14px 14px 16px;
}
.bl-svc__title{
  margin:0 0 6px;
  font-family: var(--fontH);
  text-transform: uppercase;
  color: var(--ink);
  letter-spacing:.02em;
  font-size: 18px;
}
.bl-svc__desc{
  margin:0 0 12px;
  color: rgba(31,41,55,.72);
  line-height: 1.55;
}
.bl-svc__meta{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap:wrap;
}
.bl-svc__price{
  font-weight: 900;
  color: rgba(11,19,36,.92);
}
.bl-svc__time{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background: linear-gradient(180deg,#fff,#f4f6fb);
  color: rgba(11,19,36,.80);
  font-weight: 800;
  font-size: 12px;
}
.bl-svc__time .material-symbols-rounded{ font-size: 18px; color: var(--red); }

@media (max-width:560px){
  .bl-svc__img{ height: 190px; }
}

/* BEFORE/AFTER */
.bl-compare{
  position:relative;
  border-radius: var(--r);
  overflow:hidden;
  border: 1px solid rgba(15,23,42,.10);
  background:#fff;
  box-shadow: var(--shadow);
  height: clamp(240px, 34vw, 460px);
  margin-top: 16px;
  touch-action: none;
}
.bl-compare__img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit: cover;
  user-select:none;
  pointer-events:none;
}
.bl-compare__before{
  position:absolute; inset:0;
  width:50%;
  overflow:hidden;
}
.bl-compare__handle{
  position:absolute; top:0; bottom:0; left:50%;
  width:0;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor: ew-resize;
}
.bl-compare__line{
  position:absolute; top:0; bottom:0;
  width: 3px;
  background: rgba(255,255,255,.98);
  box-shadow: 0 0 0 1px rgba(15,23,42,.10), 0 18px 60px rgba(0,0,0,.18);
}
.bl-compare__knob{
  width: 52px; height:52px;
  border-radius: 999px;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(15,23,42,.16);
  display:grid; place-items:center;
  box-shadow: 0 22px 70px rgba(15,23,42,.18);
  transition: transform .18s ease;
}
.bl-compare.is-dragging .bl-compare__knob{ transform: scale(1.05); }
.bl-compare__labels{
  position:absolute;
  inset: 14px 14px auto 14px;
  display:flex;
  justify-content: space-between;
  pointer-events:none;
}
.bl-compare__label{
  padding: 8px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.86);
  color: rgba(11,19,36,.86);
}
.bl-compare__label--after{
  background: rgba(209,20,20,.10);
  border-color: rgba(209,20,20,.16);
  color: rgba(209,20,20,.95);
}

/* Gallery */
.bl-gallery{
  display:grid;
  gap: 12px;
  margin-top: 16px;
}
@media (min-width: 720px){
  .bl-gallery{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1100px){
  .bl-gallery{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
.bl-shot{
  margin:0;
  border-radius: var(--r);
  overflow:hidden;
  border: 1px solid rgba(15,23,42,.10);
  background:#fff;
  box-shadow: 0 18px 55px rgba(15,23,42,.08);
  transition: transform .18s ease, box-shadow .18s ease;
}
.bl-shot:hover{ transform: translateY(-4px); box-shadow: var(--shadow2); }
.bl-shot img{ width:100%; height: 240px; object-fit: cover; }
@media (max-width:560px){ .bl-shot img{ height: 210px; } }
.bl-shot figcaption{
  padding: 12px 12px;
  border-top: 1px solid rgba(15,23,42,.08);
  background: linear-gradient(180deg, #ffffff, #f6f7fb);
}
.bl-shot figcaption strong{
  display:block;
  font-weight: 800;
  color: rgba(11,19,36,.90);
}
.bl-shot figcaption span{
  display:block;
  margin-top: 2px;
  color: rgba(31,41,55,.68);
  font-size: 13px;
}

/* FAQ */
.bl-faq{
  margin-top: 14px;
  border-radius: var(--r);
  border: 1px solid rgba(15,23,42,.10);
  background:#fff;
  box-shadow: 0 18px 55px rgba(15,23,42,.08);
  overflow:hidden;
}
.bl-faq__q{
  width:100%;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 14px;
  border:0;
  background:#fff;
  cursor:pointer;
  font-weight: 800;
  color: rgba(11,19,36,.90);
  border-bottom: 1px solid rgba(15,23,42,.08);
}
.bl-faq__q .material-symbols-rounded{
  color: rgba(11,19,36,.70);
  transition: transform .18s ease;
}
.bl-faq__q.is-open .material-symbols-rounded{ transform: rotate(45deg); }
.bl-faq__a{
  padding: 0 14px 14px;
  color: rgba(31,41,55,.74);
  line-height:1.6;
  display:none;
}
.bl-faq__a.is-open{ display:block; }

/* CONTACT (FIXED TYPOGRAPHY HERE) */
.bl-contact{
  position:relative;
  padding: 64px 0 34px;
  background: linear-gradient(180deg, #ffffff 0%, #f6f7fb 55%, #eef1f7 100%);
  border-top: 1px solid rgba(15,23,42,.08);
}
.bl-contact__grid{
  display:grid;
  gap: 16px;
  align-items:start;
}
@media (min-width: 980px){
  .bl-contact__grid{ grid-template-columns: 1fr 1.1fr; gap: 20px; }
}

.bl-contact__info{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.10);
  border-radius: var(--r);
  padding: 18px;
  box-shadow: var(--shadow);
}
.bl-contact__tips{
  display:flex; flex-wrap:wrap; gap: 10px;
  margin-top: 12px;
}
.bl-contact__tips span{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  background:#fff;
  border: 1px solid rgba(15,23,42,.10);
  font-weight: 700;
  color: rgba(11,19,36,.78);
}
.bl-contact__tips .material-symbols-rounded{ color: var(--red); }

.bl-contact__links{
  margin-top: 12px;
  display:grid;
  gap: 10px;
}
.bl-contact__links a{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: var(--r2);
  background:#fff;
  border: 1px solid rgba(15,23,42,.10);
  font-weight: 800;
  color: rgba(11,19,36,.82);
  box-shadow: 0 16px 40px rgba(15,23,42,.08);
}

/* THE FORM: better fonts + spacing */
.bl-form{
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(15,23,42,.10);
  border-radius: var(--r);
  padding: 18px;
  box-shadow: var(--shadow);
}
.bl-form__row{
  display:grid;
  gap: 12px;
}
@media (min-width: 720px){
  .bl-form__row{ grid-template-columns: 1fr 1fr; }
}

.bl-form label{
  display:grid;
  gap: 8px;
  font-weight: 700;           /* FIX: was too heavy */
  letter-spacing: .01em;
  color: rgba(11,19,36,.88);
  font-size: 14px;            /* FIX: more premium */
}

.bl-form label span{
  font-weight: 700;
  color: rgba(11,19,36,.88);
}

.bl-form input,
.bl-form textarea{
  width:100%;
  padding: 12px 12px;
  border-radius: var(--r2);
  border: 1px solid rgba(15,23,42,.14);
  background:#fff;
  color: rgba(11,19,36,.92);
  outline:none;
  font-family: var(--fontB);
  font-weight: 500;           /* FIX: nicer input look */
  font-size: 14px;
}
.bl-form textarea{ resize: vertical; min-height: 140px; }

.bl-form input:focus,
.bl-form textarea:focus{
  border-color: rgba(209,20,20,.45);
  box-shadow: 0 0 0 4px rgba(209,20,20,.12);
}

.bl-small{
  margin: 10px 0 0;
  color: rgba(31,41,55,.62);
  font-size: 13px;
}

.bl-contactFade{
  position:absolute;
  left:0; right:0; bottom:0;
  height: 90px;
  background: linear-gradient(180deg, rgba(238,241,247,0) 0%, rgba(11,19,36,.16) 100%);
  pointer-events:none;
}

/* MODAL (marketplace details) */
.bl-modal{
  position: fixed;
  inset: 0;
  display:none;
  z-index: 9998;
}
.bl-modal.is-open{ display:block; }
.bl-modal__backdrop{
  position:absolute; inset:0;
  background: rgba(3,7,18,.55);
  backdrop-filter: blur(6px);
}
.bl-modal__panel{
  position:absolute;
  left:50%; top:50%;
  transform: translate(-50%,-50%);
  width: min(1080px, calc(100% - 22px));
  max-height: min(86vh, 920px);
  overflow:auto;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 22px;
  box-shadow: 0 40px 120px rgba(0,0,0,.35);
}
.bl-modal__close{
  position: sticky;
  top: 12px;
  margin-left: auto;
  margin-right: 12px;
  margin-top: 12px;
  width: 44px; height:44px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.14);
  background: #fff;
  display:grid; place-items:center;
  cursor:pointer;
  z-index: 2;
}
.bl-modal__grid{
  display:grid;
  gap: 16px;
  padding: 14px 14px 18px;
}
@media (min-width: 980px){
  .bl-modal__grid{ grid-template-columns: 1.1fr .9fr; }
}
.bl-modal__gallery{
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(15,23,42,.10);
  background:#fff;
}
.bl-modal__hero{
  position:relative;
  height: clamp(240px, 34vw, 420px);
  background:#0b1324;
}
.bl-modal__hero img{
  width:100%; height:100%;
  object-fit: cover;
}
.bl-gbtn{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px; height:44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(255,255,255,.85);
  cursor:pointer;
  display:grid; place-items:center;
}
.bl-gbtn--prev{ left: 12px; }
.bl-gbtn--next{ right: 12px; }

.bl-modal__thumbs{
  display:flex;
  gap: 10px;
  padding: 12px;
  overflow:auto;
  background: linear-gradient(180deg,#fff,#f6f7fb);
  border-top: 1px solid rgba(15,23,42,.08);
}
.bl-thumb{
  width: 92px; height: 64px;
  border-radius: 12px;
  overflow:hidden;
  border: 1px solid rgba(15,23,42,.12);
  cursor:pointer;
  flex: 0 0 auto;
  opacity: .82;
  transition: opacity .18s ease, transform .18s ease;
}
.bl-thumb img{ width:100%; height:100%; object-fit:cover; }
.bl-thumb.is-active{ opacity: 1; transform: translateY(-2px); border-color: rgba(209,20,20,.30); }

.bl-modal__info{
  padding: 6px 4px 8px;
}
.bl-modal__top{
  display:flex;
  align-items:flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.bl-modal__kicker{
  margin:0 0 6px;
  font-family: var(--fontH);
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:700;
  font-size: 12px;
  color: var(--red);
}
.bl-modal__title{
  margin:0 0 8px;
  font-family: var(--fontH);
  text-transform: uppercase;
  color: var(--ink);
  letter-spacing:.02em;
  font-size: 22px;
}
.bl-modal__sub{
  margin:0;
  color: rgba(31,41,55,.72);
  line-height:1.5;
}
.bl-modal__price{
  text-align:right;
}
.bl-modal__priceVal{
  display:block;
  font-weight: 900;
  color: rgba(11,19,36,.92);
  font-size: 18px;
}
.bl-modal__priceUnit{
  display:block;
  color: rgba(31,41,55,.62);
  font-size: 12px;
  margin-top: 2px;
}
.bl-modal__meta{
  display:block;
  margin-top: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(56,189,248,.10);
  border: 1px solid rgba(56,189,248,.18);
  color: rgba(11,19,36,.84);
  font-weight: 800;
  font-size: 12px;
}

.bl-modal__badges{
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 12px 0 10px;
}
.bl-badge{
  padding: 8px 10px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 12px;
  background:#fff;
  border: 1px solid rgba(15,23,42,.12);
  color: rgba(11,19,36,.82);
}
.bl-badge--hot{
  background: rgba(209,20,20,.12);
  border-color: rgba(209,20,20,.22);
  color: rgba(209,20,20,.95);
}
.bl-modal__sectionTitle{
  margin: 12px 0 10px;
  font-weight: 900;
  color: rgba(11,19,36,.88);
}
.bl-modal__list{
  display:grid;
  gap: 8px;
}
.bl-li{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  padding: 10px 10px;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.10);
  background: linear-gradient(180deg,#fff,#f6f7fb);
  color: rgba(31,41,55,.75);
  font-weight: 600;
}
.bl-li .material-symbols-rounded{
  color: var(--red);
  margin-top: 1px;
}
.bl-modal__note{
  margin: 10px 0 0;
  color: rgba(31,41,55,.62);
  font-size: 13px;
}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  .bl-btn,.bl-mini,.bl-svc{ transition:none; }
}
/* Show more button (clean, centered, responsive) */
.bl-seeMoreWrap{
  display:flex;
  justify-content:center;
  margin-top:18px;
}

.bl-seeMoreBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 16px;
  min-width:min(260px, 92%);
  border-radius:16px;
  text-decoration:none;
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#0b1220;
  background:#ffffff;
  border:1px solid rgba(15,23,42,.12);
  box-shadow:0 12px 30px rgba(2,6,23,.08);
  transition:transform .22s cubic-bezier(.2,.85,.2,1), box-shadow .22s cubic-bezier(.2,.85,.2,1);
  -webkit-tap-highlight-color: transparent;
}

.bl-seeMoreBtn:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 46px rgba(2,6,23,.12);
}

.bl-seeMoreBtn:active{
  transform:translateY(0px) scale(.99);
}

.bl-seeMoreArrow{
  width:34px;
  height:34px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:rgba(225,29,46,.10);
  border:1px solid rgba(225,29,46,.18);
  color:#e11d2e;
  font-size:18px;
  transition:transform .22s cubic-bezier(.2,.85,.2,1);
}

.bl-seeMoreBtn:hover .bl-seeMoreArrow{
  transform:translateX(2px);
}
