/* =====================================================================
   Pfarrbrief-Druckerei – Admin-Stylesheet (eigenständig)
   Warmes, kirchlich-modernes Backend: Tannengrün + Pergament-Creme.
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

:root{
  --green:#5a8f3c; --green-dark:#3f6a28; --green-deep:#2c4d1c;
  --cream:#ece4d2; --cream-soft:#f5f1e6; --paper:#fbfaf4;
  --ink:#23291d; --ink-soft:#5e6553; --line:#ddd6c4; --white:#fff;
  --danger:#9b2c2c; --danger-bg:#fdeaea; --danger-line:#f0c3c3;
  --ok-bg:#eaf4e3; --ok-line:#bcd9a8; --ok-ink:#34601f;
  --radius:15px; --radius-sm:10px;
  --shadow:0 14px 40px rgba(45,55,30,.10);
}

*{box-sizing:border-box;margin:0;padding:0}
body.admin{
  font-family:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:var(--cream-soft);color:var(--ink);line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:600;letter-spacing:-.01em;line-height:1.2}
a{color:var(--green-dark)}
code{background:#efece1;padding:1px 6px;border-radius:5px;font-size:.85em;
     font-family:ui-monospace,SFMono-Regular,Menlo,monospace}

/* ---------- Grundgerüst ---------- */
.admin-shell{display:flex;min-height:100vh}

/* ---------- Seitenleiste ---------- */
.admin-side{
  width:248px;flex-shrink:0;background:var(--green-deep);color:#e9efe2;
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;
}
.admin-brand{
  display:flex;align-items:center;gap:11px;padding:22px 22px 18px;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.admin-brand .ab-mark{
  width:30px;height:30px;border-radius:8px;flex-shrink:0;
  background:linear-gradient(135deg,var(--green) 0%,#7fb15f 100%);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.18);
}
.admin-brand span{font-family:"Fraunces",Georgia,serif;font-size:1.05rem;line-height:1.15}
.admin-brand small{display:block;font-family:"Hanken Grotesk",sans-serif;
  font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  color:#a9c096;font-weight:600;margin-top:2px}
.admin-side nav{padding:14px 12px;flex:1;overflow-y:auto}
.admin-side nav a{
  display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;
  color:#d4e0c8;text-decoration:none;font-size:.92rem;font-weight:500;
  margin-bottom:2px;transition:background .13s ease,color .13s ease;
}
.admin-side nav a:hover{background:rgba(255,255,255,.07);color:#fff}
.admin-side nav a.active{background:var(--green);color:#fff;font-weight:600}
.admin-side nav a .ni{
  width:22px;text-align:center;font-size:.95rem;opacity:.85;flex-shrink:0;
}
.admin-side nav a .badge{
  margin-left:auto;background:#e6b34a;color:#3a2c08;font-size:.72rem;font-weight:800;
  min-width:20px;height:20px;border-radius:20px;display:flex;align-items:center;
  justify-content:center;padding:0 6px;
}
.admin-side-foot{
  padding:14px 16px;border-top:1px solid rgba(255,255,255,.10);
  display:flex;flex-direction:column;gap:4px;
}
.admin-side-foot a{
  color:#b9cca8;text-decoration:none;font-size:.84rem;padding:5px 0;
}
.admin-side-foot a:hover{color:#fff}

/* ---------- Hauptbereich ---------- */
.admin-main{flex:1;min-width:0;display:flex;flex-direction:column}
.admin-top{
  background:var(--paper);border-bottom:1px solid var(--line);
  padding:18px 32px;display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:10;
}
.admin-top h1{font-size:1.4rem}
.admin-user{font-size:.86rem;color:var(--ink-soft)}
.admin-content{padding:28px 32px;max-width:1080px}

/* ---------- Statuskarten ---------- */
.stat-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));
  gap:16px;margin-bottom:26px;
}
.stat-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 20px;display:flex;flex-direction:column;gap:3px;
}
.stat-card.highlight{
  background:linear-gradient(150deg,#5a8f3c 0%,#456f2e 100%);
  border-color:transparent;color:#fff;
}
.stat-num{font-family:"Fraunces",Georgia,serif;font-size:2rem;font-weight:600;line-height:1}
.stat-label{font-size:.82rem;color:var(--ink-soft);text-transform:uppercase;
  letter-spacing:.04em;font-weight:600}
.stat-card.highlight .stat-label{color:rgba(255,255,255,.85)}
.stat-card.highlight a{color:#fff;font-size:.85rem;font-weight:600;
  text-decoration:none;margin-top:6px;opacity:.92}
.stat-card.highlight a:hover{opacity:1;text-decoration:underline}

/* ---------- Panels ---------- */
.panel{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 22px;margin-bottom:22px;
}
.panel-head{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  margin-bottom:14px;
}
.panel-head h2{font-size:1.12rem}

/* ---------- Tabellen ---------- */
.table-wrap{overflow-x:auto;border-radius:var(--radius-sm)}
.data-table{width:100%;border-collapse:collapse;font-size:.9rem}
.data-table th,.data-table td{
  text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);
  vertical-align:top;
}
.data-table thead th{
  font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;
  color:var(--ink-soft);font-weight:700;background:var(--cream-soft);
}
.data-table tbody tr:hover{background:var(--cream-soft)}
.data-table tbody tr:last-child td{border-bottom:0}
.data-table small{color:var(--ink-soft)}
.nowrap{white-space:nowrap}
.ta-r{text-align:right}
.empty{text-align:center;color:var(--ink-soft);font-style:italic;padding:22px 12px}

/* ---------- Status-Punkte ---------- */
.dot{
  display:inline-block;padding:3px 10px;border-radius:20px;font-size:.76rem;
  font-weight:700;line-height:1.4;
}
.dot.on{background:var(--ok-bg);color:var(--ok-ink);border:1px solid var(--ok-line)}
.dot.off{background:#eceae0;color:#73796a;border:1px solid var(--line)}

/* ---------- Buttons ---------- */
.btn-sm{
  display:inline-block;padding:7px 14px;border-radius:8px;font-size:.84rem;
  font-weight:600;text-decoration:none;cursor:pointer;border:1px solid var(--line);
  background:var(--white);color:var(--ink);transition:background .12s ease,
  border-color .12s ease,transform .1s ease;line-height:1.4;
}
.btn-sm:hover{background:var(--cream-soft)}
.btn-sm:active{transform:translateY(1px)}
.btn-sm.primary{background:var(--green);border-color:var(--green);color:#fff}
.btn-sm.primary:hover{background:var(--green-dark);border-color:var(--green-dark)}
.btn-sm.danger{background:var(--white);border-color:var(--danger-line);color:var(--danger)}
.btn-sm.danger:hover{background:var(--danger-bg)}
.btn-sm.big{padding:11px 24px;font-size:.95rem}

/* ---------- Flash / Hinweise ---------- */
.flash{
  padding:12px 16px;border-radius:var(--radius-sm);font-size:.9rem;
  margin-bottom:18px;font-weight:500;
}
.flash.ok{background:var(--ok-bg);color:var(--ok-ink);border:1px solid var(--ok-line)}
.flash.err{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-line)}
.crud-intro{color:var(--ink-soft);font-size:.92rem;margin-bottom:18px;max-width:680px}
.hint-text{color:var(--ink-soft);font-size:.85rem;margin-top:14px}
.hint-text code{font-size:.85em}

/* ---------- CRUD-Leiste ---------- */
.crud-bar{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  margin-bottom:16px;flex-wrap:wrap;
}
.crud-bar span{font-size:.86rem;color:var(--ink-soft)}

/* ---------- Formulare ---------- */
.crud-form{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 26px;max-width:680px;
}
.crud-form h2{font-size:1.15rem;margin-bottom:18px}
.field{margin-bottom:16px}
.field label{
  display:block;font-weight:600;font-size:.86rem;margin-bottom:5px;
}
.field .req{color:var(--danger)}
.field input[type=text],.field input[type=number],.field input[type=password],
.field textarea,.field select{
  width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;
  font-size:.93rem;background:var(--paper);font-family:inherit;color:var(--ink);
}
.field textarea{resize:vertical;line-height:1.5}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:2px solid var(--green);outline-offset:0;border-color:var(--green);
}
.field-hint{display:block;font-size:.78rem;color:var(--ink-soft);margin-top:4px}
.switch{display:flex;align-items:center;gap:9px;font-weight:500!important;cursor:pointer}
.switch input{width:18px;height:18px;accent-color:var(--green);cursor:pointer}
.form-actions{
  display:flex;gap:10px;align-items:center;margin-top:22px;
  padding-top:18px;border-top:1px solid var(--line);
}

/* ---------- System-Grid (Dashboard) ---------- */
.sys-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;
}
.sys-grid>div{
  background:var(--cream-soft);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:14px 16px;display:flex;flex-direction:column;gap:8px;
}
.sys-grid span{font-size:.78rem;color:var(--ink-soft);text-transform:uppercase;
  letter-spacing:.04em;font-weight:600}
.sys-grid strong{font-size:1rem}

/* ---------- Detailansicht (Anfragen) ---------- */
.detail-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;
}
.detail-grid>div{display:flex;flex-direction:column;gap:3px}
.detail-grid span{font-size:.76rem;color:var(--ink-soft);text-transform:uppercase;
  letter-spacing:.04em;font-weight:600}
.detail-grid strong{font-size:.98rem;font-weight:600}
.quote-message{
  background:var(--cream-soft);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:14px 16px;font-size:.92rem;line-height:1.6;
}
.inline-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.inline-form select{
  padding:9px 12px;border:1px solid var(--line);border-radius:9px;
  font-size:.9rem;background:var(--paper);font-family:inherit;
}

/* ---------- Filter-Chips ---------- */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.chip{
  padding:6px 14px;border-radius:20px;font-size:.84rem;font-weight:600;
  text-decoration:none;background:var(--white);border:1px solid var(--line);
  color:var(--ink-soft);
}
.chip:hover{background:var(--cream-soft)}
.chip.active{background:var(--green);border-color:var(--green);color:#fff}

/* ---------- Einstellungen ---------- */
.settings-form{max-width:720px}
.settings-group{
  border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:18px 20px;margin-bottom:20px;
}
.settings-group legend{
  font-family:"Fraunces",Georgia,serif;font-weight:600;font-size:1.02rem;
  padding:0 10px;color:var(--green-deep);
}
.key-tag{
  font-size:.72em;background:#efece1;color:var(--ink-soft);padding:1px 6px;
  border-radius:5px;font-weight:500;margin-left:6px;
}
.color-field{display:flex;gap:10px;align-items:center}
.color-field input[type=color]{
  width:54px;height:42px;padding:3px;border:1px solid var(--line);
  border-radius:9px;background:var(--paper);cursor:pointer;
}
.color-field .color-hex{max-width:160px}

/* ---------- Login ---------- */
.login-page{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:32px 18px;background:
    radial-gradient(circle at 30% 20%,rgba(90,143,60,.14),transparent 55%),
    var(--cream-soft);
}
.login-card{
  width:100%;max-width:380px;background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:32px 30px;
}
.login-card .login-brand{
  display:flex;align-items:center;gap:10px;margin-bottom:22px;flex-wrap:wrap;
}
.login-card .ab-mark{
  width:32px;height:32px;border-radius:8px;flex-shrink:0;
  background:linear-gradient(135deg,var(--green) 0%,#7fb15f 100%);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.18);
}
.login-card .login-brand strong{
  font-family:"Fraunces",Georgia,serif;font-size:1.15rem;font-weight:600;
}
.login-card .login-brand small{
  font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;
}
.login-card label{
  display:block;font-weight:600;font-size:.86rem;margin:14px 0 5px;
}
.login-card input{
  width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;
  font-size:.93rem;background:var(--paper);font-family:inherit;color:var(--ink);
}
.login-card input:focus{outline:2px solid var(--green);border-color:var(--green)}
.login-card button{width:100%;margin-top:18px}
.login-card .login-back{
  display:block;text-align:center;margin-top:16px;font-size:.85rem;
  color:var(--ink-soft);text-decoration:none;
}
.login-card .login-back:hover{color:var(--green-dark)}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .admin-shell{flex-direction:column}
  .admin-side{
    width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;
    align-items:center;
  }
  .admin-brand{border-bottom:0;padding:14px 18px}
  .admin-side nav{
    display:flex;flex-wrap:wrap;gap:4px;padding:8px 12px;width:100%;
    border-top:1px solid rgba(255,255,255,.10);
  }
  .admin-side nav a{margin-bottom:0}
  .admin-side-foot{
    flex-direction:row;width:100%;border-top:1px solid rgba(255,255,255,.10);
    gap:16px;
  }
  .admin-top{padding:14px 18px}
  .admin-content{padding:18px}
}

/* ---- Posteingang (IMAP) -------------------------------------------- */
.mail-unread td{font-weight:700}
.mail-body{
  white-space:pre-wrap;word-break:break-word;font-family:inherit;
  font-size:.92rem;line-height:1.6;color:var(--ink,#23291f);
  background:#faf8f1;border:1px solid var(--line,#d8d2c2);
  border-radius:10px;padding:14px 16px;max-height:520px;overflow:auto;margin:0;
}

/* ---- CRUD: Bild- & Relationsfelder -------------------------------- */
.list-thumb{max-width:54px;max-height:40px;border-radius:4px;border:1px solid var(--line,#d8d2c2)}
.img-preview{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.img-preview img{max-width:90px;max-height:70px;border-radius:6px;border:1px solid var(--line,#d8d2c2);background:#fff}
.img-remove{font-size:.84rem;color:#6b7363;display:flex;align-items:center;gap:5px}
.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px 14px}
.checkbox-item{display:flex;align-items:center;gap:7px;font-size:.92rem;cursor:pointer}
.checkbox-item input{flex:none}

/* ---- Kundenrabatt ------------------------------------------------- */
.discount-options{display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.discount-chip{
  display:inline-flex;align-items:center;gap:6px;padding:6px 12px;
  border:1.5px solid var(--line,#d8d2c2);border-radius:999px;cursor:pointer;
  font-size:.9rem;background:#fff;
}
.discount-chip input{flex:none}
.discount-chip:has(input:checked){border-color:var(--green,#5a8f3c);background:#f3f8ee}
.discount-custom{
  padding:7px 10px;border:1.5px solid var(--line,#d8d2c2);border-radius:8px;font:inherit;
}
