/* =========================
   Perusmuuttujat
   ========================= */
:root{
  --evs-yellow:#E7E63F;
  --evs-accent:#2563eb;
  --evs-accent-600:#1d4ed8;
  --evs-hero-bg:#f1f5fe;
  --evs-hero-bg2:#edf2ff;
  --evs-muted:#64748b;
  --evs-bg:#f8fafc;
  --evs-border:#e5e7eb;
  --evs-card:#ffffff;
  --evs-text:#111827;
  --evs-ghost: var(--evs-text);
}

/* =========================
   HAKU
   ========================= */
.evs-search{display:grid;gap:1rem}

/* Kenttä (säilytetään kevyt baseline siltä varalta että näitä käytetään muualla) */
.evs-field{display:flex;flex-direction:column;gap:.25rem;min-width:180px}
.evs-field--inline{flex-direction:row;align-items:center;gap:.5rem}
.evs-field__select{padding:.5rem;border:1px solid #ddd;border-radius:6px}

/* =========================
   HERO + RIVIT
   ========================= */
.evs-hero{
  width:100%;
  background:linear-gradient(180deg,var(--evs-hero-bg),var(--evs-hero-bg2));
  border:1px solid var(--evs-border);
  border-radius:14px;
  padding: 0 18px 8px 18px;
  margin:-40px 0 14px;
  box-shadow:0 8px 20px rgba(0,0,0,.05);
}

/* yläosa: intro + ajoneuvotyyppi */
.evs-row--top{display:flex;align-items:flex-start;gap:14px}
.evs-hero__intro{flex:1 1 60%;max-width:60%}
.evs-row--top>label{flex:0 1 460px;min-width:320px}

@media (max-width:800px){
  .evs-row--top{flex-direction:column}
  .evs-hero__intro{max-width:100%}
  .evs-row--top>label{width:100%;max-width:100%;min-width:0}
}

.evs-hero__title{
  font-size:clamp(2.1rem,3.6vw,3rem);
  letter-spacing:.02em;font-weight:800;color:#0f172a;margin:0
}
.evs-hero__hint{
  margin:.35rem 0 0;color:var(--evs-muted);
  font-size:clamp(1.6rem,2.7vw,1.9rem);line-height:1.35
}

/* Yleisrivit (ulkona herosta) */
.evs-row{display:flex;flex-wrap:wrap;gap:12px;width:100%}

/* Kenttäkortti */
.evs-row label{
  flex:1 1 240px;display:flex;flex-direction:column;gap:.5rem;
  background:var(--evs-card);
  border:1px solid var(--evs-border);border-radius:8px;
  box-shadow:0 1px 2px rgba(0,0,0,.04);
  color:var(--evs-text);font-weight:600;font-size:1.3rem; /* isompi label */
}

/* Select – yhtenäinen sekä herossa että toolbarissa */
.evs-row label select,
.evs-hero select,
.evs-toolbar__right select{
  font-size:1.3rem;font-weight:600; padding:14px 42px 11px 12px;border:1px solid var(--evs-border);border-radius:8px;background-color:#fff;
  -webkit-appearance:none;-moz-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center
}

/* (Valinnainen) vain evs-row labelin sisällä hieman enemmän spacea nuolelle */
.evs-row label select { padding-right: 56px; }

.evs-row label select:focus,
.evs-hero select:focus,
.evs-toolbar__right select:focus{
  outline:none;border-color:var(--evs-accent);box-shadow:0 0 0 3px rgba(37,99,235,.18)
}

/* Hero-kortit */
.evs-hero .evs-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}
.evs-hero .evs-row label{
  flex:1 1 220px;gap:.45rem;border-radius:10px
}
.evs-hero .evs-row label:hover{border-color:#d1d5db;box-shadow:0 2px 6px rgba(0,0,0,.08)}

@media (max-width:980px){.evs-hero .evs-row label{flex:1 1 48%}}
@media (max-width:640px){
  .evs-hero .evs-row label{flex:1 1 100%}
}

/* =========================
   TOOLBAR
   ========================= */
.evs-toolbar{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:#fff;
  padding:0 12px;
}
.evs-toolbar__left{font-size:1.05rem;color:#111827}
.evs-toolbar__right{display:flex;gap:.8rem;align-items:center}
.evs-toolbar__right label{display:flex;align-items:center;gap:.5rem;font-weight:700}

@media (max-width:640px){
  .evs-toolbar{flex-direction:column;align-items:stretch}
  .evs-toolbar__right{justify-content:space-between}
}

/* =========================
   TULOKSET + KORTTI
   ========================= */
.evs-results{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}
@media (max-width:1100px){.evs-results{grid-template-columns:repeat(2,minmax(0,1fr))}}
.evs-results.is-loading{opacity:.7}
.evs-results__empty,.evs-results__loading{grid-column:1/-1;text-align:center;padding:1rem;color:#666}

.evs-card{
  display:flex;flex-direction:column;gap:.5rem;
  border:1px solid #eee;border-radius:10px;padding:.75rem;
  text-decoration:none;color:inherit;background:#fff
}
.evs-card__img{
  aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;
  overflow:hidden;background:#fafafa;border-radius:8px
}
.evs-card__img img{max-width:100%;max-height:100%;object-fit:contain}

/* Otsikko: 3-rivinen clamp + hieman isompi */
.evs-card__title{
  font-weight:600;font-size:1.25em;line-height:1.25;
  min-height:calc(1.25em * 3);max-height:calc(1.25em * 3);
  overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3
}

/* Metarivit (koko/season/car) yhdenmukaisiksi + grid-ikonituki */
.evs-meta{display:grid;grid-template-columns:28px 1fr;align-items:center;column-gap:8px;margin-top:4px}
.evs-meta__icon{width:28px;text-align:center;line-height:1}
.evs-meta__text{font-size:1.5rem;color:#1f2937}

.evs-card__size,.evs-card__season,.evs-card__car{
  display:flex;align-items:center;gap:6px;margin-top:4px;color:#1f2937;font-size:1.4rem!important;line-height:1.4
}

/* Varasto-badgetit */
.evs-badge{display:inline-block;padding:4px 10px;border-radius:9999px;font-weight:600;font-size:12px;line-height:1}
.evs-badge--green{background:#ecfdf5;color:#065f46}
.evs-badge--yellow{background:#fffbeb;color:#92400e}
.evs-badge--red{background:#fee2e2;color:#991b1b}
.evs-badge--gray{background:#f3f4f6;color:#374151}

/* Hinta & varasto rivi (oikealle tasattu hinta, ei ylivuotoa) */
.evs-card__meta{
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:nowrap
}
.evs-card__stock{flex:1 1 auto;min-width:0}
.evs-card__price{
  margin-left:auto;text-align:right;flex:0 1 60%;min-width:0;max-width:65%
}

/* Woo-hinta-asettelu: iso alehinta, del alle pienempänä; myös fallback yksittäishinnalle */
.evs-price{display:block;padding:0;background:transparent;border-radius:0;max-width:100%}
.evs-price .price{
  display:inline-flex;flex-direction:column-reverse;align-items:flex-end;gap:4px;
  line-height:1.1;max-width:100%;white-space:normal
}
.evs-price .price ins{text-decoration:none;font-weight:800;font-size:clamp(1.2rem,2.5vw,1.6rem);line-height:1.05}
.evs-price .price del{opacity:.7;font-size:.9rem;line-height:1}

.evs-card__price .price{display:flex!important;flex-direction:column-reverse!important;align-items:flex-end!important;gap:6px;white-space:normal!important}
.evs-card__price .price ins .woocommerce-Price-amount{font-size:clamp(1.7rem,3.2vw,2.4rem)!important;font-weight:900!important;line-height:1.05}
.evs-card__price .price del{opacity:.65;text-decoration:none!important}
.evs-card__price .price del .woocommerce-Price-amount,
.evs-card__price .price del .woocommerce-Price-amount bdi{
  text-decoration:line-through!important;text-decoration-thickness:1.5px;text-decoration-color:#9ca3af;text-decoration-skip-ink:auto
}
.evs-card__price>.price>.woocommerce-Price-amount{font-size:clamp(1.7rem,3.2vw,2.4rem)!important;font-weight:900!important;line-height:1.05}
.evs-card__price .woocommerce-Price-currencySymbol{font-size:.8em}
.evs-card__price .woocommerce-Price-amount{max-width:100%;word-break:break-word}

/* =========================
   SIVUTUS
   ========================= */
.evs-pagination{display:flex;gap:.5rem;justify-content:center;align-items:center}
.evs-page{
  padding:.5rem .9rem;border:1px solid var(--evs-border);background:#fff;border-radius:10px;
  transition:border-color .15s,box-shadow .15s,color .15s
}
.evs-page:hover{border-color:var(--evs-accent);box-shadow:0 0 0 3px rgba(37,99,235,.12);color:#0f172a}
.evs-page.is-active{border-color:var(--evs-accent);color:#0f172a;font-weight:800}
.evs-page.is-disabled{opacity:.5}

/* =========================
   Napit
   ========================= */
.evs-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:10px;border:1px solid transparent;font-weight:800;letter-spacing:.02em;cursor:pointer;transition:all .15s ease}
.evs-btn--lg{padding:12px 16px;font-size:1.05rem}
.evs-btn--primary{background:var(--evs-accent);color:#fff;border-color:var(--evs-accent)}
.evs-btn--primary:hover{background:var(--evs-accent-600);border-color:var(--evs-accent-600)}
.evs-btn--ghost{background:#fff;color:#111827;border-color:var(--evs-border)}
.evs-btn--ghost:hover{border-color:#cbd5e1;box-shadow:0 0 0 3px rgba(17,24,39,.08)}

/* =========================
   Sivukohtaiset
   ========================= */
.page-id-151609 #hakuvalinta{display:none}
.page-id-151609 .header-line-search{display:none}

/* =========================
   GHOST-LABEL SELECTEILLE (label vasemmalla, arvo oikealla)
   ========================= */

/* Taustalabel evs-row -selecteille (VASEN laita, keskitetty pystysuunnassa) */
.evs-row label.evs-label-ghost {
  position: relative;
  overflow: hidden;
}

/* Haalea, lihavoitu label vasemmassa laidassa */
.evs-row label.evs-label-ghost::before {
  content: attr(data-ghost);
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-weight: 800;
  letter-spacing: -.04em;
  text-transform: uppercase;
  white-space: nowrap;
  color: var(--evs-ghost);
  opacity: .44;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  font-size: clamp(18px *.7, 4.6vw*.7, 28px*.7);
  transition: opacity .15s ease;
}

/* Fokuksessa voit halutessasi keventää/voimistaa labelia */
.evs-row label.evs-label-ghost:has(select:focus)::before { opacity: .80; }

/* Oletus (suljettu): valittu arvo oikealle */
.evs-row label.evs-label-ghost select {
  position: relative;
  z-index: 1;
  background-color: transparent; /* päästää taustalabelin näkyviin */
  /*padding-left: 132px;*/            /* tila vasemmalle labelille */
  padding-right: 36px;            /* tila nuolelle */
  text-align: right;              /* arvo oikealle */
  text-align-last: right;         /* Chromium/WebKit */
  -moz-text-align-last: right;    /* Firefox */
  direction: ltr;
  text-indent: 0;
}

/* Auki: pidä otsikkorivi oikealla, peitä label taustalla */
.evs-row label.evs-label-ghost.evs-open select {
  padding-left: 12px;             /* poista se “tyhjä kaista” auki-tilassa */
  text-align: right;              /* ← arvo pysyy oikealla myös auki-tilassa */
  text-align-last: right;
  -moz-text-align-last: right;
}

/* Auki-tilassa himmennä/piilota taustalabel kokonaan */
.evs-row label.evs-label-ghost.evs-open::before {
  opacity: 0.14;                   /* tai esim. 0.06 jos haluat hyvin kevyesti näkyviin */
}

/* Dropdownin rivit vasemmalle aina */
.evs-row label.evs-label-ghost select option {
  text-align: left !important;
  direction: ltr !important;
}

@media (max-width: 480px) {
  .evs-row label.evs-label-ghost select { padding-left: 96px; }
}

/* Keskitä oikean reunan label/select pystysuunnassa vain desktopilla */
@media (min-width: 801px) {
  .evs-row--top > label {
    align-self: center;   /* pystysuuntainen keskitys flex-rivillä */
  }
}

/* 3PMSF-tag kortin kausiriville */
.evs-pmsf{
  display:inline-block;
  margin-left:8px;
  padding:2px 6px;
  border:1px solid var(--evs-border);
  border-radius:6px;
  background:#fff;
  font-weight:800;
  font-size:.80em;
  line-height:1;
  color:#0f172a;
}

/* HAE-napin pieni korostus ja väli clearin viereen */
#evs-submit{ margin-left: .5rem; }

/* (valmiiksi käytössä oleva .evs-btn--primary on jo sininen) */

/* Jos haluat header-versiossa napit oikealle linjaan kapealla: */
.evs-row__end{ gap:.5rem; flex-wrap:wrap; }

.evs-mode-submit .evs-toolbar,
.evs-mode-submit #evs-results,
.evs-mode-submit #evs-pagination{ display:none !important; }

/* status-indikaattori toolbarissa */
.evs-filter-status {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .9rem;
  opacity: .85;
}

/* yksinkertainen spinneri */
.evs-spinner {
  width: 1em;
  height: 1em;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  display: inline-block;
  animation: evs-spin 0.8s linear infinite;
}

@keyframes evs-spin {
  to { transform: rotate(360deg); }
}

/* kun filtterit latautuvat, himmennä riviä kevyesti */
.evs-filters-loading .evs-row {
  opacity: .6;
  pointer-events: none; /* estää vahingossa klikkaukset wrapperiin */
}

/* disabloidun selectin ulkoasu (tämä on vain varmistus) */
.evs-search select:disabled {
  cursor: not-allowed;
  opacity: .75;
}

.evs-filter-status {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .9rem;
  opacity: .85;
}
.evs-spinner {
  width: 1em;
  height: 1em;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  display: inline-block;
  animation: evs-spin 0.8s linear infinite;
}
@keyframes evs-spin { to { transform: rotate(360deg); } }

.evs-filters-loading .evs-row { opacity: .6; pointer-events: none; }
.evs-search select:disabled { cursor: not-allowed; opacity: .75; }

/* Yleinen: piilossa ellei .evs-filters-loading ole päällä */
.evs-filter-status {
  display: none;
  gap: .6rem;
  align-items: center;
  font-weight: 600;
  font-size: 14px;
}

/* Pieni spinneri */
.evs-spinner {
  width: 1.1rem;
  height: 1.1rem;
  border: 2px solid rgba(0,0,0,.2);
  border-top-color: rgba(0,0,0,.55);
  border-radius: 50%;
  animation: evs-spin .8s linear infinite;
}
@keyframes evs-spin { to { transform: rotate(360deg); } }

/* Mobiilissa: tee täysruutuinen overlay + keskitetty laatikko */
@media (max-width: 768px) {
  /* himmennys taustalle kun filtterit lataa */
  .evs-search.evs-filters-loading::after {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.25);
    backdrop-filter: blur(1px);
    z-index: 9998;
  }
  /* varsinainen ilmoituslaatikko keskelle */
  .evs-search.evs-filters-loading .evs-filter-status {
    position: fixed;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    z-index: 9999;
    display: flex;           /* näkyviin kun lataa */
    background: rgba(17,24,39,.95);  /* tumma laatikko */
    color: #fff;
    padding: .9rem 1.1rem;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0,0,0,.25);
    font-size: 15px;
  }
}

/* Työpöydällä: esitä pienenä “pillinä” toolbarin lopussa */
@media (min-width: 769px) {
  .evs-search.evs-filters-loading .evs-filter-status {
    display: inline-flex;
    background: #eef2ff;           /* kevyt sävy */
    color: #1e3a8a;
    padding: .35rem .6rem;
    border-radius: 999px;
    box-shadow: 0 1px 3px rgba(0,0,0,.08);
  }
}

/* Oletus */
.evs-filter-status { display: none; }

/* Submit-tila: kelluva badge yläoikealle, ei vaikuta layoutiin */
.evs-search[data-mode="submit"] .evs-filter-status {
  position: absolute;
  top: .5rem;
  right: .5rem;
  z-index: 5;
  display: none;
  align-items: center;
  gap: .5rem;

  background: #eef2ff;       /* kevyt sininen tausta */
  color: #1e3a8a;
  padding: .35rem .6rem;
  border-radius: 999px;
  box-shadow: 0 2px 10px rgba(0,0,0,.08);
  font-weight: 600;
  font-size: 13px;
  pointer-events: none;       /* ei estä klikkauksia alla */
}

/* Näytä kun ladataan */
.evs-search[data-mode="submit"].evs-filters-loading .evs-filter-status {
  display: inline-flex;
}

/* Pieni spinneri */
.evs-search[data-mode="submit"] .evs-spinner {
  width: 1rem;
  height: 1rem;
  border: 2px solid rgba(30,58,138,.25);
  border-top-color: rgba(30,58,138,.8);
  border-radius: 50%;
  animation: evs-spin .8s linear infinite;
}
@keyframes evs-spin { to { transform: rotate(360deg); } }

/* Yhteiset perusjutut */
.evs-filter-status {
  display: none;
  align-items: center;
  gap: .5rem;
  font-weight: 600;
  font-size: 13px;
  background: #eef2ff;
  color: #1e3a8a;
  padding: .4rem .7rem;
  border-radius: 999px;
  box-shadow: 0 2px 12px rgba(0,0,0,.12);
  pointer-events: none; /* ei estä klikkauksia alla */
}

/* Spinneri */
.evs-filter-status .evs-spinner{
  width: 1rem; height: 1rem;
  border: 2px solid rgba(30,58,138,.25);
  border-top-color: rgba(30,58,138,.85);
  border-radius: 50%;
  animation: evs-spin .8s linear infinite;
}
@keyframes evs-spin { to { transform: rotate(360deg); } }

/* Näytä kun ladataan */
.evs-search.evs-filters-loading .evs-filter-status { display: inline-flex; }

/* --- Submit-tila: kiinteä badge yläoikealla koko sivun päällä --- */
.evs-search[data-mode="submit"] .evs-filter-status {
  position: fixed;
  top: calc(28px + env(safe-area-inset-top));
  right: 8px;
  z-index: 20000; /* modaalien yläpuolelle */
}

/* --- Live-tila: kiinteä badge yläkeskellä (näkyy myös desktopilla) --- */
.evs-search[data-mode="live"] .evs-filter-status {
  position: fixed;
  top: calc(12px + env(safe-area-inset-top));
  left: 50%;
  transform: translateX(-50%);
  z-index: 20000;
}

/* Pienemmillä ruuduilla voit hieman pienentää */
@media (max-width: 420px){
  .evs-filter-status { font-size: 12px; padding: .35rem .6rem; }
}

