/* SSTpool Laravel – gemeinsames Designsystem
   SST-Petrol #0f7f97, an LAMA-App angelehnt, mobil-first, Light+Dark */

:root {
  --sst-petrol:      #0f7f97;
  --sst-petrol-dark: #0b5e70;
  --sst-petrol-50:   #e7f3f6;
  --sst-accent:      #f5a623;

  --bg:        #f4f6f8;
  --surface:   #ffffff;
  --surface-2: #fafbfc;
  --border:    #e2e8ec;
  --text:      #1c2b33;
  --text-mut:  #5b6b75;
  --text-soft: #8a99a3;

  --ok:   #2e9e5b;
  --warn: #f5a623;
  --err:  #d64545;

  /* Badge-Paletten (light) */
  --b-offen-bg:#e7f3f6; --b-offen-fg:#0b5e70;
  --b-arbeit-bg:#fff3df; --b-arbeit-fg:#9a6710;
  --b-erled-bg:#e6f5ec; --b-erled-fg:#2e9e5b;
  --b-pnied-bg:#eef1f3; --b-pnied-fg:#5b6b75;
  --b-pmit-bg:#fff3df;  --b-pmit-fg:#9a6710;
  --b-phoch-bg:#fbe6e6; --b-phoch-fg:#d64545;
  --al-ok-bg:#e6f5ec; --al-ok-fg:#1d7a42; --al-ok-bd:#bce5cd;
  --al-er-bg:#fbe6e6; --al-er-fg:#a83232; --al-er-bd:#f0c4c4;
  --al-in-bg:#e7f3f6; --al-in-fg:#0b5e70; --al-in-bd:#c5e3ea;
  --th-bg:#fafbfc;

  --radius:    10px;
  --radius-sm: 7px;
  --shadow:    0 1px 3px rgba(15,127,151,.08), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md: 0 4px 14px rgba(15,127,151,.12);

  --gutter: 28px;       /* Seitenrand bei voller Breite */
  --form-maxw: 560px;   /* sinnvolle Maximalbreite für Formulare */
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

:root[data-theme="dark"] {
  --sst-petrol:      #2aa6c0;
  --sst-petrol-dark: #15829b;
  --sst-petrol-50:   #16323a;
  --sst-accent:      #f5b94e;

  --bg:        #0e1417;
  --surface:   #161e23;
  --surface-2: #1b252b;
  --border:    #28353c;
  --text:      #e6edf1;
  --text-mut:  #9fb0ba;
  --text-soft: #6f828c;

  --ok:   #46c47e;
  --warn: #f5b94e;
  --err:  #ef6e6e;

  --b-offen-bg:#0f3a45; --b-offen-fg:#7fd4e6;
  --b-arbeit-bg:#3d2f12; --b-arbeit-fg:#f0c574;
  --b-erled-bg:#12351f; --b-erled-fg:#6fd99a;
  --b-pnied-bg:#222d33; --b-pnied-fg:#9fb0ba;
  --b-pmit-bg:#3d2f12;  --b-pmit-fg:#f0c574;
  --b-phoch-bg:#3d1b1b; --b-phoch-fg:#f08a8a;
  --al-ok-bg:#12351f; --al-ok-fg:#7fe0a6; --al-ok-bd:#1f5733;
  --al-er-bg:#3d1b1b; --al-er-fg:#f0a0a0; --al-er-bd:#5c2a2a;
  --al-in-bg:#0f3a45; --al-in-fg:#9fdcec; --al-in-bd:#1c5563;
  --th-bg:#1b252b;

  --shadow:    0 1px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);
  --shadow-md: 0 4px 14px rgba(0,0,0,.45);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font); background: var(--bg); color: var(--text);
  line-height: 1.5; -webkit-font-smoothing: antialiased; font-size: 15px;
  transition: background .15s, color .15s;
}
a { color: var(--sst-petrol); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---- Topbar ---- */
.topbar { background: linear-gradient(135deg, var(--sst-petrol), var(--sst-petrol-dark));
  color: #fff; box-shadow: var(--shadow-md); position: sticky; top: 0; z-index: 50; }
.topbar-inner { display: flex; align-items: center; gap: 16px;
  padding: 0 var(--gutter); height: 56px; }
.brand { display: flex; align-items: center; gap: 9px; font-weight: 700; font-size: 17px; color: #fff; letter-spacing: .2px; }
.brand:hover { text-decoration: none; opacity: .92; }
.brand-mark { width: 28px; height: 28px; border-radius: 7px; background: rgba(255,255,255,.18); display: grid; place-items: center; font-size: 15px; }
.topnav { display: flex; gap: 4px; margin-left: 8px; flex: 1; }
.topnav a { color: rgba(255,255,255,.88); padding: 7px 12px; border-radius: 7px; font-size: 14px; font-weight: 500; }
.topnav a:hover { background: rgba(255,255,255,.14); color: #fff; text-decoration: none; }
.topnav a.active { background: rgba(255,255,255,.22); color: #fff; }
.topbar-user { display: flex; align-items: center; gap: 10px; font-size: 14px; }
.topbar-user .uname { color: rgba(255,255,255,.95); font-weight: 500; }
.topbar-user form { margin: 0; }
.btn-logout { background: rgba(255,255,255,.16); color: #fff; border: none; padding: 6px 12px; border-radius: 7px; font-size: 13px; cursor: pointer; font-family: inherit; }
.btn-logout:hover { background: rgba(255,255,255,.28); }
.theme-toggle { background: rgba(255,255,255,.16); border: none; color: #fff; width: 34px; height: 34px;
  border-radius: 8px; cursor: pointer; display: grid; place-items: center; padding: 0; }
.theme-toggle:hover { background: rgba(255,255,255,.28); }
.theme-toggle .ico-sun { display: none; }
:root[data-theme="dark"] .theme-toggle .ico-sun { display: block; }
:root[data-theme="dark"] .theme-toggle .ico-moon { display: none; }
.nav-toggle { display: none; background: none; border: none; color: #fff; cursor: pointer; padding: 6px; }

/* ---- Layout: volle Breite + Seitenrand ---- */
.wrap { width: 100%; padding: 22px var(--gutter) 60px; }
.page-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.page-title { font-size: 22px; font-weight: 700; margin: 0; color: var(--text); }
.page-sub { color: var(--text-mut); font-size: 14px; margin: 2px 0 0; }
.form-narrow { max-width: var(--form-maxw); }

/* ---- Card ---- */
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 18px; margin-bottom: 16px; }
.card h3 { color: var(--text); }
.card-pad-0 { padding: 0; overflow: hidden; }

/* ---- Buttons ---- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  background: var(--sst-petrol); color: #fff; border: 1px solid var(--sst-petrol);
  padding: 9px 16px; border-radius: var(--radius-sm); font-size: 14px; font-weight: 600;
  cursor: pointer; font-family: inherit; line-height: 1; transition: background .12s; }
.btn:hover { background: var(--sst-petrol-dark); border-color: var(--sst-petrol-dark); text-decoration: none; color: #fff; }
.btn:active { transform: translateY(1px); }
.btn-ghost { background: transparent; color: var(--sst-petrol); border-color: var(--border); }
.btn-ghost:hover { background: var(--sst-petrol-50); color: var(--sst-petrol); }
.btn-sm { padding: 6px 11px; font-size: 13px; }
.btn-danger { background: var(--err); border-color: var(--err); }
.btn-danger:hover { background: #b83838; border-color: #b83838; }

/* ---- Forms ---- */
.field { margin-bottom: 14px; }
.field label { display: block; font-size: 13px; font-weight: 600; color: var(--text-mut); margin-bottom: 5px; }
.input, .select, .textarea { width: 100%; padding: 9px 11px; border: 1px solid var(--border);
  border-radius: var(--radius-sm); font-size: 15px; font-family: inherit; background: var(--surface); color: var(--text); }
.input:focus, .select:focus, .textarea:focus { outline: none; border-color: var(--sst-petrol); box-shadow: 0 0 0 3px rgba(15,127,151,.2); }
.textarea { min-height: 110px; resize: vertical; }

/* ---- Badges ---- */
.badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 9px; border-radius: 99px; font-size: 12px; font-weight: 600; line-height: 1.4; }
.badge-offen     { background: var(--b-offen-bg); color: var(--b-offen-fg); }
.badge-in_arbeit { background: var(--b-arbeit-bg); color: var(--b-arbeit-fg); }
.badge-erledigt  { background: var(--b-erled-bg); color: var(--b-erled-fg); }
.badge-prio-niedrig { background: var(--b-pnied-bg); color: var(--b-pnied-fg); }
.badge-prio-mittel  { background: var(--b-pmit-bg); color: var(--b-pmit-fg); }
.badge-prio-hoch    { background: var(--b-phoch-bg); color: var(--b-phoch-fg); }
.badge-2l { background: var(--sst-accent); color: #3a2a06; }

/* ---- Table ---- */
.table { width: 100%; border-collapse: collapse; font-size: 14px; }
.table th { text-align: left; padding: 11px 14px; font-size: 12px; font-weight: 700; color: var(--text-mut);
  text-transform: uppercase; letter-spacing: .4px; border-bottom: 1px solid var(--border); background: var(--th-bg); }
.table td { padding: 11px 14px; border-bottom: 1px solid var(--border); color: var(--text); }
.table tr:last-child td { border-bottom: none; }
.table tbody tr:hover { background: var(--sst-petrol-50); }
.table a { font-weight: 600; }

/* ---- Alerts ---- */
.alert { padding: 11px 14px; border-radius: var(--radius-sm); font-size: 14px; margin-bottom: 16px; border: 1px solid transparent; }
.alert-success { background: var(--al-ok-bg); color: var(--al-ok-fg); border-color: var(--al-ok-bd); }
.alert-error   { background: var(--al-er-bg); color: var(--al-er-fg); border-color: var(--al-er-bd); }
.alert-info    { background: var(--al-in-bg); color: var(--al-in-fg); border-color: var(--al-in-bd); }

/* ---- Auth ---- */
.auth-shell { min-height: 100vh; display: grid; place-items: center; padding: 20px;
  background: linear-gradient(135deg, var(--sst-petrol-50), var(--bg)); }
.auth-card { width: 100%; max-width: 380px; }
.auth-logo { text-align: center; margin-bottom: 20px; }
.auth-logo .brand-mark { width: 46px; height: 46px; font-size: 22px; margin: 0 auto 10px; background: var(--sst-petrol); color: #fff; border-radius: 12px; }
.auth-logo h1 { font-size: 19px; margin: 0; color: var(--text); }

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

/* ---- Mobil ---- */
@media (max-width: 720px) {
  :root { --gutter: 14px; }
  .nav-toggle { display: block; }
  .topnav { position: absolute; top: 56px; left: 0; right: 0; flex-direction: column; gap: 0;
    background: var(--sst-petrol-dark); padding: 6px; display: none; box-shadow: var(--shadow-md); }
  .topnav.open { display: flex; }
  .topnav a { border-radius: 6px; }
  .topbar-user .uname { display: none; }
  .page-title { font-size: 19px; }
  .table thead { display: none; }
  .table, .table tbody, .table tr, .table td { display: block; width: 100%; }
  .table tr { border: 1px solid var(--border); border-radius: var(--radius-sm); margin-bottom: 10px; padding: 4px 0; }
  .table td { border: none; padding: 7px 14px; }
  .table td::before { content: attr(data-label); display: block; font-size: 11px; font-weight: 700; color: var(--text-soft); text-transform: uppercase; }
}
