/* ============================================
   BLEJELIRE · WHITE + MINT 2025 THEME
   ============================================ */

:root{
  /* Gjelbër brand (BlejeLirë) — i njëjtë me theme-color / logo */
  --green:#22c55e;
  --green-dark:#16a34a;
  --green-darker:#15803d;
  --green-light:#dcfce7;
  --green-rgb:34, 197, 94;

  --text:#0f172a;
  --text-light:#475569;
  --border:#e5e7eb;

  --bg:#ffffff;
  --bg-soft:#f8fafc;

  --radius:14px;
  --radius-lg:16px;
  --radius-xl:22px;

  --shadow-soft:0 10px 25px rgba(0,0,0,.05);
  --shadow-card:0 12px 40px rgba(0,0,0,.08);
}

*{box-sizing:border-box}
body{
  margin:0;
  background:var(--bg-soft);
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  padding-left:env(safe-area-inset-left);
  padding-right:env(safe-area-inset-right);
}

/* “Bleje” në navbar / hero — i njëjtë gjelbër si butonat */
.text-success{
  color:var(--green) !important;
}

/* ============================================
   HERO
============================================ */

.hero-card{
  background:var(--bg);
  border-radius:var(--radius-xl);
  padding:40px 32px;
  box-shadow:var(--shadow-soft);
  border:1px solid var(--border);
}
.hero-title{
  font-size:2.5rem;
  font-weight:800;
}
.hero-subtext{
  color:var(--text-light);
}

/* ============================================
   BUTTONS
============================================ */

.btn-filter,
.mobile-filter-btn,
.apply-btn{
  background:var(--green);
  color:#fff;
  border:none;
  font-weight:700;
  cursor:pointer;
}

.btn-filter{
  padding:10px 16px;
  border-radius:10px;
}

.mobile-filter-btn{
  display:none;
  width:100%;
  padding:14px;
  border-radius:14px;
  font-size:16px;
  box-shadow:0 10px 24px rgba(var(--green-rgb),.35);
  margin-bottom:14px;
}

.apply-btn{
  width:100%;
  padding:16px;
  border-radius:16px;
  font-size:17px;
  margin-top:10px;
}

/* ============================================
   SEARCH
============================================ */

.search-row{
  display:flex;
  gap:10px;
  background:#fff;
  padding:14px;
  border-radius:16px;
  box-shadow:0 8px 20px rgba(0,0,0,.06);
}
.search-row input{
  flex:1;
  border:none;
  font-size:15px;
  outline:none;
}
.search-row button{
  background:var(--green);
  color:#fff;
  border:none;
  padding:10px 20px;
  border-radius:12px;
  font-weight:600;
}

/* ============================================
   DESKTOP FILTER BAR
============================================ */

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

  background:#fff;
  padding:18px 20px;
  border-radius:16px;
  border:1px solid var(--border);
  box-shadow:0 10px 30px rgba(0,0,0,.08);
}

.filter-row label{
  font-weight:600;
  color:var(--green);
}

.filter-row select{
  background:var(--green);
  color:#fff;
  border:none;
  border-radius:10px;
  padding:10px 16px;
  font-weight:600;
  min-height:44px;
  cursor:pointer;
}

/* ============================================
   PRODUCT CARDS
============================================ */

.card-product{
  background:#fff;
  border-radius:var(--radius-xl);
  border:1px solid var(--border);
  box-shadow:var(--shadow-card);
  overflow:hidden;
  transition:.2s ease;
}
.card-product:hover{
  transform:translateY(-6px);
}
.card-product-img img{
  width:100%;
  height:230px;
  object-fit:cover;
}
.card-product .price{
  font-weight:600;
  color:var(--green-dark);
}

/* ============================================
   MOBILE FILTERS (same bar, stacked — HTML has no bottom sheet)
============================================ */

.filter-overlay,
.filter-sheet{
  display:none;
}

@media (max-width:768px){

  /* Faqja përdor vetëm .filter-row — duhet të duket në telefon */
  .filter-row{
    display:flex !important;
    flex-direction:column;
    align-items:stretch;
    visibility:visible !important;
    height:auto !important;
    max-height:none !important;
    overflow:visible !important;
    padding:16px 14px;
    gap:12px;
  }

  .filter-row label{
    margin-bottom:2px;
  }

  .filter-row select{
    width:100%;
    max-width:100%;
    font-size:16px; /* shmang zoom në iOS kur fokusohet */
    -webkit-appearance:none;
    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='%23ffffff' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat:no-repeat;
    background-position:right 14px center;
    padding-right:36px;
  }

  .filter-row .btn-filter{
    display:block !important;
    width:100%;
    margin-top:4px;
    padding:14px 16px;
  }

  .mobile-filter-btn{
    display:none !important;
  }

  .filter-overlay,
  .filter-sheet{
    display:none !important;
  }
}

/* ============================================
   RESPONSIVE
============================================ */

@media (max-width:576px){
  .hero-title{font-size:2rem}
  .card-product-img img{height:200px}
}
/* ============================================
   NAVBAR FIX – CLEAN, COMPACT, PROFESSIONAL
   ============================================ */

.navbar{
  background:#ffffff;
  border-bottom:1px solid #e5e7eb;
  padding:10px 0;
  box-shadow:0 4px 20px rgba(15,23,42,.04);
}

/* container alignment */
.navbar .container{
  display:flex;
  align-items:center;
}

/* brand */
.navbar-brand{
  display:flex;
  align-items:center;
  gap:10px;
  padding:0;
  margin:0;
}

/* logo size FIX */
.navbar-logo{
  width:36px;
  height:36px;
  max-width:36px;
  max-height:36px;
  object-fit:contain;
}

/* brand text */
.navbar .brand-text{
  font-size:1rem;
  font-weight:700;
  line-height:1;
  white-space:nowrap;
}

/* nav links */
.navbar-nav .nav-link{
  padding:6px 12px;
  font-size:0.95rem;
  font-weight:500;
  color:#0f172a;
}

/* right buttons */
.navbar .btn{
  padding:6px 14px;
  font-size:0.85rem;
  border-radius:999px;
}

/* remove extra margins from collapse */
.navbar-collapse{
  align-items:center;
}

/* MOBILE */
@media (max-width: 768px){

  .navbar{
    padding:8px 0;
  }

  .navbar-logo{
    width:30px;
    height:30px;
  }

  .navbar .brand-text{
    font-size:0.95rem;
  }

  .navbar-nav{
    margin-top:10px;
  }

  .navbar .navbar-toggler{
    min-width:44px;
    min-height:44px;
    padding:10px 12px;
    border-radius:12px;
  }

  .navbar .nav-link{
    padding:10px 12px;
    min-height:44px;
    display:flex;
    align-items:center;
  }
}

/* (mobile filter “hide desktop” u hoq — përdoret .filter-row i stack-uar më sipër) */
/* =========================================
   FIX GAP BETWEEN NAVBAR & HERO
   ========================================= */

/* hiqe çdo hapsirë nën navbar */
.navbar{
  margin-bottom: 0 !important;
}

/* kontrolloje hero-shell */
.hero-shell{
  margin-top: 16px !important; /* ose 0 nëse e don ngjitur */
}

/* sigurim që container nuk shtyn */
.navbar + .container.hero-shell{
  margin-top: 16px !important;
}
/* Butonat e filtrit — gjelbër brand (jo i zi) */
.btn-filter{
  background:var(--green) !important;
  color:#fff !important;
  border:none !important;
  font-weight:700;
  box-shadow:0 8px 22px rgba(var(--green-rgb),0.38);
  transition:background .15s, box-shadow .15s, transform .12s;
}

.btn-filter:hover{
  background:var(--green-dark) !important;
  color:#fff !important;
  box-shadow:0 10px 26px rgba(var(--green-rgb),0.42);
}
.btn-filter:active{
  transform:translateY(1px);
}
/* =================
   HERO LOGO SIZE FIX
   ================= */

.hero-logo img{
  width: 180px;        /* madhësi standard */
  max-width: 180px;
  height: auto;
  object-fit: contain;
}

/* Mobile pak ma e vogël */
@media (max-width: 768px){
  .hero-logo img{
    width: 140px;
    max-width: 140px;
  }
}
/* =========================================
   FORCE LIGHT MODE (ANDROID / SAMSUNG FIX)
   ========================================= */

:root{
  color-scheme: light;
}

@media (prefers-color-scheme: dark){
  body{
    background: var(--bg-soft) !important;
    color: var(--text) !important;
  }

  .navbar,
  .hero-card,
  .filter-row,
  .filter-sheet,
  .card-product,
  .search-row{
    background: #ffffff !important;
    color: var(--text) !important;
  }

  input,
  select,
  textarea{
    background: #ffffff !important;
    color: var(--text) !important;
  }
}
/* =========================================
   WHITE OUTLINE / BORDER (ANDROID FIX)
   ========================================= */

/* HERO CARD */
.hero-card{
  border: 1px solid #ffffff;
}

/* FILTER DESKTOP */
.filter-row{
  border: 1px solid #ffffff;
}

/* FILTER MOBILE SHEET */
.filter-sheet{
  border-top: 2px solid #ffffff;
}

/* SEARCH */
.search-row{
  border: 1px solid #ffffff;
}

/* PRODUCT CARDS */
.card-product{
  border: 1px solid #ffffff;
}

/* INPUTS / SELECTS */
input,
select,
textarea{
  border: 1px solid #ffffff;
}

/* OPTIONAL: pak highlight ma i bukur */
.hero-card,
.filter-row,
.filter-sheet,
.card-product{
  box-shadow:
    0 0 0 1px #ffffff,
    0 10px 25px rgba(0,0,0,.05);
}
/* ===============================
   MOBILE FILTER HEADER (ONLY THIS)
   =============================== */

.sheet-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 6px 14px;
  margin-bottom:10px;
  border-bottom:1px solid #e5e7eb;
}

/* Teksti "Filtro produktet" */
.sheet-header strong{
  font-size:16px;
  font-weight:700;
  color:#0f172a;
}

/* X button */
.sheet-header button{
  background:#ffffff;
  border:1px solid #e5e7eb;
  border-radius:50%;
  width:28px;
  height:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  line-height:1;
  cursor:pointer;
}

/* Hover (opsional, i butë) */
.sheet-header button:hover{
  background:#f1f5f9;
}

/* ============================================
   BLEJELIRE · APP SHELL & PRO UI (global)
   ============================================ */

.btn-mint{
  background: var(--green) !important;
  color: #fff !important;
  border: none !important;
  font-weight: 600;
  border-radius: 12px;
  padding: 0.55rem 1.1rem;
  box-shadow: 0 6px 18px rgba(var(--green-rgb), 0.28);
}
.btn-mint:hover{
  background: var(--green-dark) !important;
  color: #fff !important;
}
.btn-mint,
.btn-hero,
.btn-filter,
.mobile-filter-btn,
.apply-btn{
  touch-action: manipulation;
}
.btn-soft{
  background: #fff !important;
  color: var(--text) !important;
  border: 1px solid var(--border) !important;
  font-weight: 600;
  border-radius: 12px;
}
.btn-soft:hover{
  border-color: var(--green) !important;
  color: var(--green-dark) !important;
  background: var(--green-light) !important;
}

.app-shell{
  min-height: calc(100vh - 58px);
  background: linear-gradient(180deg, #eef2f7 0%, #f8fafc 38%, #f8fafc 100%);
  padding-bottom: 2.5rem;
}

.app-page-head{ margin-bottom: 1.25rem; }
.app-page-title{
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
  margin: 0 0 0.35rem;
}
.app-page-lead{
  margin: 0;
  font-size: 0.92rem;
  color: var(--text-light);
  max-width: 40rem;
  line-height: 1.5;
}

.app-panel{
  background: #fff;
  border: 1px solid #e8ecf1;
  border-radius: 18px;
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.06);
  overflow: hidden;
}
.app-panel__body{ padding: 1rem 1.15rem; }
.app-panel .table thead th{
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  font-weight: 700;
  border-bottom-width: 1px;
  background: linear-gradient(180deg, #f8fafc, #fff) !important;
  vertical-align: middle;
}

.app-stat{
  background: #fff;
  border: 1px solid #e8ecf1;
  border-radius: 16px;
  padding: 1rem 0.75rem;
  text-align: center;
  box-shadow: 0 4px 18px rgba(15, 23, 42, 0.05);
  height: 100%;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.app-stat:hover{
  border-color: rgba(var(--green-rgb), 0.25);
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.07);
}
.app-stat__label{
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #64748b;
  font-weight: 700;
}
.app-stat__value{
  font-size: 1.65rem;
  font-weight: 800;
  color: var(--green-dark);
  line-height: 1.2;
}
.app-stat__value--warn{ color: #b45309; }
.app-stat__value--compact{ font-size: 1.35rem !important; }

.app-toolbar{
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
}
.app-section-title{
  font-size: 0.95rem;
  font-weight: 700;
  margin: 0;
  color: var(--text);
}

.app-auth-card{
  background: #fff;
  border: 1px solid #e8ecf1;
  border-radius: 18px;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.08);
  padding: 1.75rem;
}
.app-auth-card h1{
  font-size: 1.1rem;
  font-weight: 800;
  margin-bottom: 1rem;
}
.app-auth-card .form-control,
.app-auth-card .form-select{
  border-radius: 12px;
  border-color: #e2e8f0;
}

.btn-hero{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--green);
  color: #fff !important;
  padding: 12px 22px;
  min-height: 48px;
  border-radius: 14px;
  font-weight: 700;
  font-size: 0.95rem;
  text-decoration: none !important;
  box-shadow: 0 8px 22px rgba(var(--green-rgb), 0.38);
  transition: transform 0.15s, box-shadow 0.15s, background 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.btn-hero:hover{
  background: var(--green-dark);
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(var(--green-rgb), 0.42);
}
.btn-hero:focus-visible{
  outline: 3px solid rgba(var(--green-rgb), 0.45);
  outline-offset: 2px;
}

.app-empty{
  border-radius: 16px;
  border: 1px dashed #cbd5e1;
  background: #fff;
  padding: 2rem 1.25rem;
  text-align: center;
  color: #64748b;
  font-size: 0.92rem;
}

.app-alert{ border-radius: 12px; border: none; }

/* Product detail */
.product-shell .product-main-img{
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid #e8ecf1;
  box-shadow: 0 8px 32px rgba(15, 23, 42, 0.08);
  background: #fff;
}
.product-shell .product-main-img img,
.product-shell .product-main-img video{
  width: 100%;
  display: block;
  max-height: 420px;
  object-fit: contain;
  background: #f8fafc;
}
.product-thumb img,
.product-thumb video{
  width: 96px;
  height: 96px;
  object-fit: cover;
  border-radius: 12px;
  border: 2px solid #e8ecf1;
  cursor: pointer;
  transition: border-color 0.2s;
}
.product-thumb img:hover,
.product-thumb video:hover{
  border-color: var(--green);
}
.product-info{
  background: #fff;
  border: 1px solid #e8ecf1;
  border-radius: 18px;
  padding: 1.35rem 1.5rem;
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.06);
}
.product-info .form-select{
  border-radius: 12px;
  border-color: #e2e8f0;
}
.badge-condition{
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.25rem 0.55rem;
  border-radius: 8px;
  background: rgba(var(--green-rgb), 0.1);
  color: var(--green-dark);
}

.card-product .card-body{ padding: 12px 14px 14px; }
.card-product .title{ font-weight: 700; font-size: 0.92rem; color: var(--text); }
.card-product .meta{ font-size: 0.78rem; color: #64748b; line-height: 1.35; }

.footer-soft{
  margin-top: 0;
  border-top: 1px solid #e8ecf1;
  background: #fff;
  padding: 1rem 0;
  box-shadow: 0 -4px 20px rgba(15, 23, 42, 0.04);
}

/* Admin categories inline form */
.app-form-inline .form-control,
.app-form-inline .form-select{
  border-radius: 12px;
  border-color: #e2e8f0;
}

/* ========= Seller product form ========= */
.seller-product-form{
  --spf-green: var(--green);
  --spf-green-dim: var(--green-dark);
  --spf-border: #e8ecf1;
  --spf-card: #ffffff;
  --spf-muted: #64748b;
  background: transparent;
  min-height: 40vh;
}
.spf-page-title{
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
}
.spf-page-lead{
  color: var(--spf-muted);
  font-size: 0.95rem;
  max-width: 52rem;
  line-height: 1.55;
}
.spf-alert{ border-radius: 12px; border: none; }
.spf-card{
  background: var(--spf-card);
  border: 1px solid var(--spf-border);
  border-radius: 18px;
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.06);
  overflow: hidden;
}
.spf-card--muted{
  opacity: 0.95;
  box-shadow: 0 2px 12px rgba(15, 23, 42, 0.04);
}
.spf-card__head{
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1.15rem 1.25rem;
  background: linear-gradient(135deg, rgba(var(--green-rgb), 0.07) 0%, transparent 55%);
  border-bottom: 1px solid var(--spf-border);
}
.spf-card__head--sm{ padding: 0.85rem 1.15rem; }
.spf-card__badge{
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 12px;
  background: var(--spf-green);
  color: #fff;
  font-weight: 800;
  font-size: 0.95rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(var(--green-rgb), 0.35);
}
.spf-card__badge--muted{
  background: #94a3b8;
  box-shadow: none;
}
.spf-card__badge--soft{
  background: #d1fae5;
  color: var(--spf-green-dim);
  box-shadow: none;
}
.spf-card__title{
  font-size: 1.05rem;
  font-weight: 700;
  margin: 0;
  color: #0f172a;
}
.spf-card__title--sm{ font-size: 0.98rem; }
.spf-card__hint{
  font-size: 0.82rem;
  color: var(--spf-muted);
  margin: 0.25rem 0 0;
  line-height: 1.45;
}
.spf-card__body{ padding: 1.25rem; }
.spf-label{
  font-weight: 600;
  font-size: 0.88rem;
  color: #334155;
}
.spf-control,
.spf-textarea{
  border-radius: 12px;
  border-color: #e2e8f0;
}
.spf-textarea{
  resize: vertical;
  min-height: 100px;
}

.spf-photo-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}
@media (min-width: 576px){
  .spf-photo-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1200px){
  .spf-photo-grid{ grid-template-columns: repeat(3, 1fr); }
}
.spf-slot{
  border: 1px solid var(--spf-border);
  border-radius: 16px;
  padding: 1rem;
  background: #fafbfc;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.spf-slot:hover{
  border-color: rgba(var(--green-rgb), 0.35);
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.06);
}
.spf-slot__top{ display: flex; align-items: center; gap: 0.65rem; }
.spf-slot__num{
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 8px;
  background: #0f172a;
  color: #fff;
  font-size: 0.75rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.spf-slot__meta{ min-width: 0; }
.spf-slot__label{
  display: block;
  font-weight: 700;
  font-size: 0.88rem;
  color: #0f172a;
  line-height: 1.25;
}
.spf-slot__pill{
  display: inline-block;
  margin-top: 0.2rem;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--spf-green);
  background: rgba(var(--green-rgb), 0.1);
  padding: 0.12rem 0.45rem;
  border-radius: 6px;
}
.spf-slot__preview{ flex: 1; }
.spf-slot__frame{
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 4/3;
  background: #e2e8f0;
  border: 1px dashed #cbd5e1;
}
.spf-slot__frame--live{
  border-style: solid;
  border-color: var(--spf-green);
  background: #ecfdf5;
}
.spf-slot__frame--guide{
  border-style: solid;
  border-color: #e2e8f0;
  background: #fff;
}
.spf-slot__img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.spf-slot__guide{
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 140px;
}
.spf-slot__img--guide{ opacity: 0.95; }
.spf-slot__guide--missing .spf-slot__img--guide{ display: none; }
.spf-slot__guide-fallback{
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 1rem;
  height: 100%;
  min-height: 140px;
  background: #f8fafc;
}
.spf-slot__guide--missing .spf-slot__guide-fallback{ display: flex; }
.spf-slot__guide-icon{ font-size: 1.75rem; color: #94a3b8; }
.spf-slot__guide-path{
  font-size: 0.72rem;
  color: #64748b;
  word-break: break-all;
  margin-top: 0.5rem;
  line-height: 1.35;
}
.spf-slot__guide-tip{
  font-size: 0.7rem;
  color: #94a3b8;
  margin-top: 0.35rem;
  max-width: 12rem;
}
.spf-slot__note{
  font-size: 0.75rem;
  margin: 0;
  color: #475569;
}
.spf-slot__note--muted{ color: var(--spf-muted); }

.spf-upload{
  display: block;
  cursor: pointer;
  border: 2px dashed #cbd5e1;
  border-radius: 12px;
  padding: 0.65rem 0.85rem;
  text-align: center;
  background: #fff;
  transition: border-color 0.2s, background 0.2s;
}
.spf-upload:hover{
  border-color: var(--spf-green);
  background: rgba(var(--green-rgb), 0.04);
}
.spf-upload__label{
  font-size: 0.82rem;
  font-weight: 700;
  color: #334155;
  margin: 0;
}
.spf-upload__input{
  width: 100%;
  font-size: 0.8rem;
  margin-top: 0.35rem;
}

.spf-footnote{
  font-size: 0.78rem;
  color: var(--spf-muted);
  padding-top: 0.5rem;
  border-top: 1px solid var(--spf-border);
  margin-top: 1rem;
}

.spf-legacy-tile{
  border: 1px solid var(--spf-border);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}
.spf-legacy-img{
  width: 100%;
  height: 96px;
  object-fit: cover;
  display: block;
}
.spf-legacy-del{
  display: block;
  font-size: 0.72rem;
  padding: 0.35rem;
  text-align: center;
  background: #f8fafc;
  cursor: pointer;
  margin: 0;
}
.spf-legacy-del input{
  vertical-align: middle;
  margin-right: 0.25rem;
}

.spf-btn-add{
  margin-top: 0.5rem;
  border-radius: 12px;
  border: 1px solid var(--spf-border);
  background: #fff;
  color: var(--spf-green);
  font-weight: 600;
  font-size: 0.88rem;
  padding: 0.5rem 1rem;
}
.spf-btn-add:hover{
  background: rgba(var(--green-rgb), 0.08);
  border-color: var(--spf-green);
  color: var(--spf-green-dim);
}

.spf-price-card{
  border: 1px solid var(--spf-border);
  border-radius: 14px;
  margin-bottom: 12px;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
}
.spf-price-head{
  background: linear-gradient(90deg, #f8fafc, #fff);
  padding: 10px 14px;
  font-weight: 700;
  font-size: 0.85rem;
  color: #334155;
  border-bottom: 1px solid var(--spf-border);
}
.spf-price-body{ padding: 14px; }
.spf-price-input{
  width: 100%;
  padding: 12px 14px;
  font-size: 16px;
  border-radius: 10px;
  border: 1px solid #e2e8f0;
}
.spf-submit{ box-shadow: 0 8px 24px rgba(var(--green-rgb), 0.28); }

@media (prefers-color-scheme: dark){
  .app-shell,
  .app-panel,
  .app-stat,
  .app-auth-card,
  .product-info,
  .product-shell .product-main-img,
  .spf-card,
  .filter-panel{
    background: #ffffff !important;
  }
}

/* ============================================
   INDEX · FILTROT & HOME (desktop + mobile)
   ============================================ */

.home-hero{
  position: relative;
  border: 1px solid rgba(var(--green-rgb), 0.12) !important;
  box-shadow: 0 16px 48px rgba(15, 23, 42, 0.08) !important;
}

/* Telefon: butonat e hero të plotë gjerësi, më të lehta për gisht */
@media (max-width: 575.98px){
  .home-hero.hero-card{
    padding: 22px 16px 24px;
  }
  .home-hero .hero-title{
    font-size: 1.55rem;
    line-height: 1.2;
  }
  .home-hero-actions{
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
    max-width: 22rem;
    margin-left: auto;
    margin-right: auto;
  }
  .home-hero-actions .btn-hero{
    width: 100%;
    justify-content: center;
  }
}

.filter-panel{
  background: #fff;
  border-radius: 18px;
  padding: 18px 20px 20px;
  border: 1px solid #e8ecf1;
  box-shadow: 0 8px 32px rgba(15, 23, 42, 0.06);
}

.filter-panel__top{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid #eef2f7;
}

.filter-panel__title{
  font-size: 1.05rem;
  font-weight: 800;
  margin: 0;
  color: var(--text);
  letter-spacing: -0.02em;
}

.filter-panel__clear{
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--green-dark);
  text-decoration: none;
  padding: 8px 14px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: rgba(var(--green-rgb), 0.08);
  -webkit-tap-highlight-color: transparent;
}
.filter-panel__clear:hover{
  background: rgba(var(--green-rgb), 0.15);
  color: var(--green-dark);
}

.filter-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px 16px;
  align-items: end;
}

.filter-field__label{
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  margin-bottom: 6px;
}
.filter-field__label--ghost{
  visibility: hidden;
}

.filter-field--span2{
  grid-column: span 2;
}

.filter-input,
.filter-select{
  width: 100%;
  border: 1px solid #e2e8f0 !important;
  background: #fff !important;
  color: #0f172a !important;
  border-radius: 12px !important;
  padding: 10px 14px;
  min-height: 46px;
  font-size: 0.95rem;
  font-weight: 500;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.filter-select{
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23475569' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  padding-right: 40px !important;
}

.filter-input:focus,
.filter-select:focus{
  outline: none;
  border-color: var(--green) !important;
  box-shadow: 0 0 0 3px rgba(var(--green-rgb), 0.2);
}

.filter-select:disabled{
  background-color: #f1f5f9 !important;
  color: #94a3b8 !important;
  cursor: not-allowed;
  opacity: 1;
}

.filter-form .btn-filter.btn-filter--home{
  width: 100%;
  min-height: 46px;
  border-radius: 12px !important;
  padding: 12px 16px !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  background: linear-gradient(180deg, #4ade80 0%, var(--green) 45%, var(--green-dark) 100%) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 0 8px 24px rgba(var(--green-rgb), 0.35) !important;
}
.filter-form .btn-filter.btn-filter--home:hover{
  filter: brightness(1.05);
  color: #fff !important;
}

.home-products{
  scroll-margin-top: 88px;
}

@media (min-width: 576px){
  .filter-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .filter-field--span2{
    grid-column: span 2;
  }
  .filter-field--submit{
    grid-column: span 2;
    max-width: none;
  }
}

@media (min-width: 992px){
  .filter-grid{
    grid-template-columns: repeat(auto-fill, minmax(168px, 1fr));
  }
  .filter-field--span2{
    grid-column: span 2;
  }
  .filter-field--submit{
    grid-column: span 1;
    max-width: 220px;
  }
}

@media (max-width: 767.98px){
  .filter-panel{
    padding: 14px 14px 16px;
    border-radius: 16px;
  }
  .filter-grid{
    gap: 12px;
  }
  .filter-field--span2,
  .filter-field--submit{
    grid-column: 1 / -1;
    max-width: none;
  }
  .filter-input,
  .filter-select,
  .filter-form .btn-filter.btn-filter--home{
    min-height: 48px;
    font-size: 16px;
  }
}
