
/* Fonts */
@font-face{
  font-family:"OldTown";
  src:url("../fonts/OldTown.ttf") format("truetype");
  font-display:swap;
}
@font-face{
  font-family:"Go2OldWestern";
  src:url("../fonts/Go2OldWestern.otf") format("opentype");
  font-display:swap;
}
@font-face{
  font-family:"CowboyOutlaw";
  src:url("../fonts/CowboyOutlaw.otf") format("opentype");
  font-display:swap;
}
@font-face{
  font-family:"CowboyOutlawTextured";
  src:url("../fonts/CowboyOutlawTextured.otf") format("opentype");
  font-display:swap;
}

:root{
  --font-body: "Merriweather", Georgia, "Times New Roman", serif;
  --font-head: "IM Fell English SC", Georgia, "Times New Roman", serif;
  --font-west: "Go2OldWestern", "IM Fell English SC", Georgia, "Times New Roman", serif;
}

:root{
  --bg:#1a1410;
  --paper:#f2e6c9;
  --ink:#201a15;
  --ink2:#3a2f26;
  --accent:#8b5a2b;
  --accent2:#c9a24a;
  --danger:#8b2b2b;
  --ok:#2b6b3b;
  --shadow: rgba(0,0,0,.35);
}

*{box-sizing:border-box}
body{margin:0;font-family:var(--font-body);color:var(--ink);line-height:1.55}
.bg{
  min-height:100vh;
  background:
    radial-gradient(1200px 800px at 10% 10%, rgba(201,162,74,.15), transparent 60%),
    radial-gradient(900px 600px at 90% 20%, rgba(139,90,43,.12), transparent 55%),
    linear-gradient(0deg, rgba(0,0,0,.35), rgba(0,0,0,.35)),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='.25'/%3E%3C/svg%3E");
  background-color: var(--bg);
}

.wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:24px}
.container{max-width:1100px;margin:0 auto;padding:20px}
.page{padding-top:18px}
.page__title{margin:6px 0 14px;font-size:28px;font-weight:900;letter-spacing:.5px}
.page .card{width:100%}

.card{
  background: var(--paper);
  border: 2px solid rgba(32,26,21,.35);
  border-radius: 14px;
  box-shadow: 0 14px 28px var(--shadow);
  padding: 18px;
}
.card--narrow{width: min(420px, 100%)}
.card__title{font-weight:700;font-size:18px;margin-bottom:10px;letter-spacing:.3px}
.card__body{color:var(--ink2)}

.brand{margin-bottom:14px;text-align:center}
.brand__title{font-size:28px;font-weight:800;letter-spacing:.8px}
.brand__subtitle{font-size:14px;opacity:.8}

.topbar{
  position:sticky;top:0;z-index:5;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;
  background: rgba(242,230,201,.95);
  border-bottom: 2px solid rgba(32,26,21,.25);
  box-shadow: 0 10px 22px rgba(0,0,0,.25);
}
.brandmini__title{font-weight:900;letter-spacing:.7px}
.brandmini__sub{font-size:12px;opacity:.7}

.userchip{display:flex;gap:10px;align-items:center;font-weight:700}
.badge{
  font-size:11px;
  padding:3px 8px;
  border-radius: 999px;
  background: rgba(139,90,43,.15);
  border:1px solid rgba(139,90,43,.35);
}
.badge--ok{background: rgba(43,107,59,.18);border-color: rgba(43,107,59,.35)}
.badge--info{background: rgba(60,110,180,.18);border-color: rgba(60,110,180,.35)}
.badge--warn{background: rgba(201,162,74,.22);border-color: rgba(201,162,74,.45)}
.badge--danger{background: rgba(139,43,43,.18);border-color: rgba(139,43,43,.35)}
.link{color:var(--accent);text-decoration:none;font-weight:700}
.link:hover{text-decoration:underline}

.form{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.formstack{display:flex;flex-direction:column;gap:10px}
.label{font-weight:700}
.input{
  padding:10px 12px;
  border-radius: 10px;
  border: 2px solid rgba(32,26,21,.25);
  background: rgba(255,255,255,.65);
  outline:none;
  font-family: "CowboyOutlaw";
  font-weight: 1200;
  font-size: 16px;
}
.input:focus{border-color: rgba(139,90,43,.55)}

.cbfont {
  font-family: "CowboyOutlaw";
}

.btn{
  margin-top:10px;
  padding:10px 12px;
  border-radius: 12px;
  border: 2px solid rgba(32,26,21,.35);
  background: linear-gradient(180deg, rgba(201,162,74,.85), rgba(139,90,43,.85));
  color: #1b120c;
  font-weight:900;
  letter-spacing:.4px;
  cursor:pointer;
  transition:transform .08s ease, filter .12s ease;
}
.btn:hover{filter:brightness(1.03)}
.btn:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.2)}
.btn--danger{background: linear-gradient(180deg, rgba(210,110,110,.9), rgba(139,43,43,.9))}
.btn--ok{background: linear-gradient(180deg, rgba(120,200,150,.9), rgba(43,107,59,.9))}
.btn--small{padding:6px 10px;font-size:13px;border-radius:12px}
.btn:active{transform:translateY(1px)}
.btn--primary{background: linear-gradient(180deg, rgba(201,162,74,.85), rgba(139,90,43,.85))}

.table .btn{padding:7px 10px;border-radius:12px;font-size:13px;margin-top:0}

button {
  padding: 0.1em 0.25em;
  width: 13em;
  height: 4.2em;
  background-color: #383838;
  border: 0.08em solid #bda573;
  border-radius: 0.3em;
  font-size: 12px;
  cursor: pointer;
  margin-top: 1.0em;
}

button a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  bottom: 0.4em;
  width: 8.25em;
  height: 2.5em;
  background-color: #312a1d;
  border-radius: 0.2em;
  font-size: 1.5em;
  color: #bda16d;
  border: 0.08em solid #dfca9d;
  box-shadow: 0 0.4em 0.1em 0.019em #bda16d;
  font-family:"CowboyOutlawTextured";
  text-decoration: none;
}

button a:hover {
  transition: all 0.5s;
  transform: translate(0, 0.4em);
  box-shadow: 0 0 0 0 #fff;

}

button a:not(hover) {
  transition: all 1s;
}

/* Patients page layout helpers */
.searchrow{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:end}
.formgridL{display:grid;grid-template-columns:180px 1fr;gap:10px 14px;align-items:center;margin-top:6px}
.formgridL .label{justify-self:end;text-align:right}
.formactions{grid-column:2;display:flex;gap:10px}

/* Checkbox row inside form grids */
.checkline{display:flex;align-items:center;gap:10px;justify-content:flex-start}
.checkline input[type="checkbox"]{width:18px;height:18px}
@media (max-width: 640px){
  .formgridL{grid-template-columns:1fr}
  .formgridL .label{justify-self:start;text-align:left}
  .formactions{grid-column:1}
}

/* Live search dropdown (Enzyklopädie) */
.livewrap{position:relative}
.livebox{position:absolute;left:0;right:0;top:calc(100% + 6px);background:rgba(255,255,255,.96);border:1px solid rgba(0,0,0,.18);border-radius:10px;box-shadow:0 10px 24px rgba(0,0,0,.25);overflow:hidden;z-index:50}
.liveitem{display:flex;align-items:center;gap:10px;padding:10px 12px;text-decoration:none;color:inherit;border-top:1px solid rgba(0,0,0,.06)}
.liveitem:first-child{border-top:none}
.liveitem:hover{background:rgba(201,162,74,.18)}
.livetitle{font-weight:800}
.livesub{display:block;flex-basis:100%;margin-left:46px;font-size:12px;opacity:.75;line-height:1.25}

.alert{padding:10px 12px;border-radius:12px;border:2px solid rgba(0,0,0,.15);margin-top:10px}
.alert--danger{background: rgba(139,43,43,.15);border-color: rgba(139,43,43,.35)}
.alert--ok{background: rgba(46,139,87,.15);border-color: rgba(46,139,87,.35)}

.notice{margin-bottom:12px;padding:12px 14px;border-radius:12px;border:2px dashed rgba(32,26,21,.25);background: rgba(242,230,201,.92)}
.notice__title{font-weight:900;margin-bottom:4px}
.notice--info{border-color: rgba(43,85,140,.35)}
.notice--warn{border-color: rgba(201,162,74,.55)}
.notice--danger{border-color: rgba(139,43,43,.45)}

.grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
@media (max-width: 900px){
  .grid{grid-template-columns: 1fr}
}
.row{display:flex;align-items:center;justify-content:space-between;gap:14px}
.big{font-size:22px;font-weight:900}
.muted{opacity:.75}
.small{font-size:12px}
.list{margin:0;padding-left:18px}
.list__item{display:flex;justify-content:space-between;gap:10px;padding:4px 0}
.stamp{
  display:inline-block;
  font-weight:900;
  letter-spacing:.7px;
  padding:6px 10px;
  border-radius: 10px;
  border: 2px solid rgba(32,26,21,.25);
  transform: rotate(-1.2deg);
  opacity:.85;
}
.footer{margin-top:18px;text-align:center;color:rgba(242,230,201,.85)}
.actions{margin-top:10px}


/* v3 additions */
.navline{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.sep{opacity:.55}
.list{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.listitem{display:block;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.55);border:1px solid rgba(0,0,0,.12);text-decoration:none;color:var(--ink)}
.listitem:hover{transform:translateY(-1px)}
.listitem__title{font-weight:900}
.listitem__sub{opacity:.75;font-size:13px;margin-top:2px}
.records{margin-top:10px;display:flex;flex-direction:column;gap:12px}
.record{background:rgba(255,255,255,.62);border:1px solid rgba(0,0,0,.12);border-radius:16px;padding:12px}
.record__top{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.record__content{margin-top:8px;line-height:1.45}


/* Attachments */
.record__files{margin-top:10px;padding-top:10px;border-top:1px dashed rgba(0,0,0,.25)}
.filelist{margin:0;padding-left:18px}
.filelist li{margin:6px 0}
.uploadform{margin-top:10px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}


/* Image preview modal */
.modal{display:none;position:fixed;inset:0;z-index:9999}
.modal.is-open{display:block}
.modal__backdrop{position:absolute;inset:0;background:rgba(10,8,6,.65)}
.modal__dialog{position:relative;max-width:980px;margin:6vh auto;padding:0 14px}
.modal__header{display:flex;align-items:center;justify-content:space-between;gap:10px;background:rgba(242,230,201,.98);border:2px solid rgba(0,0,0,.18);border-bottom:none;border-radius:16px 16px 0 0;padding:10px 12px}
.modal__title{font-weight:900;color:var(--ink)}
.modal__close{appearance:none;border:0;background:transparent;font-size:18px;cursor:pointer;color:var(--ink);padding:4px 8px;border-radius:10px}
.modal__close:hover{background:rgba(0,0,0,.06)}
.modal__content{background:rgba(242,230,201,.98);border:2px solid rgba(0,0,0,.18);border-radius:0 0 16px 16px;padding:12px}
.modal__content img{display:block;width:100%;height:auto;border-radius:12px;border:1px solid rgba(0,0,0,.18);background:rgba(255,255,255,.55)}
body.modal-open{overflow:hidden}


/* Typography */
h1,h2{font-family:var(--font-west);letter-spacing:.5px}
h3,h4,h5,h6,.section-title,.brand{font-family:var(--font-west);letter-spacing:.3px}
label,.muted,.small, input, textarea, select, button{font-family:var(--font-body)}

/* Thumbnails */
.thumb{
  width:56px;
  height:42px;
  object-fit:cover;
  border-radius:6px;
  border:1px solid rgba(0,0,0,.18);
  box-shadow:0 2px 8px rgba(0,0,0,.18);
  vertical-align:middle;
  margin-right:8px;
}

/* Modal default */
.modal{display:none}
.modal.is-open{display:flex}


/* Enzyklopädie */
.list{display:flex;flex-direction:column;gap:10px}
.list__item{background:rgba(255,255,255,.55);border:1px solid rgba(0,0,0,.12);border-radius:14px;padding:12px}
.list__title{font-weight:700;margin-bottom:6px}
.list__text{color:rgba(0,0,0,.78);white-space:normal}
.details{margin-top:8px}
.details summary{cursor:pointer;font-weight:700}
.details__body{margin-top:8px}
.kv__k{font-weight:700;color:rgba(0,0,0,.7)}
.kv__v{white-space:normal}
.pager{display:flex;gap:10px;align-items:center;margin-top:12px}
.is-disabled{pointer-events:none;opacity:.5}


/* Enzyklopädie helpers */
.list{list-style:none;padding-left:0;margin:0}
.list-item{padding:12px 0;border-bottom:1px dashed rgba(0,0,0,.18)}
.list-item:last-child{border-bottom:none}
.list-head{display:flex;gap:12px;align-items:center}
.list-title{font-weight:700}
.link{background:none;border:none;padding:0;margin:0;color:var(--accent);text-decoration:underline;cursor:pointer;font:inherit}
.link:hover{filter:brightness(.85)}
.details{margin-top:10px}

.pager{display:flex;justify-content:space-between;align-items:center;margin-top:14px}
.pager-btns{display:flex;gap:8px;align-items:center}

/* Admin tables */
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid rgba(0,0,0,.08);vertical-align:top;text-align:left}
.table th{font-weight:700;color:rgba(0,0,0,.7)}
.check{display:flex;align-items:center;gap:6px;padding:2px 6px;border-radius:8px;background:rgba(255,255,255,.55)}
.check input{accent-color:var(--accent)}
.check span{font-size:12px;color:rgba(0,0,0,.8)}

.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.formgrid .label span{display:block;margin-bottom:6px;font-size:12px;opacity:.85}

/* ============================
   v19 — UI Polish
   ============================ */

/* Layout helpers used across pages */
.header{margin:8px 0 14px}
.header h1{margin:0 0 6px;font-size:34px}
.header h2{margin:0 0 6px}
.hr{border:0;border-top:1px dashed rgba(0,0,0,.25);margin:14px 0}

.topbar__right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width: 980px){.grid2{grid-template-columns:1fr}}

/* Card variants used in some pages */
.card--ok{border-color: rgba(43,107,59,.45);background: linear-gradient(180deg, rgba(242,230,201,.98), rgba(220,242,228,.55))}
.card--danger{border-color: rgba(139,43,43,.45);background: linear-gradient(180deg, rgba(242,230,201,.98), rgba(255,220,220,.45))}

/* Softer lists */
.listitem{transition:transform .08s ease, box-shadow .12s ease}
.listitem:hover{box-shadow:0 10px 18px rgba(0,0,0,.12)}

/* Forms */
textarea.input{resize:vertical;min-height:96px}
select.input{cursor:pointer}

/* Tables (admin pages) */
.table{width:100%;border-collapse:separate;border-spacing:0;margin-top:10px}
.table th,.table td{padding:10px 12px;border-top:1px solid rgba(0,0,0,.12);text-align:left;vertical-align:top}
.table th{border-top:none;font-weight:900;color:rgba(0,0,0,.7)}
.table tr:hover td{background:rgba(255,255,255,.35)}

/* Modal: force consistent behavior (previous rules are overridden) */
.modal{display:none !important;position:fixed;inset:0;z-index:9999;align-items:flex-start;justify-content:center}
.modal.is-open{display:flex !important}
.card__head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:6px}
.meta{font-size:12px;opacity:.78}

/* ============================
   v20 — Admin UI Polish
   ============================ */

/* Admin toolbars (search + actions) */
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:10px}
.toolbar .input{min-width:240px}

/* Card header alias (some admin pages used card__header) */
.card__header{font-weight:900;font-size:16px;margin-bottom:10px;letter-spacing:.3px}

/* Topbar fallback for older pages */
.topbar .right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}


/* v21 Admin Dashboard */
.tilegrid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap:14px;
}
.tile{
  display:block;
  background: rgba(255,255,255,.72);
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  padding:14px 14px 12px;
  text-decoration:none;
  color:inherit;
  box-shadow: 0 8px 18px rgba(0,0,0,.06);
  transition: transform .08s ease, box-shadow .08s ease;
}
.tile:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(0,0,0,.08);
}
.tile__title{
  font-family:"Go2OldWestern","OldTown", ui-serif, Georgia, "Times New Roman", serif;
  font-size: 1.05rem;
  letter-spacing:.5px;
}
.tile__meta{ margin-top:6px; }
.mt{ margin-top:14px; }
.bullets{ margin:0; padding-left:18px; }
.bullets li{ margin:6px 0; }

/* Cache bust helper (keep existing) */

/* =========================
   Encyclopedia (final KV)
   ========================= */

/* Wrapper der Detailkarte (falls vorhanden) – optional */
.enc-details {
  margin-top: 14px;
}

/* Key/Value table: nutzt volle Breite, ohne Buchstaben-Umbruch */
.kv {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed; /* wichtig: value nimmt Restbreite */
}

.kv th,
.kv td {
  padding: 8px 10px;
  vertical-align: top;
}

.kv th {
  width: 220px;              /* Label-Spalte fix */
  font-weight: 700;
  opacity: 0.92;
  white-space: normal;       /* darf umbrechen (lange Labels ok) */
}

.kv td {
  max-width: 0;              /* nötig für table-layout:fixed */
  white-space: normal;       /* verhindert "I n f e k t i o n" */
  overflow-wrap: break-word; /* bricht nur lange Wörter */
  word-break: normal;        /* KEIN buchstabenweiser Umbruch */
  line-height: 1.35;
}

/* Kleine optische Trennung zwischen KV-Reihen */
.kv tr + tr th,
.kv tr + tr td {
  border-top: 1px dashed rgba(0,0,0,0.15);
}

/* Mobile: Labels oben, Values drunter (lesbarer) */
@media (max-width: 720px) {
  .kv, .kv tbody, .kv tr, .kv th, .kv td {
    display: block;
    width: 100%;
  }
  .kv tr {
    padding: 8px 0;
  }
  .kv th {
    width: 100%;
    padding-bottom: 4px;
  }
  .kv td {
    padding-top: 0;
    max-width: none;
  }
}
