/* =====================================================================
   QAMI PLUS  -  Stylesheet  (leichtgewichtig, ohne externe Schriften)
===================================================================== */
:root{
  --blue:#0d6e8c; --blue-d:#0a5066; --green:#1f9e6e; --green-d:#157a54;
  --bg:#f4f7f8; --card:#ffffff; --ink:#16323a; --muted:#5d7480;
  --line:#e2eaed; --shadow:0 2px 10px rgba(13,110,140,.08);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Segoe UI","Tahoma",system-ui,-apple-system,sans-serif;
  background:var(--bg); color:var(--ink); line-height:1.6; font-size:16px;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---- Kopfzeile ---- */
.topbar{
  background:linear-gradient(135deg,var(--blue),var(--green));
  color:#fff; padding:14px 16px; box-shadow:var(--shadow);
  position:sticky; top:0; z-index:50;
}
.topbar .wrap{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:12px;justify-content:space-between}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.25rem;letter-spacing:.5px}
.brand .logo{background:#fff;color:var(--blue);width:38px;height:38px;border-radius:10px;
  display:grid;place-items:center;font-weight:900}
.topbar .tools{display:flex;gap:8px;align-items:center}
.btn-lang,.btn-admin{
  background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.35);
  padding:7px 12px;border-radius:9px;font-size:.9rem;cursor:pointer
}
.btn-lang:hover,.btn-admin:hover{background:rgba(255,255,255,.30)}

.tagline{max-width:1100px;margin:0 auto;padding:6px 16px;color:var(--muted);font-size:.95rem}

.container{max-width:1100px;margin:0 auto;padding:18px 16px 60px}

/* ---- Startseiten-Karten ---- */
.grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
.sec-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 14px;text-align:center;box-shadow:var(--shadow);
  transition:transform .12s,box-shadow .12s;border-top:4px solid var(--green)
}
.sec-card:nth-child(even){border-top-color:var(--blue)}
.sec-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(13,110,140,.16)}
.sec-card .ic{font-size:2.2rem;margin-bottom:8px}
.sec-card .nm{font-weight:700;font-size:1rem}

/* ---- Seitentitel ---- */
.page-head{display:flex;align-items:center;gap:10px;margin:8px 0 18px}
.page-head .ic{font-size:1.8rem}
.page-head h1{font-size:1.5rem;margin:0}

/* ---- Inhalts-Karten ---- */
.cards{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.item{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px 16px;box-shadow:var(--shadow)
}
.item h3{margin:0 0 8px;font-size:1.12rem;color:var(--blue-d)}
.item .row{display:flex;gap:6px;font-size:.93rem;color:var(--muted);margin:3px 0}
.item .row b{color:var(--ink);font-weight:600}
.item img.thumb{border-radius:10px;margin-bottom:10px;max-height:160px;object-fit:cover;width:100%}
.call{display:inline-block;margin-top:8px;background:var(--green);color:#fff;
  padding:7px 14px;border-radius:9px;font-size:.9rem}
.call:hover{background:var(--green-d)}
.tag{display:inline-block;background:#e7f3ee;color:var(--green-d);
  padding:2px 10px;border-radius:20px;font-size:.78rem;margin-bottom:6px}

/* ---- Gruppen-Ueberschrift (Kategorien) ---- */
.group-title{margin:22px 0 8px;font-size:1.1rem;color:var(--blue-d);
  border-inline-start:4px solid var(--green);padding-inline-start:10px}

/* ---- Tabellen (Preise) ---- */
.ptable{width:100%;border-collapse:collapse;background:var(--card);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.ptable th{background:var(--blue);color:#fff;padding:11px;text-align:start}
.ptable td{padding:11px;border-top:1px solid var(--line)}
.ptable tr:nth-child(even) td{background:#f8fbfc}
.price-val{font-weight:800;color:var(--green-d)}

/* ---- Notfall ---- */
.emerg{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
.emerg a{background:linear-gradient(135deg,#d9342b,#b21f17);color:#fff;border-radius:var(--radius);
  padding:16px;text-align:center;box-shadow:var(--shadow)}
.emerg .num{font-size:1.6rem;font-weight:900;letter-spacing:1px}

/* ---- Filter ---- */
.filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.filters a{background:#fff;border:1px solid var(--line);padding:6px 14px;border-radius:20px;font-size:.9rem}
.filters a.on{background:var(--blue);color:#fff;border-color:var(--blue)}

.empty{padding:40px;text-align:center;color:var(--muted)}

/* =====================  ADMIN  ===================== */
.admin-body{display:flex;min-height:100vh}
.sidebar{width:230px;background:var(--blue-d);color:#fff;flex-shrink:0;padding:16px 0}
.sidebar .s-brand{font-weight:800;font-size:1.2rem;padding:0 18px 14px;border-bottom:1px solid rgba(255,255,255,.15)}
.sidebar a{display:block;padding:11px 18px;color:#dfeef3;font-size:.95rem;border-inline-start:3px solid transparent}
.sidebar a:hover,.sidebar a.on{background:rgba(255,255,255,.08);border-inline-start-color:var(--green)}
.sidebar .grp{font-size:.72rem;text-transform:uppercase;color:#7fb6c7;padding:14px 18px 4px;letter-spacing:1px}
.admin-main{flex:1;background:var(--bg);min-width:0}
.admin-top{background:#fff;padding:12px 22px;display:flex;justify-content:space-between;align-items:center;
  box-shadow:var(--shadow);position:sticky;top:0;z-index:10}
.admin-top .who{color:var(--muted);font-size:.9rem}
.admin-content{padding:22px}
.cards-stat{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));margin-bottom:10px}
.stat{background:#fff;border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);border-top:4px solid var(--green)}
.stat .n{font-size:2rem;font-weight:900;color:var(--blue-d)}
.stat .l{color:var(--muted);font-size:.9rem}

table.data{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
table.data th{background:#eef4f6;text-align:start;padding:10px;font-size:.85rem;color:var(--muted)}
table.data td{padding:10px;border-top:1px solid var(--line);font-size:.92rem}
.btn{display:inline-block;background:var(--blue);color:#fff;border:none;padding:9px 16px;border-radius:9px;cursor:pointer;font-size:.92rem}
.btn:hover{background:var(--blue-d)}
.btn.green{background:var(--green)}.btn.green:hover{background:var(--green-d)}
.btn.red{background:#c0392b}.btn.red:hover{background:#962d22}
.btn.sm{padding:5px 10px;font-size:.82rem}
.btn.ghost{background:#fff;color:var(--blue);border:1px solid var(--line)}

.form-card{background:#fff;border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);max-width:640px}
.form-card label{display:block;margin:12px 0 4px;font-weight:600;font-size:.9rem}
.form-card input,.form-card textarea,.form-card select{
  width:100%;padding:10px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fbfdfe}
.form-card textarea{min-height:80px;resize:vertical}
.form-actions{margin-top:18px;display:flex;gap:10px}
.flash{background:#e7f3ee;color:var(--green-d);padding:10px 14px;border-radius:9px;margin-bottom:14px}
.flash.err{background:#fde8e6;color:#962d22}

.login-wrap{min-height:100vh;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--blue),var(--green));padding:20px}
.login-box{background:#fff;border-radius:18px;padding:30px;width:100%;max-width:360px;box-shadow:0 12px 40px rgba(0,0,0,.2)}
.login-box h1{margin:0 0 4px;text-align:center;color:var(--blue-d)}
.login-box p{text-align:center;color:var(--muted);margin:0 0 18px;font-size:.9rem}

/* ---- Responsive ---- */
@media(max-width:760px){
  .admin-body{flex-direction:column}
  .sidebar{width:100%;display:flex;flex-wrap:wrap;padding:8px}
  .sidebar .s-brand,.sidebar .grp{width:100%}
  .sidebar a{border-inline-start:none;border-radius:8px}
  .grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}
  .brand{font-size:1.05rem}
  table.data{display:block;overflow-x:auto}
}
