/* =========================================================
   HOTFIX — Make gmf (filters) look premium (home + catalog)
   Put this at the END of filters.css
   ========================================================= */

/* -----------------------------
   1) Card container
------------------------------ */
.gmf-card{
  background: var(--app-surface);
  border: 1px solid var(--app-border);
  border-radius: 1rem;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .06);
}

/* -----------------------------
   2) Top layout (search + pills + apply)
------------------------------ */
.gmf-top{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .75rem;
}

/* Search */
.gmf-search{
  position: relative;
  display: flex;
  align-items: center;
  gap: .5rem;
  min-width: 260px;
  flex: 1 1 320px;
}

.gmf-search-icon{
  position: absolute;
  left: .85rem;
  top: 50%;
  transform: translateY(-50%);
  opacity: .65;
  pointer-events: none;
}

.gmf-search-input{
  width: 100%;
  height: 42px;
  padding: .5rem .9rem .5rem 2.35rem;
  border-radius: .9rem;
  border: 1px solid var(--app-border);
  background: var(--app-soft);
  color: var(--app-text);
  outline: none;
}

.gmf-search-input::placeholder{
  color: rgba(100,116,139,.85);
}

.gmf-search-input:focus{
  background: var(--app-surface);
  border-color: rgba(109, 40, 217, .45);
  box-shadow: 0 0 0 .18rem rgba(109, 40, 217, .18);
}

.gmf-clear-q{
  position: absolute;
  right: .55rem;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: transparent;
  width: 34px;
  height: 34px;
  border-radius: .75rem;
  display: grid;
  place-items: center;
  color: var(--app-muted);
}
.gmf-clear-q:hover{
  background: rgba(0,0,0,.06);
  color: var(--app-text);
}

/* Type pills */
.gmf-type{
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
}

.gmf-pill{
  appearance: none;
  -webkit-appearance: none;

  border: 1px solid var(--app-border);
  background: var(--app-soft);
  color: var(--app-text);
  border-radius: 999px;

  height: 40px;
  padding: 0 .9rem;
  display: inline-flex;
  align-items: center;
  gap: .5rem;

  font-weight: 800;
  font-size: .9rem;
  line-height: 1;

  cursor: pointer;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;

  transition: transform .12s ease, background .12s ease, border-color .12s ease, box-shadow .12s ease;
}

.gmf-pill i{ font-size: 1.05rem; opacity: .9; }

.gmf-pill:hover{
  background: var(--app-surface);
  border-color: rgba(109, 40, 217, .28);
  box-shadow: 0 8px 16px rgba(15, 23, 42, .08);
  transform: translateY(-1px);
}

/* Active state (support both conventions) */
.gmf-pill.active,
.gmf-pill.is-active{
  border-color: rgba(109, 40, 217, .45);
  background: linear-gradient(135deg, rgba(29,78,216,.12), rgba(109,40,217,.12));
  color: #0f172a;
  box-shadow: 0 10px 22px rgba(109,40,217,.14);
}

/* Apply button alignment */
.gmf-top .btn{
  height: 40px;
  border-radius: 999px;
  font-weight: 900;
}

/* -----------------------------
   3) Advanced panel (Sort / Price / etc.)
------------------------------ */
.gmf-panel{
  margin-top: .75rem;
  padding-top: .75rem;
  border-top: 1px dashed rgba(148,163,184,.35);
}

.gmf-panel-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: .75rem 1rem;
  align-items: center;
}

/* Each field: label + control by default (for Sort) */
.gmf-field{
  display: flex;
  align-items: center;
  gap: .75rem;
  min-height: 54px;
}

/* Label: keep compact and aligned */
.gmf-field label{
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin: 0;
  white-space: nowrap;
  font-weight: 900;
  font-size: .95rem;
  color: rgba(15,23,42,.85);
  min-width: 72px; /* makes "Sort" align cleanly */
}

/* Controls (works even if markup is imperfect) */
.gmf-panel select,
.gmf-panel input[type="text"],
.gmf-panel input[type="number"]{
  -webkit-appearance: none;
  appearance: none;

  width: 100%;
  height: 44px;
  border-radius: 999px;
  padding: 0 1rem;
  border: 1px solid rgba(148,163,184,.35);
  background: #fff;
  color: rgba(15,23,42,.92);
  font-weight: 800;
  outline: none;
}

/* Custom arrow for select */
.gmf-panel select{
  background-image:
    linear-gradient(45deg, transparent 50%, #64748b 50%),
    linear-gradient(135deg, #64748b 50%, transparent 50%);
  background-position:
    calc(100% - 18px) 55%,
    calc(100% - 12px) 55%;
  background-size: 6px 6px;
  background-repeat: no-repeat;
  padding-right: 2.25rem;
}

/* Focus state */
.gmf-panel select:focus,
.gmf-panel input[type="text"]:focus,
.gmf-panel input[type="number"]:focus{
  border-color: rgba(109, 40, 217, .45);
  box-shadow: 0 0 0 .18rem rgba(109, 40, 217, .18);
}

/* Price field: label on top + min/max on one row */
.gmf-field--price{
  flex-direction: column;
  align-items: flex-start;
  gap: .35rem;
}
.gmf-field--price label{
  min-width: unset;
}
.gmf-field--price .d-flex.gap-2{
  width: 100%;
  align-items: center;
}

/* Actions row (Apply filters / Reset) */
.gmf-panel-actions{
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  align-items: center;
  margin-top: .85rem;
}
.gmf-panel-actions .btn{
  height: 40px;
  border-radius: 999px;
  font-weight: 900;
}

/* -----------------------------
   4) Dark mode refinements
------------------------------ */
body.dark-mode .gmf-card,
html[data-bs-theme="dark"] .gmf-card{
  box-shadow: 0 16px 34px rgba(0,0,0,.28);
}

body.dark-mode .gmf-search-input,
html[data-bs-theme="dark"] .gmf-search-input{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.10);
  color: rgba(226,232,240,.95);
}
body.dark-mode .gmf-search-input::placeholder,
html[data-bs-theme="dark"] .gmf-search-input::placeholder{
  color: rgba(226,232,240,.55);
}

body.dark-mode .gmf-clear-q:hover,
html[data-bs-theme="dark"] .gmf-clear-q:hover{
  background: rgba(255,255,255,.08);
  color: rgba(226,232,240,.95);
}

body.dark-mode .gmf-pill,
html[data-bs-theme="dark"] .gmf-pill{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
  color: rgba(226,232,240,.95);
}
body.dark-mode .gmf-pill:hover,
html[data-bs-theme="dark"] .gmf-pill:hover{
  background: rgba(255,255,255,.09);
  border-color: rgba(255,255,255,.18);
}
body.dark-mode .gmf-pill.active,
body.dark-mode .gmf-pill.is-active,
html[data-bs-theme="dark"] .gmf-pill.active,
html[data-bs-theme="dark"] .gmf-pill.is-active{
  color: rgba(226,232,240,.98);
  background: linear-gradient(135deg, rgba(29,78,216,.22), rgba(109,40,217,.18));
  border-color: rgba(167,139,250,.35);
  box-shadow: 0 10px 22px rgba(0,0,0,.35);
}

/* Dark: advanced inputs */
body.dark-mode .gmf-panel select,
body.dark-mode .gmf-panel input[type="text"],
body.dark-mode .gmf-panel input[type="number"],
html[data-bs-theme="dark"] .gmf-panel select,
html[data-bs-theme="dark"] .gmf-panel input[type="text"],
html[data-bs-theme="dark"] .gmf-panel input[type="number"]{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
  color: rgba(226,232,240,.95);
}

body.dark-mode .gmf-panel select{
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(226,232,240,.75) 50%),
    linear-gradient(135deg, rgba(226,232,240,.75) 50%, transparent 50%);
}
html[data-bs-theme="dark"] .gmf-panel select{
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(226,232,240,.75) 50%),
    linear-gradient(135deg, rgba(226,232,240,.75) 50%, transparent 50%);
}
