/* Fallmanager Pro - Frontend Styles v1.0.3 */

:root {
    --fmf-primary: #5b7fa4; --fmf-primary-dark: #44607d; --fmf-primary-light: #e8eff6; --fmf-primary-pastel: #f0f5fa;
    --fmf-success: #6a9a7b; --fmf-success-dark: #4e7a5e; --fmf-success-light: #e6f2ea;
    --fmf-warning: #c2944a; --fmf-warning-dark: #9a7438; --fmf-warning-light: #f8f0e0;
    --fmf-danger: #b56b6b; --fmf-danger-dark: #8f5050; --fmf-danger-light: #f6e8e8; --fmf-danger-pastel: #faf0f0;
    --fmf-gray-50: #fafaf9; --fmf-gray-100: #f3f2f0; --fmf-gray-200: #e6e4e1; --fmf-gray-300: #d4d1cc;
    --fmf-gray-400: #a8a49e; --fmf-gray-500: #7c7872; --fmf-gray-600: #5a5650; --fmf-gray-700: #3d3a36; --fmf-gray-800: #2a2826;
    --fmf-radius: 8px; --fmf-radius-lg: 14px;
    --fmf-shadow: 0 1px 3px rgba(42,40,38,.06); --fmf-shadow-md: 0 4px 12px rgba(42,40,38,.07);
    --fmf-transition: .2s ease;
}

.fm-frontend { max-width: 1200px; margin: 0 auto; color: var(--fmf-gray-800); font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; }

/* ── Header & Tabs ── */
.fm-fe-header { margin-bottom: 28px; }
.fm-fe-header h2 { font-size: 22px; font-weight: 700; margin: 0 0 18px; }
.fm-fe-tabs { display: flex; gap: 2px; background: var(--fmf-gray-100); border-radius: var(--fmf-radius); padding: 3px; flex-wrap: wrap; }
.fm-fe-tab { background: transparent; border: none; padding: 10px 20px; cursor: pointer; font-size: 14px; font-weight: 500; color: var(--fmf-gray-500); border-radius: 6px; transition: all var(--fmf-transition); }
.fm-fe-tab:hover { color: var(--fmf-gray-700); background: rgba(255,255,255,.5); }
.fm-fe-tab.active { color: var(--fmf-primary-dark); background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.06); }
.fm-fe-view { display: none; }
.fm-fe-view.active { display: block; }
.fm-fe-notice { background: var(--fmf-warning-light); border: 1px solid rgba(194,148,74,.25); padding: 16px 20px; border-radius: var(--fmf-radius-lg); color: var(--fmf-warning-dark); }

/* ── KPIs ── */
.fm-fe-kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 14px; margin-bottom: 28px; }
.fm-fe-kpi { background: #fff; border: 1px solid var(--fmf-gray-200); border-radius: var(--fmf-radius-lg); padding: 18px; text-align: center; position: relative; overflow: hidden; transition: transform var(--fmf-transition); }
.fm-fe-kpi::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--kpi-color, var(--fmf-primary)); }
.fm-fe-kpi:hover { transform: translateY(-2px); box-shadow: var(--fmf-shadow-md); }
.fm-fe-kpi-num { display: block; font-size: 32px; font-weight: 700; color: var(--kpi-color, var(--fmf-primary)); line-height: 1; }
.fm-fe-kpi span:last-child { font-size: 12px; color: var(--fmf-gray-500); font-weight: 500; margin-top: 4px; display: block; }

/* ── Filters ── */
.fm-fe-filters { display: flex; gap: 10px; margin-bottom: 14px; flex-wrap: wrap; }
.fm-fe-input, .fm-fe-select { padding: 9px 14px; border: 1px solid var(--fmf-gray-300); border-radius: var(--fmf-radius); font-size: 14px; background: #fff; color: var(--fmf-gray-700); transition: all var(--fmf-transition); }
.fm-fe-input:focus, .fm-fe-select:focus { border-color: var(--fmf-primary); outline: none; box-shadow: 0 0 0 3px rgba(91,127,164,.1); }
.fm-fe-input { flex: 1; min-width: 180px; }
.fm-fe-select-sm { padding: 6px 10px; font-size: 13px; min-width: auto; }

/* ── Toolbar (Ansicht + Pro Seite + Spalten) ── */
.fm-fe-toolbar { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 16px; flex-wrap: wrap; }
.fm-fe-toolbar-left { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }

/* View Toggle */
.fm-fe-view-toggle { display: flex; background: var(--fmf-gray-100); border-radius: 6px; padding: 2px; gap: 2px; }
.fm-fe-toggle-btn { background: transparent; border: none; padding: 6px 10px; cursor: pointer; color: var(--fmf-gray-400); border-radius: 4px; transition: all var(--fmf-transition); display: flex; align-items: center; }
.fm-fe-toggle-btn:hover { color: var(--fmf-gray-600); }
.fm-fe-toggle-btn.active { background: #fff; color: var(--fmf-primary-dark); box-shadow: 0 1px 3px rgba(0,0,0,.06); }
.fm-fe-toggle-btn svg { display: block; }

/* Per Page */
.fm-fe-per-page { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--fmf-gray-500); }
.fm-fe-per-page label { white-space: nowrap; }

/* Column Picker */
.fm-fe-col-picker { position: relative; }
.fm-fe-col-dropdown {
    display: none; position: absolute; right: 0; top: calc(100% + 6px); z-index: 100;
    background: #fff; border: 1px solid var(--fmf-gray-200); border-radius: var(--fmf-radius-lg); padding: 14px 16px;
    box-shadow: var(--fmf-shadow-md); min-width: 220px; max-height: 380px; overflow-y: auto;
}
.fm-fe-col-dropdown.open { display: block; }
.fm-fe-col-dropdown-title { font-size: 12px; font-weight: 700; color: var(--fmf-gray-500); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--fmf-gray-100); }
.fm-fe-col-dropdown label {
    display: flex; align-items: center; gap: 8px; padding: 5px 0; font-size: 13px; color: var(--fmf-gray-700);
    cursor: pointer; transition: color var(--fmf-transition);
}
.fm-fe-col-dropdown label:hover { color: var(--fmf-primary-dark); }
.fm-fe-col-dropdown input[type="checkbox"] { accent-color: var(--fmf-primary); width: 16px; height: 16px; }
.fm-fe-col-dropdown input[disabled] { opacity: .5; }

/* Result Info */
.fm-fe-result-info { display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: var(--fmf-gray-400); margin-bottom: 12px; padding: 0 2px; }
.fm-fe-result-mode { font-weight: 500; }

/* ── Cards View ── */
.fm-fe-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; }
.fm-fe-card { background: #fff; border: 1px solid var(--fmf-gray-200); border-radius: var(--fmf-radius-lg); padding: 18px; transition: box-shadow var(--fmf-transition), transform var(--fmf-transition); }
.fm-fe-card:hover { box-shadow: var(--fmf-shadow-md); transform: translateY(-1px); }
.fm-fe-card-overdue { border-left: 4px solid var(--fmf-danger); background: var(--fmf-danger-pastel); }
.fm-fe-card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; gap: 8px; }
.fm-fe-card-header strong { font-size: 15px; color: var(--fmf-gray-800); }
.fm-fe-pill { background: var(--fmf-primary-light); color: var(--fmf-primary-dark); padding: 3px 12px; border-radius: 20px; font-size: 11px; font-weight: 600; white-space: nowrap; flex-shrink: 0; }
.fm-fe-card-date { font-size: 13px; color: var(--fmf-gray-600); margin-bottom: 4px; line-height: 1.5; }
.fm-fe-card-meta { font-size: 12px; color: var(--fmf-gray-500); margin-bottom: 3px; }
.fm-fe-card-status { margin-top: 6px; }
.fm-fe-card-todo { font-size: 12px; color: var(--fmf-gray-500); margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--fmf-gray-100); line-height: 1.5; }
.fm-fe-card-actions { margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--fmf-gray-100); display: flex; gap: 8px; flex-wrap: wrap; }
.fm-fe-empty { text-align: center; color: var(--fmf-gray-400); padding: 36px; font-size: 14px; grid-column: 1 / -1; }

/* ── List View ── */
.fm-fe-list-mode { display: block; }
.fm-fe-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; border: 1px solid var(--fmf-gray-200); border-radius: var(--fmf-radius-lg); }
.fm-fe-table { width: 100%; border-collapse: collapse; font-size: 13px; min-width: 600px; }
.fm-fe-table th { background: var(--fmf-gray-50); padding: 10px 14px; text-align: left; font-weight: 600; color: var(--fmf-gray-500); font-size: 11px; text-transform: uppercase; letter-spacing: .5px; border-bottom: 2px solid var(--fmf-gray-200); white-space: nowrap; }
.fm-fe-table td { padding: 10px 14px; border-bottom: 1px solid var(--fmf-gray-100); color: var(--fmf-gray-700); vertical-align: middle; }
.fm-fe-table tbody tr { transition: background var(--fmf-transition); }
.fm-fe-table tbody tr:hover { background: var(--fmf-primary-pastel); }
.fm-fe-table tbody tr:last-child td { border-bottom: none; }
.fm-fe-row-overdue { background: var(--fmf-danger-pastel) !important; }
.fm-fe-row-overdue:hover { background: var(--fmf-danger-light) !important; }
.fm-fe-row-overdue td { color: var(--fmf-danger-dark) !important; }
.fm-fe-cell-truncate { max-width: 140px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.fm-fe-list-actions { white-space: nowrap; display: flex; gap: 4px; }

/* ── Status Badges ── */
.fm-fe-status-badge { display: inline-block; padding: 3px 10px; border-radius: 20px; font-size: 11px; font-weight: 600; letter-spacing: .2px; }
.fm-fe-st-offen { background: var(--fmf-primary-light); color: var(--fmf-primary-dark); }
.fm-fe-st-abgeschlossen { background: var(--fmf-success-light); color: var(--fmf-success-dark); }
.fm-fe-st-ruhend { background: var(--fmf-warning-light); color: var(--fmf-warning-dark); }

/* ── Buttons ── */
.fm-fe-btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px; border: 1px solid var(--fmf-gray-300); border-radius: var(--fmf-radius); background: #fff; cursor: pointer; font-size: 13px; font-weight: 500; color: var(--fmf-gray-600); transition: all var(--fmf-transition); }
.fm-fe-btn:hover { background: var(--fmf-primary-pastel); border-color: var(--fmf-primary-light); color: var(--fmf-primary-dark); }
.fm-fe-btn-primary { background: var(--fmf-primary); color: #fff; border-color: var(--fmf-primary); }
.fm-fe-btn-primary:hover { background: var(--fmf-primary-dark); border-color: var(--fmf-primary-dark); }
.fm-fe-btn-sm { padding: 6px 12px; font-size: 12px; }
.fm-fe-btn-xs { padding: 4px 8px; font-size: 11px; min-width: 30px; justify-content: center; }

/* ── Form ── */
.fm-fe-form { background: #fff; border: 1px solid var(--fmf-gray-200); border-radius: var(--fmf-radius-lg); padding: 26px; box-shadow: var(--fmf-shadow); }
.fm-fe-form-heading { font-size: 18px; font-weight: 600; color: var(--fmf-gray-700); margin: 0 0 20px; padding-bottom: 14px; border-bottom: 1px solid var(--fmf-gray-100); }
.fm-fe-form-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 16px; margin-bottom: 22px; }
.fm-fe-field label { display: block; font-size: 12px; font-weight: 600; color: var(--fmf-gray-500); margin-bottom: 5px; letter-spacing: .2px; text-transform: uppercase; }
.fm-fe-field input, .fm-fe-field select, .fm-fe-field textarea { width: 100%; padding: 9px 13px; border: 1px solid var(--fmf-gray-300); border-radius: var(--fmf-radius); font-size: 14px; box-sizing: border-box; background: var(--fmf-gray-50); color: var(--fmf-gray-800); transition: all var(--fmf-transition); }
.fm-fe-field input:focus, .fm-fe-field select:focus, .fm-fe-field textarea:focus { border-color: var(--fmf-primary); outline: none; background: #fff; box-shadow: 0 0 0 3px rgba(91,127,164,.1); }
.fm-fe-field textarea { resize: vertical; min-height: 80px; }
.fm-fe-field-full { grid-column: 1 / -1; }

/* ── Pagination ── */
.fm-fe-pagination { display: flex; gap: 4px; margin-top: 22px; justify-content: center; }
.fm-fe-pagination button { min-width: 36px; height: 36px; border: 1px solid var(--fmf-gray-200); border-radius: var(--fmf-radius); background: #fff; cursor: pointer; font-size: 13px; font-weight: 500; color: var(--fmf-gray-600); transition: all var(--fmf-transition); }
.fm-fe-pagination button:hover { background: var(--fmf-primary-pastel); border-color: var(--fmf-primary-light); }
.fm-fe-pagination button.active { background: var(--fmf-primary); color: #fff; border-color: var(--fmf-primary); }

/* ── Responsive ── */
@media (max-width: 768px) {
    .fm-fe-tabs { gap: 0; }
    .fm-fe-tab { padding: 8px 14px; font-size: 13px; }
    .fm-fe-kpis { grid-template-columns: repeat(2, 1fr); }
    .fm-fe-cards { grid-template-columns: 1fr; }
    .fm-fe-filters { flex-direction: column; }
    .fm-fe-input { min-width: auto; width: 100%; }
    .fm-fe-toolbar { flex-direction: column; align-items: stretch; }
    .fm-fe-toolbar-left { justify-content: space-between; }
    .fm-fe-col-picker { align-self: flex-end; }
    .fm-fe-col-dropdown { right: 0; left: auto; }
    .fm-fe-form-grid { grid-template-columns: 1fr; }
    .fm-fe-form { padding: 18px; }
    .fm-fe-card-header { flex-direction: column; align-items: flex-start; }
    .fm-fe-result-info { flex-direction: column; gap: 4px; }
}
@media (max-width: 480px) {
    .fm-fe-kpis { grid-template-columns: 1fr; }
    .fm-fe-per-page { display: none; }
}
