:root{--blue:#173b7a;--blue2:#2563eb;--bg:#f3f6fb;--line:#dce5f2;--text:#071a38}*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text)}.topbar{height:74px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:10}.brand{font-weight:800;text-decoration:none;color:var(--blue);font-size:18px}.topbar nav{display:flex;gap:10px}.topbar nav a,.btn{border:0;text-decoration:none;background:#eaf1ff;color:var(--blue);padding:12px 18px;border-radius:14px;font-weight:800;display:inline-block}.btn.primary{background:var(--blue);color:white}.page{max-width:1180px;margin:0 auto;padding:26px}.hero,.card,.form-shell{background:white;border:1px solid var(--line);border-radius:24px;box-shadow:0 18px 40px rgba(23,59,122,.08);padding:26px;margin-bottom:22px}.hero{display:flex;justify-content:space-between;gap:20px;align-items:center}.hero h1,.form-head h1{margin:0 0 10px;font-size:32px}.chips{display:flex;gap:9px;flex-wrap:wrap}.chips span{background:#f1f5fb;border:1px solid var(--line);border-radius:999px;padding:8px 12px}.chips.vertical{display:grid;gap:8px}.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}.actions{margin-top:18px}.empty,.alert{background:#fff4d6;border:1px solid #f6d887;border-radius:14px;padding:14px}.form-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:22px}.smart-form{display:grid;grid-template-columns:1fr 1fr;gap:18px}.field{display:flex;flex-direction:column;gap:8px}.field.wide,.new-hippo.wide{grid-column:span 1}label{font-weight:800}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:14px;padding:14px 16px;font-size:15px;background:white}input:focus,select:focus,textarea:focus{outline:3px solid rgba(37,99,235,.18);border-color:#7aa2ff}.info-panel{grid-row:span 3;background:linear-gradient(180deg,#f8fbff,#eef5ff);border:1px solid var(--line);border-radius:20px;padding:18px}.new-hippo{grid-column:1/-1;border:1px dashed #a9bee0;background:#f8fbff;border-radius:18px;padding:16px}.mini-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.submit-row{grid-column:1/-1}.runner-form{display:grid;grid-template-columns:70px 2fr repeat(4,1fr);gap:12px}.runner-form textarea{grid-column:1/-1;min-height:80px}.runner-form button{grid-column:1/3}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:13px;border-bottom:1px solid var(--line)}th{background:#f8fbff}.analysis{white-space:pre-wrap;background:#f8fbff;border:1px solid var(--line);border-radius:16px;padding:18px}.login-page{display:grid;place-items:center;min-height:100vh}.login-card{background:white;border:1px solid var(--line);border-radius:24px;padding:34px;box-shadow:0 20px 60px rgba(23,59,122,.12);width:min(420px,92vw)}.login-card .btn{width:100%;margin-top:14px}@media(max-width:850px){.smart-form,.runner-form,.mini-grid{grid-template-columns:1fr}.hero,.form-head{display:block}.field.wide{grid-column:1}.runner-form button{grid-column:1}.topbar{height:auto;display:block}.topbar nav{margin-top:12px;flex-wrap:wrap}.page{padding:14px}}
/* Patch V15 */
.alert-error{background:#ffe5e5;border-color:#ff9b9b;color:#941b1b}.alert-success{background:#e9fbe9;border-color:#a6e3a6;color:#145214}.danger,.btn.danger{background:#ffe1e1!important;color:#a31616!important}.btn.small{padding:8px 12px;border-radius:12px;font-size:13px}.action-stack{display:grid;gap:10px;min-width:230px}.weather-box{margin-top:18px;padding:16px;border-radius:18px;background:#f8fbff;border:1px solid var(--line)}.weather-actions{margin-top:14px}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.form-grid.four{grid-template-columns:repeat(4,1fr)}.form-field label{display:block;font-weight:800;margin-bottom:6px}.form-field input,.form-field select,.form-field textarea{width:100%}.help,.muted{color:#64748b;font-size:13px}.pretty{width:100%;border-collapse:separate;border-spacing:0}.pretty th{background:#f8fbff;color:#64748b}.pretty th,.pretty td{padding:13px;border-bottom:1px solid var(--line);text-align:left}.runner-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;margin:16px 0}.runner-title{display:flex;align-items:center;gap:12px}.runner-num{width:38px;height:38px;border-radius:999px;background:#eaf1ff;display:inline-grid;place-items:center;font-weight:900}.runner-details{display:none;margin-top:15px;border-top:1px solid var(--line);padding-top:15px}.runner-card.open .runner-details{display:block}.gauge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.gauge-box{border-left:5px solid #ddd;background:#fff;border-radius:12px;padding:12px}.gauge-box label{font-weight:900}.gauge-ok{border-left-color:#22c55e}.gauge-warn{border-left-color:#f59e0b}.gauge-missing{border-left-color:#ef4444}.range-row{display:grid;grid-template-columns:1fr 55px;gap:10px;align-items:center}.range-row span{background:#eaf1ff;border-radius:10px;font-weight:900;text-align:center;padding:10px}.gauge-missing .range-row span{background:#ffe1e1;color:#b91c1c}.gauge-warn .range-row span{background:#fff2cc;color:#92400e}.gauge-ok .range-row span{background:#dcfce7;color:#166534}.gauge-box textarea{margin-top:8px;min-height:56px}.score-preview{background:#eef4ff;border:1px solid #d7e4ff;border-radius:18px;padding:18px;font-weight:800;font-size:18px;margin:15px 0}.program-results{margin-top:20px}.card.compact{box-shadow:none}.tipster-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin:18px 0}.tip-card{background:#f8fbff;border:1px solid var(--line);border-radius:18px;padding:18px}.analysis{white-space:pre-wrap;background:#f8fbff;border:1px solid var(--line);border-radius:16px;padding:18px;line-height:1.6}.topbar .navlinks{display:flex;gap:10px}.chip{display:inline-flex;background:#f1f5fb;border:1px solid var(--line);border-radius:999px;padding:8px 12px;margin:3px}@media(max-width:900px){.form-grid,.form-grid.four,.gauge-grid,.tipster-grid{grid-template-columns:1fr}.hero{display:block}.action-stack{margin-top:20px}}
/* Patch V15.2 — présentation import et tableaux */
.table-wrap{overflow-x:auto}.pretty td{vertical-align:middle}.row-actions{display:flex;gap:8px;flex-wrap:wrap}.import-page{max-width:1180px;margin-left:auto;margin-right:auto}.sources-panel{margin:14px 0}.sources-panel summary{cursor:pointer}.sources-panel ul{max-height:180px;overflow:auto;margin:10px 0 0}.import-card{padding:14px 16px}.import-title{display:grid;grid-template-columns:auto 42px minmax(220px,1fr) auto auto auto;gap:12px;align-items:center}.import-check{display:flex;align-items:center;gap:6px;font-weight:800}.runner-main{display:flex;flex-direction:column;gap:4px}.runner-main small{color:#64748b}.pill{background:#eaf1ff;color:var(--blue);font-weight:900;border-radius:999px;padding:7px 10px;font-size:13px;white-space:nowrap}.pill-ok{background:#dcfce7;color:#166534}.pill-warn{background:#fff2cc;color:#92400e}.pill-missing{background:#ffe1e1;color:#991b1b}.sticky-submit{position:sticky;bottom:18px;box-shadow:0 12px 32px rgba(23,59,122,.22);z-index:4}.runner-details{background:#fbfdff;border-radius:16px}.runner-card:not(.open) .runner-details{display:none!important}.runner-card.open .runner-details{display:block!important}.gauge-box textarea{font-family:inherit;font-size:13px}.alert{margin:12px 0}.alert-error{background:#ffe5e5;border-color:#ff9b9b;color:#941b1b}.alert-success{background:#e9fbe9;border-color:#a6e3a6;color:#145214}@media(max-width:900px){.import-title{grid-template-columns:auto 38px 1fr}.import-title .pill,.import-title .btn.small{grid-column:1/-1}.row-actions{display:grid}}


/* ==================================================
   PATCH UX/UI RESPONSIVE 2026-05 — interface only
   Objectif : lisibilité métier, responsive mobile, workflow visible.
   Aucun calcul / pipeline / SQL métier n'est modifié par ce bloc CSS.
   ================================================== */
:root{
  --ui-bg:#f4f7fb;
  --ui-card:#ffffff;
  --ui-ink:#0f172a;
  --ui-muted:#64748b;
  --ui-soft:#eef4ff;
  --ui-primary:#173b7a;
  --ui-primary-2:#2563eb;
  --ui-green:#16a34a;
  --ui-orange:#f59e0b;
  --ui-red:#dc2626;
  --ui-shadow:0 18px 45px rgba(15,23,42,.08);
}
body{background:radial-gradient(circle at top left,#eef5ff 0,#f8fafc 34%,var(--ui-bg) 100%);line-height:1.45}.container,.page{max-width:1280px;width:100%;margin:0 auto;padding:24px}.topbar{backdrop-filter:saturate(140%) blur(10px);box-shadow:0 8px 30px rgba(15,23,42,.04)}.topbar nav,.topbar .navlinks{align-items:center;overflow-x:auto;padding-bottom:2px}.topbar nav a,.topbar .navlinks a{white-space:nowrap}.brand{letter-spacing:-.02em}.card,.hero,.form-shell{box-shadow:var(--ui-shadow);border-color:#dbe7f5}.card{position:relative;overflow:hidden}.card h2{margin-top:0;letter-spacing:-.02em}.hero{align-items:stretch}.hero h1{font-size:clamp(26px,3.5vw,42px);line-height:1.05}.actions.vertical-actions,.action-stack{display:flex;flex-direction:column;gap:10px;align-items:stretch}.actions.vertical-actions .btn{width:100%;text-align:center}.btn{transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(23,59,122,.14)}.btn:active{transform:translateY(0)}.btn-secondary{border:0;text-decoration:none;background:#173b7a;color:#fff;padding:12px 18px;border-radius:14px;font-weight:800;display:inline-block}.chip,.chips span,.pill{box-shadow:inset 0 0 0 1px rgba(255,255,255,.45)}.muted,.muted-small,.help{color:var(--ui-muted)}.muted-small{font-size:13px}.alert{border-radius:16px}.table-wrap{width:100%;overflow:auto;-webkit-overflow-scrolling:touch;border-radius:18px}.pretty-table,.pretty{min-width:760px}.pretty-table th,.pretty th{position:sticky;top:0;z-index:1}.pretty-table td,.pretty-table th,.pretty td,.pretty th{vertical-align:top}.score-pill,.conf-pill{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:7px 11px;font-weight:900;background:#eaf1ff;color:#173b7a}.ai-score{background:#eef2ff;color:#3730a3}.conf-pill.conf-haute,.conf-pill.high,.conf-pill.elevee{background:#dcfce7;color:#166534}.conf-pill.conf-moyenne,.conf-pill.medium{background:#fef3c7;color:#92400e}.conf-pill.conf-faible,.conf-pill.low{background:#fee2e2;color:#991b1b}.analysis-box{background:#f8fbff;border:1px solid var(--line);border-radius:18px;padding:18px;line-height:1.6}.report-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.report-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.report-metric{background:#f8fbff;border:1px solid var(--line);border-radius:18px;padding:16px}.report-metric strong{display:block;color:var(--ui-muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em}.report-metric span{display:block;font-size:16px;font-weight:900;margin-top:6px}.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}.factor-list{margin:8px 0 14px;padding-left:20px}.factor-list li{margin:5px 0}.runner-card{transition:border-color .15s ease,box-shadow .15s ease}.runner-card:hover{border-color:#bad1ff;box-shadow:0 14px 28px rgba(15,23,42,.07)}

/* Parcours métier course */
.workflow-panel{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--ui-shadow);padding:22px;margin-bottom:22px}.workflow-panel h2{margin:0 0 6px}.workflow-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:16px}.workflow-step{border:1px solid var(--line);background:#f8fbff;border-radius:18px;padding:14px;min-height:120px;display:flex;flex-direction:column;gap:8px}.workflow-step .num{width:32px;height:32px;border-radius:999px;display:grid;place-items:center;background:#eaf1ff;color:var(--ui-primary);font-weight:900}.workflow-step strong{font-size:14px}.workflow-step small{color:var(--ui-muted);line-height:1.35}.workflow-step.done{background:#f0fdf4;border-color:#bbf7d0}.workflow-step.done .num{background:#dcfce7;color:#166534}.workflow-step.todo{background:#fff7ed;border-color:#fed7aa}.workflow-step.todo .num{background:#ffedd5;color:#9a3412}.workflow-step.blocked{background:#f8fafc;color:#64748b}.status-badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 9px;font-size:12px;font-weight:900;width:max-content}.status-badge.done{background:#dcfce7;color:#166534}.status-badge.todo{background:#fef3c7;color:#92400e}.status-badge.blocked{background:#e5e7eb;color:#475569}

/* Grilles et formulaires */
.form-grid,.score-grid,.profile-grid{gap:16px}.form-field,.score-control,.profile-box{min-width:0}.score-control,.profile-box{background:#fbfdff;border-radius:16px;padding:14px}.range-row input[type=range]{accent-color:var(--ui-primary-2)}input,select,textarea{font-family:inherit}.sticky-mobile-actions{position:sticky;bottom:12px;z-index:5}

/* Mode mobile : tableaux -> cartes lisibles */
@media(max-width:900px){
  .container,.page{padding:14px}.topbar{padding:14px 16px}.topbar nav,.topbar .navlinks{margin-top:12px;display:flex;gap:8px}.topbar nav a,.topbar .navlinks a,.btn,.btn-secondary{padding:10px 12px;border-radius:12px;font-size:14px}.hero,.report-header{display:block}.hero .actions,.vertical-actions{margin-top:18px}.card,.hero,.form-shell,.workflow-panel{border-radius:20px;padding:18px}.chips{gap:7px}.chip,.chips span{font-size:13px;padding:7px 10px}.workflow-steps{grid-template-columns:1fr}.workflow-step{min-height:auto}.report-grid,.two-cols{grid-template-columns:1fr}.report-metric{padding:14px}.pretty-table,.pretty{min-width:0;border-collapse:separate;border-spacing:0}.pretty-table thead,.pretty thead{display:none}.pretty-table tbody,.pretty tbody,.pretty-table tr,.pretty tr,.pretty-table td,.pretty td{display:block;width:100%}.pretty-table tr,.pretty tr{background:#fff;border:1px solid var(--line);border-radius:18px;margin:12px 0;padding:10px;box-shadow:0 8px 20px rgba(15,23,42,.05)}.pretty-table tr td,.pretty tr td{border:0!important;border-radius:0!important;background:transparent!important;padding:9px 6px;display:grid;grid-template-columns:42% 1fr;gap:8px;align-items:start}.pretty-table td::before,.pretty td::before{content:attr(data-label);font-weight:900;color:#64748b}.tiny-actions,.row-actions{display:flex;gap:8px}.tiny-actions .btn,.row-actions .btn{flex:1;text-align:center}.analysis-box{padding:14px}.runner-card{padding:14px}.runner-card h3{font-size:17px}.weather-box{padding:14px}.score-preview{position:sticky;bottom:10px;z-index:3}.form-grid,.score-grid,.profile-grid,.smart-form,.runner-form,.mini-grid{grid-template-columns:1fr!important}.form-head{display:block}.action-stack{min-width:0}.import-title{grid-template-columns:1fr!important}.import-title>*{grid-column:auto!important}.table-wrap{overflow:visible}
}
@media(max-width:520px){.topbar nav a,.topbar .navlinks a{font-size:13px}.hero h1{font-size:25px}.card h2{font-size:20px}.pretty-table tr td,.pretty tr td{grid-template-columns:1fr}.pretty-table td::before,.pretty td::before{margin-bottom:2px}.btn,.btn-secondary{width:100%;text-align:center}.report-header [style*="justify-content:flex-end"]{justify-content:stretch!important}.report-header [style*="justify-content:flex-end"]>*{width:100%;text-align:center}}

/* Patch UX 2026-05-21 : blocs rétractables course_view.php */
.ui-collapse{padding:0;overflow:hidden;}
.ui-collapse>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 22px;font-size:1.15rem;font-weight:900;color:var(--blue,#173b7a);background:linear-gradient(180deg,#ffffff,#f8fbff);border-radius:inherit;}
.ui-collapse>summary::-webkit-details-marker{display:none;}
.ui-collapse>summary::after{content:'+';width:30px;height:30px;border-radius:999px;display:inline-grid;place-items:center;background:#eaf1ff;color:var(--blue,#173b7a);font-weight:900;flex:0 0 auto;}
.ui-collapse[open]>summary{border-bottom:1px solid var(--line,#e5e7eb);border-bottom-left-radius:0;border-bottom-right-radius:0;}
.ui-collapse[open]>summary::after{content:'−';}
.ui-collapse .collapse-hint{font-size:12px;font-weight:800;color:#64748b;margin-left:auto;white-space:nowrap;}
.ui-collapse .collapse-body{padding:18px 22px 22px;}
@media(max-width:700px){.ui-collapse>summary{padding:15px 16px;font-size:1rem;align-items:flex-start}.ui-collapse .collapse-hint{display:none}.ui-collapse .collapse-body{padding:15px 16px 18px}}

/* Patch UX 2026-05-21 B — menu smartphone + cartes chevaux mobile */
.mobile-menu-bar{display:flex;align-items:center;gap:14px;justify-content:space-between;min-height:72px;height:auto;}
.user-chip{margin-left:auto;background:#f1f5fb;border:1px solid var(--line,#dce5f2);color:#173b7a;border-radius:999px;padding:8px 12px;font-weight:900;white-space:nowrap;}
.phone-menu{position:relative;}
.phone-menu>summary{list-style:none;cursor:pointer;background:#173b7a;color:#fff;border-radius:14px;padding:11px 15px;font-weight:900;user-select:none;}
.phone-menu>summary::-webkit-details-marker,.phone-submenu>summary::-webkit-details-marker{display:none;}
.phone-menu-panel{position:absolute;right:0;top:calc(100% + 10px);min-width:245px;background:#fff;border:1px solid var(--line,#dce5f2);border-radius:18px;box-shadow:0 20px 45px rgba(15,23,42,.16);padding:12px;z-index:50;display:grid!important;gap:8px;}
.phone-submenu{border:1px solid #e5edf8;border-radius:14px;background:#f8fbff;overflow:hidden;}
.phone-submenu>summary{cursor:pointer;padding:12px 13px;font-weight:900;color:#173b7a;display:flex;justify-content:space-between;align-items:center;}
.phone-submenu>summary::after{content:'›';transform:rotate(90deg);font-size:18px;}
.phone-submenu:not([open])>summary::after{transform:rotate(0deg);}
.phone-submenu a,.phone-menu-panel>a{display:block;text-decoration:none;color:#173b7a;background:#eaf1ff;border-radius:12px;padding:11px 13px;font-weight:800;margin:6px;}
.phone-menu-panel>a.logout-link{background:#ffe1e1;color:#a31616;margin:0;}
.phone-menu-panel nav{display:grid!important;}
.mobile-runner-list{display:none;}
.runner-mobile-card{border:1px solid var(--line,#dce5f2);border-radius:18px;background:#fff;margin:12px 0;padding:13px;box-shadow:0 8px 20px rgba(15,23,42,.05);}
.runner-mobile-card.ok{border-left:5px solid #22c55e}.runner-mobile-card.warn{border-left:5px solid #f59e0b}.runner-mobile-card.bad{border-left:5px solid #ef4444}.runner-mobile-card.manual{border-left:5px solid #94a3b8}
.runner-mobile-head{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;}
.runner-mobile-rank{min-width:38px;height:38px;border-radius:999px;background:#eaf1ff;color:#173b7a;display:grid;place-items:center;font-weight:900;font-size:13px;}
.runner-mobile-title{min-width:0;display:flex;flex-direction:column;gap:3px;}
.runner-mobile-title strong{font-size:15px;line-height:1.15;white-space:normal;overflow-wrap:anywhere;}
.runner-mobile-title span{font-size:12px;color:#64748b;font-weight:800;}
.runner-mobile-score{min-width:46px;height:38px;border-radius:14px;background:#173b7a;color:#fff;display:grid;place-items:center;font-weight:900;}
.runner-mobile-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;}
.runner-mobile-meta span{min-width:0;background:#f8fbff;border:1px solid #e5edf8;border-radius:12px;padding:8px 9px;font-size:13px;line-height:1.25;overflow-wrap:anywhere;}
.runner-mobile-meta b{display:block;color:#64748b;font-size:11px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px;}
.runner-mobile-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;}
.runner-mobile-actions .btn{width:100%;text-align:center;margin:0;}
@media(max-width:900px){
  .topbar.mobile-menu-bar{display:grid;grid-template-columns:1fr auto;gap:10px;padding:12px 14px;align-items:center;}
  .topbar.mobile-menu-bar .brand{font-size:16px;line-height:1.15;}
  .user-chip{grid-column:1/2;grid-row:2;font-size:13px;margin-left:0;width:max-content;max-width:100%;}
  .phone-menu{grid-column:2;grid-row:1 / span 2;justify-self:end;}
  .phone-menu-panel{right:0;min-width:min(82vw,300px);}
  .desktop-runner-table{display:none!important;}
  .mobile-runner-list{display:block;}
}
@media(min-width:901px){
  .phone-menu-panel{min-width:260px;}
  .desktop-runner-table{display:block;}
}
@media(max-width:420px){
  .runner-mobile-meta{grid-template-columns:1fr;}
  .runner-mobile-head{grid-template-columns:auto 1fr;}
  .runner-mobile-score{grid-column:1/-1;width:100%;height:34px;}
}

/* Patch UX 2026-05-21 C — menu demandé + course_view compact */
.btn.disabled,.btn[aria-disabled="true"]{opacity:.48;cursor:not-allowed;pointer-events:none;filter:grayscale(.1)}
.course-action-bar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;position:sticky;top:86px;z-index:8;padding:16px;background:rgba(255,255,255,.94);backdrop-filter:blur(10px)}
.course-action-bar .btn{text-align:center;font-size:16px;padding:14px 16px}
.course-summary-card{align-items:flex-start}.course-summary-card h1{margin-bottom:12px}.course-summary-card .weather-box{padding:13px 14px;margin-top:12px}.course-summary-card .weather-box strong{display:block;margin-bottom:5px}.course-summary-card .weather-actions{margin-top:10px}.course-summary-card .muted{margin:8px 0 0}
.mobile-menu-bar{display:flex;align-items:center;gap:14px}.mobile-menu-bar .brand{margin-right:auto}.course-menu,.user-menu{position:relative}.course-menu>summary,.user-menu>summary{list-style:none;cursor:pointer;border-radius:14px;padding:11px 15px;font-weight:900;user-select:none}.course-menu>summary::-webkit-details-marker,.user-menu>summary::-webkit-details-marker{display:none}.course-menu>summary{background:#173b7a;color:#fff}.user-menu>summary{background:#f1f5fb;color:#173b7a;border:1px solid var(--line,#dce5f2)}.course-menu>summary::after,.user-menu>summary::after{content:' ▾';font-size:12px}.course-menu .phone-menu-panel,.user-menu .phone-menu-panel{position:absolute;right:0;top:calc(100% + 10px);min-width:210px;background:#fff;border:1px solid var(--line,#dce5f2);border-radius:18px;box-shadow:0 20px 45px rgba(15,23,42,.16);padding:10px;z-index:60;display:grid!important;gap:8px}.course-menu .phone-menu-panel a,.user-menu .phone-menu-panel a{display:block;margin:0;text-decoration:none;border-radius:12px;padding:11px 13px;font-weight:850;background:#eaf1ff;color:#173b7a}.user-menu .phone-menu-panel a.logout-link{background:#ffe1e1;color:#a31616}.phone-submenu,.user-chip{display:none!important}
.runner-mobile-card.compact{padding:10px 11px;margin:9px 0;border-radius:15px}.runner-line{display:flex;align-items:center;gap:7px;min-width:0}.runner-line>*{min-width:0}.runner-main-line{justify-content:space-between}.runner-main-line strong{font-size:14px;line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.runner-quality-pill{font-size:11px;font-weight:900;border-radius:999px;background:#f1f5fb;color:#334155;padding:5px 7px;white-space:nowrap}.runner-mobile-card.compact .runner-mobile-score{min-width:40px;height:30px;border-radius:11px;font-size:13px;display:inline-grid;flex:0 0 auto}.runner-person-line,.runner-facts-line{margin-top:7px;justify-content:space-between;font-size:12.5px;color:#334155}.runner-person-line span,.runner-facts-line span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.runner-person-line b,.runner-facts-line b{color:#64748b;font-size:11px;text-transform:uppercase;letter-spacing:.03em}.compact-actions{grid-template-columns:1fr 1fr;margin-top:8px}.compact-actions .btn.small{padding:7px 9px;font-size:12px;border-radius:10px}
@media(min-width:901px){.topbar.mobile-menu-bar{height:70px;display:flex}.topbar.mobile-menu-bar .brand{font-size:19px}.course-menu,.user-menu{display:block}.course-action-bar{top:78px}.course-summary-card .chips{gap:8px}.course-summary-card .chip,.course-summary-card .chips span{font-size:13px}.desktop-runner-table table{font-size:14px}.desktop-runner-table th,.desktop-runner-table td{padding:10px 11px}.card{margin-bottom:18px}}
@media(max-width:900px){.topbar.mobile-menu-bar{display:grid;grid-template-columns:1fr auto auto;gap:8px;padding:10px 12px}.topbar.mobile-menu-bar .brand{font-size:15px}.course-menu{grid-column:2;grid-row:1}.user-menu{grid-column:3;grid-row:1}.course-menu>summary,.user-menu>summary{padding:9px 11px;font-size:13px}.course-menu .phone-menu-panel{right:-48px;min-width:190px}.user-menu .phone-menu-panel{right:0;min-width:165px}.course-action-bar{position:sticky;top:58px;grid-template-columns:repeat(3,1fr);gap:7px;padding:9px;margin-bottom:12px;border-radius:16px}.course-action-bar .btn{width:100%;font-size:13px;padding:10px 7px;border-radius:11px}.course-summary-card{padding:13px 14px}.course-summary-card h1{font-size:21px;margin-bottom:8px}.course-summary-card .chips{gap:5px}.course-summary-card .chip,.course-summary-card .chips span{font-size:11.5px;padding:5px 7px}.course-summary-card .weather-box{padding:10px;margin-top:9px;border-radius:14px}.course-summary-card .weather-actions .btn{padding:8px 10px;font-size:12px}.legend{display:none}.runner-mobile-list{margin-top:8px}.runner-person-line,.runner-facts-line{gap:8px}.runner-main-line strong{max-width:52vw}.runner-quality-pill{max-width:112px;overflow:hidden;text-overflow:ellipsis}.mobile-runner-list{display:block!important}.desktop-runner-table{display:none!important}}
@media(max-width:430px){.topbar.mobile-menu-bar{grid-template-columns:1fr auto auto}.course-action-bar .btn{font-size:12px;padding:9px 5px}.runner-main-line{align-items:flex-start}.runner-main-line strong{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:none}.runner-quality-pill{font-size:10.5px;padding:4px 6px;max-width:88px}.runner-person-line,.runner-facts-line{font-size:12px}.runner-person-line span,.runner-facts-line span{white-space:nowrap}}


/* Patch UX 2026-05-21 D — correction affichage partants desktop/mobile */
/* Desktop : une seule vue, tableau uniquement */
.mobile-runner-list{display:none!important;}
.desktop-runner-table{display:block!important;}

/* Score compact : ne doit pas ressembler à un gros bouton */
.runner-mobile-score{
  min-width:auto!important;
  width:auto!important;
  height:auto!important;
  padding:2px 7px!important;
  border-radius:999px!important;
  background:#edf4ff!important;
  color:#173b7a!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  font-size:12px!important;
  line-height:1.2!important;
  font-weight:900!important;
  box-shadow:none!important;
}

@media(max-width:900px){
  /* Mobile : cartes uniquement, pas de tableau */
  .desktop-runner-table{display:none!important;}
  .mobile-runner-list{display:block!important;}

  .runner-mobile-card.compact{
    padding:9px 10px!important;
    margin:7px 0!important;
    border-radius:13px!important;
  }

  /* Ligne 1 : nom + score + jauges, sans saut vertical inutile */
  .runner-main-line{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) auto auto!important;
    align-items:center!important;
    gap:6px!important;
  }
  .runner-main-line strong{
    max-width:none!important;
    min-width:0!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    white-space:nowrap!important;
    font-size:13.5px!important;
    line-height:1.15!important;
  }
  .runner-quality-pill{
    max-width:none!important;
    font-size:10.5px!important;
    padding:2px 6px!important;
    border-radius:999px!important;
    line-height:1.2!important;
    white-space:nowrap!important;
    background:#f7fafc!important;
  }

  /* Ligne 2 : jockey + entraîneur */
  .runner-person-line,
  .runner-facts-line{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;
    gap:6px!important;
    margin-top:5px!important;
    font-size:11.5px!important;
    line-height:1.2!important;
  }
  .runner-person-line span,
  .runner-facts-line span{
    min-width:0!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    white-space:nowrap!important;
  }
  .runner-person-line b,
  .runner-facts-line b{
    display:inline!important;
    font-size:10.5px!important;
    margin:0 3px 0 0!important;
    letter-spacing:0!important;
  }

  .runner-mobile-actions.compact-actions{
    display:flex!important;
    gap:6px!important;
    margin-top:7px!important;
  }
  .runner-mobile-actions.compact-actions .btn.small{
    width:auto!important;
    flex:0 0 auto!important;
    padding:5px 8px!important;
    font-size:11.5px!important;
    border-radius:9px!important;
  }
}

@media(max-width:430px){
  .runner-main-line{
    grid-template-columns:minmax(0,1fr) auto auto!important;
  }
  .runner-main-line strong{
    white-space:nowrap!important;
    display:block!important;
    font-size:13px!important;
  }
  .runner-quality-pill{
    font-size:10px!important;
    padding:2px 5px!important;
  }
  .runner-person-line,
  .runner-facts-line{
    font-size:11px!important;
  }
}


/* Patch UX 2026-05-21 E — ligne mobile cheval/score/jauges vraiment compacte */
@media(max-width:900px){
  .runner-mobile-card.compact .runner-main-line{
    display:flex!important;
    flex-direction:row!important;
    flex-wrap:nowrap!important;
    align-items:center!important;
    gap:6px!important;
    width:100%!important;
  }
  .runner-mobile-card.compact .runner-main-line strong{
    flex:1 1 auto!important;
    min-width:0!important;
    max-width:none!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    white-space:nowrap!important;
    display:block!important;
    font-size:13px!important;
    line-height:1.15!important;
  }
  .runner-mobile-card.compact .runner-mobile-score{
    flex:0 0 auto!important;
    width:auto!important;
    min-width:0!important;
    max-width:max-content!important;
    display:inline-flex!important;
    padding:2px 6px!important;
    font-size:11.5px!important;
    line-height:1!important;
  }
  .runner-mobile-card.compact .runner-quality-pill{
    flex:0 0 auto!important;
    width:auto!important;
    min-width:0!important;
    max-width:max-content!important;
    display:inline-flex!important;
    padding:2px 5px!important;
    font-size:10px!important;
    line-height:1!important;
  }
}
@media(max-width:380px){
  .runner-mobile-card.compact .runner-main-line{gap:4px!important;}
  .runner-mobile-card.compact .runner-main-line strong{font-size:12.3px!important;}
  .runner-mobile-card.compact .runner-mobile-score{font-size:10.8px!important;padding:2px 5px!important;}
  .runner-mobile-card.compact .runner-quality-pill{font-size:9.5px!important;padding:2px 4px!important;}
}
