﻿#view-admin details.card{ width: 100%; }
#view-admin .card-inner{ width: 100%; }
.table--tools-admin, .table--loans-admin{ width: 100%; }
@media (min-width: 901px){
  .container{ padding-left: 18px; padding-right: 18px; }
  .card{ padding: 18px; }
}
@media (max-width: 900px){
  .grid{ max-width: 100%; }
}

.card--admin-section{
  width: 100%;
  max-width: 100%;
}
#view-admin .card--admin-section .table{
  max-width: 100%;
}
#view-admin .card--admin-section details{
  width: 100%;
}
#view-admin .card--admin-subsection{
  padding: 0;
}
#view-admin .card--admin-subsection summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  list-style:none;
  cursor:pointer;
  padding:14px 18px;
}
#view-admin .card--admin-subsection summary::-webkit-details-marker{
  display:none;
}
#view-admin .card--admin-subsection[open] summary{
  border-bottom:1px solid var(--line);
}

/* Admin-Navigation ueberall gleich ausrichten */
.card--admin-nav{
  width: 100%;
}
.card--admin-nav{
  position: sticky;
  top: 14px;
  z-index: 5;
}
.card--admin-nav .admin-tabs-row{
  margin-top: 14px;
  justify-content: flex-start;
  align-items: center;
}
.admin-tabs-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(170px, 1fr));
  gap:10px;
}
.admin-tabs-grid .btn{
  width:100%;
  justify-content:center;
  min-height: 46px;
}
.admin-filter-panel,
.report-filter-panel{
  border: 1px solid rgba(226,232,240,.92);
  border-radius: 16px;
  background: rgba(248,250,252,.78);
  padding: 14px;
}
.admin-filter-panel__intro,
.report-filter-panel__intro{
  display:flex;
  flex-direction:column;
  gap: 4px;
}
.admin-filter-panel__intro b,
.report-filter-panel__intro b{
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.admin-filter-panel__intro span,
.report-filter-panel__intro span{
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}
.report-toolbar-actions{
  gap: 8px;
  flex-wrap: wrap;
}
.report-tabs-row .btn{
  min-width: 120px;
}
.admin-section-toolbar,
.admin-list-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.admin-general-grid{
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:12px;
}
#view-admin .card--admin-nav,
#view-admin .card--admin-section{
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
#view-admin .card--admin-section{
  overflow: visible;
}

.time-mode-switch{
  display: inline-flex;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: 8px;
}
.time-mode-switch > .btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 96px;
  white-space: nowrap;
  text-align: center;
  flex: 0 0 auto;
}

.entity-form{
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(248,250,252,.95), #fff 18%);
  padding: 18px;
}
.entity-form__header{
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.entity-form__body{
  margin-top: 0;
}
.entity-form__section{
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,.82);
  padding: 14px;
}
.entity-form__sectionTitle{
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .2px;
  color: var(--gray);
}
.entity-form__actions{
  align-items: center;
  flex-wrap: wrap;
}
.entity-form--user .field{ min-width: 180px; }
.entity-form--user .field.grow{ min-width: 260px; }
.entity-form--user .user-role-field{
  max-width: 360px;
}
.entity-form--user select[multiple]{
  min-height: 140px;
}

@media (max-width: 520px){
  /* Container als Flex-Reihe (kein Umbruch) */
  .time-mode-switch {
    display: flex !important;
    flex-wrap: nowrap !important;
    width: 100%;
    gap: 8px;
  }

  .time-mode-switch .btn {
    flex: 1 1 0;              
    min-width: 70px;          
    width: auto;              
    height: auto;             
    min-height: 44px;
    padding: 10px 8px;
    white-space: nowrap;      
    overflow: hidden;
    text-overflow: ellipsis;  
    line-height: 1.2;
    text-align: center;
    font-size: 15px;          
    box-sizing: border-box;
  }

  /* Bei wirklich winzigen Displays (iPhone SE, 320px) Schrift weiter reduzieren */
  @media (max-width: 360px) {
    .time-mode-switch .btn {
      font-size: 13px;
      padding: 10px 4px;
    }
  }
  .entity-form{
    padding: 12px;
  }
  .entity-form__section{
    padding: 12px;
  }
  .entity-form__actions .btn{
    width: 100%;
  }
}

@media (max-width: 760px){
  .card--admin-nav{
    position: static;
  }
  .admin-section-toolbar,
  .admin-list-meta{
    align-items: stretch;
  }
  .admin-section-toolbar .btn,
  .admin-list-meta .btn{
    width: 100%;
  }
  .report-toolbar-actions{
    width: 100%;
  }
  .report-toolbar-actions .btn,
  .report-tabs-row .btn{
    width: 100%;
  }
}

.log-details-cell{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.log-details-text{
  min-width:0;
  white-space:normal;
  overflow-wrap:anywhere;
  line-height:1.35;
}
.log-info-btn{
  flex:0 0 auto;
  width:24px;
  height:24px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--panel);
  color:var(--text);
  font-size:12px;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:help;
  padding:0;
}
.log-info-btn:hover{
  background:var(--bg-soft);
}

/* Benutzerliste: Rollen rechts ausrichten, mobil sauber umbrechen */
.user-list-item{
  align-items: center;
}
.user-list-item__info{
  min-width: 0;
}
.user-list-item__roles{
  margin-left: auto;
  justify-content: flex-end;
  align-self: center;
  flex: 0 1 auto;
}
.user-list-item__actions{
  justify-content: flex-end;
  flex: 0 0 auto;
}

@media (max-width: 820px){
  .user-list-item{
    flex-wrap: wrap;
    align-items: flex-start;
  }
  .user-list-item__info{
    width: 100%;
  }
  .user-list-item__roles{
    margin-left: 0;
    width: 100%;
    justify-content: flex-start;
  }
  .user-list-item__actions{
    width: 100%;
    justify-content: flex-end;
  }
}


.profile-password-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  align-items:start;
}
.profile-facts-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
}
.profile-fact-card{
  min-height: 110px;
  padding: 12px 14px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap: 6px;
}
.profile-fact-card__label{
  margin-bottom: 0;
  font-size: 11px;
  letter-spacing: .04em;
}
.profile-fact-card__value{
  min-height: 40px;
  display:flex;
  align-items:flex-start;
  align-content:flex-start;
  flex-wrap:wrap;
  gap: 6px;
  font-size: 14px;
  line-height: 1.35;
  color: #0f172a;
}
.profile-fact-card__value b{
  font-size: 15px;
}
.profile-fact-card__badges{
  gap: 5px;
}
.profile-fact-card__badges .pill{
  margin: 0;
}
.profile-fact-card__sub{
  margin-top: auto;
  font-size: 12px;
}
.profile-password-grid > .field{
  display:flex;
  flex-direction:column;
}
.profile-password-grid .hint--ghost{
  visibility:hidden;
}
@media (max-width: 700px){
  .profile-password-grid{ grid-template-columns: 1fr; }
  .profile-password-grid .hint--ghost{ display:none; }
  .admin-general-grid{ grid-template-columns: 1fr; }
  .profile-facts-grid{ grid-template-columns: 1fr; }
  .profile-fact-card{ min-height: 0; }
}

.table--admin-reviews .admin-review-table__head,
.table--admin-reviews .admin-review-table__row{
  grid-template-columns: 140px 140px 100px minmax(340px, 1.8fr) 148px;
}
.table--admin-reviews .admin-review-table__row{
  align-items: start;
}
.admin-review-note-cell,
.admin-review-note,
.admin-review-project{
  min-width: 0;
}
.admin-review-note,
.admin-review-project{
  white-space: normal;
  word-break: normal;
  overflow-wrap: anywhere;
  line-height: 1.45;
}
.admin-review-actions{
  justify-content: flex-end;
  align-items: stretch;
  flex-direction: column;
  flex-wrap: nowrap;
  gap: 8px;
}
.admin-review-actions .btn{
  width: 100%;
  min-width: 0;
  height: auto;
  min-height: 40px;
  padding: 8px 12px;
  font-size: 13px;
  line-height: 1.2;
  text-align: center;
  white-space: normal;
}
@media (max-width: 900px){
  .table--admin-reviews .admin-review-table__row{
    grid-template-columns: 1fr;
  }
  .table--admin-reviews .admin-review-table__row > div:last-child{
    justify-content: flex-start;
  }
  .table--admin-reviews .admin-review-table__head{
    display:none;
  }
  .admin-review-actions{
    justify-content: flex-start;
  }
}
