/* contacura Portal — CI übernommen von www.contacura.work */
:root{
  --navy:#003966; --navy-d:#00263f; --accent:#1769a8;
  --petrol:#bed6d7; --petrol-l:#e7f1f2;
  --ink:#2a3640; --muted:#5a6772; --line:#e3e9ec; --soft:#f2f4f5;
  --ok:#1c7c43; --ok-bg:#e6f4ec; --warn:#9a6b00; --warn-bg:#fdf3dc; --err:#a3242c; --err-bg:#fbe9ea;
  --maxw:1720px;
  --f:'Source Sans 3',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--f);font-size:16px;line-height:1.6;color:var(--ink);background:var(--soft);-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{color:var(--navy);line-height:1.2;margin:0 0 .45em;font-weight:700}
h1{font-size:clamp(24px,3vw,32px)}h2{font-size:21px}h3{font-size:17px}
p{margin:0 0 1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px}
.acc{width:54px;height:4px;background:var(--accent);border-radius:3px;margin:0 0 20px}

/* ---- Topbar ---- */
.topbar{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.topbar .row{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:72px}
.topbar .logo{height:40px;width:auto;display:block}
.mainnav{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.mainnav a{font-weight:600;color:var(--ink);font-size:15px;padding:8px 13px;border-radius:6px}
.mainnav a:hover{background:var(--petrol-l);color:var(--navy);text-decoration:none}
.mainnav a.active{background:var(--navy);color:#fff}
.subnav{background:var(--soft);border-bottom:1px solid var(--line)}
.subnav .subnav-row{display:flex;gap:4px;overflow-x:auto;padding:7px 0;-webkit-overflow-scrolling:touch}
.subnav a{white-space:nowrap;color:var(--navy);font-weight:600;font-size:13.5px;padding:6px 12px;border-radius:8px}
.subnav a:hover{background:#fff;text-decoration:none}
.subnav a.active{background:var(--navy);color:#fff}
.userbox{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--muted)}
.userbox b{color:var(--navy)}

/* ---- Zahnrad-Untermenü Administration ---- */
.gearmenu{position:relative}
.gearmenu summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:7px;
  font-weight:600;color:var(--ink);font-size:15px;padding:8px 13px;border-radius:6px;user-select:none}
.gearmenu summary::-webkit-details-marker{display:none}
.gearmenu summary:hover{background:var(--petrol-l);color:var(--navy)}
.gearmenu summary.active,.gearmenu[open] summary{background:var(--navy);color:#fff}
.gearmenu summary svg{width:17px;height:17px;flex:none}
.gearmenu-dd{position:absolute;top:calc(100% + 6px);left:0;min-width:190px;background:#fff;
  border:1px solid var(--line);border-radius:10px;box-shadow:0 16px 38px -18px rgba(0,42,77,.45);
  padding:6px;z-index:60;display:flex;flex-direction:column}
.gearmenu-dd a{font-weight:600;color:var(--ink);font-size:14.5px;padding:9px 13px;border-radius:7px}
.gearmenu-dd a:hover{background:var(--petrol-l);color:var(--navy);text-decoration:none}
.gearmenu-dd a.active{background:var(--navy);color:#fff}
@media(max-width:760px){.gearmenu-dd{position:static;box-shadow:none;border:0;padding:0 0 0 22px}}
.btn-out{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:13.5px;padding:8px 14px;
  border-radius:6px;border:1.5px solid var(--navy);background:#fff;color:var(--navy);transition:.15s;white-space:nowrap}
.btn-out:hover{background:var(--navy);color:#fff;text-decoration:none}

/* ---- Layout ---- */
.main{padding:34px 0 60px}
.pagehead{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:22px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;box-shadow:0 10px 30px -24px rgba(0,42,77,.5);margin-bottom:22px}
.card.tight{padding:0;overflow:hidden}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media(max-width:900px){.grid2,.grid3,.grid4{grid-template-columns:1fr}}

/* ---- Kennzahlen ---- */
.stat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 22px;box-shadow:0 10px 30px -24px rgba(0,42,77,.5)}
.stat .num{font-size:34px;font-weight:700;color:var(--navy);line-height:1.1}
.stat .lbl{font-size:13.5px;color:var(--muted);font-weight:600;letter-spacing:.03em;text-transform:uppercase;margin-top:4px}
.stat.hl{background:var(--navy)}.stat.hl .num{color:#fff}.stat.hl .lbl{color:var(--petrol)}

/* ---- Tabellen ---- */
table.list{width:100%;border-collapse:collapse;font-size:15px}
table.list th{background:var(--petrol-l);color:var(--navy);text-align:left;font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;padding:11px 16px;border-bottom:1px solid var(--line)}
table.list td{padding:12px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
table.list tr:last-child td{border-bottom:0}
table.list tr:hover td{background:#f8fbfc}
tr.unread td{font-weight:600}
tr.unread td:first-child{position:relative}
tr.unread td:first-child::before{content:"";position:absolute;left:4px;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--accent)}

/* ---- Badges ---- */
.badge{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.04em;padding:3px 10px;border-radius:999px}
.badge.new{background:var(--accent);color:#fff}
.badge.ok{background:var(--ok-bg);color:var(--ok)}
.badge.warn{background:var(--warn-bg);color:var(--warn)}
.badge.err{background:var(--err-bg);color:var(--err)}
.badge.muted{background:var(--soft);color:var(--muted)}

/* ---- Buttons & Formulare ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:700;font-size:14px;letter-spacing:.05em;
  padding:12px 22px;border-radius:6px;border:2px solid var(--navy);background:var(--navy);color:#fff;cursor:pointer;transition:.16s;font-family:inherit}
.btn:hover{background:#fff;color:var(--navy);text-decoration:none}
.btn.ghost{background:#fff;color:var(--navy)}
.btn.ghost:hover{background:var(--petrol-l)}
.btn.sm{padding:7px 14px;font-size:13px;border-width:1.5px}
.btn.danger{border-color:var(--err);background:var(--err)}
.btn.danger:hover{background:#fff;color:var(--err)}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:6px;color:var(--navy)}
.field input,.field select,.field textarea{width:100%;font:inherit;font-size:15.5px;padding:11px 13px;border:1.5px solid var(--line);border-radius:8px;background:#fcfdfd;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:#fff}
.field .hint{font-size:13px;color:var(--muted);margin-top:5px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:700px){.row2{grid-template-columns:1fr}}

/* ---- Flash ---- */
.flash{border-radius:10px;padding:13px 18px;margin-bottom:18px;font-weight:600;font-size:15px;border:1px solid}
.flash.ok{background:var(--ok-bg);color:var(--ok);border-color:#bfe3cd}
.flash.warn{background:var(--warn-bg);color:var(--warn);border-color:#f1dfb0}
.flash.err{background:var(--err-bg);color:var(--err);border-color:#f0c4c7}

/* ---- Login ---- */
body.authpage{background:linear-gradient(150deg,var(--navy-d) 0%,var(--navy) 55%,#0a4a7e 100%);min-height:100vh;display:flex;flex-direction:column}
.authwrap{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px}
.authcard{background:#fff;border-radius:16px;padding:38px;width:100%;max-width:420px;box-shadow:0 30px 70px -30px rgba(0,12,24,.7)}
.authcard .logo{height:46px;margin:0 auto 22px;display:block}
.authcard h1{font-size:22px;text-align:center}
.authcard .sub{text-align:center;color:var(--muted);font-size:14.5px;margin-bottom:24px}
.authfoot{text-align:center;color:#9db4c6;font-size:13px;padding:18px}
.authfoot a{color:#cdd9e3}
.authlinks{text-align:center;margin-top:18px;font-size:14px}

/* ---- 2FA / QR ---- */
.qrbox{display:flex;gap:26px;align-items:flex-start;flex-wrap:wrap}
.qrbox svg{border:1px solid var(--line);border-radius:10px}
.secretcode{font-family:ui-monospace,Consolas,monospace;font-size:15px;background:var(--petrol-l);border:1px solid #d4e6e7;border-radius:8px;padding:10px 14px;letter-spacing:.08em;word-break:break-all;color:var(--navy)}
.codeinput{font-size:26px !important;letter-spacing:.35em;text-align:center;font-family:ui-monospace,Consolas,monospace}

/* ---- Tabs (document.php) ---- */
.tabs{display:inline-flex;background:var(--soft);border:1px solid var(--line);border-radius:999px;padding:5px;gap:4px;margin-bottom:18px}
.tab{border:0;background:transparent;font:inherit;font-weight:700;color:var(--muted);padding:8px 20px;border-radius:999px;cursor:pointer;font-size:14px}
.tab.active{background:var(--navy);color:#fff}
.tabpane{display:none}.tabpane.active{display:block}

/* ---- Footer ---- */
.footer{background:var(--navy-d);color:#aebfcd;padding:22px 0;font-size:13.5px;margin-top:auto}
.footer .row{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
.footer a{color:#cdd9e3}

/* ---- Diverses ---- */
.muted{color:var(--muted)}
.small{font-size:13.5px}
.nowrap{white-space:nowrap}
.right{text-align:right}
.empty{padding:46px 20px;text-align:center;color:var(--muted)}
.empty svg{width:44px;height:44px;color:var(--petrol);margin-bottom:10px}
.pager{display:flex;gap:8px;justify-content:center;margin-top:18px}
.pager a,.pager span{padding:7px 13px;border:1px solid var(--line);border-radius:7px;background:#fff;font-weight:600;font-size:14px}
.pager span.cur{background:var(--navy);color:#fff;border-color:var(--navy)}
.filterbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.filterbar input,.filterbar select{font:inherit;font-size:14.5px;padding:9px 12px;border:1.5px solid var(--line);border-radius:8px;background:#fff}
@media(max-width:760px){
  .topbar .row{flex-wrap:wrap;padding:10px 0}
  .mainnav{order:3;width:100%;padding-bottom:8px}
  table.list{font-size:14px}
  table.list th,table.list td{padding:9px 10px}
  .hide-m{display:none}
}

/* Matchcode-Combobox */
.ccb{position:relative}
.ccb-input{width:100%;font:inherit;font-size:14.5px;padding:10px 13px;border:1.5px solid var(--line);border-radius:8px;background:#fff}
.ccb-input:focus{outline:none;border-color:var(--accent)}
.ccb-input.ccb-chosen{border-color:var(--ok);background:#f4faf6}
.ccb-list{position:absolute;left:0;right:0;top:calc(100% + 4px);max-height:300px;overflow:auto;background:#fff;
  border:1.5px solid var(--line);border-radius:10px;box-shadow:0 14px 34px -14px rgba(0,20,45,.35);z-index:40}
.ccb-item{padding:9px 13px;cursor:pointer;font-size:14.5px;border-bottom:1px solid var(--bg)}
.ccb-item:hover{background:var(--petrol-l)}
.ccb-item:last-child{border-bottom:none}
.ccb-extra{color:var(--muted);font-size:13px}
.ccb-sub{color:var(--muted);font-size:12.5px;margin-top:2px}
.ccb-none{color:var(--muted);cursor:default}
.ccb-none:hover{background:none}

.navbadge{display:inline-block;background:var(--accent);color:#fff;border-radius:99px;font-size:11.5px;
  font-weight:700;padding:1px 7px;margin-left:4px;vertical-align:1px}
