/* =====================================================
   THEME — Cella Vinaria (Oliv & Pergament)
   Justera stämning här, inte utspritt i filen
   ===================================================== */

:root {
  accent-color: var(--accent-primary);

  /* Bas */
  --bg-main: #141612;        /* Mörk oliv-svart */
  --bg-card: #1b1e18;        /* Djup olivgrå */
  --border-soft: #2a2e24;

  /* Tabellhuvud */
  --table-head-bg: #0f130e;   /* Mycket mörk oliv */
  --table-head-border: #2a2e24;
  --table-head-text: #cfcbbd; /* Dämpat pergament */

  /* Tabellrader */
  --row-odd: #171a15;     /* Djup oliv-svart */
  --row-even: #1c2019;   /* En aning ljusare oliv */
  --row-hover: #23281f;  /* Oljad sten / varm hover */

  /* Text */
  --text-main: #e7e5dc;      /* Pergament */
  --text-muted: #b6b3a6;
  --text-dim: #8c8a7d;

  /* Accent */
  --accent-primary: #7c8a4a; /* Oliv */
  --accent-info: #9aa37a;
  --accent-warn: #c2a44a;   /* Dämpat guld */
  --accent-danger: #a15c4a; /* Tegel */

  /* Drickfönster */
  --window-young: #6b8aa6;
  --window-ready: #7c8a4a;
  --window-near-end: #c2a44a;
  --window-past: #a15c4a;
  --window-unknown: #4b5563;
}

:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg-main);color:var(--text-main)}
body{margin:0;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;max-width:1200px;margin-inline:auto;background:var(--bg-main);color:var(--text-main)}
h1{font-size:1.9rem;margin:0;letter-spacing:.03em}
h2{font-size:1.2rem;margin-top:0}
.subtle{font-size:.85rem;color:var(--text-muted)}
.card{background:var(--bg-card);border-radius:.75rem;padding:1.25rem 1.5rem;border:1px solid var(--border-soft);box-shadow:0 18px 40px rgba(0,0,0,.55)}
.layout-vertical{display:flex;flex-direction:column;gap:1.5rem}
.card-header-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem;flex-wrap:wrap}
.collapsible{margin-top:.75rem}
.collapsible.collapsed{display:none}
form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem 1rem}
@media (max-width:768px){form{grid-template-columns:minmax(0,1fr)}}
.field{display:flex;flex-direction:column;gap:.25rem}
.field-full{grid-column:1/-1}
label{font-size:.78rem;text-transform:uppercase;letter-spacing:.09em;color:#9ca3af}
input,textarea,select{background:var(--bg-card);border-radius:.5rem;border:1px solid var(--border-soft);padding:.45rem .6rem;color:var(--text-main);font-size:.9rem;outline:none;transition:border .15s ease,box-shadow .15s ease,background .15s ease}
input:focus,textarea:focus,select:focus{border-color:var(--accent-info);box-shadow:0 0 0 1px rgba(154,163,122,.35);background:var(--bg-card)}
textarea{min-height:60px;resize:vertical}
.actions{grid-column:1/-1;display:flex;gap:.5rem;margin-top:.25rem;flex-wrap:wrap}
button{border-radius:999px;border:1px solid transparent;padding:.45rem .9rem;font-size:.85rem;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem;white-space:nowrap;background:var(--accent-primary);color:#0b1408;font-weight:600;letter-spacing:.03em;text-transform:uppercase}
button.small{padding:.25rem .6rem;font-size:.75rem;text-transform:none;letter-spacing:.02em;font-weight:500}
button:disabled{opacity:.6;cursor:default}
.button-icon{padding:.15rem .4rem;font-size:.9rem;border-radius:999px}
.pill{display:inline-flex;align-items:center;gap:.25rem;border-radius:999px;padding:.1rem .5rem;font-size:.7rem;border:1px solid var(--border-soft);color:#9ca3af}
.pill-dot{width:6px;height:6px;border-radius:999px;background:#22c55e}
.status-line{margin-top:.35rem;font-size:.8rem;color:#9ca3af}
.table-card{padding-top:1rem}
.toolbar{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;align-items:center;margin-bottom:.75rem}
.toolbar-left,.toolbar-right{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.toolbar input[type=search]{width:260px;max-width:100%}
.table-wrapper{overflow-x:auto;width:100%}
table{width:100%;min-width:900px;border-collapse:collapse;font-size:.9rem;border-radius:.6rem;overflow:hidden;border:1px solid var(--border-soft);table-layout:auto}
thead{background:var(--table-head-bg);border-bottom:1px solid var(--table-head-border)}
th,td{padding:.75rem .85rem;text-align:left;vertical-align:top;line-height:1.45;white-space:normal;word-break:break-word}
th{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--table-head-text);border-bottom:1px solid var(--table-head-border);white-space:nowrap}
th.numeric{text-align:right}
tbody tr:nth-child(odd){
  background: var(--row-odd);
}

tbody tr:nth-child(even){
  background: var(--row-even);
}

tbody tr:hover{
  background: var(--row-hover);
}

.numeric{text-align:right;white-space:nowrap}
.muted{color:var(--text-dim);font-size:.75rem}
.status-footer{margin-top:.45rem;font-size:.8rem;color:var(--text-muted);display:flex;gap:.75rem;align-items:baseline;justify-content:space-between;flex-wrap:wrap}
.status-footer-right{margin-left:auto;text-align:right}
.window-pill{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;padding:.18rem .6rem;border-radius:999px;border:1px solid transparent;font-size:.78rem;line-height:1.2;text-align:center}
.window-pill div{font-size:.78rem}
.window-young{border-color:var(--window-young);background:rgba(107,138,166,.18);color:#d6e7f5}
.window-ready{border-color:var(--window-ready);background:rgba(124,138,74,.18);color:#e5f1c6}
.window-near_end{border-color:var(--window-near-end);background:rgba(194,164,74,.18);color:#f3e2aa}
.window-past{border-color:var(--window-past);background:rgba(161,92,74,.18);color:#f0c1b6}
.window-unknown{border-color:var(--window-unknown);background:rgba(31,41,55,.8);color:var(--text-muted)}
.card-list{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}
.wine-card{border-radius:.75rem;border: 1px solid var(--border-soft);padding:.75rem .85rem;background: var(--bg-card);display:flex;flex-direction:column;gap:.35rem}
.wine-card-header{display:flex;flex-direction:column;gap:.15rem}
.wine-card-title{font-weight:600;font-size:.98rem}
.wine-card-subtitle{font-size:.8rem;color: var(--text-muted);}
.wine-card-row{font-size:.82rem}
.wine-card-row.muted-row{color: var(--text-muted); font-size:.78rem}
.wine-card-footer{margin-top:.25rem;display:flex;gap:.4rem;flex-wrap:wrap;justify-content:flex-end}
.hidden{display:none!important}
.modal-backdrop{position:fixed;inset:0; background: rgba(20, 22, 18, .85); /* oliv-svart skugga */display:flex;align-items:center;justify-content:center;z-index:50}
.modal{background: var(--bg-card);border-radius:.75rem;border:1px solid var(--border-soft);padding:1.25rem 1.5rem;width:100%;max-width:360px;box-shadow:0 18px 40px rgba(0,0,0,.7)}
.modal h3{margin:0 0 .5rem 0;font-size:1rem}
.modal p{margin:0 0 .75rem 0;font-size:.85rem;color: var(--text-muted);}
.modal-actions{margin-top:.75rem;display:flex;justify-content:flex-end;gap:.5rem}
#password-error{margin-top:.35rem;font-size:.78rem;color:#fca5a5;min-height:1em}
.avatar-wrapper{width:44px;height:44px;border-radius:999px;overflow:hidden;border:1px solid var(--border-soft);box-shadow:0 0 0 2px rgba(15,23,42,.9);flex-shrink:0}
.avatar-image{width:100%;height:100%;object-fit:cover;display:block}

/* =====================================================
   Subtil guldaccent – aktiv rad
   ===================================================== */
tbody tr {
  transition: transform 0.18s ease;
}

tbody tr:hover {
  transform: translateX(1px);
}

/* Indexsiffran får en varm guldton vid hover */
tbody tr:hover td.numeric {
  color: var(--accent-warn);
}

/* Mycket diskret guldlinje i vänsterkant */
tbody tr:hover td:first-child {
  box-shadow: inset 2px 0 0 rgba(194, 164, 74, 0.45);
}
tbody tr td {
  transition:
    background-color 0.18s ease,
    color 0.18s ease,
    box-shadow 0.18s ease;
}




/* =====================================================
   Native controls — mild theming
   ===================================================== */
/*
  OBS: native dropdown-menyer är delvis OS-/browserstyrda.
  Dessa regler minskar "Windows-blå" känslan så långt det är realistiskt,
  utan att bygga en helt egen custom-select.
*/
select{color-scheme:dark;accent-color:var(--accent-primary)}
select,option{background:var(--bg-card);color:var(--text-main)}
select:hover{border-color:var(--accent-primary)}
select:focus{border-color:var(--accent-warn);box-shadow:0 0 0 1px rgba(194,164,74,.35);background:var(--bg-card)}

/* =====================================================
   Modal button tones
   ===================================================== */
button.primary{background:var(--accent-primary);color:#0b1408;border-color:transparent}
button.warn{background:var(--accent-warn);color:#1a1206;border-color:transparent}
button.danger{background:var(--accent-danger);color:#1a0b08;border-color:transparent}
button.secondary{background:transparent;color:var(--text-main);border-color:var(--border-soft)}
