/* LogiDrink Portail v2 */
:root {
  --radius-lg: 18px; --radius: 14px; --radius-sm: 10px; --radius-pill: 999px;
  --shadow-card: 0 1px 2px rgba(16,24,42,.05), 0 8px 28px -6px rgba(16,24,42,.1);
}
body { background: #f6f7fb !important; }
.sidebar { width: 268px !important; border-right: none !important; box-shadow: 1px 0 0 var(--line), 6px 0 28px -10px rgba(16,24,42,.08) !important; }
.main { margin-left: 268px !important; }
.topbar { height: 64px !important; padding: 0 24px 0 28px !important; background: rgba(255,255,255,.92) !important; backdrop-filter: blur(12px) saturate(180%) !important; gap: 12px !important; }
.topbar-tools { display: flex; align-items: center; gap: 8px; margin-left: auto; }
.topbar-notif { position: relative; width: 40px; height: 40px; border-radius: 10px; border: 1px solid var(--line); background: #fff; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; color: var(--muted); transition: .15s; }
.topbar-notif:hover { border-color: var(--accent); color: var(--accent); }
.topbar-notif .dot { position: absolute; top: 8px; right: 8px; width: 8px; height: 8px; border-radius: 50%; background: #ef4444; border: 2px solid #fff; }
.notif-panel { position: fixed; top: 68px; right: 20px; width: min(360px, calc(100vw - 32px)); background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); z-index: 100; display: none; overflow: hidden; }
.notif-panel.open { display: block; }
.notif-panel-hd { padding: 14px 16px; font-weight: 700; font-size: 14px; border-bottom: 1px solid var(--line-2); }
.notif-item { padding: 12px 16px; border-bottom: 1px solid var(--line-2); font-size: 13px; }
.notif-item:last-child { border-bottom: none; }
.notif-item small { display: block; color: var(--soft); margin-top: 4px; font-size: 11px; }
.nav-item { border-radius: var(--radius-sm) !important; padding: 9px 12px !important; margin: 1px 0 !important; }
.nav-item.active { background: var(--accent-soft) !important; color: var(--accent-700) !important; box-shadow: none !important; border-left: 3px solid var(--accent) !important; padding-left: 9px !important; }
.nav-ic { width: 30px; height: 30px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.nav-ic svg { width: 16px !important; height: 16px !important; stroke: currentColor !important; }
.nav-item.active .nav-ic { filter: saturate(1.1); }
.userbox { background: var(--bg-soft) !important; border-radius: var(--radius-sm) !important; padding: 10px !important; }
.content { padding: 24px 28px 48px !important; }
.kpi-grid { gap: 18px !important; }
.kpi { border-radius: var(--radius-lg) !important; border: none !important; box-shadow: var(--shadow-card) !important; padding: 20px !important; }
.kpi:hover { transform: translateY(-1px); }
.card { border-radius: var(--radius-lg) !important; border: none !important; box-shadow: var(--shadow-card) !important; }
.card-head { padding: 16px 20px !important; }
th { background: #f8f9fc !important; font-size: 10.5px !important; }
td { padding: 14px 20px !important; }
.btn { border-radius: var(--radius-pill) !important; }
.btn-primary { box-shadow: 0 2px 8px rgba(253,112,32,.28) !important; }
.modal { border-radius: var(--radius-lg) !important; }
#auth { background: linear-gradient(165deg, #fff8f3 0%, #f4f6fa 55%, #eef1f8 100%) !important; }
.auth-card { max-width: 440px !important; padding: 36px !important; }
.auth-back { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; margin-top: 14px; padding: 12px 18px; border-radius: var(--radius-pill); border: 1.5px solid var(--line); background: #fff; color: var(--ink); font-weight: 600; font-size: 14px; text-decoration: none; transition: .15s; }
.auth-back:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
.auth-back svg { width: 16px; height: 16px; }
.auth-primary-stack .btn-primary { width: 100%; padding: 13px !important; }
.acc-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px; padding-bottom: 4px; }
.acc-tab { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; border-radius: var(--radius-pill); border: 1px solid var(--line); background: #fff; color: var(--muted); font-size: 13px; font-weight: 600; cursor: pointer; transition: .15s; }
.acc-tab:hover { border-color: #d7dde6; color: var(--ink); }
.acc-tab.active { background: var(--accent-soft); border-color: var(--accent); color: var(--accent-700); }
.acc-tab-ic { width: 28px; height: 28px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; font-size: 14px; }
.settings-save-bar { position: sticky; bottom: 16px; z-index: 4; display: flex; justify-content: flex-end; padding: 12px 0; margin-top: 8px; }
.settings-save-bar .btn-primary { min-width: 220px; box-shadow: 0 8px 24px rgba(253,112,32,.25) !important; }
.settings-grid .card { margin-bottom: 16px !important; }
.field input, .field select, .field textarea, select.ld-select, .period-filter select { appearance: none; -webkit-appearance: none; background-color: #fff !important; border: 1px solid var(--line) !important; border-radius: var(--radius-sm) !important; padding: 11px 36px 11px 13px !important; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a93a4' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important; background-repeat: no-repeat !important; background-position: right 12px center !important; }
.field select:focus, select.ld-select:focus { border-color: var(--accent) !important; box-shadow: 0 0 0 3px var(--accent-soft) !important; outline: none !important; }
.ts-wrapper .ts-control { border-radius: var(--radius-sm) !important; min-height: 42px !important; }
.crumb { font-size: 13px !important; }
.crumb b::before { content: none !important; }
.sidebar-toggle { display: none; width: 40px; height: 40px; border-radius: 10px; border: 1px solid var(--line); background: #fff; align-items: center; justify-content: center; }
@media (max-width: 980px) {
  .sidebar { transform: translateX(-100%); transition: transform .25s ease; z-index: 50; width: 280px !important; }
  .sidebar.open { transform: translateX(0); }
  .main { margin-left: 0 !important; }
  .sidebar-toggle { display: inline-flex !important; }
  .kpi-grid { grid-template-columns: 1fr 1fr !important; }
  .topbar { padding: 0 16px !important; }
  .content { padding: 16px !important; }
  .search input { width: 100% !important; max-width: 200px; }
  #topActions { flex-wrap: wrap; gap: 6px; }
  .acc-tabs { gap: 6px; }
  .acc-tab { padding: 8px 12px; font-size: 12px; }
  .acc-tab span:last-child { display: none; }
  .grid2 { grid-template-columns: 1fr !important; }
}
@media (max-width: 560px) {
  .kpi-grid { grid-template-columns: 1fr !important; }
  .auth-card { padding: 28px 22px !important; }
}

/* v3 */
.settings-grid { display: grid; gap: 16px; margin-bottom: 0; }
.settings-save-bar { background: linear-gradient(180deg, transparent, #f6f7fb 35%); padding-top: 20px !important; }
.acc-tab-ic svg { display: block; }
.acc-tab-ic { background: transparent !important; }
.notif-item a { font-weight: 600; }
.card-head { border-bottom: none !important; }
.card { border: 1px solid rgba(233,237,243,.6) !important; }
#topActions .btn-sm { font-size: 12.5px; padding: 8px 14px; }
.analytics-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media (max-width: 980px) { .analytics-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .analytics-grid { grid-template-columns: 1fr; } }

/* v4 ClubPlanner-like typography + unified palette */
body { font-size: 15px !important; font-weight: 500 !important; line-height: 1.6 !important; color: var(--ink) !important; }
.nav-group { font-size: 11.5px !important; color: var(--muted) !important; letter-spacing: .06em !important; }
.nav-item { font-size: 14px !important; font-weight: 600 !important; color: var(--muted) !important; }
.nav-item:hover { color: var(--ink) !important; }
.nav-item.active { color: var(--accent-700) !important; font-weight: 700 !important; }
.nav-item.active .nav-ic { background: var(--accent-soft) !important; color: var(--accent) !important; }
.nav-ic { background: #f4f6fa !important; color: #586173 !important; width: 32px !important; height: 32px !important; border-radius: 9px !important; }
.nav-item svg, .nav-ic svg { width: 17px !important; height: 17px !important; }
.userbox .meta b { font-size: 14px !important; font-weight: 700 !important; }
.userbox .meta span { font-size: 12.5px !important; color: var(--muted) !important; font-weight: 500 !important; }
.crumb { font-size: 14px !important; font-weight: 600 !important; color: var(--muted) !important; }
.crumb b { font-weight: 700 !important; color: var(--ink) !important; }
.card-head h3 { font-size: 16px !important; font-weight: 700 !important; letter-spacing: -.01em !important; }
th { font-size: 12px !important; font-weight: 700 !important; color: var(--muted) !important; letter-spacing: .03em !important; padding: 13px 18px !important; }
td { font-size: 14.5px !important; font-weight: 500 !important; }
.field label { font-size: 13px !important; font-weight: 600 !important; color: var(--ink) !important; }
.field input, .field select, .field textarea { font-size: 14.5px !important; font-weight: 500 !important; }
.btn { font-size: 14px !important; font-weight: 600 !important; }
.badge { font-size: 12px !important; font-weight: 600 !important; }
.kpi .lbl, .kpi-lbl { font-size: 12.5px !important; font-weight: 600 !important; color: var(--muted) !important; }
.kpi .val, .kpi-val { font-size: 28px !important; font-weight: 800 !important; }
.acc-tab { font-size: 14px !important; font-weight: 600 !important; color: var(--muted) !important; }
.acc-tab.active { color: var(--accent-700) !important; }
.acc-tab-ic { color: var(--muted) !important; width: 30px !important; height: 30px !important; }
.acc-tab.active .acc-tab-ic { color: var(--accent) !important; }
.acc-tab-ic svg { stroke: currentColor !important; }
.notif-item { font-size: 14px !important; font-weight: 500 !important; }
.notif-item strong { font-weight: 700 !important; }
.notif-item small { font-size: 12.5px !important; }
.empty { font-size: 14.5px !important; font-weight: 500 !important; color: var(--muted) !important; }
.auth-switch { font-size: 14px !important; }

/* v5 settings bar + modals */
.settings-save-bar {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  margin-top: 20px !important;
  padding-bottom: 0 !important;
}
.content { padding-bottom: 32px !important; }
.modal { max-width: min(920px, calc(100vw - 32px)) !important; margin: 0 auto !important; }
.modal-body { max-height: min(72vh, 720px) !important; overflow-y: auto !important; overflow-x: visible !important; padding: 22px 24px !important; }
.modal-foot { padding: 15px 24px !important; flex-wrap: wrap !important; gap: 10px !important; }
.modal-foot .btn { flex: 0 1 auto !important; min-width: 0 !important; }
.modal-foot.detail-actions { justify-content: flex-end !important; }
.modal-foot.detail-actions .btn { flex: 0 0 auto !important; white-space: nowrap !important; }
.modal .lines { width: 100%; border-collapse: separate; border-spacing: 0; table-layout: fixed; }
.modal .lines th { font-size: 11px !important; padding: 10px 8px !important; white-space: nowrap; }
.modal .lines td { padding: 8px 6px !important; vertical-align: top !important; }
.modal .lines td:first-child { width: 34% !important; }
.modal .lines .num { width: 11% !important; }
.modal .lines input, .modal .lines select { width: 100% !important; min-width: 0 !important; font-size: 13.5px !important; padding: 10px 10px !important; box-sizing: border-box !important; }
.modal .lines .ts-wrapper { width: 100% !important; min-width: 0 !important; }
.modal .lines .ts-control { min-height: 40px !important; }
.modal .lines .line-total { font-size: 13px !important; font-weight: 600 !important; white-space: nowrap; }
.modal .grid2 { gap: 14px !important; }
@media (max-width: 700px) { .modal .grid2 { grid-template-columns: 1fr !important; } }

/* Lignes cliquables + aperçu */
table tbody tr.row-click { cursor: pointer; transition: background .12s; }
table tbody tr.row-click:hover { background: rgba(253,112,32,.06) !important; }
table tbody tr.row-click:active { background: rgba(253,112,32,.1) !important; }
.detail-preview { padding: 0 !important; }
.detail-preview .detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 24px; margin: 0 0 16px; }
.detail-preview .detail-item { min-width: 0; overflow: visible; }
.detail-preview .detail-item label { display: block; font-size: 11px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 4px; }
.detail-preview .detail-item div { font-size: 14px; color: var(--ink); overflow: visible; word-break: break-word; }
.detail-preview .detail-hint { font-size: 13px; color: var(--muted) !important; line-height: 1.55; padding: 12px 16px !important; background: var(--bg-soft); border-radius: var(--radius-sm); margin-bottom: 16px !important; }
.detail-actions { display: flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end; }
#topActions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

/* v6 toggles rouge/vert + modales comptabilité */
.overlay { align-items: center !important; padding: 24px 16px !important; }
.modal { max-height: calc(100vh - 48px); display: flex; flex-direction: column; }
.modal-body { flex: 1 1 auto; min-height: 0; }
.modal-wide { max-width: min(1040px, calc(100vw - 32px)) !important; }
.detail-grid, .modal-body .detail-grid, .detail-preview .detail-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px 24px; margin: 0 0 16px;
}
.detail-item label { display: block; font-size: 11px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; margin-bottom: 4px; }
.detail-item div { font-size: 14px; color: var(--ink); word-break: break-word; }
.detail-hint { font-size: 13px; color: var(--muted) !important; line-height: 1.55; padding: 12px 16px !important; background: var(--bg-soft); border-radius: var(--radius-sm); margin-bottom: 16px !important; }
.acc-content-wrap { overflow-x: auto; }
.acc-content-wrap .card { overflow-x: auto; }
.acc-result-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 900px) { .acc-result-grid { grid-template-columns: 1fr; } .detail-grid, .modal-body .detail-grid { grid-template-columns: 1fr; } }
.toggle-field { margin-bottom: 15px; }
.toggle-label { display: block; font-size: 13px; font-weight: 600; color: var(--ink); margin-bottom: 8px; }
.ld-toggle { display: inline-flex; align-items: center; gap: 12px; cursor: pointer; user-select: none; }
.ld-toggle input { position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none; }
.ld-toggle-track { width: 52px; height: 28px; border-radius: 999px; background: #dc2626; transition: background .2s ease; position: relative; flex-shrink: 0; box-shadow: inset 0 1px 2px rgba(0,0,0,.12); }
.ld-toggle input:checked + .ld-toggle-track { background: #16a34a; }
.ld-toggle-thumb { position: absolute; top: 3px; left: 3px; width: 22px; height: 22px; border-radius: 50%; background: #fff; transition: transform .2s ease; box-shadow: 0 1px 3px rgba(0,0,0,.18); }
.ld-toggle input:checked + .ld-toggle-track .ld-toggle-thumb { transform: translateX(24px); }
.ld-toggle-text { font-size: 13px; font-weight: 600; min-width: 72px; color: #dc2626; }
.ld-toggle input:checked ~ .ld-toggle-text { color: #16a34a; }
.field input[type="checkbox"]:not([data-toggle]) { width: auto; }
