/**
 * Famylio — Reseller Portal Design System
 * Version 1.0.0 — 2026-03-04
 *
 * Accent: terra #D4654A (meme univers backoffice)
 * Structure identique au superadmin avec prefixes rs-
 */

/* ══════════════════════════════════════════════════════════════════════════════
   CSS VARIABLES
   ══════════════════════════════════════════════════════════════════════════════ */
:root {
    --bg: #F5F2ED;
    --sidebar-bg: #F0EBE3;
    --sidebar-border: #E4DDD4;
    --terra: #D4654A;
    --terra-soft: #E8846C;
    --terra-glow: rgba(212,101,74,0.1);
    --navy: #2C3340;
    --navy-soft: #4A5568;

    /* Reseller accent = terra */
    --rs-accent: #D4654A;
    --rs-accent-soft: #E8846C;
    --rs-accent-glow: rgba(212,101,74,0.1);
    --rs-accent-hover: rgba(212,101,74,0.07);

    /* Neutrals */
    --slate: #6B7280;
    --slate-light: #9CA3AF;
    --border: #E0DCD5;
    --border-light: #EDE8E0;

    /* Surfaces */
    --white: #FFFFFF;
    --cream: #FFF8F0;
    --cloud: #F5F2ED;
    --card-bg: #FFFFFF;
    --card-shadow: 0 2px 16px rgba(44,51,64,0.06);
    --card-hover: 0 8px 32px rgba(44,51,64,0.1);

    /* Radius */
    --radius: 16px;
    --radius-sm: 10px;
    --radius-xs: 6px;

    /* Status */
    --success: #059669;
    --success-bg: rgba(5,150,105,0.08);
    --warning: #D97706;
    --warning-bg: rgba(217,119,6,0.08);
    --danger: #DC2626;
    --danger-bg: rgba(220,38,38,0.08);
    --info: #3B82F6;
    --info-bg: rgba(59,130,246,0.08);

    --sidebar-w: 240px;
    --topbar-h: 64px;
    --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ══════════════════════════════════════════════════════════════════════════════
   DARK MODE
   ══════════════════════════════════════════════════════════════════════════════ */
html.dark {
    --bg: #1A1D23;
    --sidebar-bg: #1F2229;
    --sidebar-border: #2D3139;
    --navy: #E5E7EB;
    --navy-soft: #9CA3AF;
    --slate: #9CA3AF;
    --slate-light: #6B7280;
    --border: #2D3139;
    --border-light: #252830;
    --white: #252830;
    --cream: #1F2229;
    --cloud: #1A1D23;
    --card-bg: #252830;
    --card-shadow: 0 2px 16px rgba(0,0,0,0.2);
    --card-hover: 0 8px 32px rgba(0,0,0,0.3);
}
html.dark body { color: #E5E7EB; }
html.dark input, html.dark select, html.dark textarea {
    background: #1F2229;
    color: #E5E7EB;
    border-color: #3D4149;
}
html.dark input:focus, html.dark select:focus, html.dark textarea:focus {
    border-color: var(--rs-accent);
}

/* ══════════════════════════════════════════════════════════════════════════════
   RESET & BASE
   ══════════════════════════════════════════════════════════════════════════════ */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html, body { height: 100%; }
body {
    font-family: var(--font);
    background: var(--bg);
    color: var(--navy);
    display: flex;
    overflow: hidden;
    font-size: 14px;
    line-height: 1.5;
}
a { color: var(--rs-accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ══════════════════════════════════════════════════════════════════════════════
   LAYOUT
   ══════════════════════════════════════════════════════════════════════════════ */
.rs-layout { display: flex; width: 100%; height: 100vh; }
.rs-main { flex: 1; display: flex; flex-direction: column; overflow: hidden; min-width: 0; }
.rs-content { flex: 1; overflow-y: auto; padding: 28px 32px; }

/* ══════════════════════════════════════════════════════════════════════════════
   SIDEBAR
   ══════════════════════════════════════════════════════════════════════════════ */
.rs-sidebar {
    width: var(--sidebar-w);
    min-width: var(--sidebar-w);
    height: 100vh;
    background: var(--sidebar-bg);
    border-right: 1px solid var(--sidebar-border);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    z-index: 100;
    transition: transform 0.3s ease;
}
.rs-sidebar::-webkit-scrollbar { width: 4px; }
.rs-sidebar::-webkit-scrollbar-thumb { background: rgba(44,51,64,0.08); border-radius: 4px; }

.rs-sidebar-logo { padding: 20px 24px 8px; text-align: center; }
.rs-sidebar-logo a { display: inline-block; }
.rs-sidebar-logo img { height: 32px; width: auto; }

.rs-sidebar-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin: 4px 20px 16px;
    padding: 5px 12px;
    background: var(--rs-accent-glow);
    color: var(--rs-accent);
    border-radius: 8px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.rs-sidebar-section {
    padding: 12px 24px 6px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--slate-light);
}

.rs-sidebar-nav { list-style: none; padding: 0 12px; }
.rs-sidebar-nav li { margin-bottom: 2px; }
.rs-sidebar-nav a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 12px;
    border-radius: var(--radius-sm);
    color: var(--navy-soft);
    font-size: 13px;
    font-weight: 500;
    transition: all 0.15s;
    text-decoration: none;
}
.rs-sidebar-nav a:hover { background: var(--rs-accent-hover); color: var(--navy); }
.rs-sidebar-nav a.active {
    background: var(--rs-accent-glow);
    color: var(--rs-accent);
    font-weight: 600;
}
.rs-sidebar-nav a i { width: 18px; text-align: center; font-size: 14px; }

.rs-nav-badge {
    margin-left: auto;
    background: var(--rs-accent);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 7px;
    border-radius: 10px;
    min-width: 20px;
    text-align: center;
}

.rs-sidebar-footer {
    margin-top: auto;
    padding: 16px 24px;
    border-top: 1px solid var(--sidebar-border);
    text-align: center;
}

/* ══════════════════════════════════════════════════════════════════════════════
   TOPBAR
   ══════════════════════════════════════════════════════════════════════════════ */
.rs-topbar {
    height: var(--topbar-h);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 28px;
    background: var(--card-bg);
    border-bottom: 1px solid var(--border-light);
}
.rs-topbar-left { display: flex; align-items: center; gap: 16px; }
.rs-topbar-title h1 { font-size: 1.1rem; font-weight: 700; line-height: 1.2; }
.rs-topbar-title p { font-size: .75rem; color: var(--slate); }
.rs-topbar-right { display: flex; align-items: center; gap: 14px; }

.rs-menu-toggle {
    display: none;
    background: none;
    border: none;
    font-size: 18px;
    color: var(--navy);
    cursor: pointer;
}

.rs-dark-toggle {
    background: none;
    border: 1px solid var(--border);
    border-radius: 8px;
    width: 34px;
    height: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--slate);
    transition: all .2s;
}
.rs-dark-toggle:hover { border-color: var(--rs-accent); color: var(--rs-accent); }

.rs-user-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px;
    background: var(--cloud);
    border-radius: 10px;
    font-size: 12px;
    font-weight: 600;
    color: var(--navy);
}
.rs-user-dot {
    width: 8px;
    height: 8px;
    background: var(--success);
    border-radius: 50%;
}

/* ══════════════════════════════════════════════════════════════════════════════
   CARDS & COMPONENTS (memes patterns que superadmin)
   ══════════════════════════════════════════════════════════════════════════════ */
.rs-card {
    background: var(--card-bg);
    border-radius: var(--radius);
    box-shadow: var(--card-shadow);
    padding: 24px;
    transition: box-shadow .2s;
}
.rs-card:hover { box-shadow: var(--card-hover); }
.rs-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
}
.rs-card-header h2 {
    font-size: 1rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* KPI */
.rs-kpi-card {
    background: var(--card-bg);
    border-radius: var(--radius);
    box-shadow: var(--card-shadow);
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    transition: box-shadow .2s;
}
.rs-kpi-card:hover { box-shadow: var(--card-hover); }
.rs-kpi-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}
.rs-kpi-icon.terra   { background: var(--terra-glow); color: var(--terra); }
.rs-kpi-icon.success { background: var(--success-bg); color: var(--success); }
.rs-kpi-icon.info    { background: var(--info-bg);    color: var(--info); }
.rs-kpi-icon.warning { background: var(--warning-bg); color: var(--warning); }
.rs-kpi-label { font-size: .75rem; color: var(--slate); margin-bottom: 2px; }
.rs-kpi-body h3 { font-size: 1.5rem; font-weight: 800; line-height: 1.2; }

/* Grids */
.rs-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.rs-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.rs-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }

/* Table */
.rs-table-wrap { overflow-x: auto; }
.rs-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.rs-table thead th {
    padding: 10px 12px;
    text-align: left;
    font-weight: 600;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--slate);
    border-bottom: 2px solid var(--border);
}
.rs-table tbody td {
    padding: 12px;
    border-bottom: 1px solid var(--border-light);
    vertical-align: middle;
}
.rs-table tbody tr:hover { background: var(--rs-accent-hover); }
.rs-table-empty { text-align: center; padding: 40px 12px !important; color: var(--slate-light); }

/* Buttons */
.rs-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 18px;
    border-radius: var(--radius-sm);
    border: none;
    background: var(--rs-accent);
    color: #fff;
    font-weight: 600;
    font-size: 13px;
    cursor: pointer;
    transition: all .2s;
}
.rs-btn:hover { background: var(--rs-accent-soft); transform: translateY(-1px); }
.rs-btn-sm { padding: 6px 12px; font-size: 12px; }
.rs-btn-outline {
    background: transparent;
    border: 1px solid var(--border);
    color: var(--navy);
}
.rs-btn-outline:hover { border-color: var(--rs-accent); color: var(--rs-accent); background: transparent; }
.rs-btn-icon {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--slate);
    padding: 4px;
    font-size: 14px;
    transition: color .2s;
}
.rs-btn-icon:hover { color: var(--rs-accent); }

/* Badges */
.rs-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 600;
}
.rs-badge-success { background: var(--success-bg); color: var(--success); }
.rs-badge-warning { background: var(--warning-bg); color: var(--warning); }
.rs-badge-danger  { background: var(--danger-bg);  color: var(--danger); }
.rs-badge-info    { background: var(--info-bg);    color: var(--info); }
.rs-badge-terra   { background: var(--terra-glow); color: var(--terra); }

/* Form */
.rs-form-group { margin-bottom: 16px; }
.rs-label { display: block; font-size: 12px; font-weight: 600; margin-bottom: 6px; color: var(--navy); }
.rs-input {
    width: 100%;
    padding: 10px 14px;
    border-radius: var(--radius-xs);
    border: 1px solid var(--border);
    font-family: inherit;
    font-size: 13px;
    transition: border-color .2s;
}
.rs-input:focus { outline: none; border-color: var(--rs-accent); box-shadow: 0 0 0 3px var(--rs-accent-glow); }

/* Toast */
.rs-toast-container { position: fixed; top: 80px; right: 24px; z-index: 9999; }
.rs-toast {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 20px;
    border-radius: var(--radius-sm);
    background: var(--card-bg);
    box-shadow: 0 8px 32px rgba(44,51,64,0.14);
    font-size: 13px;
    font-weight: 500;
    max-width: 400px;
    animation: rsToastIn .3s ease;
}
@keyframes rsToastIn { from { opacity:0; transform:translateX(40px); } to { opacity:1; transform:translateX(0); } }
.rs-toast.success i { color: var(--success); }
.rs-toast.error i { color: var(--danger); }
.rs-toast.info i { color: var(--info); }
.rs-toast-close { background:none; border:none; cursor:pointer; color:var(--slate-light); margin-left:8px; }

/* Empty state */
.rs-empty { text-align: center; padding: 60px 20px; color: var(--slate); }
.rs-empty i { font-size: 48px; color: var(--slate-light); margin-bottom: 16px; display: block; }
.rs-empty h3 { font-size: 1.1rem; margin-bottom: 8px; }

/* Modal */
.rs-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(44,51,64,0.4);
    z-index: 9998;
    display: none;
    align-items: center;
    justify-content: center;
}
.rs-modal-backdrop.open { display: flex; }
.rs-modal {
    background: var(--card-bg);
    border-radius: var(--radius);
    box-shadow: 0 20px 60px rgba(44,51,64,0.15);
    max-width: 520px;
    width: 94%;
    max-height: 85vh;
    overflow-y: auto;
}
.rs-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid var(--border-light);
}
.rs-modal-header h3 { font-size: .95rem; font-weight: 700; display: flex; align-items: center; gap: 8px; }
.rs-modal-close { background: none; border: none; cursor: pointer; color: var(--slate); font-size: 16px; }
.rs-modal-body { padding: 24px; }
.rs-modal-footer { padding: 16px 24px; border-top: 1px solid var(--border-light); display: flex; justify-content: flex-end; gap: 10px; }

/* Copy box */
.rs-copy-box {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--cloud);
    border: 1px solid var(--border);
    border-radius: var(--radius-xs);
    padding: 10px 14px;
}
.rs-copy-box input {
    flex: 1;
    border: none;
    background: transparent;
    font-family: 'Courier New', monospace;
    font-size: 12px;
    color: var(--navy);
}
.rs-copy-box input:focus { outline: none; }

/* Utilities */
.rs-mb-16 { margin-bottom: 16px; }
.rs-mb-24 { margin-bottom: 24px; }
.rs-fw-700 { font-weight: 700; }
.rs-text-small { font-size: 12px; }
.rs-text-xs { font-size: 11px; }
.rs-text-muted { color: var(--slate-light); }
.rs-text-center { text-align: center; }
.rs-text-mono { font-family: 'Courier New', monospace; }

/* Sidebar overlay (mobile) */
.rs-sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.3);
    z-index: 99;
}
.rs-sidebar-overlay.open { display: block; }

/* ══════════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
    .rs-grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .rs-sidebar {
        position: fixed;
        left: 0;
        top: 0;
        transform: translateX(-100%);
        box-shadow: 4px 0 16px rgba(0,0,0,0.08);
    }
    .rs-sidebar.open { transform: translateX(0); }
    .rs-menu-toggle { display: block; }
    .rs-content { padding: 20px 16px; }
    .rs-grid-4, .rs-grid-3, .rs-grid-2 { grid-template-columns: 1fr; }
    .rs-topbar { padding: 0 16px; }
}
