/* components.css */

/* --- Cards --- */
.card{
    background:var(--card-bg); border:1px solid var(--border);
    border-radius:var(--radius); box-shadow:var(--shadow);
    padding:var(--space-6);
}

/* --- Titres / textes utilitaires --- */
.fs20{ font-size:var(--fs-20); }
.fs18{ font-size:var(--fs-18); }
.muted{ color:var(--muted); }

/* --- Boutons --- */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    border:1px solid transparent;
    border-radius:12px;
    padding:8px 12px;
    font-weight:700;
    letter-spacing:.2px;
    cursor:pointer;
    transition: .18s background, .18s border-color, .18s box-shadow, .18s transform;
    text-decoration:none;
    line-height:1.1;
    font-size:14px;
}
.btn-sm{ padding:6px 10px; font-size:13px; }
.btn-lg{ padding:12px 16px; font-size:15px; }
.btn:active{ transform:translateY(0); }

.btn-primary{
    background:var(--brand); color:#fff; box-shadow:0 8px 16px rgba(0,115,234,.18);
}
.btn-primary:hover{ background:var(--brand-600); box-shadow:0 12px 20px rgba(0,115,234,.24); }

.btn-subtle{
    background:#fff !important;
    color:#0b1324 !important;
    border:1px solid var(--border) !important;
}
.btn-subtle:hover{
    border-color:var(--border-strong) !important;
    background:var(--brand-50) !important;
}

.btn-ghost{
    background:transparent !important; color:var(--brand) !important; border:1px dashed var(--border) !important;
}
.btn-ghost:hover{ background:var(--brand-50); border-color:var(--brand-100); }

/* Héritage de ton ancienne .btn-brand si tu veux garder la classe */
.btn-brand{ composes: btn btn-primary; }

/* --- Badges --- */
.badge{
    display:inline-flex;
    align-items:center;
    gap:6px;
    font-size:12px;
    padding:6px 10px;
    border-radius:999px;
    background:#f3f4f6 !important;
    color:#374151 !important;
    border:1px solid #e5e7eb !important;
}
.badge-success {
    background:var(--success-100) !important;
    color:#065f46 !important;
    border-color:#a7f3d0 !important;
}
.badge-danger{
    background:var(--danger-100);
    color:#991b1b;
    border-color:#fecdd3;
}
.badge-warning{
    background:var(--warning-100) !important;
    color:#854d0e !important;
    border-color:#fde68a !important;
}

/* --- Inputs / Select / Search --- */
.input, input[type="text"], input[type="email"], input[type="search"], input[type="number"], input[type="password"], select, textarea{
    width:100%;
    border:1px solid var(--input-border);
    background:var(--input-bg);
    border-radius:12px;
    padding:12px 14px;
    font-size:var(--fs-15); color:var(--text);
    transition:.18s border, .18s box-shadow, .18s background;
    outline:none;
}
.input:focus, input:focus, select:focus, textarea:focus{
    border-color:var(--brand); box-shadow:0 0 0 3px var(--input-focus);
}
input::placeholder{ color:#9aa7bf; }
select{ background-image: none; }

/* --- Tables --- */
.table{
    width:100%; border-collapse:separate; border-spacing:0;
}
.table thead th{
    font-weight:700; color:var(--muted); text-transform:uppercase; font-size:12px;
    padding:.65rem .75rem; background:#f8fafc; border-bottom:1px solid var(--border);
}
.table td{
    padding:.75rem .8rem; border-bottom:1px solid var(--border);
}
.table tr:hover td{ background:#fbfdff; }

/* --- KPI tuiles --- */
.kpi-row{
    display:grid; grid-template-columns:repeat(4,1fr); gap:12px;
}
@media (max-width: 900px){ .kpi-row{ grid-template-columns:repeat(2,1fr); } }
.kpi{
    background: #fff; border:1px solid var(--border); border-radius:14px; padding:16px;
}
.kpi .kpi-label{ font-size:12px; color:var(--muted); }
.kpi .kpi-value{ font-size:26px; font-weight:800; }
.kpi .kpi-note{ margin-top:6px; }

/* --- Quickbar (barre de recherche/filtre) --- */
.quickbar{
    display:flex; gap:10px; flex-wrap:wrap; align-items:center;
}
.quickbar .input{ min-width:260px; flex:1; }


.form-grid {
    display: grid;
    gap: 1rem;
}
.form-grid label {
    font-weight: 500;
}
.form-grid input,
.form-grid select,
.form-grid textarea {
    border-radius: var(--radius);
    border: 1px solid var(--border);
    padding: .5rem .75rem;
    width: 100%;
}


/* @layer components { ... } si tu segmentes par layer */

.topbar{
    position:sticky; top:0; z-index:1000;
    display:flex; align-items:center; justify-content:space-between;
    padding: var(--space-3) var(--space-6);
    background:#fff; border-bottom:1px solid var(--border);
}

.topbar .brand{
    font-weight:800; letter-spacing:.2px;
    color:var(--brand); text-decoration:none; font-size:var(--fs-18);
}

.topnav{ display:flex; align-items:center; gap: var(--space-4); }

.toplink{
    text-decoration:none; color:var(--text); font-weight:600;
    padding:8px 10px; border-radius:10px; transition:.18s background;
}
.toplink:hover{ background:var(--brand-50); }

.account{ position:relative; }
.account-btn{
    list-style:none; display:flex; align-items:center; gap:8px; cursor:pointer;
    border:1px solid var(--border); border-radius:999px; padding:6px 10px; background:#fff;
    font-weight:600;
}
.account[open] .account-btn{ background:var(--brand-50); border-color:var(--brand-100); }

.account .menu{
    position:absolute; right:0; margin-top:8px; min-width:220px;
    background:#fff; border:1px solid var(--border); border-radius:12px; box-shadow:var(--shadow);
    padding:6px; display:grid; gap:4px;
}
.account .menu a{
    display:block; padding:10px 12px; border-radius:8px;
    text-decoration:none; color:var(--text); font-weight:500;
}
.account .menu a:hover{ background:#f5f7fb; }

.btn {
    border-radius: var(--radius-bootstrap) !important;
}

.btn-primary {
    background: var(--brand) !important;
    color: #fff !important;
    border-color: var(--brand) !important;
}
