/* =======================
   KT Single – layout
   ======================= */

.kt-single {
  padding: 24px 16px;
}

.kt-single__grid {
  display: grid;
  gap: 24px;
}

/* Desktop: 2 saraketta – header + aside samalle riville, article omalleen */
@media (min-width: 992px) {
  .kt-single__grid {
    grid-template-columns: minmax(0, 1fr) 340px;
    grid-template-areas:
      "header aside"
      "article article";
    align-items: stretch; /* venyttää aside-kortin saman korkuiseksi kuin header-rivi */
  }
  .kt-single__header   { grid-area: header; }
  .kt-single__aside    { grid-area: aside;  align-self: stretch; }
  .kt-single__article  { grid-area: article; }
}

/* Header / kansikuva */
.kt-single__title { margin: 0 0 6px; }
.kt-single__org   { margin: 0 0 12px; opacity: .8; }
.kt-single__cover { margin: 12px 0 0; }
.kt-single__cover img { width: 100%; height: auto; display: block; }

/* Aside – harmaa laatikko, sama korkeus kuin header-rivin korkeus */
.kt-aside__card {
  background: #f4f4f5;
  border: 1px solid #e6e6e7;
  border-radius: 12px;
  padding: 16px;
  height: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Artikkelin runko */
.kt-single__content p { margin: 0 0 1em; }


/* =======================
   SUMMARY – lukutilastorivi (kt_rating_summary)
   ======================= */

.kt-single .kt-summary { margin: 8px 0 10px; }

/* koko rivi yhdelle linjalle: pallurat + keskiarvo + peukku */
.kt-single .kt-summary .kt-summary__row,
.kt-single .kt-summary .rating-row {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  line-height: 1;
  /* EI flex-wrapia tähän riviin */
}

/* pallurat vierekkäin */
.kt-single .kt-summary .kt-summary__dots {
  display: inline-flex;
  gap: 6px;
}

/* numero + peukku vierekkäin */
.kt-single .kt-summary .kt-summary__num {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

/* keskiarvoluku */
.kt-single .kt-summary .rating-row__value {
  font-weight: 700;
  font-size: 1.05rem;
  margin: 0;
}

/* peukun koko ja kehä (poista border+padding jos et halua kehää) */
.kt-single .kt-summary .kt-summary__thumb {
  width: 20px;
  height: 20px;
  display: inline-block;
  box-sizing: border-box;
}

/* arviomäärä omalle riville */
.kt-single .kt-summary .kt-summary__count {
  margin-top: 4px;
  font-size: .925rem;
  color: #6b7280;
}

/* =======================
   RATING – äänestysboksi (kt_rating)
   ======================= */

.kt-single .kt-rating__title {
  font-weight: 700;
  font-size: 1.25rem;
  line-height: 1.25;
  margin: 24px 0 8px;
  color: #111; /* otsikko pysyy mustana */
}

/* Äänestyslaatikko pinoon: otsikko yläreunaan, pallurat alle */
.kt-single .kt-rating{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:12px;
  padding:12px;
  display:block;            /* ← EI flexiä */
}


/* pallurat selkeiksi */
.kt-single .kt-rating .kt-vote-dots,
.kt-single .kt-summary .kt-summary__dots{
  display:inline-flex;
  gap:8px !important;
}

.kt-single .kt-rating .kt-dot,
.kt-single .kt-summary .kt-dot,
.kt-single .kt-rating .dot,
.kt-single .kt-summary .dot{
  width:14px !important;
  height:14px !important;
  border-width:1px;
}

.kt-single .kt-rating .kt-dot,
.kt-single .kt-rating .dot{
  background:#e5e7eb !important;
  border-color:#cbd5e1 !important;
}

.kt-single .kt-rating .kt-dot.is-fill,
.kt-single .kt-rating .dot.is-fill{
  background:currentColor !important;
  border-color:currentColor !important;
}

/* mahdollinen äänestyksen palauteviesti */
.kt-single .kt-vote-message{
  margin:6px 0 0;
  font-size:.925rem;
  color:#475569;
}

/* =======================
   Värit laadun mukaan (vain single)
   ======================= */

body.laatu-hyva  .kt-single .kt-summary,
body.laatu-hyva  .kt-single .kt-rating { color: #12448b; }

body.laatu-huono .kt-single .kt-summary,
body.laatu-huono .kt-single .kt-rating { color: #6f201d; }

/* Summary: pallurat + keskiarvo + peukku samalla rivillä, määrä alle */
.kt-single .kt-summary > .kt-summary__row,
.kt-single .kt-summary > .rating-row{
  display:inline-flex;
  align-items:center;
  gap:10px;
  flex-wrap:nowrap;
  line-height:1;
}
.kt-single .kt-summary .kt-summary__dots{ display:inline-flex; gap:6px; }
.kt-single .kt-summary .kt-summary__num{ display:inline-flex; align-items:center; gap:6px; }
.kt-single .kt-summary .rating-row__value{ font-weight:700; font-size:1.05rem; margin:0; }
.kt-single .kt-summary .kt-summary__thumb{
  width:20px; height:20px; display:inline-block;
  border:2px solid currentColor; border-radius:50%; padding:2px; box-sizing:border-box;
}
.kt-single .kt-summary .kt-summary__count{ margin-top:4px; font-size:.925rem; color:#6b7280; }


/* 3) Pallurat siistiksi riviksi (poista UL:n oletusvälit) */
.kt-vote-widget .kt-dots{
  display: flex;
  align-items: center;      /* keskitys pystyyn */
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.kt-vote-widget .kt-dot{ display:block; }

/* 4) Mahdollinen palauteviesti omalle rivilleen alle */
.kt-vote-message{
  display: block;
  margin-top: 6px;
  line-height: 1.2;
}


/* Kun otsikkoa seuraa äänestyswidget, pidä rivillä ja keskitettynä */
.kt-rating__title + .kt-vote-widget[data-post]{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  vertical-align: middle;
}

/* Palluroiden lista ilman UL-oletussisennyksiä ja baseline-heiluntaa */
.kt-vote-widget .kt-dots{
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.kt-vote-widget .kt-dot{ display: block; }

/* Palauteviesti omalle riville */
.kt-vote-message{
  display: block;
  margin-top: 6px;
  line-height: 1.2;
}

/* --- KT summary -ikonin “kill switch”: poista kehät, paddingit, taustat --- */
.single-kieliteko .kt-summary, 
.single-kieliteko .kt-summary__wrap{
  display: flex;
  align-items: center;
  gap: 8px;
}

/* itse peukku-kuva (oli se <img> tai <svg>) */
.single-kieliteko .kt-summary__thumb,
.single-kieliteko img.kt-summary__thumb,
.single-kieliteko .kt-summary__thumb img,
.single-kieliteko .kt-summary__thumb svg{
  width: 22px;
  height: 22px;
  display: inline-block;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  vertical-align: middle;
  object-fit: contain;
}

/* jos jokin yleinen sääntö tyylittelee “contentin kuvia” */
.single-kieliteko .entry-content img.kt-summary__thumb{
  border: 0 !important;
  background: none !important;
  padding: 0 !important;
  box-shadow: none !important;
}

/* pisteiden rivi ja teksti samalla linjalla */
.single-kieliteko .kt-summary__dots{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 0;
  padding: 0;
  line-height: 1;
}
.single-kieliteko .kt-summary__value,
.single-kieliteko .kt-summary__count{
  line-height: 1.1;
}

/* --- Arviointilohko: otsikko ja pallurat omille riveilleen --- */
.kt-single .kt-rating__title{
  display: block !important;   /* pakota omalle riville */
  margin: 0 0 8px;             /* pieni väli otsikon ja palluroiden väliin */
  line-height: 1.25;
}

/* [kt_rating] tulostaa yleensä .kt-vote-widget[data-post] -kääreen */
.kt-single .kt-rating__title + .kt-vote-widget[data-post]{
  display: block !important;   /* varmuudeksi blockiksi */
}

/* Jos jossain aiemmassa CSS:ssä on h2 + .kt-vote-widget { display:inline-flex; } → yliaja */
.kt-single .entry-content h2 + .kt-vote-widget[data-post]{
  display: block !important;
}

/* Otsikko omalle rivilleen ja pieni väli */
.kt-single .kt-rating__title{
  display:block;
  margin:0 0 8px;
  line-height:1.25;
}

/* Varmista, että [kt_rating]–shortcoden kääre tulee seuraavalle riville */
.kt-single .kt-rating .kt-vote-widget,
.kt-single .kt-rating [data-post].kt-vote-widget {
  display:inline-block;     /* block tai inline-block, kumpi miellyttää enemmän */
}



