/* =============================================================
   admin-compat.css — Mappe les classes legacy de l'admin vers
   les patterns spikto-ui. Permet aux 17 vues /admin/* de rendre
   correctement sans réécriture HTML.
   Toutes les règles sont scopées sur .k-page pour éviter les
   fuites en dehors du design system.
   ============================================================= */

/* Fix : le reset .k-page button{background:none} (spécificité 0,1,1)
   écrase les variantes .k-btn--* (0,1,0). On force la spécificité
   button.k-btn--* (0,1,1 + variant) pour gagner. */
.k-page button.k-btn        {background:var(--k-ink);color:var(--k-cream);}
.k-page button.k-btn--magenta{background:var(--k-magenta);color:#fff;}
.k-page button.k-btn--yellow {background:var(--k-yellow);color:var(--k-ink);}
.k-page button.k-btn--ghost  {background:transparent;color:var(--k-ink);}

/* Header admin */
.k-page .admin-header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin:32px auto 28px;max-width:1200px;flex-wrap:wrap;padding:0 24px;}
.k-page .admin-header h1{font-size:clamp(28px,4vw,44px);margin:8px 0 0;letter-spacing:-.02em;}
.k-page .admin-subnav{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start;}
.k-page .admin-subnav a{padding:7px 14px;background:#fff;border:1.5px solid var(--k-black);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--k-ink);text-decoration:none;box-shadow:2px 2px 0 var(--k-black);transition:transform 150ms,box-shadow 150ms;}
.k-page .admin-subnav a:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--k-black);}
.k-page .admin-subnav a.is-active{background:var(--k-magenta);color:var(--k-cream);}

.k-page .hero-eyebrow{display:inline-block;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.18em;color:var(--k-magenta);}

/* Wrapper admin */
.k-page .admin-stats,.k-page .admin-quick-actions,.k-page .admin-section,.k-page .admin-content{max-width:1200px;margin:0 auto 32px;padding:0 24px;}
.k-page .admin-stats h2,.k-page .admin-quick-actions h2{font-size:18px;margin:24px 0 14px;letter-spacing:-.01em;}

/* Alerts */
.k-page .alert{padding:14px 18px;border:1.5px solid var(--k-black);background:var(--k-magenta);color:var(--k-cream);box-shadow:4px 4px 0 var(--k-black);margin:0 auto 24px;max-width:1200px;font-size:14px;line-height:1.5;}
.k-page .alert-warning{background:var(--k-yellow);color:var(--k-ink);}
.k-page .alert-success{background:#D8EBC0;color:var(--k-ink);}
.k-page .alert-error{background:var(--k-magenta);color:var(--k-cream);}
.k-page .alert-info{background:#C5E7F8;color:var(--k-ink);}
.k-page .alert ul{padding-left:18px;margin:6px 0 0;}
.k-page .alert a{color:inherit;text-decoration:underline;font-weight:700;}

/* Stats */
.k-page .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:24px;}
.k-page .stat-card{padding:18px 20px;background:#fff;border:1.5px solid var(--k-black);box-shadow:4px 4px 0 var(--k-black);}
.k-page .stat-card.big{padding:24px 26px;}
.k-page .stat-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--k-ink-soft);margin-bottom:6px;}
.k-page .stat-value{display:block;font-size:32px;font-weight:900;letter-spacing:-.03em;line-height:1;color:var(--k-ink);}
.k-page .stat-card.big .stat-value{font-size:42px;}
.k-page .stat-hint{display:block;font-size:11px;color:var(--k-ink-mute);margin-top:8px;line-height:1.4;}

/* Surface card */
.k-page .surface{padding:24px 28px;background:#fff;border:1.5px solid var(--k-black);box-shadow:4px 4px 0 var(--k-black);margin:0 0 16px;max-width:1200px;}

/* Action tiles */
.k-page .actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;}
.k-page .action-tile{display:flex;flex-direction:column;gap:6px;padding:20px 22px;text-decoration:none;color:inherit;font-size:14px;transition:transform 200ms,box-shadow 200ms;}
.k-page .action-tile:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--k-black);}
.k-page .action-tile strong{font-size:15px;font-weight:800;}
.k-page .action-tile small{color:var(--k-ink-soft);font-size:12px;line-height:1.5;}

/* Buttons (legacy) */
.k-page .btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:700;border:1.5px solid var(--k-black);background:#fff;cursor:pointer;text-decoration:none;color:var(--k-ink);box-shadow:3px 3px 0 var(--k-black);transition:transform 200ms,box-shadow 200ms;font-family:inherit;}
.k-page .btn:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--k-black);}
.k-page .btn-primary{background:var(--k-magenta);color:var(--k-cream);}
.k-page .btn-secondary{background:var(--k-yellow);color:var(--k-ink);}
.k-page .btn-ghost{background:transparent;box-shadow:none;}
.k-page .btn-ghost:hover{background:var(--k-cream-2);box-shadow:none;transform:none;}
.k-page .btn-sm{padding:6px 12px;font-size:12px;box-shadow:2px 2px 0 var(--k-black);}
.k-page .btn-sm:hover{box-shadow:3px 3px 0 var(--k-black);}
.k-page .btn-lg{padding:14px 26px;font-size:16px;}
.k-page .btn-link{background:none;border:0;color:var(--k-magenta);cursor:pointer;text-decoration:underline;padding:0;font-size:13px;font-weight:600;font-family:inherit;}

/* Badges legacy */
.k-page .badge{display:inline-block;padding:3px 10px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:1.5px solid var(--k-black);background:#fff;}
.k-page .badge-blue{background:var(--k-cyan);color:var(--k-ink);}
.k-page .badge-mint,.k-page .badge-green{background:#D8EBC0;color:var(--k-ink);}
.k-page .badge-amber,.k-page .badge-warning{background:var(--k-yellow);color:var(--k-ink);}
.k-page .badge-red,.k-page .badge-error{background:var(--k-magenta);color:var(--k-cream);}

/* Forms (legacy) */
.k-page .form-group{margin:0 0 16px;}
.k-page .form-group label{display:block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;color:var(--k-ink);}
.k-page .form-group label small{font-weight:400;text-transform:none;letter-spacing:0;color:var(--k-ink-soft);}
.k-page .form-group input[type="text"],.k-page .form-group input[type="email"],.k-page .form-group input[type="number"],.k-page .form-group input[type="datetime-local"],.k-page .form-group input[type="date"],.k-page .form-group input[type="search"],.k-page .form-group input[type="url"],.k-page .form-group input[type="password"],.k-page .form-group input[type="tel"],.k-page .form-group select,.k-page .form-group textarea{width:100%;padding:10px 14px;border:1.5px solid var(--k-black);background:var(--k-cream);font-size:14px;font-family:inherit;color:var(--k-ink);}
.k-page .form-group input:focus,.k-page .form-group select:focus,.k-page .form-group textarea:focus{outline:0;background:#fff;}
.k-page .form-group small.help,.k-page .form-help{display:block;font-size:11px;color:var(--k-ink-soft);margin-top:6px;line-height:1.4;}
.k-page .form-check{display:flex;align-items:flex-start;gap:10px;margin:0 0 14px;font-size:14px;}
.k-page .form-check input[type="checkbox"]{width:18px;height:18px;flex-shrink:0;margin-top:2px;}

/* Tables (legacy) */
.k-page .admin-content table:not(.k-table),.k-page .surface table:not(.k-table){width:100%;border-collapse:collapse;background:#fff;border:1.5px solid var(--k-black);}
.k-page table:not(.k-table) th{background:var(--k-black);color:var(--k-cream);padding:10px 14px;text-align:left;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;border:0;}
.k-page table:not(.k-table) td{padding:10px 14px;border-top:1px solid var(--k-line);font-size:14px;vertical-align:top;}
.k-page table:not(.k-table) tbody tr:hover{background:var(--k-cream-2);}

/* Headings inside admin */
.k-page .admin-stats h2,.k-page .admin-quick-actions h2,.k-page .admin-content h2{font-size:18px;margin:28px 0 14px;letter-spacing:-.01em;font-weight:900;}
.k-page .admin-content h3{font-size:15px;margin:18px 0 10px;font-weight:800;}

/* Pager */
.k-page .pager{display:flex;justify-content:space-between;align-items:center;gap:14px;margin:32px 0;flex-wrap:wrap;}
.k-page .pager-info{font-size:13px;color:var(--k-ink-soft);}

/* Lesson quiz (block editor renderer) */
.k-page .lesson-quiz__option{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fff;border:1.5px solid var(--k-line);font-size:14px;text-align:left;cursor:pointer;font-family:inherit;color:var(--k-ink);transition:border-color .15s,background .15s;}
.k-page .lesson-quiz__option:hover{border-color:var(--k-magenta);}
.k-page .lesson-quiz__option.is-correct{background:#D8EBC0;border-color:var(--k-green);}
.k-page .lesson-quiz__option.is-wrong{background:#FFD0CD;border-color:var(--k-magenta);}
.k-page .lesson-quiz__option.is-correct .lesson-quiz__bullet,.k-page .lesson-quiz__option.is-wrong .lesson-quiz__bullet{font-weight:900;}
.k-page .lesson-quiz__bullet{font-size:18px;width:20px;text-align:center;flex-shrink:0;}
.k-page .lesson-quiz__explain{margin:14px 0 0;padding:10px 14px;background:var(--k-cream-2);border-left:3px solid var(--k-magenta);font-size:13px;line-height:1.55;color:var(--k-ink-soft);}

/* Sortable rows (drag-drop admin) */
.k-page [data-sortable-item]{cursor:default;}
.k-page [data-sortable-item].is-dragging{opacity:.5;}
.k-page [data-sortable-handle]{cursor:grab;color:var(--k-ink-soft);font-size:18px;padding:0 8px;}
.k-page [data-sortable-handle]:active{cursor:grabbing;}
