/* -----------------------------------------------------------
   PSB Sort Bar – Kurumsal UI (soft, stabil)  [FULL FINAL v2]
   - Mobil/Tablet: Tüm satır yazıları TAM ORTALI (tik varken bile)
   - Mobil/Tablet: "Şuna göre sırala" başlığı TAM ORTALI
   - Mobil: seçili/hover arka plan YOK (sade)
   - X: absolute + top:-8 (senin sevdiğin konum)
----------------------------------------------------------- */

/* -----------------------------
0. Variables
----------------------------- */
:root{
  --psb-text:#1f1f1f;
  --psb-muted:#6b6b6b;

  --psb-border:#e5e5e5;
  --psb-border-strong:#d7d7d7;

  --psb-bg:#fff;
  --psb-hover:#f7f7f7;

  --psb-shadow:0 10px 30px rgba(0,0,0,.10);

  --psb-radius:10px;
  --psb-radius-sheet:18px;

  --psb-check-gap:10px;
  --psb-chevron-size:14px;
}

/* -----------------------------
1. Safety / Overrides
----------------------------- */
form.woocommerce-ordering:not(.psb-wc-ordering){
  display:none !important;
}

.psb-wc-ordering{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
  clip: rect(0 0 0 0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
}

.psb-sort-bar .psb-sort-label,
.psb-sort-bar .psb-sort-selected,
.psb-sort-bar .psb-sort-mobile-trigger,
.psb-sort-bar .psb-sort-dropdown li,
.psb-sort-bar .psb-sort-mobile-sheet li{
  text-transform:none !important;
  letter-spacing:normal !important;
  font-variant-caps: normal !important;
}

/* Mobilde highlight/selection sade */
.psb-sort-bar *{ -webkit-tap-highlight-color: transparent; }
.psb-sort-bar ::selection{ background: transparent; }

/* -----------------------------
2. Bar Layout (Desktop/Mobile)
----------------------------- */
.psb-sort-bar{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:8px;
  margin-top:16px;
  width:100%;
  position:relative;
  font-family:"Segoe UI",system-ui,-apple-system,Arial,sans-serif;
  font-size:16px;
}

.psb-inline{
  display:flex;
  align-items:baseline;
  gap:8px;
}

.psb-sort-label{
  color:var(--psb-muted);
  font-weight:400;
  font-size:16px;
  line-height:40px;
  height:40px;
  display:flex;
  align-items:center;
  white-space:nowrap;
}

/* Desktop */
.psb-sort-desktop{ position:relative; }

.psb-sort-selected{
  color:var(--psb-text);
  font-weight:600;
  background:none;
  border:none;
  padding:0 24px 0 0;
  cursor:pointer;
  display:flex;
  align-items:center;
  height:40px;
  line-height:40px;
  position:relative;
  outline:none;
  transition:opacity .16s ease, transform .16s ease;
}

.psb-sort-selected::after{
  content:"";
  width:var(--psb-chevron-size);
  height:var(--psb-chevron-size);
  position:absolute;
  right:2px;
  top:50%;
  transform:translateY(-50%);
  background-repeat:no-repeat;
  background-size:var(--psb-chevron-size) var(--psb-chevron-size);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24'%3E%3Cpath fill='%23888888' d='M7 10l5 5 5-5'/%3E%3C/svg%3E");
  transition:transform .18s ease;
}

.psb-sort-bar.is-open .psb-sort-selected::after{
  transform:translateY(-50%) rotate(180deg);
}

.psb-sort-selected:focus-visible{
  outline:2px solid rgba(0,0,0,.10);
  outline-offset:3px;
  border-radius:12px;
}

/* -----------------------------
3. Dropdown (Desktop)
----------------------------- */
.psb-sort-dropdown{
  position:absolute;
  right:0;
  top:110%;
  min-width:260px;
  width:max-content;
  max-width:420px;
  background:var(--psb-bg);
  border:1px solid var(--psb-border);
  border-radius:var(--psb-radius);
  box-shadow:var(--psb-shadow);
  padding:6px 0;
  z-index:99;
  font-size:15px;
  box-sizing:border-box;
  transform-origin: 85% 0%;
}

.psb-sort-dropdown[hidden]{ display:none !important; }
.psb-sort-dropdown:not([hidden]){
  animation: psb-dropdown-pop .18s cubic-bezier(.2,.8,.2,1);
}

.psb-sort-dropdown li{
  padding:10px 14px;
  cursor:pointer;
  background:var(--psb-bg);
  color:var(--psb-text);
  display:flex;
  align-items:center;
  white-space:nowrap;
  font-weight:500;
  transition:background-color .12s ease;
}
.psb-sort-dropdown li:hover{ background:var(--psb-hover); }

.psb-sort-dropdown li.selected{
  background:var(--psb-hover);
  font-weight:600;
}

/* Desktop tik: yazının yanında */
.psb-sort-dropdown li.selected::after{
  content:"";
  width:16px;height:16px;
  margin-left:var(--psb-check-gap);
  background-repeat:no-repeat;
  background-size:16px 16px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24'%3E%3Cpath fill='%23111111' d='M9.2 16.6 4.9 12.3l-1.4 1.4 5.7 5.7L20.5 8.1l-1.4-1.4z'/%3E%3C/svg%3E");
}

/* -----------------------------
4. Mobile Trigger + Sheet
----------------------------- */
.psb-sort-mobile-trigger{
  display:none;
  background:none;
  color:var(--psb-text);
  border:none;
  font-size:15px;  /* hafif küçük */
  font-weight:600;
  padding:0 22px 0 0;
  cursor:pointer;
  position:relative;
}

.psb-sort-mobile-trigger::after{
  content:"";
  width:var(--psb-chevron-size);
  height:var(--psb-chevron-size);
  position:absolute;
  right:0;
  top:50%;
  transform:translateY(-50%);
  background-repeat:no-repeat;
  background-size:var(--psb-chevron-size) var(--psb-chevron-size);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24'%3E%3Cpath fill='%23888888' d='M7 10l5 5 5-5'/%3E%3C/svg%3E");
}

/* Modal: arkaplan yok */
.psb-sort-mobile-modal{
  position:fixed;
  z-index:9999;
  inset:0;
  display:flex;
  justify-content:center;
  align-items:flex-end;
  background:transparent;
}
.psb-sort-mobile-modal[hidden]{ display:none !important; }
.psb-sort-mobile-modal:not([hidden]){
  animation: psb-overlay-fade .16s ease;
}

/* Overlay görünmez ama kapanma için var */
.psb-filter-overlay{
  position:absolute;
  inset:0;
  background:transparent;
}

/* Sheet */
.psb-sort-mobile-sheet{
  width:100%;
  max-width:520px;
  margin:0 auto;
  background:var(--psb-bg);
  border-radius:var(--psb-radius-sheet) var(--psb-radius-sheet) 0 0;
  padding:10px 0 8px 0;
  box-shadow:0 -10px 40px rgba(0,0,0,.12);
  transform:translateY(16px);
  animation: psb-sheet-slide .20s cubic-bezier(.2,.9,.2,1);
}

/* HEADER: başlık TAM ORTALI + X için eşit padding */
.psb-sort-mobile-header{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:14px 56px 12px 56px; /* sağ-sol eşit => tam ortalar */
}

.psb-sort-mobile-title{
  font-size:16px;
  color:var(--psb-text);
  font-weight:700;
  text-align:center;
  width:100%;
}

/* X: senin istediğin gibi */
.psb-sort-mobile-close{
  position:absolute;
  right:12px;
  top:-8px;
  border:none;
  background:none;
  cursor:pointer;
  color:#333;
  font-size:26px;
  line-height:1;
  padding:10px 12px;
  opacity:.9;
  transition:opacity .12s ease;
}
.psb-sort-mobile-close:hover{ opacity:1; }

/* Liste */
.psb-sort-mobile-list{
  list-style:none;
  margin:0;
  padding:0;
}

/* Mobil seçenekler: TAM ORTALI (tik olsa bile)
   Çözüm: sağda tik slotu varsa, solda da eşdeğer boş slot koy (before).
   Böylece metin geometrik olarak hep tam merkezde kalır.
*/
.psb-sort-mobile-sheet li{
  padding:14px 16px;
  font-size:15px;
  color:var(--psb-text);
  cursor:pointer;
  background:transparent;
  border-bottom:1px solid var(--psb-border-strong);
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-weight:500;
  transition:none;
}
.psb-sort-mobile-sheet li:last-child{ border-bottom:none; }
.psb-sort-mobile-sheet li:hover{ background:transparent; }

.psb-sort-mobile-sheet li.selected{
  background:transparent;
  font-weight:600;
}

/* Sol denge slotu (her zaman görünmez) */
.psb-sort-mobile-sheet li::before{
  content:"";
  width:18px;
  height:18px;
  flex:0 0 18px;
  opacity:0;
  pointer-events:none;
  margin-right:var(--psb-check-gap); /* sağdaki tik boşluğu ile simetrik */
}

/* Sağ tik slotu (seçili değilse görünmez) */
.psb-sort-mobile-sheet li::after{
  content:"";
  width:18px;
  height:18px;
  flex:0 0 18px;
  opacity:0;
  pointer-events:none;
  margin-left:var(--psb-check-gap);
  background-repeat:no-repeat;
  background-size:18px 18px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24'%3E%3Cpath fill='%23111111' d='M9.2 16.6 4.9 12.3l-1.4 1.4 5.7 5.7L20.5 8.1l-1.4-1.4z'/%3E%3C/svg%3E");
}
.psb-sort-mobile-sheet li.selected::after{ opacity:1; }

/* Scroll kilidi */
html.psb-lock-scroll, html.psb-lock-scroll body{ overflow:hidden; }

/* -----------------------------
5. Loading (soft)
----------------------------- */
.psb-sort-bar.is-loading .psb-sort-selected,
.psb-sort-bar.is-loading .psb-sort-mobile-trigger{
  opacity:.65;
  cursor:progress;
  pointer-events:none;
}

.psb-sort-bar.is-loading .psb-sort-selected::before,
.psb-sort-bar.is-loading .psb-sort-mobile-trigger::before{
  content:"";
  width:14px;height:14px;
  margin-right:8px;
  border:2px solid rgba(0,0,0,.18);
  border-top-color:rgba(0,0,0,.55);
  border-radius:999px;
  display:inline-block;
  animation: psb-spin .7s linear infinite;
}

/* -----------------------------
6. Responsive
----------------------------- */
@media (max-width:991px){
  .psb-sort-bar{
    justify-content:center;
    font-size:15px;
  }

  .psb-sort-label{
    font-size:15px;
    height:36px;
    line-height:36px;
  }

  .psb-sort-desktop{ display:none !important; }

  .psb-sort-mobile-trigger{
    display:inline-block !important;
    font-size:15px !important;
  }

  /* Mobil/Tablet sheet tam genişlik */
  .psb-sort-mobile-modal{ justify-content:stretch; }

  .psb-sort-mobile-sheet{
    width:100% !important;
    max-width:100% !important;
    margin:0 !important;
    border-radius:18px 18px 0 0;
  }
}

@media (max-width:575px){
  .psb-sort-bar{ font-size:16px; }
  .psb-sort-label{ font-size:16px; }
  .psb-sort-mobile-trigger{ font-size:16px !important; }
}

/* -----------------------------
7. Animations
----------------------------- */
@keyframes psb-dropdown-pop{
  from{ opacity:0; transform:translateY(-4px) scale(.985); }
  to{ opacity:1; transform:translateY(0) scale(1); }
}

@keyframes psb-overlay-fade{
  from{ opacity:0; }
  to{ opacity:1; }
}

@keyframes psb-sheet-slide{
  from{ opacity:0; transform:translateY(28px); }
  to{ opacity:1; transform:translateY(16px); }
}

@keyframes psb-spin{ to{ transform:rotate(360deg); } }

/* -----------------------------
8. Reduced motion
----------------------------- */
@media (prefers-reduced-motion: reduce){
  .psb-sort-dropdown:not([hidden]),
  .psb-sort-mobile-modal:not([hidden]),
  .psb-sort-mobile-sheet{
    animation:none !important;
  }
  .psb-sort-selected::after{ transition:none !important; }
  .psb-sort-mobile-close{ transition:none !important; }
}
