/* ═══════════════════════════════════════════════════
   COMPONENTS — Reusable UI Elements
   InteriorsExpress Services Module
   ═══════════════════════════════════════════════════ */

/* ─── Container ─── */
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; }

/* ─── Section Headers ─── */
.section-eyebrow {
  font-family: 'Rajdhani', sans-serif; font-size: 11.5px; font-weight: 700;
  letter-spacing: 3px; text-transform: uppercase; color: var(--svc);
  margin-bottom: 7px; display: flex; align-items: center; gap: 10px;
}
.section-eyebrow::before { content: ''; width: 28px; height: 1.5px; background: var(--svc); display: inline-block; }
.section-heading {
  font-family: 'Playfair Display', serif; font-size: var(--fs-2xl); font-weight: 700;
  color: var(--charcoal); line-height: 1.15; margin-bottom: 9px;
}
.section-heading em { font-style: italic; color: var(--svc); }
.section-sub { font-size: var(--fs-md); color: var(--stone); line-height: 1.75; max-width: 560px; }

/* ─── Buttons ─── */
.btn-primary {
  background: var(--charcoal); color: var(--white); padding: 12px 26px; border-radius: 6px;
  font-size: var(--fs-base); font-weight: 600; letter-spacing: .3px; transition: all .2s;
  cursor: pointer; display: inline-flex; align-items: center; gap: 8px; border: none;
}
.btn-primary:hover { background: var(--svc); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-outline {
  background: transparent; color: var(--charcoal); padding: 11px 24px; border-radius: 6px;
  font-size: var(--fs-base); font-weight: 600; border: 1.5px solid var(--charcoal);
  transition: all .2s; cursor: pointer; display: inline-flex; align-items: center; gap: 8px;
}
.btn-outline:hover { background: var(--charcoal); color: var(--white); }
.btn-svc {
  background: var(--svc); color: var(--white); padding: 12px 26px; border-radius: 6px;
  font-size: var(--fs-base); font-weight: 600; transition: all .2s; cursor: pointer;
  display: inline-flex; align-items: center; gap: 8px; border: none;
}
.btn-svc:hover { background: #144b70; transform: translateY(-1px); }
.btn-sm { padding: 7px 16px; font-size: 12.5px; border-radius: 5px; }
.btn-xs { padding: 5px 12px; font-size: 12px; border-radius: 4px; }
.btn-full { width: 100%; justify-content: center; padding: 13px; border-radius: 6px; font-size: var(--fs-base); font-weight: 600; letter-spacing: .3px; }
.btn-full-dark { background: var(--charcoal); color: var(--white); border: none; }
.btn-full-dark:hover { background: var(--svc); }
.btn-full-svc { background: var(--svc); color: var(--white); border: none; }
.btn-full-svc:hover { background: #144b70; }

/* ─── Badges & Chips ─── */
.badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: 4px; font-size: 11px; font-weight: 600; letter-spacing: .4px; }
.badge-svc { background: var(--svc-bg); color: var(--svc); border: 1px solid var(--svc-pale); }
.badge-gold { background: var(--gold-bg); color: var(--gold-rich); border: 1px solid var(--gold-pale); }
.badge-green { background: rgba(34,117,58,.08); color: var(--green); border: 1px solid rgba(34,117,58,.2); }
.badge-dark { background: var(--charcoal); color: var(--white); }
.badge-amber { background: var(--svc-amber-bg); color: var(--svc-amber); border: 1px solid #FDE68A; }
.badge-light { background: var(--warm-white); color: var(--stone); border: 1px solid var(--border); }
.chip {
  display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; border-radius: 20px;
  font-size: 12.5px; font-weight: 500; border: 1.5px solid var(--border); color: var(--stone);
  background: var(--white); cursor: pointer; transition: all .2s; white-space: nowrap;
}
.chip:hover, .chip.active { background: var(--charcoal); color: var(--white); border-color: var(--charcoal); }
.chip-svc.active { background: var(--svc-bg); color: var(--svc); border-color: var(--svc-l); }
.tag { padding: 3px 10px; border-radius: 4px; font-size: 12px; font-weight: 500; background: var(--warm-white); color: var(--stone); border: 1px solid var(--border); }
.stars { color: var(--gold); font-size: 12px; letter-spacing: 1px; }
.rating { display: flex; align-items: center; gap: 6px; }
.rating-val { font-size: 14px; font-weight: 600; color: var(--charcoal); }
.rating-ct { font-size: 12.5px; color: var(--pebble); }
.divider { height: 1px; background: var(--border-light); margin: var(--sp-xl) 0; }

/* ─── Forms ─── */
.fg { margin-bottom: 14px; }
.lbl { display: block; font-size: 12.5px; font-weight: 600; color: var(--stone); margin-bottom: 5px; letter-spacing: .3px; text-transform: uppercase; font-family: 'Rajdhani', sans-serif; }
.inp {
  width: 100%; border: 1.5px solid var(--border); border-radius: 6px; padding: 10px 14px;
  font-size: 14px; color: var(--ink); background: var(--white); transition: border .2s;
}
.inp:focus { border-color: var(--svc); }
.inp::placeholder { color: var(--mist); }
.inp-select {
  width: 100%; border: 1.5px solid var(--border); border-radius: 6px; padding: 10px 34px 10px 14px;
  font-size: 14px; color: var(--ink); background: var(--white); appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238C867E' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center; cursor: pointer; transition: border .2s;
}
.inp-select:focus { border-color: var(--svc); }
.inp-area { resize: vertical; min-height: 90px; }
.frm-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-error { background: rgba(192,57,43,.07); color: var(--rust); border: 1px solid rgba(192,57,43,.2); border-radius: 6px; padding: 10px 14px; font-size: 13.5px; margin-bottom: 10px; }
.form-success { background: rgba(34,117,58,.07); color: var(--green); border: 1px solid rgba(34,117,58,.2); border-radius: 6px; padding: 10px 14px; font-size: 13.5px; margin-bottom: 10px; }

/* ─── Toast ─── */
.toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px);
  background: var(--charcoal); color: var(--white); padding: 12px 22px; border-radius: 8px;
  font-size: 14px; font-weight: 500; z-index: 9999; opacity: 0; pointer-events: none;
  transition: all .3s; white-space: nowrap;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ─── Upload Zone ─── */
.upload-zone {
  border: 2px dashed var(--border); border-radius: 8px; padding: 24px; text-align: center;
  cursor: pointer; transition: border .2s; background: var(--off-white);
}
.upload-zone:hover { border-color: var(--svc-l); background: var(--svc-bg); }
.uz-ico { font-size: 30px; margin-bottom: 8px; }
.uz-title { font-size: 13.5px; font-weight: 600; color: var(--charcoal); margin-bottom: 4px; }
.uz-sub { font-size: 12px; color: var(--pebble); line-height: 1.5; }

/* ─── Modals ─── */
.modal-ov {
  position: fixed; inset: 0; background: rgba(26,24,20,.6); z-index: 2000;
  display: none; align-items: center; justify-content: center; padding: 16px; backdrop-filter: blur(4px);
}
.modal-ov.open { display: flex; }
.modal-box {
  background: var(--white); border-radius: 12px; width: 100%; max-width: 480px;
  max-height: 90vh; overflow-y: auto; box-shadow: var(--shadow-xl); animation: pageIn .28s ease;
}
.modal-hd { padding: 22px 24px; border-bottom: 1px solid var(--border-light); position: relative; }
.modal-title { font-family: 'Playfair Display', serif; font-size: 22px; font-weight: 700; color: var(--charcoal); margin-bottom: 3px; }
.modal-sub { font-size: 13.5px; color: var(--stone); }
.modal-cls {
  position: absolute; top: 18px; right: 18px; width: 30px; height: 30px; border-radius: 50%;
  border: 1.5px solid var(--border); display: flex; align-items: center; justify-content: center;
  font-size: 14px; color: var(--stone); cursor: pointer; transition: all .2s;
}
.modal-cls:hover { background: var(--cream); }
.modal-bd { padding: 24px; }
.modal-tabs { display: flex; border-bottom: 1px solid var(--border-light); margin-bottom: var(--sp-md); }
.modal-tab {
  flex: 1; padding: 11px; text-align: center; font-size: 14px; font-weight: 500;
  color: var(--pebble); cursor: pointer; border-bottom: 2px solid transparent; transition: all .2s;
}
.modal-tab.active { color: var(--svc); border-bottom-color: var(--svc); }
.modal-tab-panel { display: none; }
.modal-tab-panel.active { display: block; }
.divider-or { display: flex; align-items: center; gap: 12px; margin: 14px 0; font-size: 12.5px; color: var(--pebble); }
.divider-or::before, .divider-or::after { content: ''; flex: 1; height: 1px; background: var(--border-light); }
.social-login-btns { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.soc-btn {
  border: 1.5px solid var(--border); border-radius: 7px; padding: 9px 14px; display: flex;
  align-items: center; justify-content: center; gap: 7px; font-size: 13px; font-weight: 500;
  cursor: pointer; transition: all .2s; color: var(--ink);
}
.soc-btn:hover { border-color: var(--charcoal); background: var(--off-white); }
.modal-footer-link { text-align: center; margin-top: 14px; font-size: 13px; color: var(--pebble); }
.modal-footer-link a { color: var(--svc); cursor: pointer; font-weight: 500; }
.modal-footer-link a:hover { text-decoration: underline; }
.enquiry-service-info {
  background: var(--svc-bg); border: 1px solid var(--svc-pale); border-radius: 8px;
  padding: 14px; margin-bottom: var(--sp-md); display: flex; align-items: center; gap: 12px;
}
.esi-ico { font-size: 28px; }
.esi-name { font-size: 14px; font-weight: 700; color: var(--charcoal); }
.esi-prov { font-size: 12px; color: var(--svc); }

/* ─── Pagination ─── */
.pagination {
  display: flex; align-items: center; justify-content: center; gap: 5px;
  margin-top: var(--sp-xl); padding-top: var(--sp-lg); border-top: 1px solid var(--border-light);
}
.pg-btn {
  width: 36px; height: 36px; border-radius: 5px; border: 1.5px solid var(--border);
  font-size: 13.5px; font-weight: 500; color: var(--stone); cursor: pointer;
  display: flex; align-items: center; justify-content: center; transition: all .2s;
}
.pg-btn:hover { border-color: var(--svc); color: var(--svc); }
.pg-btn.active { background: var(--svc); color: var(--white); border-color: var(--svc); }

/* ─── Star Picker (Review) ─── */
.star-picker { display: flex; gap: 6px; margin-bottom: var(--sp-sm); }
.star-btn { font-size: 26px; cursor: pointer; transition: transform .15s; opacity: .35; }
.star-btn:hover, .star-btn.lit { opacity: 1; transform: scale(1.12); }
.review-tag-row { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: var(--sp-md); }
.rtag { padding: 5px 12px; border-radius: 20px; font-size: 12.5px; border: 1.5px solid var(--border); color: var(--stone); cursor: pointer; transition: all .15s; }
.rtag:hover, .rtag.sel { background: var(--svc); color: #fff; border-color: var(--svc); }

/* ─── Search Autocomplete ─── */
.search-wrap { position: relative; }
.autocomplete-dd {
  display: none; position: absolute; top: calc(100% + 4px); left: 0; right: 0;
  background: var(--white); border: 1px solid var(--border); border-radius: 8px;
  box-shadow: var(--shadow-lg); z-index: 200; overflow: hidden;
}
.autocomplete-dd.open { display: block; animation: pageIn .15s ease; }
.ac-sec-label {
  padding: 7px 14px; font-size: 10.5px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; color: var(--pebble); background: var(--off-white);
  font-family: 'Rajdhani', sans-serif; border-bottom: 1px solid var(--border-light);
}
.ac-item {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px; cursor: pointer;
  transition: background .12s; border-bottom: 1px solid var(--border-light);
}
.ac-item:last-child { border-bottom: none; }
.ac-item:hover { background: var(--svc-bg); }
.ac-ico { font-size: 16px; width: 24px; text-align: center; flex-shrink: 0; }
.ac-label { font-size: 14px; color: var(--ink); flex: 1; }
.ac-cat { font-size: 12px; color: var(--pebble); }
