/* =====================================================
 * Tinax — Mobile-Optimierungen
 * Greift unter ~720px Breite
 * ===================================================== */

/* iOS-Zoom verhindern bei Inputs (Font-Size mind. 16px) */
@media (max-width: 720px) {
  input[type="text"],
  input[type="number"],
  input[type="email"],
  input[type="password"],
  input[type="tel"],
  input[type="date"],
  input[type="time"],
  input[type="search"],
  textarea,
  select {
    font-size: 16px !important;
  }
}

/* Sidebar mobil als Drawer — Steuerung erfolgt komplett via JS-Inline-Styles,
   damit kein CSS/JS-Konflikt entsteht. Hier nur noch: Hauptinhalt nicht einrücken. */
@media (max-width: 720px) {
  .tinax-main {
    margin-left: 0 !important;
  }
  .tinax-hamburger {
    display: flex !important;
  }
}
.tinax-hamburger { display: none; }

/* Modals: full-screen auf Mobile */
@media (max-width: 720px) {
  body { -webkit-text-size-adjust: 100%; }
}

/* Globale Klasse für alle Tinax-Modals — Komponenten setzen className="tinax-modal-overlay" / "tinax-modal-box" */
.tinax-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 200;
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.tinax-modal-box {
  background: #fff;
  border-radius: 12px;
  padding: 24px;
  max-width: 720px;
  width: 100%;
  max-height: 92vh;
  overflow: auto;
}
@media (max-width: 720px) {
  .tinax-modal-overlay {
    padding: 0 !important;
    align-items: stretch !important;
  }
  .tinax-modal-box {
    padding: 16px !important;
    border-radius: 0 !important;
    max-width: 100% !important;
    max-height: 100vh !important;
    width: 100% !important;
  }
}

/* V16: Slide-Over (Asana-Style) — eigene Klasse, NICHT mit tinax-modal überlagert */
.tinax-slideover-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.35);
  z-index: 200;
  display: flex;
  justify-content: flex-end;
  align-items: stretch;
  padding: 0;
}
.tinax-slideover-box {
  background: #fff;
  width: 100%;
  max-width: 720px;
  height: 100vh;
  max-height: 100vh;
  overflow: auto;
  border-radius: 0;
  box-shadow: -8px 0 24px rgba(0,0,0,0.15);
  animation: tinaxSlideInRight 0.2s ease-out;
}
@keyframes tinaxSlideInRight {
  from { transform: translateX(100%); }
  to { transform: translateX(0); }
}
@media (max-width: 720px) {
  .tinax-slideover-box {
    max-width: 100% !important;
  }
}

/* Drag&Drop Tabellen etc: horizontal scrollbar erlauben */
@media (max-width: 720px) {
  .tinax-table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* Buttons: Touch-Target mind. 40px */
@media (max-width: 720px) {
  button, .tinax-btn {
    min-height: 40px;
  }
  /* Aber nicht für inline-Icons im Tabler-Icon-Format */
  button.tinax-icon-btn {
    min-height: auto;
  }
}

/* FullCalendar mobil: Toolbar mehrzeilig */
@media (max-width: 720px) {
  .fc .fc-toolbar.fc-header-toolbar {
    flex-direction: column;
    gap: 8px;
    align-items: stretch !important;
  }
  .fc .fc-toolbar-chunk {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 4px;
  }
  .fc .fc-toolbar-title {
    font-size: 16px !important;
    text-align: center;
  }
  .fc .fc-button {
    padding: 6px 10px !important;
    font-size: 12px !important;
  }
  /* Tag/Wochenansicht: Stunden-Spalte schmaler */
  .fc-timegrid-slot-label {
    font-size: 10px !important;
  }
  .fc-col-header-cell-cushion {
    font-size: 11px !important;
  }
}

/* Kanban-Board (Aufgaben/Projekte) horizontal scrollen */
@media (max-width: 720px) {
  .tinax-kanban-board {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 12px;
  }
  .tinax-kanban-spalte {
    min-width: 280px !important;
    max-width: 280px !important;
    flex-shrink: 0 !important;
  }
}

/* Karten in Kanban-Board: nicht zu breit */
@media (max-width: 720px) {
  .tinax-karte {
    font-size: 13px !important;
  }
}

/* Kalkulator-Eingaben: full-width */
@media (max-width: 720px) {
  /* Grid-Layouts mit 2-3 Spalten zu 1 Spalte machen */
  .tinax-grid-mobile-stack {
    grid-template-columns: 1fr !important;
  }
}

/* Header / Top-Bar mobile */
@media (max-width: 720px) {
  .tinax-topbar {
    padding: 10px 12px !important;
    flex-wrap: wrap;
    gap: 8px;
  }
  .tinax-topbar h1 {
    font-size: 17px !important;
  }
  /* Such-Felder im Header full-width auf Mobile */
  .tinax-topbar input[type="text"],
  .tinax-topbar input[type="search"] {
    width: 100% !important;
    flex: 1 1 100% !important;
  }
}

/* Pagination-Buttons auf Mobile auch kleiner */
@media (max-width: 720px) {
  /* Generell auf Mobile: Inhalt-Padding reduzieren */
  main, .tinax-page-content {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}

/* Touch-feedback auf Mobile (Buttons leuchten kurz beim Antippen) */
@media (max-width: 720px) {
  button:active {
    opacity: 0.75;
  }
}

/* Email-Modul: 3-Spalten-Layout zu Stack */
@media (max-width: 720px) {
  .tinax-email-layout {
    flex-direction: column !important;
    position: relative;
  }
  /* Ordner-Sidebar: oben als horizontale Pillenleiste */
  .tinax-email-folders {
    width: 100% !important;
    max-height: 56px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    border-right: none !important;
    border-bottom: 1px solid #E5E7EB !important;
    padding: 8px !important;
    white-space: nowrap;
    display: flex;
    flex-direction: row !important;
    gap: 4px;
  }
  .tinax-email-folders > * {
    flex-shrink: 0;
  }
  /* E-Mail-Liste: full-width wenn keine Mail offen */
  .tinax-email-list {
    width: 100% !important;
    border-right: none !important;
    flex: 1 !important;
  }
  /* Wenn Mail offen ist: Liste verstecken (Vollbild Detail) */
  .tinax-email-list-with-detail {
    display: none !important;
  }
  /* Detail-Anzeige: Vollbild über alles */
  .tinax-email-detail {
    position: fixed !important;
    inset: 0 !important;
    z-index: 250;
    background: #fff !important;
  }
  /* Mobile-Back-Button anzeigen, Desktop-Close ausblenden */
  .tinax-mobile-back { display: flex !important; }
  .tinax-desktop-close { display: none !important; }
}

/* Tabelle responsiv: bei zu schmal scrollbar */
@media (max-width: 720px) {
  table.tinax-responsive {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }
}

/* Kunden-Tabelle wird auf Mobile zu Karten-Layout */
@media (max-width: 720px) {
  table.tinax-customers-table thead {
    display: none !important;
  }
  table.tinax-customers-table,
  table.tinax-customers-table tbody,
  table.tinax-customers-table tr,
  table.tinax-customers-table td {
    display: block !important;
    width: 100% !important;
  }
  table.tinax-customers-table tr {
    background: #fff !important;
    border: 1px solid #E5E7EB !important;
    border-radius: 8px !important;
    margin-bottom: 8px !important;
    padding: 10px !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
  }
  table.tinax-customers-table td {
    padding: 4px 0 !important;
    border: none !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 10px;
    font-size: 13px;
  }
  /* Label vor jeder Zelle (aus data-label-Attribute) */
  table.tinax-customers-table td[data-label]:not([data-label=""])::before {
    content: attr(data-label);
    font-weight: 600;
    color: #6B7280;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    flex-shrink: 0;
  }
  /* Checkbox-Zellen ohne Label kompakt */
  table.tinax-customers-table td[data-label=""] {
    justify-content: flex-start !important;
  }
}

/* Filter-Bar im Kalender mehrzeilig */
@media (max-width: 720px) {
  .tinax-filter-bar {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .tinax-filter-bar > div {
    width: 100%;
  }
}

/* Termin-Modal: enger Spacing */
@media (max-width: 720px) {
  .tinax-event-modal {
    padding: 14px !important;
  }
}

/* Kalkulator-Position: Fläche-Eingabe untereinander */
@media (max-width: 720px) {
  .tinax-flaeche-input {
    grid-template-columns: 1fr 1fr !important;
    gap: 6px !important;
  }
  .tinax-flaeche-row {
    flex-wrap: wrap;
  }
}

/* Login-Page mobile-friendly */
@media (max-width: 720px) {
  .tinax-login-card {
    margin: 16px !important;
    padding: 20px !important;
    width: auto !important;
    max-width: 100% !important;
  }
}

/* V16: Projekte-Liste auf Mobile als Karten */
@media (max-width: 720px) {
  table.tinax-projects-list thead {
    display: none !important;
  }
  table.tinax-projects-list,
  table.tinax-projects-list tbody,
  table.tinax-projects-list tr,
  table.tinax-projects-list td {
    display: block !important;
    width: 100% !important;
  }
  table.tinax-projects-list tr {
    background: #fff !important;
    border: 1px solid #E5E7EB !important;
    border-bottom: 1px solid #E5E7EB !important;
    border-radius: 8px !important;
    margin-bottom: 8px !important;
    padding: 10px !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
  }
  table.tinax-projects-list td {
    padding: 6px 0 !important;
    border: none !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 4px;
    font-size: 13px;
  }
  table.tinax-projects-list td[data-label]:not([data-label=""])::before {
    content: attr(data-label);
    font-weight: 600;
    color: #6B7280;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
  }
  table.tinax-projects-list td[data-label=""] {
    text-align: left !important;
  }
}

/* V16: Read-only-Modus für Mitarbeiter im Projekt-Modal */
.tinax-readonly-modal input,
.tinax-readonly-modal textarea,
.tinax-readonly-modal select,
.tinax-readonly-modal button:not(.tinax-readonly-allow):not([data-readonly-allow]) {
  pointer-events: none !important;
  background: #F9FAFB !important;
  color: #6B7280 !important;
  cursor: not-allowed !important;
}
.tinax-readonly-modal label,
.tinax-readonly-modal summary {
  pointer-events: none !important;
}
/* Erlaubte Bereiche (Datei-Upload, Zeit-Tracking, Erledigt-Button) bleiben aktiv */
.tinax-readonly-modal .tinax-readonly-allow,
.tinax-readonly-modal .tinax-readonly-allow * {
  pointer-events: auto !important;
  background: initial !important;
  color: initial !important;
  cursor: initial !important;
}

/* V16: Rich-Text-Editor — Placeholder + Listen-Layout */
.tinax-rich-editor:empty:before {
  content: attr(data-placeholder);
  color: #9CA3AF;
  pointer-events: none;
  display: block;
}
.tinax-rich-editor ul, .tinax-rich-editor ol {
  padding-left: 24px;
  margin: 6px 0;
}
.tinax-rich-editor a {
  color: #3B82F6;
  text-decoration: underline;
}
.tinax-rich-editor p {
  margin: 0 0 8px;
}

/* V16: Spinner-Animation */
@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
