/* ============================================================
   Kirpputori Kassa — Mobiiliystävällinen CSS
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --sin: #1a1a2e;
  --sin2: #16213e;
  --aksentti: #e94560;
  --vihrea: #27ae60;
  --keltainen: #f39c12;
  --harmaa: #6c757d;
  --vaalea: #f8f9fa;
  --teksti: #212529;
  --reuna: #dee2e6;
  --kortti-bg: #ffffff;
  --varjo: 0 2px 8px rgba(0,0,0,.10);
  --r: 8px;
  font-size: 16px;
}

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background: #f0f2f5;
  color: var(--teksti);
  min-height: 100vh;
}

/* ── Topbar ───────────────────────────────────────────────── */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--sin);
  color: #fff;
  padding: .75rem 1rem;
  gap: 1rem;
  flex-wrap: wrap;
  position: sticky;
  top: 0;
  z-index: 100;
}
.topbar-nimi   { font-weight: 700; font-size: 1.05rem; }
.topbar-kayttaja { font-size: .9rem; opacity: .85; }
.topbar-otsikko { font-size: .95rem; flex: 1; text-align: center; }
.topbar-takaisin { color: #fff; text-decoration: none; font-size: 1.1rem; }
.topbar-nav { display: flex; gap: .5rem; flex-wrap: wrap; }
.topbar-nav a {
  color: #fff;
  text-decoration: none;
  background: rgba(255,255,255,.15);
  padding: .35rem .7rem;
  border-radius: var(--r);
  font-size: .85rem;
  white-space: nowrap;
}
.topbar-nav a:hover { background: rgba(255,255,255,.28); }

/* ── Napit ────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  padding: .55rem 1.1rem;
  border: none;
  border-radius: var(--r);
  font-size: .95rem;
  font-weight: 600;
  cursor: pointer;
  background: var(--sin);
  color: #fff;
  transition: opacity .15s, transform .1s;
  text-decoration: none;
  white-space: nowrap;
}
.btn:active { transform: scale(.97); }
.btn:hover  { opacity: .88; }
.btn-iso    { padding: .8rem 1.6rem; font-size: 1.05rem; }
.btn-pieni  { padding: .3rem .6rem; font-size: .8rem; }
.btn-vihrea { background: var(--vihrea); }
.btn-punainen { background: var(--aksentti); }
.btn-harmaa { background: var(--harmaa); }
.btn-keltainen { background: var(--keltainen); }

/* ── Kirjautuminen ────────────────────────────────────────── */
.kirjautuminen-sivu {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background: var(--sin);
}
.kirjautuminen-kortti {
  background: var(--kortti-bg);
  border-radius: calc(var(--r)*2);
  padding: 2.5rem 2rem;
  width: min(100%, 380px);
  box-shadow: var(--varjo);
}
.kirjautuminen-kortti h1 {
  text-align: center;
  margin-bottom: 1.5rem;
  color: var(--sin);
}
.kirjautuminen-kortti label {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  margin-bottom: 1rem;
  font-weight: 600;
  font-size: .95rem;
}
.kirjautuminen-kortti input {
  padding: .65rem .9rem;
  border: 1.5px solid var(--reuna);
  border-radius: var(--r);
  font-size: 1rem;
  width: 100%;
}
.kirjautuminen-kortti input:focus { outline: none; border-color: var(--sin); }
.kirjautuminen-kortti button { width: 100%; margin-top: .5rem; }
.virhe { color: var(--aksentti); margin-bottom: 1rem; font-size: .9rem; }

/* ── Kassa päänäkymä ──────────────────────────────────────── */
.kassa-main { padding: 1.25rem; max-width: 1000px; margin: 0 auto; }
.kassa-otsikko {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.25rem;
  gap: 1rem;
}
.kassa-otsikko h2 { font-size: 1.4rem; }

.myynti-lista {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1rem;
}
.myynti-kortti {
  background: var(--kortti-bg);
  border-radius: var(--r);
  padding: 1rem 1.1rem;
  box-shadow: var(--varjo);
  text-decoration: none;
  color: var(--teksti);
  display: flex;
  flex-direction: column;
  gap: .5rem;
  border-left: 4px solid var(--sin);
  transition: box-shadow .15s;
}
.myynti-kortti:hover { box-shadow: 0 4px 16px rgba(0,0,0,.16); }
.myynti-kortti-nro  { font-size: .8rem; color: var(--harmaa); }
.myynti-kortti-tiedot { display: flex; justify-content: space-between; flex-wrap: wrap; gap: .25rem; }
.myynti-kayttaja, .myynti-aika { font-size: .88rem; }
.myynti-kortti-info { display: flex; justify-content: space-between; align-items: baseline; }
.myynti-summa { font-weight: 700; font-size: 1.05rem; color: var(--vihrea); }
.tyhja-lista { color: var(--harmaa); padding: 2rem 0; }

/* ── Myyntinäkymä ─────────────────────────────────────────── */
.myynti-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 0;
  height: calc(100vh - 52px);
}
@media (max-width: 700px) {
  .myynti-layout {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr auto;
    height: auto;
  }
}

.myynti-vasen {
  display: flex;
  flex-direction: column;
  padding: 1rem;
  gap: .75rem;
  overflow-y: auto;
}

.skannaus-alue {
  display: flex;
  gap: .5rem;
}
.skannaus-alue input {
  flex: 1;
  padding: .7rem 1rem;
  font-size: 1.1rem;
  border: 2px solid var(--sin);
  border-radius: var(--r);
}
.skannaus-alue input:focus { outline: none; border-color: var(--aksentti); }

.myynti-taulukko {
  width: 100%;
  border-collapse: collapse;
  font-size: .95rem;
}
.myynti-taulukko th {
  background: var(--sin);
  color: #fff;
  padding: .5rem .75rem;
  text-align: left;
}
.myynti-taulukko th.oikea, .myynti-taulukko td.oikea { text-align: right; }
.myynti-taulukko td { padding: .55rem .75rem; border-bottom: 1px solid var(--reuna); }
.myynti-taulukko tr:last-child td { border-bottom: none; }
.myynti-taulukko tr:hover td { background: #f5f5f5; }

.myynti-oikea {
  background: var(--sin2);
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  padding: 1.5rem 1rem;
}
@media (max-width: 700px) {
  .myynti-oikea {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 1rem;
    border-top: 3px solid var(--aksentti);
  }
}

.summa-kortti { text-align: center; }
.summa-otsikko { font-size: .9rem; opacity: .75; text-transform: uppercase; letter-spacing: .05em; }
.summa-arvo { font-size: 2.5rem; font-weight: 700; color: #fff; margin-top: .25rem; }
@media (max-width: 700px) { .summa-arvo { font-size: 1.8rem; } }

.toiminnot { display: flex; flex-direction: column; gap: .75rem; width: 100%; }
@media (max-width: 700px) { .toiminnot { flex-direction: row; width: auto; } }

/* ── Modal ────────────────────────────────────────────────── */
.modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 200;
  padding: 1rem;
}
.modal.piilotettu { display: none; }
.modal-sisalto {
  background: var(--kortti-bg);
  border-radius: calc(var(--r)*1.5);
  padding: 1.75rem 1.5rem;
  width: min(100%, 440px);
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 8px 32px rgba(0,0,0,.25);
}
.modal-sisalto h3 { margin-bottom: 1rem; font-size: 1.2rem; }
.modal-napit { display: flex; gap: .75rem; margin-top: 1.25rem; flex-wrap: wrap; }

.tuote-valinta-nappi {
  display: block;
  width: 100%;
  text-align: left;
  background: var(--vaalea);
  border: 1.5px solid var(--reuna);
  border-radius: var(--r);
  padding: .75rem 1rem;
  margin-bottom: .5rem;
  cursor: pointer;
  font-size: .95rem;
  transition: background .12s;
}
.tuote-valinta-nappi:hover { background: #e8eef5; border-color: var(--sin); }

/* ── Viimeistely-modal ────────────────────────────────────── */
.summa-iso { font-size: 2rem; font-weight: 700; text-align: center; margin: .75rem 0; color: var(--vihrea); }
.maksu-rivit { display: flex; flex-direction: column; gap: .75rem; }
.maksu-rivit label {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  font-weight: 600;
}
.maksu-rivit input {
  padding: .65rem .9rem;
  border: 1.5px solid var(--reuna);
  border-radius: var(--r);
  font-size: 1.1rem;
}

/* ── Lomakkeet ────────────────────────────────────────────── */
.lomake-sivu { padding: 1.25rem; max-width: 700px; margin: 0 auto; }
.lomake-kortti {
  background: var(--kortti-bg);
  border-radius: var(--r);
  padding: 1.5rem;
  box-shadow: var(--varjo);
}
.lomake-kortti h2 { margin-bottom: 1.25rem; }
.lomake-rivi { display: flex; flex-direction: column; gap: .35rem; margin-bottom: 1rem; }
.lomake-rivi label { font-weight: 600; font-size: .92rem; }
.lomake-rivi input,
.lomake-rivi select,
.lomake-rivi textarea {
  padding: .6rem .9rem;
  border: 1.5px solid var(--reuna);
  border-radius: var(--r);
  font-size: .97rem;
  width: 100%;
}
.lomake-rivi input:focus,
.lomake-rivi select:focus,
.lomake-rivi textarea:focus { outline: none; border-color: var(--sin); }
.lomake-rivi textarea { resize: vertical; min-height: 80px; }
.lomake-2kol { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 500px) { .lomake-2kol { grid-template-columns: 1fr; } }
.lomake-napit { display: flex; gap: .75rem; margin-top: 1rem; flex-wrap: wrap; }

/* ── Viivakooditulostus ────────────────────────────────────── */
.vk-sivu { padding: 1.25rem; max-width: 900px; margin: 0 auto; }
.vk-suodatin {
  background: var(--kortti-bg);
  border-radius: var(--r);
  padding: 1rem 1.25rem;
  margin-bottom: 1.25rem;
  box-shadow: var(--varjo);
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  align-items: flex-end;
}
.vk-suodatin .lomake-rivi { margin: 0; min-width: 180px; flex: 1; }
.vk-tulosta-alue {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: .75rem;
}
.vk-kortti {
  background: var(--kortti-bg);
  border: 1px solid var(--reuna);
  border-radius: var(--r);
  padding: .75rem;
  text-align: center;
  font-size: .8rem;
}
.vk-kortti svg { max-width: 100%; height: 60px; }
.vk-nimi { font-weight: 600; margin-top: .4rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.vk-hinta { color: var(--vihrea); font-weight: 700; }
.vk-koodi { font-size: .7rem; color: var(--harmaa); }

/* ── Hallintapaneeli ──────────────────────────────────────── */
.hallinta-main { padding: 1.25rem; max-width: 1100px; margin: 0 auto; }

.tilasto-ruudukko {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}
.tilasto-kortti {
  background: var(--kortti-bg);
  border-radius: var(--r);
  padding: 1.25rem 1rem;
  box-shadow: var(--varjo);
  text-align: center;
  border-top: 3px solid var(--sin);
}
.tilasto-arvo   { font-size: 2rem; font-weight: 700; }
.tilasto-otsikko { font-size: .85rem; color: var(--harmaa); margin-top: .25rem; }

.taulu-wrapper { overflow-x: auto; }
.hallinta-taulu {
  width: 100%;
  border-collapse: collapse;
  font-size: .93rem;
  background: var(--kortti-bg);
  border-radius: var(--r);
  overflow: hidden;
  box-shadow: var(--varjo);
}
.hallinta-taulu th {
  background: var(--sin);
  color: #fff;
  padding: .6rem .85rem;
  text-align: left;
  white-space: nowrap;
}
.hallinta-taulu td {
  padding: .55rem .85rem;
  border-bottom: 1px solid var(--reuna);
  vertical-align: middle;
}
.hallinta-taulu tr:last-child td { border-bottom: none; }
.hallinta-taulu tr.inaktiivinen td { opacity: .45; }
.hallinta-taulu tr:hover td { background: #f7f9fc; }
.taulu-toiminnot { white-space: nowrap; display: flex; gap: .35rem; }
.oikea { text-align: right; }

.suodatin-rivi {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
  align-items: flex-end;
}
.suodatin-rivi input,
.suodatin-rivi select {
  padding: .55rem .85rem;
  border: 1.5px solid var(--reuna);
  border-radius: var(--r);
  font-size: .93rem;
}
.suodatin-rivi input { flex: 1; min-width: 160px; }

.sivutus { display: flex; gap: .4rem; flex-wrap: wrap; margin-top: 1rem; }
.sivutus-nappi {
  padding: .35rem .7rem;
  border-radius: var(--r);
  background: var(--kortti-bg);
  border: 1.5px solid var(--reuna);
  text-decoration: none;
  color: var(--teksti);
  font-size: .88rem;
}
.sivutus-nappi.aktiivinen { background: var(--sin); color: #fff; border-color: var(--sin); }

/* Badget */
.badge-vihrea   { background: #d4edda; color: #155724; padding: .2rem .55rem; border-radius: 20px; font-size: .8rem; }
.badge-harmaa   { background: #e9ecef; color: #495057; padding: .2rem .55rem; border-radius: 20px; font-size: .8rem; }
.badge-punainen { background: #f8d7da; color: #721c24; padding: .2rem .55rem; border-radius: 20px; font-size: .8rem; }

@media print {
  .topbar, .vk-suodatin, .btn { display: none !important; }
  .vk-tulosta-alue {
    grid-template-columns: repeat(4, 1fr);
    gap: .5rem;
  }
  .vk-kortti { break-inside: avoid; }
}
