:root{
  --bg:#eef3fb;
  --card:#ffffff;
  --text:#1c2940;
  --muted:#5f6b7a;
  --primary:#6c2ea6;
  --primary-2:#4f1f7d;
  --ok:#0d8d49;
  --ok-bg:#e8fff0;
  --bad:#a62222;
  --bad-bg:#fff1f1;
  --warn:#f39c12;
  --warn-bg:#fff7e8;
  --border:#d7deeb;
  --shadow:0 18px 40px rgba(19,32,61,.08);
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,sans-serif;background:linear-gradient(180deg,#f7f9fe 0%,var(--bg) 100%);color:var(--text);padding:18px}
a{color:var(--primary)}
.wrap{max-width:1260px;margin:0 auto}
.card{background:var(--card);border-radius:18px;padding:22px;box-shadow:var(--shadow);margin-bottom:20px}
.compact-card{margin-bottom:0;padding:16px}
.hero{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.hero img{width:54px;height:54px}
h1,h2,h3{margin:0 0 14px}
p{line-height:1.5}
.small,.muted{color:var(--muted);font-size:14px}
.grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:20px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
label{display:block;margin:14px 0 6px;font-weight:700}
input,select,button{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--border);font-size:16px;background:#fff}
input:focus,select:focus{outline:none;border-color:#8a51c2;box-shadow:0 0 0 4px rgba(108,46,166,.12)}
button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--primary);color:#fff;border:none;font-weight:700;cursor:pointer;text-decoration:none;min-height:46px}
button:hover,.btn:hover{background:var(--primary-2)}
.btn.secondary,.btn-link{background:#edf0f7;color:var(--text)}
.btn.secondary:hover,.btn-link:hover{background:#dfe6f2}
.logout-btn{
  border:1px solid #d7deeb;
  border-radius:12px;
  background:linear-gradient(180deg,#f8fbff 0%,#e8edf6 100%);
  box-shadow:0 8px 18px rgba(19,32,61,.08);
}
.logout-btn:hover{
  background:linear-gradient(180deg,#eef4ff 0%,#dce6f5 100%);
  box-shadow:0 10px 22px rgba(19,32,61,.12);
}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.actions > *{flex:1 1 220px}
.notice{padding:14px 16px;border-radius:12px;margin-bottom:18px}
.notice.success{background:var(--ok-bg);color:#126236;border:1px solid #9bd4b3}
.notice.error{background:var(--bad-bg);color:#8d1f1f;border:1px solid #e0a2a2}
.notice.info{background:#edf5ff;color:#174a84;border:1px solid #b9d1f3}
.pill-row{display:flex;gap:12px;flex-wrap:wrap}
.pill{background:#eef2f8;border-radius:999px;padding:10px 14px;font-weight:700}
.table-responsive{overflow:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;min-width:720px}
th,td{border:1px solid var(--border);padding:12px;text-align:left;vertical-align:top}
th{background:var(--primary);color:#fff;position:sticky;top:0}
.stat-card{background:#f4f7fc;border:1px solid var(--border);border-radius:16px;padding:16px}
.stat-label{color:var(--muted);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.stat-value{font-size:28px;font-weight:800;margin-top:6px}
.stat-sub{margin-top:6px;color:var(--muted);font-size:13px}
.chart-card{padding:18px}
.chart-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.toggle{display:inline-flex;background:#eef2f8;border-radius:999px;padding:4px;gap:4px}
.toggle button{width:auto;border-radius:999px;padding:8px 14px;background:transparent;color:var(--text);border:none;min-height:auto}
.toggle button.active{background:var(--primary);color:#fff}
.chart-wrap{position:relative;background:#fbfcff;border:1px solid var(--border);border-radius:16px;padding:12px}
canvas{width:100%;height:320px;display:block}
.legend{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px;font-size:14px}
.legend-item{display:flex;align-items:center;gap:8px}
.legend-color{width:12px;height:12px;border-radius:99px;display:inline-block}
.score-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.score-box{background:#f7f9fd;border:1px solid var(--border);border-radius:14px;padding:14px}
.score-box strong{display:block;font-size:24px;margin-top:6px}
.auth-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.auth-tabs a{padding:10px 14px;border-radius:999px;text-decoration:none;background:#eef2f8;color:var(--text);font-weight:700}
.auth-tabs a.active{background:var(--primary);color:#fff}
.icon-title{display:flex;align-items:center;gap:12px}
.icon-title img{width:40px;height:40px}
.spacer-top{margin-top:16px}
.center{text-align:center}
.difficulty-badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800;line-height:1.2;border:1px solid var(--border);white-space:nowrap}
.difficulty-one_missing{background:#edf7ed;color:#1f6a2b}
.difficulty-two_missing{background:#fff7e8;color:#8a5a00}
.difficulty-three_missing{background:#ffecec;color:#9a1f1f}
.difficulty-french_only{background:#edf3ff;color:#1e4da1}
.precision-low{color:#e74c3c;font-weight:800}
.precision-mid{color:#f39c12;font-weight:800}
.precision-high{color:#27ae60;font-weight:800}
.admin-banner{background:linear-gradient(135deg,#f4ebff 0%,#eef7ff 100%);border:1px solid #d9c1f7}
@media (max-width:960px){
  body{padding:10px}
  .grid-2{grid-template-columns:1fr}
  .card{padding:16px;border-radius:14px}
  .hero img{width:42px;height:42px}
  .stat-value{font-size:24px}
  .actions{flex-direction:column}
  .actions > *{flex:1 1 auto;width:100%}
  table{min-width:640px}
  canvas{height:260px}
}
@media (max-width:560px){
  h1{font-size:24px}
  h2{font-size:20px}
  h3{font-size:18px}
  input,select,button,.btn{font-size:15px;padding:11px 12px}
  .pill{font-size:13px;padding:8px 12px}
  table{min-width:560px}
  canvas{height:220px}
}


.pill-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.hero-tight{align-items:flex-start}
.game-wrap{max-width:940px}
.game-card{padding:20px}
.game-heading{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap;margin-bottom:10px}
.game-fields{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.game-field-row{display:flex;flex-direction:column;gap:6px;padding:14px;border:1px solid var(--border);border-radius:14px;background:#fbfcff}
.game-field-label{font-weight:800;color:var(--text)}
.game-field-control input{width:100%;font-size:18px;padding:14px 16px;border:2px solid #cfb6ea;border-radius:14px}
.game-fixed-value{padding:13px 14px;border-radius:12px;background:#eef2f8;font-weight:800;font-size:18px}
.game-actions > *{flex:1 1 220px}

@media (max-width:960px){
  .table-responsive{overflow:visible}
  table.mobile-cards, .table-responsive table{min-width:0}
  .table-responsive thead{display:none}
  .table-responsive table, .table-responsive tbody, .table-responsive tr, .table-responsive td{display:block;width:100%}
  .table-responsive tr{background:#fbfcff;border:1px solid var(--border);border-radius:14px;padding:10px;margin-bottom:12px;box-shadow:0 6px 18px rgba(19,32,61,.05)}
  .table-responsive td{border:none;padding:8px 6px;text-align:left}
  .table-responsive td::before{content:attr(data-label);display:block;color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;margin-bottom:3px}
  .chart-wrap{padding:8px}
}

@media (max-width:560px){
  body{padding:8px}
  .wrap{max-width:100%}
  .card{padding:14px;border-radius:14px;margin-bottom:14px}
  .hero{gap:10px}
  .hero p{margin:0}
  .icon-title{align-items:flex-start}
  .pill-grid{grid-template-columns:1fr 1fr;gap:10px}
  .pill{display:flex;align-items:center;justify-content:center;text-align:center;min-height:62px;line-height:1.25;padding:10px}
  .grid-auto{grid-template-columns:1fr 1fr}
  .score-list{grid-template-columns:1fr}
  .auth-tabs{display:grid;grid-template-columns:1fr 1fr}
  .actions{gap:10px}
  .game-wrap{max-width:100%}
  .game-heading{align-items:stretch}
  .game-field-row{padding:12px}
  .game-field-control input,.game-fixed-value{font-size:17px}
  canvas{height:210px}
}

.stacked-cards{display:flex;flex-direction:column;gap:20px;margin-bottom:20px}
.game-card-top{margin-top:0}
.game-status-card{margin-top:0}
@media (max-width:560px){
  .game-card-top{position:relative;top:0}
  .game-heading{margin-bottom:6px}
}


.compact-play-wrap{max-width:1120px}
.compact-game-card{padding:12px 14px}
.game-topline{margin-bottom:8px}
.game-mini-pills{display:flex;flex-wrap:wrap;gap:6px}
.mini-pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;background:#eef2f8;border:1px solid var(--border);font-size:13px;font-weight:800;line-height:1.1;white-space:nowrap}
.compact-game-form{margin-top:4px}
.game-compact-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;align-items:start}
.compact-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:12px;background:#fbfcff;min-height:62px}
.compact-label{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;flex:0 0 auto}
.compact-control{flex:1 1 auto;min-width:0}
.compact-control input{width:100%;font-size:20px;padding:10px 12px;border:2px solid #cfb6ea;border-radius:12px;min-height:44px}
.compact-control .game-fixed-value{padding:10px 12px;border-radius:10px;background:#eef2f8;font-weight:800;font-size:20px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.game-submit-bar{display:flex;gap:8px;align-items:center;margin-top:10px}
.game-submit-bar button{flex:1 1 auto;min-height:46px}
.compact-quit{flex:0 0 auto;min-width:110px}
.compact-feedback{padding:8px 10px;margin-bottom:10px}
.compact-feedback-head{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:6px;font-size:13px}
.feedback-chip-list{display:flex;flex-wrap:wrap;gap:6px}
.feedback-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 8px;border-radius:999px;font-size:12px;line-height:1.2;background:#f4f7fc;border:1px solid var(--border)}
.feedback-chip.ok{background:#eefaf3;border-color:#b8dfc6;color:#146b38}
.feedback-chip.bad{background:#fff3f3;border-color:#efb7b7;color:#972a2a}

@media (max-width:960px){
  .compact-play-wrap{max-width:100%}
  .compact-game-card{padding:10px}
  .game-compact-grid{grid-template-columns:1fr}
  .compact-item{display:grid;grid-template-columns:64px 1fr;gap:8px;padding:6px 8px;min-height:auto}
  .compact-label{font-size:10px;align-self:center}
  .compact-control input{font-size:18px;padding:8px 10px;min-height:40px}
  .compact-control .game-fixed-value{font-size:18px;padding:8px 10px}
  .game-submit-bar{position:sticky;bottom:6px;z-index:20;background:linear-gradient(180deg,rgba(247,249,254,0) 0%,rgba(247,249,254,.95) 18%,rgba(247,249,254,1) 100%);padding-top:8px}
}

@media (max-width:560px){
  .compact-game-card{padding:8px;border-radius:12px}
  .game-topline{margin-bottom:6px}
  .game-mini-pills{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px}
  .mini-pill{font-size:10px;padding:5px 4px;text-align:center;white-space:normal;min-height:34px}
  .compact-feedback{padding:7px 8px;margin-bottom:8px}
  .compact-feedback-head{font-size:12px;margin-bottom:4px}
  .feedback-chip-list{gap:4px}
  .feedback-chip{font-size:10px;padding:4px 6px}
  .game-compact-grid{gap:6px}
  .compact-item{grid-template-columns:58px 1fr;gap:6px;padding:5px 6px;border-radius:10px}
  .compact-label{font-size:9px}
  .compact-control input{font-size:16px;padding:7px 9px;min-height:36px;border-radius:10px}
  .compact-control .game-fixed-value{font-size:16px;padding:7px 9px;border-radius:9px}
  .game-submit-bar{gap:6px;margin-top:8px;padding-top:6px;padding-bottom:2px}
  .game-submit-bar button,.compact-quit{min-height:40px;font-size:15px;padding:9px 10px;border-radius:10px}
  .compact-quit{min-width:82px}
}

.player-stats-stack .card{margin-bottom:0}
.mobile-friendly-table td strong{font-size:15px}

@media (max-width:960px){
  .mobile-friendly-table{overflow:visible}
  .mobile-friendly-table table{min-width:0 !important}
  .mobile-friendly-table thead{display:none}
  .mobile-friendly-table table,
  .mobile-friendly-table tbody,
  .mobile-friendly-table tr,
  .mobile-friendly-table td{display:block;width:100%}
  .mobile-friendly-table tr{background:#fff;border:1px solid var(--border);border-radius:14px;padding:10px 12px;margin-bottom:12px;box-shadow:0 6px 18px rgba(19,32,61,.05)}
  .mobile-friendly-table td{border:none;padding:5px 0;text-align:left}
  .mobile-friendly-table td::before{content:attr(data-label);display:block;color:var(--muted);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
}

/* compact play improvements */
.compact-game-card{padding:8px 10px}
.game-mini-pills{gap:4px}
.mini-pill{font-size:11px;padding:4px 7px;min-height:0}
.game-compact-grid{gap:6px}
.compact-item{padding:6px 8px;min-height:0}
.compact-inline-row{display:flex;align-items:center;gap:8px}
.compact-label-inline{font-size:10px;min-width:52px;max-width:52px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.compact-control input{font-size:18px;padding:8px 10px;min-height:38px}
.compact-control .game-fixed-value{font-size:18px;padding:8px 10px}
.game-submit-bar{display:flex;align-items:center;gap:6px;margin-top:8px;position:sticky;bottom:0;background:linear-gradient(180deg,rgba(247,249,254,0) 0%,rgba(247,249,254,.94) 20%,rgba(247,249,254,1) 100%);padding:6px 0 2px}
.compact-quit{order:1;flex:0 0 auto;min-width:78px;max-width:88px;font-size:12px;min-height:34px;padding:6px 8px}
.game-submit-bar button{order:2;flex:1 1 auto;min-height:34px;padding:7px 10px;font-size:16px}
.feedback-chip-list{gap:4px}
.feedback-chip{font-size:10px;padding:3px 6px}
.compact-feedback-head{font-size:11px}

@media (min-width:961px){
  .compact-inline-row{display:flex;align-items:center;gap:8px}
  .compact-label-inline{min-width:auto;max-width:none;font-size:11px}
  .compact-control .game-fixed-value,.compact-control input{font-size:18px}
  .game-submit-bar{position:static;background:none;padding:0}
  .compact-quit{min-width:90px;font-size:13px}
}

@media (max-width:560px){
  .compact-game-card{padding:6px}
  .game-topline{margin-bottom:4px}
  .game-mini-pills{grid-template-columns:repeat(4,minmax(0,1fr));gap:3px}
  .mini-pill{font-size:9px;padding:3px 4px;line-height:1.05}
  .compact-feedback{padding:5px 6px;margin-bottom:6px}
  .compact-feedback-head{font-size:10px;margin-bottom:3px}
  .feedback-chip{font-size:9px;padding:2px 5px}
  .game-compact-grid{gap:4px}
  .compact-item{padding:4px 6px;border-radius:9px}
  .compact-label-inline{font-size:9px;min-width:48px;max-width:48px}
  .compact-control input{font-size:16px;padding:6px 8px;min-height:32px;border-radius:9px}
  .compact-control .game-fixed-value{font-size:16px;padding:6px 8px;border-radius:8px}
  .game-submit-bar{gap:5px;margin-top:6px;padding-top:4px;padding-bottom:1px}
  .compact-quit{min-width:68px;max-width:72px;font-size:11px;min-height:30px;padding:5px 6px}
  .game-submit-bar button{min-height:30px;font-size:14px;padding:6px 8px}
}

/* Mobile readability pass for dashboard/statistics */
.stats-dashboard{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.stats-dashboard .stat-card{padding:12px 12px 10px;border-radius:14px}
.stats-dashboard .stat-label{font-size:12px;line-height:1.15;margin-bottom:6px}
.stats-dashboard .stat-value{font-size:28px;line-height:1;margin-bottom:4px}
.stats-dashboard .stat-sub{font-size:11px;line-height:1.2}

.review-table table tbody tr,
.verbstats-table table tbody tr,
.history-table table tbody tr{position:relative}

@media (max-width:960px){
  .ranking-table{overflow-x:auto}
  .chart-card{padding:14px}
  .chart-toolbar{gap:10px;align-items:flex-start;flex-direction:column}
  .chart-toolbar .toggle{width:100%;justify-content:flex-start}
  .chart-wrap{padding:8px 4px 2px}
  canvas{height:280px}
  .legend{gap:8px}
  .legend-item{font-size:12px}
  .stats-dashboard{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
  .stats-dashboard .stat-card{padding:10px}
  .stats-dashboard .stat-label{font-size:11px}
  .stats-dashboard .stat-value{font-size:24px}
  .stats-dashboard .stat-sub{font-size:10px}

  .review-table table tbody tr,
  .verbstats-table table tbody tr,
  .history-table table tbody tr{padding:8px 9px;border-radius:12px;margin-bottom:10px}

  .review-table td,
  .verbstats-table td,
  .history-table td{padding:3px 0 !important}

  .review-table td::before,
  .verbstats-table td::before,
  .history-table td::before{font-size:10px;margin-bottom:1px}

  .review-table td strong,
  .verbstats-table td strong,
  .history-table td strong{font-size:14px}
}

@media (max-width:560px){
  .stats-dashboard{grid-template-columns:1fr 1fr;gap:7px}
  .stats-dashboard .stat-card{padding:9px 8px;border-radius:12px}
  .stats-dashboard .stat-label{font-size:10px;margin-bottom:5px}
  .stats-dashboard .stat-value{font-size:21px}
  .stats-dashboard .stat-sub{font-size:9px}

  .review-table table,
  .verbstats-table table,
  .history-table table,
  .review-table tbody,
  .verbstats-table tbody,
  .history-table tbody{display:block}

  .review-table tr,
  .verbstats-table tr,
  .history-table tr{display:grid !important;width:100%;background:#fff;border:1px solid var(--border);border-radius:12px;padding:7px 8px !important;margin-bottom:8px;box-shadow:0 5px 14px rgba(19,32,61,.05)}

  .review-table td,
  .verbstats-table td,
  .history-table td{display:block !important;width:100% !important;border:none;padding:1px 0 !important;min-width:0}

  .review-table td::before,
  .verbstats-table td::before,
  .history-table td::before{display:inline-block;font-size:9px;font-weight:800;color:#93a0b5;text-transform:uppercase;letter-spacing:.03em;margin:0 5px 0 0;vertical-align:baseline}

  .review-table td[data-label="Infinitif"],
  .verbstats-table td[data-label="Infinitif"]{font-size:15px;font-weight:800;color:var(--text);padding-top:0 !important}
  .review-table td[data-label="Infinitif"]::before,
  .verbstats-table td[data-label="Infinitif"]::before{display:none}

  .review-table td[data-label="Prétérit"],
  .review-table td[data-label="Participe passé"],
  .review-table td[data-label="Français"],
  .verbstats-table td[data-label="Prétérit"],
  .verbstats-table td[data-label="Participe passé"],
  .verbstats-table td[data-label="Français"]{font-size:12px;color:#344054;line-height:1.2}

  .review-table td[data-label="Tentatives"],
  .review-table td[data-label="Précision"],
  .review-table td[data-label="Jours"],
  .review-table td[data-label="Priorité"],
  .verbstats-table td[data-label="Tentatives"],
  .verbstats-table td[data-label="Parfaites"],
  .verbstats-table td[data-label="Précision"],
  .verbstats-table td[data-label="Faiblesse"]{display:inline-block !important;width:auto !important;margin:4px 6px 0 0;padding:4px 7px !important;border-radius:999px;background:#f4f7fc;font-size:11px;line-height:1.1}

  .review-table td[data-label="Tentatives"]::before,
  .review-table td[data-label="Précision"]::before,
  .review-table td[data-label="Jours"]::before,
  .review-table td[data-label="Priorité"]::before,
  .verbstats-table td[data-label="Tentatives"]::before,
  .verbstats-table td[data-label="Parfaites"]::before,
  .verbstats-table td[data-label="Précision"]::before,
  .verbstats-table td[data-label="Faiblesse"]::before{margin-right:4px}

  .history-table tr{gap:0}
  .history-table td[data-label="#"]{display:none !important}
  .history-table td[data-label="Date"]{font-size:13px;font-weight:800;color:var(--text);padding-top:0 !important}
  .history-table td[data-label="Date"]::before{display:none}
  .history-table td[data-label="Difficulté"],
  .history-table td[data-label="Base"],
  .history-table td[data-label="Verbes"],
  .history-table td[data-label="Réponses"],
  .history-table td[data-label="Précision"],
  .history-table td[data-label="Temps"],
  .history-table td[data-label="Bonus vitesse"],
  .history-table td[data-label="Score"],
  .history-table td[data-label="Cumul"]{display:inline-block !important;width:auto !important;margin:4px 6px 0 0;padding:4px 7px !important;border-radius:999px;background:#f4f7fc;font-size:11px;line-height:1.1}

  .history-table td .difficulty-badge{font-size:10px;padding:4px 6px}

  .card h2{font-size:18px;line-height:1.15;margin-bottom:6px}
  .small{font-size:12px;line-height:1.35}
  .legend{display:grid;grid-template-columns:1fr 1fr;gap:6px 10px}
  .legend-item{font-size:11px;gap:6px}
  canvas{height:260px}
}


/* Compact mobile cards for verb review/stats and rankings */
@media (max-width: 560px) {
  .verbs-compact-table tr {
    position: relative;
    grid-template-columns: 1fr;
    gap: 0;
    padding: 8px 9px 7px !important;
  }
  .verbs-compact-table td[data-label="Infinitif"] {
    display: inline-block !important;
    width: auto !important;
    font-size: 16px;
    font-weight: 800;
    line-height: 1.1;
    margin: 0;
    padding: 0 !important;
  }
  .verbs-compact-table td[data-label="Prétérit"],
  .verbs-compact-table td[data-label="Participe passé"] {
    display: inline-block !important;
    width: auto !important;
    font-size: 12px;
    color: #516079;
    line-height: 1.15;
    margin: 0 0 0 8px;
    padding: 0 !important;
  }
  .verbs-compact-table td[data-label="Français"] {
    display: block !important;
    width: 100% !important;
    font-size: 12px;
    color: #475467;
    line-height: 1.15;
    margin: 3px 0 0;
    padding: 0 !important;
  }
  .verbs-compact-table td[data-label="Infinitif"]::before,
  .verbs-compact-table td[data-label="Prétérit"]::before,
  .verbs-compact-table td[data-label="Participe passé"]::before,
  .verbs-compact-table td[data-label="Français"]::before {
    display: none !important;
  }
  .verbs-compact-table td[data-label="Tentatives"],
  .verbs-compact-table td[data-label="Parfaites"],
  .verbs-compact-table td[data-label="Précision"],
  .verbs-compact-table td[data-label="Faiblesse"],
  .verbs-compact-table td[data-label="Jours"],
  .verbs-compact-table td[data-label="Priorité"] {
    display: inline-flex !important;
    align-items: center;
    width: calc(50% - 4px) !important;
    margin: 5px 4px 0 0;
    padding: 4px 6px !important;
    border-radius: 9px;
    background: #f5f7fb;
    font-size: 10px;
    line-height: 1.15;
    box-sizing: border-box;
  }
  .verbs-compact-table td[data-label="Tentatives"]::before,
  .verbs-compact-table td[data-label="Parfaites"]::before,
  .verbs-compact-table td[data-label="Précision"]::before,
  .verbs-compact-table td[data-label="Faiblesse"]::before,
  .verbs-compact-table td[data-label="Jours"]::before,
  .verbs-compact-table td[data-label="Priorité"]::before {
    display: inline-block !important;
    margin: 0 4px 0 0 !important;
    font-size: 9px;
    color: #92a0b5;
  }

  .compact-ranking-table tr {
    padding: 8px 9px !important;
    margin-bottom: 8px;
    border-radius: 12px;
  }
  .compact-ranking-table td {
    padding: 2px 0 !important;
    font-size: 11px;
  }
  .compact-ranking-table td::before {
    font-size: 9px;
    margin-bottom: 0;
    margin-right: 4px;
  }
  .compact-ranking-table td[data-label="Joueur"] {
    font-size: 14px;
    padding-top: 0 !important;
  }
  .compact-ranking-table td[data-label="Joueur"]::before {
    display: none;
  }
  .compact-ranking-table td[data-label="#"],
  .compact-ranking-table td[data-label="Score rang"],
  .compact-ranking-table td[data-label="Points"],
  .compact-ranking-table td[data-label="Parties"],
  .compact-ranking-table td[data-label="Précision"],
  .compact-ranking-table td[data-label="Triples"],
  .compact-ranking-table td[data-label="Simple"],
  .compact-ranking-table td[data-label="Double"],
  .compact-ranking-table td[data-label="Triple"] {
    display: inline-block !important;
    width: auto !important;
    margin: 4px 6px 0 0;
    padding: 3px 6px !important;
    border-radius: 999px;
    background: #f4f7fc;
    font-size: 10px;
    line-height: 1.1;
  }
  .compact-ranking-table td[data-label="Email"],
  .compact-ranking-table td[data-label="Dernière activité"] {
    font-size: 10px;
    color: #667085;
  }
}


/* ===== FIX FINAL : COULEUR BULLES UNIQUEMENT ===== */

/* Mes verbes à revoir */
.review-table td[data-label="Tentatives"],
.review-table td[data-label="Précision"],
.review-table td[data-label="Jours"],
.review-table td[data-label="Priorité"]{
  background: #fff0cc !important;
}

/* Stats par verbe */
.verbstats-table td[data-label="Tentatives"],
.verbstats-table td[data-label="Parfaites"],
.verbstats-table td[data-label="Précision"],
.verbstats-table td[data-label="Faiblesse"]{
  background: #efe7fb !important;
}

/* Couleur dynamique précision */
.review-table td.precision-low[data-label="Précision"],
.verbstats-table td.precision-low[data-label="Précision"]{
  background: #ffe1e1 !important;
}

.review-table td.precision-mid[data-label="Précision"],
.verbstats-table td.precision-mid[data-label="Précision"]{
  background: #fff0cc !important;
}

.review-table td.precision-high[data-label="Précision"],
.verbstats-table td.precision-high[data-label="Précision"]{
  background: #e4f7e8 !important;
}


/* ===== Final stable desktop/mobile separation ===== */
.desktop-only{display:block !important}
.mobile-only{display:none !important}
.is-hidden{display:none !important}

/* keep old generic mobile table transforms away from custom desktop blocks */
@media (max-width:960px){
  .desktop-only{display:none !important}
  .mobile-only{display:block !important}
  .mobile-only.mobile-ranking-list,
  .mobile-only.mobile-verb-list,
  .mobile-only.mobile-history-list,
  .mobile-only.admin-player-list{display:flex !important}
}

/* Full-row colors by precision on desktop */
.verb-row.precision-low td{background:#fde3e3 !important}
.verb-row.precision-mid td{background:#fff0d7 !important}
.verb-row.precision-high td{background:#e4f6e8 !important}

/* Mobile ranking base */
.mobile-ranking-list{display:flex;flex-direction:column;gap:10px}
.mobile-rank-card{border:1px solid var(--border);border-radius:14px;padding:10px 12px;background:#fff;box-shadow:0 6px 18px rgba(19,32,61,.05)}
.mobile-rank-top{display:flex;align-items:baseline;gap:8px;justify-content:space-between;flex-wrap:wrap}


.trophy-challenge-card{border:1px solid var(--border);border-radius:12px;padding:12px;margin:10px 0 14px;background:#f7f9fd}
.trophy-challenge-top{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.trophy-challenge-top strong{font-size:15px}
.trophy-challenge-top span{font-weight:800;color:#667085;white-space:nowrap}
.trophy-progress{height:9px;border-radius:999px;background:#e8edf5;overflow:hidden;margin-top:9px}
.trophy-progress span{display:block;height:100%;border-radius:999px;background:#6b7cff;transition:width .2s ease}
.trophy-requirements{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.trophy-requirements span{display:inline-flex;align-items:center;padding:4px 7px;border-radius:999px;background:#eef2f8;color:#667085;font-size:11px;font-weight:800;line-height:1.1}
.trophy-requirements .is-next{background:#fff0d7;color:#925400}
.trophy-requirements .trophy-ok{background:#e4f6e8;color:#177245}
.trophy-hint{margin:8px 0 0}
.trophy-mid .trophy-progress span{background:#38bdf8}
.trophy-near .trophy-progress span{background:#f4b740}
.trophy-ready .trophy-progress span{background:#27ae60}
.trophy-blocked .trophy-progress span{background:#ef6b73}
.trophy-play-btn{position:relative;overflow:hidden;isolation:isolate;box-shadow:0 12px 28px rgba(108,46,166,.24);animation:trophyButtonPulse 2.8s ease-in-out infinite}
.trophy-play-btn::before{content:"";position:absolute;inset:-2px;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.08) 32%,rgba(255,255,255,.55) 48%,rgba(255,255,255,.1) 64%,transparent 100%);transform:translateX(-120%);animation:trophyButtonShine 3.4s ease-in-out infinite;pointer-events:none;z-index:0}
.trophy-play-btn.trophy-mid{background:#0ea5e9}
.trophy-play-btn.trophy-near{background:#d97706}
.trophy-play-btn.trophy-ready{background:#16803d}
.trophy-play-btn.trophy-blocked{background:#c2410c}
.trophy-play-btn.trophy-missing-three{background:linear-gradient(135deg,#dc2626 0%,#f97316 100%);box-shadow:0 14px 30px rgba(220,38,38,.3)}
.trophy-play-btn.trophy-missing-two{background:linear-gradient(135deg,#f59e0b 0%,#facc15 100%);color:#2f2300;box-shadow:0 14px 30px rgba(245,158,11,.32)}
.trophy-play-btn.trophy-missing-translation{background:linear-gradient(135deg,#2563eb 0%,#06b6d4 100%);box-shadow:0 14px 30px rgba(37,99,235,.3)}
.trophy-play-btn:hover{filter:brightness(.94)}
@keyframes trophyButtonPulse{
  0%,100%{transform:translateY(0) scale(1);box-shadow:0 12px 28px rgba(108,46,166,.22)}
  45%{transform:translateY(-1px) scale(1.015);box-shadow:0 18px 36px rgba(108,46,166,.34)}
  60%{transform:translateY(0) scale(1)}
}
@keyframes trophyButtonShine{
  0%,42%{transform:translateX(-120%)}
  70%,100%{transform:translateX(120%)}
}
@media (prefers-reduced-motion:reduce){
  .trophy-play-btn,.trophy-play-btn::before{animation:none}
}
.mobile-rank-trophy{width:64px;height:64px;flex:0 0 64px}
.mobile-rank-id{display:flex;align-items:baseline;gap:6px;min-width:0}
.mobile-rank-pos{font-weight:800;color:var(--muted);white-space:nowrap}
.mobile-rank-name{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mobile-rank-level{font-size:10px;font-weight:800;color:#7e8aa0;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}
.mobile-rank-points{font-weight:800;white-space:nowrap}
.mobile-rank-stats-line{display:flex;flex-wrap:nowrap;gap:5px;margin-top:7px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.mobile-rank-stats-line::-webkit-scrollbar{display:none}
.metric-chip{display:inline-flex;align-items:center;flex:0 0 auto;padding:4px 8px;border-radius:999px;background:#eef2f8;font-size:12px;line-height:1.1;white-space:nowrap}
.empty-mobile-card{padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff}

/* Mobile verb cards compact */
.mobile-verb-list{display:flex;flex-direction:column;gap:8px}
.mobile-verb-card{border:1px solid var(--border);border-radius:12px;padding:8px 10px;box-shadow:0 6px 18px rgba(19,32,61,.05)}
.mobile-verb-card.precision-low{background:#fde3e3}
.mobile-verb-card.precision-mid{background:#fff0d7}
.mobile-verb-card.precision-high{background:#e4f6e8}
.mobile-verb-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px;min-width:0}
.mobile-verb-main{font-size:14px;font-weight:800;line-height:1.05}
.mobile-verb-forms{display:flex;align-items:baseline;gap:9px;min-width:0;font-size:16px;font-weight:800;line-height:1.05;color:var(--text);white-space:nowrap;text-align:left}
.mobile-verb-forms strong{font-size:17px}
.mobile-verb-forms span{font-size:15px;font-weight:800;color:#28364d;overflow:hidden;text-overflow:ellipsis}
.mobile-verb-fr{flex:0 1 42%;font-size:13px;font-weight:800;line-height:1.1;color:#25324a;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mobile-verb-summary{margin-top:5px;font-size:10px;font-weight:700;line-height:1.15;color:#7e8aa0}
.mobile-verb-metrics{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.mobile-verb-metrics .metric-chip{font-size:11px;padding:4px 7px}

/* Mobile history compact */
.mobile-history-list{display:flex;flex-direction:column;gap:8px}
.mobile-history-card{border:1px solid var(--border);border-radius:14px;padding:10px 12px;background:#fff;box-shadow:0 6px 18px rgba(19,32,61,.05)}
.mobile-history-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px}
.mobile-history-top strong{font-size:14px;line-height:1.1}
.mobile-history-line{display:flex;flex-wrap:wrap;gap:6px;margin-top:5px}
.history-more-wrap{text-align:center;margin-top:10px}
.compact-history-table td{white-space:nowrap}

/* ranking table compact on desktop */
.compact-ranking-table table{min-width:0}
.compact-ranking-table td,.compact-ranking-table th{padding:10px}
.ranking-player{display:flex;align-items:center;gap:8px;min-width:0}
.ranking-trophy{width:60px;height:60px;flex:0 0 60px}
.ranking-player strong{display:block;line-height:1.1}
.ranking-level{display:block;margin-top:2px;font-size:10px;font-weight:800;color:#7e8aa0;text-transform:uppercase;letter-spacing:.03em;line-height:1.1}

/* Admin mobile */
.admin-player-list{display:flex;flex-direction:column;gap:8px}
.admin-player-card{border:1px solid var(--border);border-radius:12px;background:#fff;padding:9px 10px;box-shadow:0 6px 18px rgba(19,32,61,.05)}
.admin-player-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.admin-player-id{min-width:0}
.admin-player-id strong{display:block;font-size:15px;line-height:1.1}
.admin-player-id span{display:block;margin-top:2px;color:#667085;font-size:11px;line-height:1.1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.admin-player-points{flex:0 0 auto;font-weight:800;font-size:14px;line-height:1.1;color:var(--text)}
.admin-player-metrics{display:flex;gap:5px;margin-top:7px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.admin-player-metrics::-webkit-scrollbar{display:none}
.admin-difficulty-bars{display:flex;height:7px;overflow:hidden;border-radius:999px;background:#eef2f8;margin-top:8px}
.admin-difficulty-bars span{display:block;min-width:0}
.admin-difficulty-simple{background:#58c87a}
.admin-difficulty-double{background:#f4b740}
.admin-difficulty-triple{background:#ef6b73}
.admin-player-breakdown{display:flex;justify-content:space-between;gap:6px;margin-top:5px;color:#7e8aa0;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.02em}

@media (max-width:560px){
  .mobile-rank-card,.mobile-history-card{padding:9px 10px;border-radius:12px}
  .mobile-verb-card{padding:7px 9px;border-radius:10px}
  .mobile-rank-top{gap:6px}
  .mobile-rank-name{font-size:15px}
  .mobile-rank-trophy{width:56px;height:56px;flex-basis:56px}
  .mobile-rank-level{font-size:9px}
}

/* Presentation restore: compact trophies and continuous table headers */
@media (min-width:961px){
  .table-responsive{
    border:1px solid rgba(157,172,197,.55);
    border-radius:14px;
    background:linear-gradient(180deg,#ffffff 0%,#f7faff 100%);
    box-shadow:0 14px 32px rgba(19,32,61,.07);
  }
  .table-responsive table{
    border-collapse:separate;
    border-spacing:0;
    overflow:hidden;
  }
  .table-responsive thead tr{
    background:linear-gradient(90deg,#6c2ea6 0%,#3158d4 42%,#0ea5e9 100%);
  }
  .table-responsive th{
    background:transparent !important;
    border-color:rgba(255,255,255,.18);
    border-top:0;
    color:#fff;
    text-shadow:0 1px 0 rgba(25,34,60,.18);
  }
  .table-responsive th:first-child{
    border-left:0;
    border-top-left-radius:13px;
  }
  .table-responsive th:last-child{
    border-right:0;
    border-top-right-radius:13px;
  }
  .table-responsive td{
    border-color:#e2e8f4;
    background:rgba(255,255,255,.9);
  }
  .table-responsive tbody tr:nth-child(even) td{background:#f7fbff}
  .table-responsive tbody tr:hover td{background:#eef7ff}
  .ranking-trophy{
    width:44px !important;
    height:44px !important;
    max-width:44px !important;
    max-height:44px !important;
    flex:0 0 44px !important;
    object-fit:contain;
    display:block;
  }
  .ranking-player{gap:7px}
  .ranking-level{font-size:9px}
}
