/**
 * ISOPI Widget · Dashboard
 *
 * Extracted from index.html (Phase 1.5, ADR 013).
 * Verbatim 1:1 copy — no refactoring.
 */

/* Container-Padding/-max-width kommt aus .isopi-shell__main —
 * die Dashboard-Stylesheets fügen NUR Inner-Layout hinzu, kein
 * eigenes Padding/max-width (sonst Doppel-Padding). */

/* Inhalts-Padding für edge-to-edge Sticky-Components (Footer-Bar,
 * Wetter-Panel). Math siehe .dash-info-bar-Comment unten. Eine
 * Definition für alle Stellen → DRY + konsistente Inhalts-Edge
 * unter dem Topbar-Inhalt. */
body {
  --dash-content-pad: max(1.5rem, calc((100vw - var(--w-wide, 1200px)) / 2 + 1.5rem));
}

/* Sticky-Footer-Bar: Datum links, User/Logout rechts. */
.dash-info-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--z-sticky);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block: 0.55rem;
  padding-bottom: calc(0.55rem + env(safe-area-inset-bottom));
  padding-inline: var(--dash-content-pad);
  background: var(--isopi-sand-light);
  border-top: 1px solid var(--isopi-border);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--isopi-muted);
}
.dash-info-zone {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  min-width: 0;
}
.dash-info-zone--end {
  justify-content: flex-end;
  min-width: 90px;
}
body {
  padding-bottom: calc(var(--isopi-info-bar-h, 3rem) + env(safe-area-inset-bottom));
}
@media print {
  .dash-info-bar {
    display: none !important;
  }
  body {
    padding-bottom: 0 !important;
  }
}
.dash-info-item {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  line-height: 1;
}
.dash-info-item svg {
  width: 14px;
  height: 14px;
  display: block;
  flex: 0 0 auto;
}
button.dash-info-item--user {
  background: transparent;
  border: none;
  margin: 0;
  padding: 0.5rem 0.4rem;
  font: inherit;
  color: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  cursor: pointer;
  min-height: 44px;
}
button.dash-info-item--user:hover {
  color: var(--isopi-ink);
}
button.dash-info-item--user:hover span:last-child {
  text-decoration: underline;
}
button.dash-info-item--user:focus-visible {
  outline: 2px solid var(--isopi-ink);
  outline-offset: 2px;
}
@media (max-width: 600px) {
  .dash-info-bar {
    padding: 0.45rem 0.7rem calc(0.45rem + env(safe-area-inset-bottom));
  }
  .dash-info-item--user span:last-child {
    max-width: 90px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
}
.dash-wrap {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.dash-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 1.5rem;
}
/* V3: asymmetrisch 66/33 für Row 1 — Announcements links breit,
 * Heute-Events kompakt rechts. */
.dash-row--asym {
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
}
@media (max-width: 860px) {
  .dash-row,
  .dash-row--asym {
    grid-template-columns: 1fr;
  }
  /* Mobile-Empty-States: kompakter rendern statt komplett verstecken,
   * damit der User nicht eine 100px+ leere Fläche sieht. Dezent
   * hint-text, keine extra-Padding-Höhe.
   * (Vorher: display:none — versteckte aber auch CTA-Aktionen wie
   * "+ Event anlegen", die explizit als Button gedacht sind.) */
  .dash-card .isopi-empty {
    padding: 0.6rem 0;
    text-align: left;
    font-size: 0.85rem;
  }
  .dash-card .isopi-empty__title {
    font-size: 0.85rem;
  }
  .dash-card .isopi-empty__hint {
    font-size: 0.78rem;
    opacity: 0.7;
  }
}
.dash-card {
  background: var(--isopi-sand-light);
  border: 1px solid var(--isopi-border);
  padding: 1rem 1.2rem;
}

/* Apps-Grid Result-Count im Toolbar ausblenden — Anzahl ist
 * redundant, der User sieht ja die Cards. */
.ag-result-count {
  display: none !important;
}

/* Gleiche Kartenhöhe in row — Cards strecken sich auf die höchste Karte */
.dash-row--equal {
  align-items: stretch;
}
.dash-row--equal .dash-card {
  display: flex;
  flex-direction: column;
}

/* Termin/Event-Picker */
.dash-new-picker {
  position: absolute;
  z-index: var(--z-dropdown, 1000);
  background: var(--isopi-sand);
  border: 1px solid var(--isopi-border-strong);
  min-width: 140px;
}
.dash-new-picker button {
  display: block;
  width: 100%;
  padding: 0.75rem 1.2rem;
  font-family: var(--font-brandon);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-align: left;
  background: none;
  border: none;
  border-bottom: 1px solid var(--isopi-border);
  color: var(--isopi-ink);
  cursor: pointer;
}
.dash-new-picker button:last-child {
  border-bottom: none;
}
.dash-new-picker button:hover {
  background: var(--isopi-sand-dark);
}

/* V3-Header-Pattern: Title (optional als Link) + dezenter Subtitle +
 * Plus-Button rechts. Wird von Nachrichten / Events / Kalender /
 * Menüs gleich gerendert. */
.dash-card-title-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s ease;
}
.dash-card-title-link:hover,
.dash-card-title-link:focus-visible {
  color: inherit;
  border-bottom-color: currentColor;
  outline: none;
}
.dash-card-sub {
  font-family: var(--font-brandon);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--isopi-muted);
}

/* Cardless Sections auf Mobile (dashboard-mobile-polish.md T1):
 * <600px verlieren die .dash-card-Container ihren Frame. Sections
 * sitzen edge-to-edge auf der Page, Items behalten ihre Bereich-Tints.
 * Spart ~80-100px Content-Breite auf 390px-iPhone. */
@media (max-width: 600px) {
  .dash-card {
    background: transparent;
    border: 0;
    padding: 0;
  }
  /* 1px-Trenner zwischen aufeinanderfolgenden Sections — dünn
   * statt protzig. Greift sowohl bei Card↔Card als auch bei
   * Card↔Row und Row↔Row (das Apps-Grid liegt nicht in einer
   * Card, ist also als Sibling sichtbar). */
  .dash-card + .dash-card,
  .dash-row + .dash-card,
  .dash-card + .dash-row,
  .dash-row + .dash-row,
  .dash-card + *:not(.dash-card):not(.dash-row),
  .dash-row + *:not(.dash-card):not(.dash-row) {
    border-top: 1px solid var(--isopi-border);
    padding-top: 1.5rem;
  }
}

/* Card-Frame fürs Drucken bleibt erhalten — auch wenn das Mobile-
 * Browserfenster <600px ist, soll der Print-Preview wie Desktop
 * aussehen. */
@media print {
  .dash-card {
    background: var(--isopi-sand-light) !important;
    border: 1px solid var(--isopi-border) !important;
    padding: 1rem 1.2rem !important;
  }
}
