:root{--bg:#111827;--card:#0b1220;--text:#e5e7eb;--muted:#9ca3af;--border:#1f2937;--accent:#60a5fa;--danger:#ef4444;--btn:#111827}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;background:var(--bg);color:var(--text)}
.container{max-width:1720px;width:100%;margin:0 auto;padding:24px}
.container.narrow{max-width:520px}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
h1{margin:0 0 4px 0;font-size:22px}
h2{margin:0 0 12px 0;font-size:16px}
.muted{color:var(--muted)}
.small{font-size:12px}
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width: 900px){.grid{grid-template-columns:1fr}}
.entry-row{display:flex;gap:10px;align-items:center;margin:12px 0}
.entry-row input{flex:1}
.inline{margin:0}
.inline input{width:100%;padding:8px;border-radius:8px;min-width:0}
.inline input.mono{min-width:0}
.inline input.pnr-field{width:151px}
.inline input.name-field{width:270px}
.inline input.time-field{width:58px}
.inline input.ringde-field{width:250px;margin-right:8px}
.inline input.diag-field{width:96px;margin-right:8px}
.inline input.framme-field{width:66px}
.patients-table td:nth-child(1){padding-right:4px}
.patients-table td:nth-child(2), .patients-table th:nth-child(2){padding-left:4px;padding-right:6px}
.actions-cell{white-space:nowrap}
.actions-cell > div{display:flex;gap:8px;justify-content:flex-end;flex-wrap:nowrap}

.hint{margin-top:10px}
.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:10px}
@media (max-width: 900px){.two-cols{grid-template-columns:1fr}}
input.secondary{background:transparent}

.suggestions{margin-top:8px;display:flex;flex-wrap:wrap;gap:8px}
.suggestions .chip{border:1px solid var(--border);background:rgba(255,255,255,0.02);padding:6px 10px;border-radius:999px;font-size:13px;color:var(--text);cursor:pointer}
.suggestions .chip:hover{border-color:rgba(96,165,250,.7)}

label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}
input,select{background:#0a0f1a;color:var(--text);border:1px solid var(--border);border-radius:10px;padding:10px;font-size:14px}
button,.button{display:inline-block;border:1px solid var(--border);background:#0a0f1a;color:var(--text);padding:10px 12px;border-radius:10px;cursor:pointer;text-decoration:none;font-size:14px;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease,transform .12s ease}
button:hover,.button:hover{border-color:rgba(96,165,250,.65);box-shadow:0 0 0 1px rgba(96,165,250,.35) inset,0 0 14px rgba(96,165,250,.14);transform:translateY(-1px)}
button.secondary,.button.secondary{background:transparent}
button.secondary:hover,.button.secondary:hover{background:rgba(96,165,250,.10)}
button.btn-carecert{background:transparent;border-color:rgba(250,204,21,.55);color:#fde047}
button.btn-carecert:hover{background:rgba(250,204,21,.12)}
button.btn-death{background:transparent;border-color:rgba(125,211,252,.6);color:#7dd3fc}
button.btn-death:hover{background:rgba(125,211,252,.12)}
button.btn-homevisit{background:transparent;border-color:rgba(74,222,128,.55);color:#86efac}
button.btn-homevisit:hover{background:rgba(74,222,128,.12)}
button.danger{border-color:rgba(239,68,68,.45);color:#fecaca}
button.danger:hover{border-color:rgba(239,68,68,.75);box-shadow:0 0 0 1px rgba(239,68,68,.35) inset,0 0 14px rgba(239,68,68,.20);background:rgba(239,68,68,.12)}
button.danger.secondary{background:transparent}
.actions{display:flex;gap:10px;align-items:end}
.form-grid{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:12px}
.form-grid .actions{grid-column:1 / -1}
.alert{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.35);padding:10px 12px;border-radius:10px;margin:12px 0}
.login-form button{margin-top:10px}
.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:12px;margin:12px 0}
table{width:100%;border-collapse:collapse;table-layout:fixed}
th,td{padding:10px;border-bottom:1px solid var(--border);text-align:left;font-size:13px;vertical-align:middle}
th{color:var(--muted);font-weight:600;background:#070b12}
tr:last-child td{border-bottom:none}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace}

.patients-toolbar{display:grid;grid-template-columns:1fr auto;gap:8px 12px;align-items:end}
.patients-toolbar h2{grid-column:1 / -1}
.patients-toolbar .muted{grid-column:1}
.patients-toolbar #patients-toggle-btn{grid-column:2;justify-self:end}
/* Default collapsed: show only newest (last) patient row */
#patients-table-wrap.patients-collapsed .patients-table tbody tr:not(:last-child){display:none !important}

@media (max-width: 1024px){
  .container{padding:14px}
  .actions-cell > div{flex-wrap:wrap;justify-content:flex-start}
}

@media (max-width: 760px){
  body{overflow-x:hidden}
  .container{padding:calc(env(safe-area-inset-top, 0px) + 12px) 10px 12px}
  .grid{gap:12px}
  .card{padding:12px;overflow:hidden;border-radius:14px}

  .topbar{flex-direction:column;align-items:stretch;gap:10px}
  .topbar h1{font-size:20px;line-height:1.2}
  .topbar form{width:100%}
  .topbar form button{width:100%;text-align:center}

  h2{padding-top:2px}
  .muted{line-height:1.35;word-break:break-word}

  .entry-row{flex-direction:column;align-items:stretch;gap:8px}
  .entry-row input{min-width:0}
  .entry-row button{width:100%}

  .form-grid{grid-template-columns:1fr;gap:10px}
  .actions{display:grid;grid-template-columns:1fr;gap:8px;align-items:stretch}
  .actions .button,
  .actions button{width:100%;text-align:center}

  .inline input,
  .inline input.pnr-field,
  .inline input.name-field,
  .inline input.time-field,
  .inline input.ringde-field,
  .inline input.diag-field,
  .inline input.framme-field{width:100%;min-width:0}

  .table-wrap{max-width:100%;margin:10px 0 0}

  .patients-toolbar{grid-template-columns:1fr auto;align-items:end}
  .patients-toolbar h2{grid-column:1 / -1}
  .patients-toolbar .muted{grid-column:1}
  .patients-toolbar #patients-toggle-btn{grid-column:2;width:auto;text-align:center}

  /* Patienten-tabellen får avancerad mobil-layout */
  .patients-table colgroup{display:none}
  .patients-table{display:block;min-width:0;table-layout:auto}
  .patients-table thead{display:none}
  .patients-table tbody{display:block}
  .patients-table tbody tr{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:8px;border:1px solid var(--border);border-radius:12px;padding:10px;background:#070b12;margin-bottom:10px}
  .patients-table tbody td{border-bottom:none;padding:0;margin:0;min-width:0}

  .patients-table tbody td:nth-child(1){display:none}
  .patients-table tbody td:nth-child(2){grid-column:1 / span 2;grid-row:1;padding-top:17px}
  .patients-table tbody td:nth-child(3){grid-column:3 / span 4;grid-row:1}
  .patients-table tbody td:nth-child(4){grid-column:7 / span 6;grid-row:1}
  .patients-table tbody td:nth-child(5){grid-column:1 / span 2;grid-row:2}
  .patients-table tbody td:nth-child(6){grid-column:3 / span 6;grid-row:2}
  .patients-table tbody td:nth-child(7){grid-column:9 / span 4;grid-row:2}
  .patients-table tbody td:nth-child(8):not(.actions-cell){grid-column:1 / span 2;grid-row:3;margin-top:4px}
  .patients-table tbody td:nth-child(9),
  .patients-table tbody td:nth-child(8).actions-cell{grid-column:3 / span 10;grid-row:3}

  .patients-table tbody td:nth-child(3)::before,
  .patients-table tbody td:nth-child(4)::before,
  .patients-table tbody td:nth-child(5)::before,
  .patients-table tbody td:nth-child(6)::before,
  .patients-table tbody td:nth-child(7)::before,
  .patients-table tbody td:nth-child(8):not(.actions-cell)::before{display:block;color:var(--muted);font-size:11px;font-weight:600;margin-bottom:4px}
  .patients-table tbody td:nth-child(3)::before{content:"PNR"}
  .patients-table tbody td:nth-child(4)::before{content:"Namn"}
  .patients-table tbody td:nth-child(5)::before{content:"Tid"}
  .patients-table tbody td:nth-child(6)::before{content:"Ringde"}
  .patients-table tbody td:nth-child(7)::before{content:"Diagnos"}
  body.framjour .patients-table tbody td:nth-child(8):not(.actions-cell)::before{content:"Framme"}
  body.telefonjour .patients-table tbody td:nth-child(8):not(.actions-cell)::before{content:"Rap övr"}

  .patients-table tbody td .inline,
  .patients-table tbody td .inline input,
  .patients-table tbody td select,
  .patients-table tbody td button{width:100%;min-width:0}
  .patients-table tbody td input,.patients-table tbody td select{padding:8px;font-size:12px}

  .patients-table tbody td:nth-child(2) button{
    min-height:34px;
    height:34px;
    padding:6px 8px;
    display:flex;
    align-items:center;
    justify-content:center;
    line-height:1;
  }

  .patients-table .actions-cell{display:block}
  .patients-table .actions-cell::before{content:"";display:block;height:19px}
  .patients-table .actions-cell > div{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}
  .patients-table .actions-cell form{margin:0;min-width:0}
  .patients-table .actions-cell button{width:100%;padding:8px 6px;font-size:12px;min-height:36px}

  /* Telefonbok + Diagnosgenvägar: kompakt card-layout med korrekta etiketter */
  .phonebook-table,
  .diagnosis-table{table-layout:auto}
  .phonebook-table thead,
  .diagnosis-table thead{display:none}
  .phonebook-table tbody,
  .diagnosis-table tbody{display:block}
  .phonebook-table tr,
  .diagnosis-table tr{display:block;border:1px solid var(--border);border-radius:12px;padding:10px;background:#070b12;margin-bottom:10px}
  .phonebook-table td,
  .diagnosis-table td{display:block;border-bottom:none;padding:0 0 8px 0}
  .phonebook-table td:last-child,
  .diagnosis-table td:last-child{padding-bottom:0}
  .phonebook-table td::before,
  .diagnosis-table td::before{content:attr(data-label);display:block;color:var(--muted);font-size:11px;font-weight:600;margin-bottom:4px}
  .phonebook-table td .button,
  .phonebook-table td button,
  .diagnosis-table td input{width:100%}

  button,.button{min-height:44px}
  .card form[action="/clear"]{margin-top:12px}
}
form[action$="/clear"]{
  margin-top:16px;
}
