/* ===========================================================
   sentire — v2 utilitarian style overrides
   Reference-driven: flat cards, outline icons, simple grids.
   =========================================================== */

:root {
  --bg: #FFFFFF;
  --bg-elev: #FFFFFF;
  --bg-sunk: #F4F4F2;
  --bg-soft: #F8F8F6;
  --bg-deep: #1A1A1A;
  --line: #ECECE8;
  --line-soft: #F2F1ED;
  --line-strong: #DCDBD5;
  --ink: #1A1A1A;
  --ink-2: #2D2D2D;
  --ink-3: #6B6B6B;
  --ink-4: #9A9A9A;
  --ink-5: #C8C8C5;
  --whatsapp: #25D366;
  --whatsapp-ink: #1FB85A;
  --r-card: 14px;
  --r-tile: 12px;
}

/* ===== Header refresh — flat, no blur, no topbar shadow ===== */
.site-header {
  background: var(--bg);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-bottom: 1px solid var(--line);
}
.brand__logo { height: 48px; }

/* Hide phone link on small screens (handled below) */
.phone-link {
  font-size: 14px;
  font-weight: 700;
}
.phone-link svg { color: var(--accent); }

/* ===== Hero v2 — full-width photo with overlay text ===== */
.hero-v2 {
  position: relative;
  height: clamp(360px, 48vw, 540px);
  border-radius: var(--r-card);
  overflow: hidden;
  margin: 16px 0 56px;
  background: #DDD7CB;
}
.hero-v2__media {
  position: absolute; inset: 0;
}
.hero-v2__media .scene {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.4) 0%, rgba(255,255,255,0) 40%),
    linear-gradient(180deg, #E8E1D1 0%, #BFB39A 100%);
}
.hero-v2__media::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(255,255,255,.55) 0%, rgba(255,255,255,0) 60%);
}
.hero-v2__copy {
  position: absolute; left: 56px; top: 50%; transform: translateY(-50%);
  z-index: 2;
  max-width: 540px;
}
.hero-v2__copy h1 {
  font-size: clamp(40px, 5vw, 72px);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1;
  margin: 0 0 12px;
  color: var(--ink);
}
.hero-v2__copy h2 {
  font-size: clamp(20px, 2.2vw, 30px);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink-2);
  margin: 0 0 32px;
}
.hero-v2__copy .btn { font-size: 16px; padding: 0 28px; height: 52px; }

@media (max-width: 720px) {
  .hero-v2 { height: auto; aspect-ratio: 4/5; margin-top: 8px; margin-bottom: 32px; }
  .hero-v2__copy { left: 24px; right: 24px; top: auto; bottom: 32px; transform: none; }
  .hero-v2__copy h1 { font-size: 44px; }
  .hero-v2__copy h2 { font-size: 18px; margin-bottom: 20px; }
  .hero-v2__media::after { background: linear-gradient(180deg, rgba(255,255,255,0) 30%, rgba(255,255,255,.7) 100%); }
}

/* ===== CSS Banner Hero — illustrated interior scene ===== */

/* Scene container */
.bh {
  position: absolute; inset: 0; overflow: hidden;
  background: linear-gradient(145deg, #F5EDE0 0%, #EDE3CF 50%, #E2D5BE 100%);
}

/* Dot-grid texture */
.bh__dots {
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(150,115,65,.16) 1.2px, transparent 1.2px);
  background-size: 30px 30px;
  pointer-events: none;
}

/* ── Main orb (warm golden circle — the hero focal point) ── */
.bh__orb {
  position: absolute;
  right: -8%; top: -42%;
  width: 70%; padding-top: 70%;
  border-radius: 50%;
  background: radial-gradient(circle at 36% 36%,
    #F6E4C2 0%, #E2BE78 38%, #C89848 70%, #A87A32 100%);
  animation: bh-drift 11s ease-in-out infinite;
}
@keyframes bh-drift {
  0%,100% { transform: translate(0,0); }
  38%      { transform: translate(-10px,-14px); }
  72%      { transform: translate(6px,-7px); }
}

/* ── Floor plane ── */
.bh__floor {
  position: absolute; bottom: 0; inset-inline: 0; height: 36%;
  background: linear-gradient(180deg, #DDD2BC 0%, #CAB99A 100%);
}
.bh__floor::before {
  content: ''; position: absolute; top: 0; inset-inline: 0; height: 2px;
  background: linear-gradient(90deg, transparent 0%, rgba(115,85,45,.3) 25%, rgba(115,85,45,.3) 75%, transparent 100%);
}

/* ── Rug ── */
.bh__rug {
  position: absolute;
  bottom: 36%; right: 9%; width: 40%; height: 5%;
  background: repeating-linear-gradient(
    90deg, #C0A07A 0%, #CEAE86 8%, #C0A07A 16%
  );
  border-radius: 4px;
  transform: perspective(260px) rotateX(38deg);
  transform-origin: bottom center;
}

/* ── Plant ── */
.bh__plant {
  position: absolute;
  bottom: 36%; right: 47%;
  width: clamp(38px, 5vw, 58px);
}
.bh__plant-leaves {
  position: relative;
  height: clamp(55px, 8.5vw, 96px);
}
.bh__plant-leaf {
  position: absolute; bottom: 0; left: 50%;
  width: clamp(13px, 1.8vw, 20px);
  height: clamp(42px, 6vw, 72px);
  border-radius: 50% 50% 30% 30% / 65% 65% 35% 35%;
  transform-origin: bottom center;
}
.bh__plant-leaf:nth-child(1) { background: #7A9E62; transform: translateX(-50%) rotate(-36deg); }
.bh__plant-leaf:nth-child(2) { background: #5E8248; transform: translateX(-50%) rotate(-14deg) translateY(-10px); }
.bh__plant-leaf:nth-child(3) { background: #7A9E62; transform: translateX(-50%) rotate(12deg) translateY(-5px); }
.bh__plant-leaf:nth-child(4) { background: #628A50; transform: translateX(-50%) rotate(38deg); }
.bh__plant-leaf:nth-child(5) { background: #4E7040; width: 60%; transform: translateX(-40%) rotate(-55deg) translateY(-18px); }
.bh__plant-pot {
  height: clamp(20px, 3vw, 32px);
  background: linear-gradient(175deg, #C29065 0%, #A07048 100%);
  clip-path: polygon(8% 0%, 92% 0%, 84% 100%, 16% 100%);
}

/* ── Sofa ── */
.bh__sofa {
  position: absolute;
  bottom: 36%; right: 12%;
  width: clamp(175px, 29%, 345px);
}
.bh__sofa-body {
  display: flex; align-items: stretch;
}
.bh__sofa-arm {
  width: clamp(18px, 2.4vw, 28px); flex-shrink: 0;
  background: #664C34;
}
.bh__sofa-arm--l { border-radius: 8px 0 0 6px; }
.bh__sofa-arm--r { border-radius: 0 8px 6px 0; }
.bh__sofa-inner { flex: 1; display: flex; flex-direction: column; }
.bh__sofa-back {
  background: #7C5A3C;
  min-height: clamp(50px, 7.5vw, 86px);
  border-radius: 6px 6px 0 0;
  position: relative;
}
/* Cushions on backrest */
.bh__sofa-back::before, .bh__sofa-back::after {
  content: ''; position: absolute;
  top: 10px; bottom: 10px; width: 25%;
  background: #906848; border-radius: 5px;
}
.bh__sofa-back::before { left: 10%; }
.bh__sofa-back::after  { right: 10%; }
.bh__sofa-seat {
  background: #8A6248;
  height: clamp(28px, 4vw, 46px);
}
.bh__sofa-legs {
  display: flex; justify-content: space-around; padding-inline: 18%;
}
.bh__sofa-leg {
  width: 7px; height: clamp(10px, 1.4vw, 16px);
  background: #503828; border-radius: 0 0 3px 3px;
}
/* Shadow under sofa */
.bh__sofa::after {
  content: ''; position: absolute; bottom: -5px; inset-inline: 5%;
  height: 8px;
  background: radial-gradient(ellipse, rgba(40,20,5,.2) 0%, transparent 70%);
  border-radius: 50%;
  filter: blur(3px);
}

/* ── Floor lamp ── */
.bh__lamp {
  position: absolute;
  bottom: 36%; right: 5%;
  display: flex; flex-direction: column; align-items: center;
  position: absolute;
}
.bh__lamp-shade {
  width: clamp(34px, 4.8vw, 58px);
  height: clamp(22px, 3.2vw, 40px);
  background: linear-gradient(180deg, #C8A858 0%, #E2C882 55%, #C8A858 100%);
  clip-path: polygon(12% 0%, 88% 0%, 100% 100%, 0% 100%);
  position: relative;
}
/* Glow emanating from shade */
.bh__lamp-shade::after {
  content: ''; position: absolute; top: -8px; left: 50%;
  transform: translateX(-50%);
  width: 120%; padding-top: 80%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,215,105,.28) 0%, transparent 65%);
}
.bh__lamp-pole {
  width: 4px;
  height: clamp(98px, 14.5vw, 165px);
  background: linear-gradient(90deg, #8A6838 0%, #C8A858 50%, #8A6838 100%);
  border-radius: 2px;
}
.bh__lamp-foot {
  width: clamp(26px, 3.8vw, 46px);
  height: 7px; background: #9A7848; border-radius: 3px;
}
.bh__lamp-base {
  width: clamp(16px, 2.4vw, 32px);
  height: 5px; background: #785838; border-radius: 2px;
}

/* ── Thin decorative rules (editorial accent) ── */
.bh__rule {
  position: absolute; height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(110,82,42,.35) 30%, rgba(110,82,42,.35) 70%, transparent 100%);
  pointer-events: none;
}
.bh__rule--1 { top: 18%; left: 37%; width: 17%; }
.bh__rule--2 { top: 24%; left: 34%; width: 11%; opacity: .55; }

/* ── Small floating accent dots ── */
.bh__spark {
  position: absolute; border-radius: 50%;
  background: rgba(155,115,55,.22);
}
.bh__spark--1 { width: 10px; height: 10px; top: 14%; right: 31%; }
.bh__spark--2 { width:  6px; height:  6px; top: 40%; right: 56%; }
.bh__spark--3 { width: 14px; height: 14px; top: 29%; right: 22%; opacity: .5; }

/* ── Mobile adjustments ── */
@media (max-width: 720px) {
  .bh__sofa  { right: 4%;  width: 56%; }
  .bh__lamp  { right: 1%; }
  .bh__plant { display: none; }
  .bh__rug   { right: 2%;  width: 66%; }
  .bh__rule  { display: none; }
}

/* ===== Categories v2 — outline icons on flat cards ===== */
.cats-v2 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 64px;
}
@media (max-width: 900px) { .cats-v2 { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px) { .cats-v2 { grid-template-columns: repeat(2, 1fr); gap: 12px; } }

.cat-v2 {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 16px;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-tile);
  padding: 32px 16px 24px;
  min-height: 140px;
  transition: all var(--dur-2) var(--ease);
  text-align: center;
  text-decoration: none;
}
.cat-v2:hover {
  background: var(--bg);
  border-color: var(--accent);
  transform: translateY(-2px);
}
.cat-v2 svg { color: var(--ink-3); transition: color var(--dur-1) var(--ease); }
.cat-v2:hover svg { color: var(--accent); }
.cat-v2__label {
  font-size: 15px; font-weight: 600; color: var(--ink);
  letter-spacing: -0.01em;
}

/* ===== Section headings ===== */
.section-title-v2 {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: 24px;
}

/* ===== Features row v2 (Avantajele) ===== */
.feats-v2 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 64px;
}
@media (max-width: 900px) { .feats-v2 { grid-template-columns: repeat(2, 1fr); } }

.feat-v2 {
  display: flex; align-items: center; gap: 14px;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-tile);
  padding: 18px 20px;
}
.feat-v2 svg { color: var(--ink-2); flex-shrink: 0; width: 36px; height: 36px; }
.feat-v2__copy strong {
  display: block;
  font-size: 15px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.01em;
  line-height: 1.2;
}
.feat-v2__copy span {
  display: block;
  font-size: 12px;
  color: var(--ink-3);
  margin-top: 2px;
  line-height: 1.3;
}

/* ===== Contact block v2 ===== */
.contact-v2 {
  text-align: center;
  padding: 64px 24px;
  background: var(--bg-soft);
  border-radius: var(--r-card);
  margin-bottom: 64px;
}
.contact-v2 h2 {
  font-size: clamp(28px, 3.5vw, 40px);
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 24px;
}
.contact-v2__phone {
  display: inline-flex; align-items: center; gap: 12px;
  font-size: clamp(22px, 2.6vw, 30px);
  font-weight: 700;
  color: var(--ink);
  text-decoration: none;
  margin-bottom: 24px;
}
.contact-v2__phone .ico {
  width: 40px; height: 40px;
  background: var(--whatsapp);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: white;
}
.contact-v2__phone .ico svg { width: 22px; height: 22px; }

.contact-v2__btns {
  display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
  margin-bottom: 28px;
}
.btn--call {
  background: var(--accent);
  color: white;
  border: 0;
  height: 52px; padding: 0 28px;
  border-radius: 8px;
  font-weight: 700;
  font-size: 15px;
  display: inline-flex; align-items: center; gap: 10px;
  text-decoration: none;
  transition: background var(--dur-1) var(--ease);
}
.btn--call:hover { background: var(--accent-ink); }
.btn--whatsapp {
  background: var(--whatsapp);
  color: white;
}
.btn--whatsapp:hover { background: var(--whatsapp-ink); }

.contact-v2__addr {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--ink-3);
  font-size: 14px;
}
.contact-v2__addr svg { width: 18px; height: 18px; color: var(--accent); }

/* ===== Map block ===== */
.map-v2 {
  position: relative;
  height: 320px;
  border-radius: var(--r-card);
  overflow: hidden;
  background: linear-gradient(135deg, #DDD8CC 0%, #C8C2B0 100%);
  margin-bottom: 64px;
}
.map-v2__pin {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -100%);
  color: var(--accent);
}
.map-v2__pin svg { width: 56px; height: 56px; }
.map-v2__chip {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, calc(-100% - 64px));
  background: white;
  padding: 10px 20px 10px 14px;
  border-radius: 999px;
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14px; font-weight: 700;
  box-shadow: 0 4px 16px rgba(0,0,0,.1);
  white-space: nowrap;
}
.map-v2__chip::before {
  content: ""; width: 8px; height: 8px;
  background: var(--accent); border-radius: 50%;
}
.map-v2__grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.18) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.18) 1px, transparent 1px);
  background-size: 40px 40px;
  opacity: .5;
}

/* ===== Override product card to flat utilitarian ===== */
.product__media {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--r-tile);
  aspect-ratio: 4/3;
}
.product__title { font-weight: 600; font-size: 16px; letter-spacing: -0.01em; }

/* ===== Override section heading h1/h2 to bolder, sans ===== */
h1, h2, h3, h4 {
  font-weight: 700;
  letter-spacing: -0.02em;
}
.page-head h1 { font-weight: 800; }
.hero__title { font-weight: 800; letter-spacing: -0.025em; }

/* ===== Page header section — full-width wrapper with border ===== */
.page-header-section {
  border-bottom: 1px solid var(--line);
  margin-bottom: 48px;
}

/* ===== Page head ===== */
.page-head {
  padding: 0 0 24px;
}
.page-head h1 {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800;
  letter-spacing: -0.025em;
  margin: 0 0 8px;
  color: var(--ink);
}
.page-head p {
  color: var(--ink-3);
  font-size: 15px;
  max-width: 640px;
  margin: 0;
}

/* ===== Sec head simpler ===== */
.sec-head {
  display: flex; justify-content: space-between; align-items: end;
  margin-bottom: 24px;
  border: 0;
  padding: 0;
}
.sec-head h2 { font-size: clamp(24px, 2.8vw, 32px); font-weight: 700; }
.sec-head .eyebrow { display: none; }

/* ===== Buttons unified ===== */
.btn {
  border-radius: 8px;
  font-weight: 700;
  letter-spacing: -0.005em;
}
.btn--primary { background: var(--accent); color: white; }
.btn--primary:hover { background: var(--accent-ink); color: white; }
.btn--ghost {
  background: transparent;
  border: 1.5px solid var(--line-strong);
  color: var(--ink);
}
.btn--ghost:hover { border-color: var(--ink); }

/* ===== Footer simpler ===== */
.site-footer { background: #1A1A1A; padding-top: 60px; margin-top: 100px; }
.site-footer h4 { letter-spacing: .12em; }

/* ===== Catalog filter & cards simpler ===== */
.filter-card { background: var(--bg-soft); border: 1px solid var(--line); border-radius: var(--r-tile); }

/* ===== Mobile nav overlay ===== */
.mobile-nav {
  display: none;
  position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,.5);
}
.mobile-nav.is-open { display: block; }
.mobile-nav__inner {
  position: absolute; top: 0; right: 0;
  width: min(320px, 90vw); height: 100%;
  background: var(--bg);
  padding: 24px 20px;
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 8px;
}
.mobile-nav__links { display: flex; flex-direction: column; gap: 4px; }
.mobile-nav__links a {
  display: block; padding: 12px 0;
  font-size: 16px; font-weight: 600; color: var(--ink);
  border-bottom: 1px solid var(--line);
  text-decoration: none;
}
.mobile-nav__links a:hover { color: var(--accent); }
.mobile-nav__lang {
  display: flex; gap: 8px; padding-top: 16px;
}
.mobile-nav__lang a {
  padding: 6px 14px; border: 1px solid var(--line);
  border-radius: var(--r-pill); font-size: 12px; font-weight: 700;
  color: var(--ink-3); text-decoration: none;
}
.mobile-nav__lang a.is-active { background: var(--ink); color: white; border-color: var(--ink); }

/* ===== Navbar search bar ===== */
.navbar-search-bar {
  border-top: 1px solid var(--line);
  background: var(--bg);
  padding: 12px 0;
}
.navbar-search-bar-form {
  display: flex; align-items: center; gap: 8px;
}
.navbar-search-bar-form input[type="search"] {
  flex: 1;
  height: 44px;
  padding: 0 14px;
  border: 1.5px solid var(--line-strong);
  border-radius: 8px;
  font-size: 15px;
  color: var(--ink);
  background: var(--bg-soft);
  outline: none;
}
.navbar-search-bar-form input[type="search"]:focus {
  border-color: var(--accent);
  background: var(--bg);
}
.navbar-search-bar-form button {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--line-strong);
  border-radius: 8px;
  background: var(--bg-soft);
  color: var(--ink-3);
  cursor: pointer;
  flex-shrink: 0;
}
.navbar-search-bar-form button:hover { border-color: var(--accent); color: var(--accent); }

/* ===== Lang switch as links ===== */
.lang-switch a {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 6px 12px;
  font-size: 12px; font-weight: 700; letter-spacing: .08em;
  border-radius: var(--r-pill); color: var(--ink-3);
  text-decoration: none;
}
.lang-switch a.is-active { background: var(--ink); color: white; }

/* ===== Bootstrap-compat utilities (thin layer, no BS dependency) ===== */
.row { display: flex; flex-wrap: wrap; margin: 0 -12px; }
.row.g-3 { margin: 0 -8px; }
.row.g-3 > * { padding: 0 8px; margin-bottom: 16px; }
.row.g-4 { margin: 0 -12px; }
.row.g-4 > * { padding: 0 12px; margin-bottom: 24px; }
.row.g-5 { margin: 0 -16px; }
.row.g-5 > * { padding: 0 16px; margin-bottom: 32px; }
.col-sm-6 { width: 50%; }
.col-sm-4 { width: 33.333%; }
.col-sm-8 { width: 66.666%; }
.col-lg-4 { width: 33.333%; }
.col-lg-5 { width: 41.666%; }
.col-lg-6 { width: 50%; }
.col-lg-7 { width: 58.333%; }
.col-lg-8 { width: 66.666%; }
.col-lg-9 { width: 75%; }
@media (max-width: 991px) {
  .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9 { width: 100%; }
}
@media (max-width: 575px) {
  .col-sm-4, .col-sm-6, .col-sm-8 { width: 100%; }
}

/* Form controls */
.form-control, .form-select {
  display: block; width: 100%;
  height: 44px; padding: 0 14px;
  font-size: 14px; color: var(--ink);
  background: var(--bg-soft);
  border: 1.5px solid var(--line-strong);
  border-radius: 8px;
  outline: none;
  transition: border-color var(--dur-1) var(--ease);
}
.form-control:focus, .form-select:focus { border-color: var(--accent); background: var(--bg); }
textarea.form-control { height: auto; padding: 12px 14px; }
.form-control-sm { height: 36px; font-size: 13px; padding: 0 10px; }
.form-label { display: block; margin-bottom: 6px; font-size: 13px; font-weight: 600; color: var(--ink-2); }
.form-text { font-size: 12px; color: var(--ink-4); margin-top: 4px; }

/* Button overrides */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; height: 44px; padding: 0 20px; font-size: 14px; border-radius: 8px; border: 0; cursor: pointer; font-weight: 700; transition: background var(--dur-1) var(--ease), color var(--dur-1) var(--ease); }
.btn-primary, .btn.btn-primary { background: var(--accent); color: white; }
.btn-primary:hover, .btn.btn-primary:hover { background: var(--accent-ink); color: white; }
.btn-outline-secondary, .btn.btn-outline-secondary { background: transparent; border: 1.5px solid var(--line-strong); color: var(--ink-2); }
.btn-outline-secondary:hover { border-color: var(--ink); color: var(--ink); }
.btn-sm { height: 34px; padding: 0 14px; font-size: 13px; }
.btn-link { background: transparent; border: 0; color: var(--accent); padding: 0; height: auto; }
.btn-group { display: inline-flex; }
.btn-group .btn { border-radius: 0; border-right: 0; }
.btn-group .btn:first-child { border-radius: 8px 0 0 8px; }
.btn-group .btn:last-child { border-radius: 0 8px 8px 0; border-right: 1.5px solid var(--line-strong); }

/* Spacing utilities */
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 16px; }
.mt-4 { margin-top: 24px; }
.mt-5 { margin-top: 40px; }
.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 16px; }
.mb-4 { margin-bottom: 24px; }
.ms-auto { margin-left: auto; }
.me-2 { margin-right: 8px; }
.w-100 { width: 100%; }
.d-block { display: block; }
.d-inline-block { display: inline-block; }
.d-flex { display: flex; }
.align-items-center { align-items: center; }
.justify-content-between { justify-content: space-between; }
.justify-content-center { justify-content: center; }
.flex-wrap { flex-wrap: wrap; }
.gap-2 { gap: 8px; }
.gap-3 { gap: 12px; }
.text-muted { color: var(--ink-3); }
.text-center { text-align: center; }
.small { font-size: 13px; }
.py-5 { padding-top: 48px; padding-bottom: 48px; }

/* ===== Category sidebar tree accordion ===== */
.shop-cat-sub { display: none; }
.shop-cat-sub.is-open { display: block; }
.shop-cat-toggle svg { transition: transform var(--dur-1) var(--ease); }
.shop-cat-toggle.is-open svg { transform: rotate(180deg); }

/* ===== Shop search form ===== */
.shop-search-form { margin-top: 16px; }
.shop-search-input-group {
  display: flex; align-items: stretch; gap: 0;
  max-width: 680px;
  border: 1.5px solid var(--line-strong);
  border-radius: 10px;
  overflow: hidden;
}
.shop-search-input-group .form-control {
  border: 0; border-radius: 0; background: var(--bg-soft);
  flex: 1; height: 52px; font-size: 16px;
}
.shop-search-input-group .form-control:focus { background: var(--bg); outline: none; box-shadow: none; }
.shop-search-input-group .btn {
  border-radius: 0; height: 52px; padding: 0 24px;
  border: 0; border-left: 1.5px solid var(--line-strong);
  flex-shrink: 0;
}

/* Bootstrap collapse compat */
.collapse { display: none; }
.collapse.show { display: block; }

/* ===== Mobile nav — missing subcomponent styles ===== */
.mobile-nav__header {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 8px;
  position: sticky; top: 0; background: var(--bg); z-index: 1;
}
.mobile-nav__section-link {
  display: block; padding: 12px 0;
  font-size: 15px; font-weight: 600; color: var(--ink);
  border-bottom: 1px solid var(--line);
  text-decoration: none;
}
.mobile-nav__section-link:hover { color: var(--accent); }
.mobile-nav__footer {
  margin-top: auto;
  padding-top: 20px;
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 16px;
}
.mobile-nav__phone {
  display: flex; align-items: center; gap: 10px;
  font-size: 17px; font-weight: 700; color: var(--ink);
  text-decoration: none;
}
.mobile-nav__phone svg { color: var(--accent); flex-shrink: 0; }
.mobile-nav__phone:hover { color: var(--accent); }

/* ===== Mobile-specific improvements ===== */
@media (max-width: 600px) {
  /* Contact block: full-width stacked buttons */
  .contact-v2 { padding: 40px 20px; }
  .contact-v2__btns { flex-direction: column; align-items: stretch; }
  .btn--call { justify-content: center; }

  /* Map: shorter on small screens */
  .map-v2 { height: 240px; }

  /* Section spacing tighter */
  .cats-v2, .feats-v2, .contact-v2, .map-v2 { margin-bottom: 40px; }

  /* Features: labels smaller */
  .feat-v2__copy strong { font-size: 14px; }
}
