/* ==========================================================================
   Belgian Masters — Refonte (design tokens + composants)
   Palette « Slate » / fond « Warm sand » / Poppins + JetBrains Mono
   Tout est scope sous .bm pour ne pas impacter le reste du site.
   ========================================================================== */

.bm {
	--paper:#EFE7D6;
	--card:#FFFFFF;
	--ink:#1B1C1E;
	--soft:#54565B;
	--muted:#84868C;
	--line:#E2DCCD;
	--line2:#ECE6D9;
	--dark:#232830;
	--darkSoft:#1A1E25;
	--darkText:#F1F1ED;
	--darkMuted:#B8BCC4;
	--darkMuted2:#7C828C;
	--accent:#CBA24C;
	--onAccent:#232830;
	--kicker:#B9894A;
	--underpar:#B22A1E;
	--display:'Poppins', sans-serif;
	--body:'Poppins', sans-serif;
	--mono:'JetBrains Mono', monospace;
	--phA:color-mix(in srgb, var(--ink) 9%, var(--paper));
	--phB:color-mix(in srgb, var(--ink) 4%, var(--paper));

	min-height:100%;
	background:var(--paper);
	font-family:var(--body);
	color:var(--ink);
}

.bm *, .bm *::before, .bm *::after { box-sizing:border-box; }
.bm img { max-width:100%; }

@keyframes bm-liveDot { 0%,100%{ opacity:1; transform:scale(1); } 50%{ opacity:.3; transform:scale(.7); } }

/* Largeur de contenu centree */
.bm-container { max-width:1320px; margin:0 auto; }

/* ---------------------------------------------------------------- NAV ---- */
.bm-nav {
	display:flex; justify-content:space-between; align-items:center; position:relative;
	padding:22px 34px; background:var(--card); border-bottom:1px solid var(--line);
}
.bm-nav__logo { height:48px; width:auto; display:block; }
.bm-nav__menu {
	display:flex; gap:34px; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
	font:600 12px/1 var(--display); letter-spacing:.06em; text-transform:uppercase;
}
.bm-nav__menu a { color:var(--soft); text-decoration:none; padding-bottom:7px; }
.bm-nav__menu a.is-active { color:var(--dark); border-bottom:2px solid var(--accent); }
.bm-nav__search {
	width:38px; height:38px; border:1px solid var(--dark); border-radius:50%;
	display:flex; align-items:center; justify-content:center; color:var(--dark); font-size:15px;
	text-decoration:none; flex:none;
}
/* Burger (mobile uniquement) */
.bm-nav__burger { display:none; background:none; border:none; color:var(--dark); font-size:22px; cursor:pointer; padding:4px 8px; }

/* --------------------------------------------------------------- HERO ---- */
.bm-hero { position:relative; background:var(--dark); overflow:hidden; }
.bm-hero__halo {
	position:absolute; right:-120px; bottom:-160px; width:480px; height:480px;
	background:radial-gradient(circle, var(--accent) 0%, transparent 68%); opacity:.14;
}
.bm-hero__inner {
	position:relative; display:grid; grid-template-columns:1fr 430px; gap:52px;
	padding:72px 34px 76px; align-items:center; max-width:1320px; margin:0 auto;
}
.bm-kicker {
	display:inline-flex; align-items:center; gap:12px;
	font:700 11px var(--mono); letter-spacing:.2em; color:var(--accent);
}
.bm-kicker__line { width:26px; height:1px; background:var(--accent); }
.bm-hero__title {
	font:700 84px/.92 var(--display); letter-spacing:-.02em; margin:22px 0 0; color:var(--darkText);
}
.bm-hero__title span { color:var(--accent); }
.bm-hero__intro { font-size:16px; line-height:1.65; color:var(--darkMuted); max-width:430px; margin:24px 0 0; }
.bm-hero__cta { display:flex; gap:26px; align-items:center; margin-top:34px; }

.bm-btn {
	display:inline-block; background:var(--accent); color:var(--onAccent);
	font:700 13px var(--display); letter-spacing:.04em; padding:16px 30px; border-radius:3px;
	text-decoration:none; text-transform:uppercase;
}
.bm-link {
	color:var(--darkText); font:600 13px var(--display); letter-spacing:.04em; text-decoration:none;
	border-bottom:1px solid color-mix(in srgb, var(--accent) 60%, transparent); padding-bottom:5px;
}

/* ------------------------------------------------- LEADERBOARD (minimal) - */
.bm-lb {
	background:var(--card); border:1px solid var(--line); border-radius:8px; overflow:hidden;
	box-shadow:0 34px 64px -26px rgba(0,0,0,.55);
}
.bm-lb__head { padding:20px 24px 16px; display:flex; justify-content:space-between; align-items:center; }
.bm-lb__title { font:700 22px var(--display); color:var(--ink); }
.bm-lb__live {
	display:inline-flex; align-items:center; gap:8px;
	font:700 10px var(--mono); letter-spacing:.14em; color:var(--muted);
}
.bm-lb__dot { width:7px; height:7px; border-radius:50%; background:var(--underpar); animation:bm-liveDot 1.4s infinite; }
.bm-lb__dot--static { background:var(--accent); animation:none; }
.bm-lb__tabs { display:flex; gap:26px; padding:0 24px; border-bottom:1px solid var(--line); }
.bm-tab {
	background:none; border:none; font:700 11px var(--display); letter-spacing:.06em; text-transform:uppercase;
	color:var(--muted); border-bottom:2px solid transparent; margin-bottom:-1px; padding:0 0 10px; cursor:pointer;
}
.bm-tab.is-active { color:var(--ink); border-bottom-color:var(--accent); }
.bm-lb__body { padding:4px 24px 8px; }
/* Cross-fade Men/Women : panneaux empiles, opacite croisee + hauteur fluide */
.bm-lb__stage { position:relative; transition:height .45s cubic-bezier(.4,0,.2,1); }
.bm-lb__stage > [data-lb-panel] {
	position:absolute; top:0; left:0; right:0;
	opacity:0; visibility:hidden; pointer-events:none;
	transition:opacity .45s ease, visibility .45s;
}
.bm-lb__stage > [data-lb-panel].is-shown {
	position:relative; opacity:1; visibility:visible; pointer-events:auto;
}
.bm-lb__row {
	display:grid; grid-template-columns:30px 1fr 48px 42px 52px; align-items:baseline;
	padding:13px 0; border-top:1px solid var(--line);
}
.bm-lb__row--head { padding:10px 0 8px; font:700 9px var(--mono); letter-spacing:.08em; color:var(--muted); border-top:0; }
.bm-lb__row--leader { border-top:2px solid var(--ink); }
.bm-lb__pos { font:500 13px var(--mono); color:var(--muted); }
.bm-lb__row--leader .bm-lb__pos { font-weight:700; color:var(--ink); }
.bm-lb__name { font-weight:600; font-size:14px; color:var(--ink); display:inline-flex; align-items:center; gap:6px; text-decoration:none; min-width:0; }
.bm-lb__name span { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
a.bm-lb__name:hover { color:var(--accent); }
.bm-lb__row--leader .bm-lb__name { font-weight:700; }
.bm-lb__today { text-align:center; font:600 13px var(--mono); color:var(--kicker); }
.bm-lb__thru { text-align:center; font:500 12px var(--mono); color:var(--muted); }
.bm-lb__tot { text-align:right; font:700 15px var(--mono); color:var(--ink); } /* rouge (var(--underpar)) applique en inline uniquement si sous le par */
.bm-lb__row--head .c-center { text-align:center; }
.bm-lb__row--head .c-right { text-align:right; }
.bm-lb__trophy { color:var(--accent); font-size:11px; }
.bm-lb__foot {
	display:block; text-align:center; background:var(--card); color:var(--dark);
	font:700 12px var(--display); letter-spacing:.04em; padding:15px; text-decoration:none;
	text-transform:uppercase; border-top:1px solid var(--line);
}

/* --------------------------------------------------------- INFO STRIP ---- */
.bm-info { display:flex; background:var(--card); border-bottom:1px solid var(--line); }
.bm-info__cell { flex:1; padding:20px 34px; border-right:1px solid var(--line2); }
.bm-info__cell:last-child { border-right:0; }
.bm-info__label { font:700 9px var(--mono); color:var(--kicker); letter-spacing:.14em; }
.bm-info__value { font-weight:700; margin-top:6px; color:var(--ink); }
.bm-tee { display:inline-block; width:9px; height:9px; border-radius:50%; vertical-align:middle; margin-right:6px; position:relative; top:-1px; }
.bm-tee--white { background:#fff; border:1px solid #9a948a; }
.bm-tee--blue { background:#2f6fb0; }
.bm-weather__icon { margin-right:10px; font-size:1.55em; vertical-align:-3px; --fa-primary-color:var(--accent); --fa-secondary-color:var(--accent); --fa-secondary-opacity:.38; }

/* --------------------------------------------------------------- NEWS ---- */
.bm-section { padding:60px 34px 8px; background:var(--paper); max-width:1320px; margin:0 auto; }
.bm-section--news { padding:60px 34px 8px; }
.bm-section__head { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:30px; }
.bm-eyebrow { font:700 11px var(--mono); color:var(--kicker); letter-spacing:.16em; }
.bm-section__title { font:700 36px/1 var(--display); letter-spacing:-.01em; color:var(--ink); margin:10px 0 0; }
.bm-seeall { color:var(--dark); font:700 12px var(--display); letter-spacing:.04em; text-decoration:none; text-transform:uppercase; }

.bm-news-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
/* Carte news "B2" : portrait immersif, texte sur l'image, signe presse (tag + filet or + lien) */
.bm-card { position:relative; display:block; text-decoration:none; color:#fff; border-radius:14px; overflow:hidden; aspect-ratio:4/5; background:#23262d; }
.bm-card__img, .bm-card__thumb { position:absolute; inset:0; z-index:0; background-color:#23262d; background-size:cover; background-position:center; transition:transform .45s ease; }
a.bm-card:hover .bm-card__img, a.bm-card:hover .bm-card__thumb { transform:scale(1.05); }
.bm-card::after { content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(to top, rgba(20,22,27,.94) 0%, rgba(20,22,27,.5) 40%, rgba(20,22,27,0) 66%); }
.bm-card__tag { position:absolute; top:14px; left:14px; z-index:3; background:var(--paper); color:var(--ink); font:700 9px var(--mono); letter-spacing:.14em; text-transform:uppercase; padding:6px 11px; border-radius:100px; }
.bm-card__year { position:absolute; top:14px; right:14px; z-index:3; background:rgba(20,22,27,.55); -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px); color:#fff; font:700 9px var(--mono); letter-spacing:.1em; padding:6px 10px; border-radius:100px; }
.bm-card__overlay { position:absolute; left:0; right:0; bottom:0; z-index:2; padding:22px 22px 20px; }
.bm-card__rule { width:30px; height:2px; background:var(--accent); margin-bottom:12px; }
.bm-card__title { font:700 19px/1.26 var(--display); letter-spacing:-.01em; margin:0; color:#fff; }
.bm-card__meta { display:block; margin-top:10px; font:500 10.5px var(--mono); letter-spacing:.06em; color:rgba(255,255,255,.7); }
.bm-card__read { display:inline-block; margin-top:12px; font:700 10px var(--mono); letter-spacing:.12em; text-transform:uppercase; color:var(--accent); }
.bm-card__read i { font-size:9px; margin-left:5px; transition:transform .2s ease; }
a.bm-card:hover .bm-card__read i { transform:translateX(3px); }
.bm-card__play { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; z-index:2; }
.bm-card__play span { width:56px; height:56px; border-radius:50%; background:rgba(255,255,255,.16); -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px); border:1px solid rgba(255,255,255,.55); display:flex; align-items:center; justify-content:center; }
.bm-card__play span::after { content:""; width:0; height:0; border-left:16px solid #fff; border-top:10px solid transparent; border-bottom:10px solid transparent; margin-left:4px; }

/* ----------------------------------------------------------- PALMARES ---- */
.bm-section--palmares { padding:56px 34px; }
.bm-palmares { background:var(--dark); border-radius:10px; padding:40px 42px; }
.bm-palmares__head { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:30px; }
.bm-palmares__eyebrow { font:700 11px var(--mono); color:var(--accent); letter-spacing:.16em; }
.bm-palmares__title { font:700 34px/1 var(--display); letter-spacing:-.01em; color:var(--darkText); margin:10px 0 0; }
.bm-palmares__link { color:var(--accent); font:700 12px var(--display); letter-spacing:.04em; text-decoration:none; text-transform:uppercase; }
.bm-palmares__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:26px; }
.bm-year { border-top:2px solid var(--accent); padding-top:16px; }
.bm-year__n { font:700 30px/1 var(--display); color:var(--accent); }
.bm-year__names { margin-top:16px; }
.bm-year__name { font-weight:600; font-size:15px; color:var(--darkText); }
.bm-year__sep { height:1px; background:color-mix(in srgb, var(--darkText) 16%, transparent); margin:11px 0; }

/* --------------------------------------------------------- SPONSORS ------ */
.bm-sponsors { background:var(--card); padding:44px 34px; border-top:1px solid var(--line); text-align:center; }
.bm-sponsors__title { font:700 22px var(--display); letter-spacing:-.01em; color:var(--ink); }
.bm-sponsors__sub { font:500 11px var(--mono); color:var(--muted); letter-spacing:.06em; margin-top:6px; }
.bm-sponsors__logos { display:flex; align-items:center; gap:56px; flex-wrap:wrap; justify-content:center; margin-top:30px; }
.bm-sponsors__logos img { height:80px; object-fit:contain; }

/* ------------------------------------------------------------- FOOTER ---- */
.bm-footer {
	background:var(--darkSoft); padding:46px 34px; display:grid; grid-template-columns:1.4fr 1fr 1fr;
	gap:40px; border-top:3px solid var(--accent); color:var(--darkMuted);
}
.bm-footer__brand { display:flex; align-items:center; gap:12px; }
.bm-footer__brand img { height:48px; width:auto; display:block; }
.bm-footer__brand-name { font:700 16px/1 var(--display); letter-spacing:.26em; color:var(--darkText); }
.bm-footer__desc { font-size:13px; color:var(--darkMuted2); line-height:1.6; margin:16px 0 0; max-width:300px; }
.bm-footer__label { font:700 10px var(--mono); color:var(--accent); letter-spacing:.12em; margin-bottom:14px; }
.bm-footer__list { font-size:13px; color:var(--darkMuted); line-height:2; }
.bm-footer__list a { color:var(--darkMuted); text-decoration:none; }
.bm-footer__list a:hover { color:var(--darkText); }

/* ============================================ PAGE LEADERBOARD (Dark Table) */
.bm-page { max-width:1320px; margin:0 auto; padding:52px 34px; }
.bm-page__head { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:28px; gap:20px; }
.bm-archive { display:flex; flex-wrap:wrap; align-items:center; gap:14px; }
.bm-archive__lbl { font:700 10px var(--mono); letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.bm-archive a { font:600 13px var(--mono); color:var(--soft); text-decoration:none; padding-bottom:3px; border-bottom:2px solid transparent; }
.bm-archive a:hover { color:var(--ink); }
.bm-archive a.is-active { color:var(--ink); border-bottom-color:var(--accent); }
.bm-page__kicker { font:700 11px var(--mono); color:var(--kicker); letter-spacing:.16em; }
.bm-page__title { font:700 34px/1 var(--display); letter-spacing:-.01em; color:var(--ink); margin:10px 0 0; }
.bm-page__live { display:inline-flex; align-items:center; gap:8px; font:700 10px var(--mono); letter-spacing:.14em; color:var(--muted); white-space:nowrap; }

.bm-page__tabs { display:flex; gap:28px; border-bottom:1px solid var(--line); margin-bottom:24px; }
.bm-page__tab {
	background:none; border:0; cursor:pointer; border-bottom:2px solid transparent;
	font:700 12px var(--display); letter-spacing:.08em; text-transform:uppercase; color:var(--muted);
	text-decoration:none; padding:0 0 12px; margin-bottom:-1px;
}
.bm-page__tab.is-active { color:var(--ink); border-bottom-color:var(--accent); }

.bm-dt { background:var(--dark); border-radius:10px; overflow:hidden; box-shadow:0 18px 44px -22px rgba(0,0,0,.5); }
.bm-dt__head, .bm-dt__row {
	display:grid; grid-template-columns:32px 1fr 132px 36px 36px 44px; align-items:center; column-gap:8px;
}
.bm-dt__head { padding:14px 26px; background:var(--darkSoft); font:700 10px var(--mono); letter-spacing:.1em; color:color-mix(in srgb, var(--darkText) 50%, transparent); }
.bm-dt__head .c-center { text-align:center; }
.bm-dt__head .c-right { text-align:right; }
.bm-lbl-sm { display:none; } /* libelle court (mobile) : "Tot" au lieu de "TOTAL" */

.bm-dt__row {
	padding:15px 26px; border-top:1px solid color-mix(in srgb, var(--darkText) 7%, transparent);
	cursor:pointer; color:var(--darkText); transition:background .15s ease;
}
.bm-dt__row.is-alt { background:color-mix(in srgb, var(--darkText) 2%, transparent); }
.bm-dt__row:hover { background:color-mix(in srgb, var(--darkText) 6%, transparent); }
.bm-dt__pos { font:500 13px var(--mono); color:color-mix(in srgb, var(--darkText) 55%, transparent); }
.bm-dt__name { font:600 14px var(--display); color:var(--darkText); display:inline-flex; align-items:center; gap:5px; min-width:0; line-height:1.25; }
/* nom complet sur 2 lignes plutot que tronque a l'ellipse (comme le leaderboard de la home) */
.bm-dt__name span { min-width:0; overflow-wrap:anywhere; }
.bm-dt__club { font:500 12px var(--mono); color:color-mix(in srgb, var(--darkText) 50%, transparent); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.bm-dt__r { text-align:center; font:500 13px var(--mono); color:color-mix(in srgb, var(--darkText) 60%, transparent); }
.bm-dt__thru { text-align:center; font:500 13px var(--mono); color:color-mix(in srgb, var(--darkText) 42%, transparent); }
.bm-dt__tot { text-align:right; font:700 15px var(--mono); color:var(--darkText); } /* meme taille que le leaderboard home ; rouge (var(--underpar)) en inline si sous le par */
.bm-dt__trophy { color:var(--accent); font-size:11px; flex:none; }
.bm-dt__caret { margin-left:4px; font-size:10px; flex:none; color:color-mix(in srgb, var(--darkText) 35%, transparent); transition:transform .2s ease; }
.bm-dt__row.is-open .bm-dt__caret { transform:rotate(180deg); }
/* Favoris (localStorage) : etoile de la ligne + lignes epinglees en haut. Declare apres
   .is-alt et :hover pour gagner l'egalite de specificite (le fond favori doit primer). */
.bm-dt__fav { flex:none; margin:0 0 0 -2px; padding:1px; background:none; border:0; cursor:pointer; font-size:12px; line-height:1; color:color-mix(in srgb, var(--darkText) 24%, transparent); transition:color .15s ease, transform .1s ease; }
.bm-dt__fav:hover { color:var(--accent); }
.bm-dt__fav.is-on { color:var(--accent); }
.bm-dt__fav:active { transform:scale(.8); }
.bm-dt__row.is-fav { background:color-mix(in srgb, var(--accent) 9%, transparent); }
.bm-dt__row.is-fav:hover { background:color-mix(in srgb, var(--accent) 14%, transparent); }
.bm-dt__row.is-fav-last { box-shadow:inset 0 -2px 0 color-mix(in srgb, var(--accent) 45%, transparent); }
/* Board "Favoris" distinct, affiche au-dessus du classement complet */
.bm-fav { margin-bottom:22px; }
.bm-fav__title { display:flex; align-items:center; gap:9px; margin:0 0 10px 2px; font:700 11px var(--mono); letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }
.bm-fav__title i { font-size:12px; }
.bm-dt--fav { box-shadow:0 0 0 1px color-mix(in srgb, var(--accent) 32%, transparent), 0 14px 36px -20px rgba(0,0,0,.5); }
/* pas de fond dore sur les lignes DANS le board favoris (le cadre + le titre suffisent) */
.bm-dt--fav .bm-dt__row.is-fav { background:transparent; }
.bm-dt--fav .bm-dt__row.is-fav:hover { background:color-mix(in srgb, var(--darkText) 6%, transparent); }
/* libelle de categorie (Men / Ladies) dans le board favoris quand les 2 sont presents */
.bm-fav__group { padding:11px 26px 5px; font:700 9px var(--mono); letter-spacing:.14em; text-transform:uppercase; color:color-mix(in srgb, var(--darkText) 42%, transparent); }
.bm-dt__empty { padding:40px 26px; text-align:center; color:color-mix(in srgb, var(--darkText) 55%, transparent); font:600 13px var(--mono); }

/* Detail depliable : scorecard existante (reutilisee) habillee sombre */
.bm-dt__detail { display:none; background:color-mix(in srgb, #000 16%, var(--dark)); border-top:1px solid color-mix(in srgb, var(--darkText) 7%, transparent); }
.bm-dt__detail.is-open { display:block; }
.bm-dt__box { padding:24px 26px 26px; color:var(--darkText); }

/* En-tete joueur : avatar rond + bouton profil en pilule */
.bm-dt__box .fiche_info { display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.bm-dt__box .fiche_info img { width:46px; height:46px; border-radius:50%; object-fit:cover; background:color-mix(in srgb, var(--darkText) 8%, transparent); border:1px solid color-mix(in srgb, var(--darkText) 16%, transparent); }
.bm-dt__box .fiche_info .btn { display:inline-flex; align-items:center; background:transparent; color:var(--accent); font:700 11px var(--display); text-transform:uppercase; letter-spacing:.08em; padding:9px 16px; border:1px solid color-mix(in srgb, var(--accent) 45%, transparent); border-radius:100px; text-decoration:none; transition:background .15s ease, color .15s ease; }
.bm-dt__box .fiche_info .btn:hover { background:var(--accent); color:var(--onAccent); }

/* Scorecard : grille de pastilles de score */
.bm-dt__box .scoreCard { overflow-x:auto; padding-bottom:2px; }
.bm-dt__box table { border-collapse:separate; border-spacing:3px; font:600 12px var(--mono); }
.bm-dt__box th, .bm-dt__box td { width:30px; min-width:30px; height:30px; padding:0; text-align:center; vertical-align:middle; border:0; border-radius:5px; color:var(--darkText); }
.bm-dt__box th { font-weight:700; font-size:11px; color:color-mix(in srgb, var(--darkText) 42%, transparent); background:transparent; }
/* libelles de ligne (Hole / Par / Round n) */
.bm-dt__box th:first-child, .bm-dt__box td:first-child { width:auto; min-width:78px; text-align:left; padding-left:2px; padding-right:12px; white-space:nowrap; background:transparent; }
.bm-dt__box td:first-child { font-weight:700; color:color-mix(in srgb, var(--darkText) 72%, transparent); }
/* cellules de score : fond neutre par defaut */
.bm-dt__box td { background:color-mix(in srgb, var(--darkText) 7%, transparent); }
/* totaux OUT / IN / TOTAL : mis en avant, sans pastille */
.bm-dt__box .tot { background:transparent !important; color:var(--darkText) !important; font-weight:700; font-size:13px; }
/* couleurs golf (reprises du site) */
.bm-dt__box td.eagle  { background:#EE5A00 !important; color:#2a1c0c !important; }
.bm-dt__box td.birdie { background:#F7B942 !important; color:#2c2208 !important; }
.bm-dt__box td.par    { background:color-mix(in srgb, var(--darkText) 14%, transparent) !important; color:var(--darkText) !important; }
.bm-dt__box td.bogey  { background:#A9CFF2 !important; color:#152537 !important; }
.bm-dt__box td.dbogey { background:#37AADD !important; color:#06222f !important; }

/* Legende */
.bm-dt__box .legend { display:flex; flex-wrap:wrap; gap:18px; margin-top:18px; padding-top:16px; border-top:1px solid color-mix(in srgb, var(--darkText) 8%, transparent); font:600 10px var(--mono); letter-spacing:.08em; text-transform:uppercase; color:color-mix(in srgb, var(--darkText) 55%, transparent); }
.bm-dt__box .scorecard_legend { display:inline-flex; align-items:center; gap:7px; }
.bm-dt__box .scorecard_legend > div:first-child { width:12px; height:12px; border-radius:50%; }
.bm-dt__box .scorecard_legend .eagle  { background:#EE5A00; }
.bm-dt__box .scorecard_legend .birdie { background:#F7B942; }
.bm-dt__box .scorecard_legend .par    { background:#6a6f78; }
.bm-dt__box .scorecard_legend .bogey  { background:#A9CFF2; }
.bm-dt__box .scorecard_legend .dbogey { background:#37AADD; }
.bm-dt__box .loading { color:color-mix(in srgb, var(--darkText) 55%, transparent); font:600 12px var(--mono); padding:6px 0; }

@media (max-width:760px) {
	.bm-page { padding:32px 16px; }
	.bm-page__title { font-size:26px; }
	/* l'entete de page passe a la ligne : le titre garde sa largeur, la recherche/badge descend */
	.bm-page__head { flex-wrap:wrap; align-items:flex-start; }
	.bm-dt__head, .bm-dt__row { grid-template-columns:24px 1fr 28px 34px; column-gap:6px; }
	.bm-lbl-lg { display:none; } .bm-lbl-sm { display:inline; } /* "Tot" au lieu de "TOTAL" */
	/* on masque CLUB (col 3) + R1 (col 4) dans l'entete ET les lignes (nth-child = header et
	   cellules alignes) : on garde POS / PLAYER / R2 / TOTAL. Le nom recupere la place. */
	.bm-dt__head > *:nth-child(3), .bm-dt__row > *:nth-child(3),
	.bm-dt__head > *:nth-child(4), .bm-dt__row > *:nth-child(4) { display:none; }
	.bm-dt__tot { font-size:14px; } /* aligne sur le leaderboard home en mobile */
	/* noms plus compacts sur mobile (Poppins prend de la place, wrappe sur 2 lignes) */
	.bm-dt__name { font-size:12.5px; line-height:1.18; }
	.bm-dt__pos { font-size:12px; }
	.bm-dt__r { font-size:12px; }
	.bm-dt__row { padding-top:12px; padding-bottom:12px; }
	.bm-dt__row, .bm-dt__head { padding-left:16px; padding-right:16px; }
	/* le scroll horizontal ne concerne que la scorecard (.scoreCard a deja overflow-x:auto),
	   pas la legende ni l'image du trou */
	.bm-dt__box { padding:14px 16px; }
}

/* ================================================ PAGE PLAYER PROFILE ===== */
.bm-player__back { display:inline-block; font:600 12px var(--mono); letter-spacing:.04em; color:var(--soft); text-decoration:none; margin-bottom:18px; }
.bm-player__back:hover { color:var(--ink); }

.bm-player__hero {
	display:flex; align-items:center; gap:30px; background:var(--dark); border-radius:10px;
	padding:34px 38px; box-shadow:0 18px 44px -22px rgba(0,0,0,.5); color:var(--darkText);
}
.bm-player__avatar {
	width:104px; height:104px; border-radius:50%; object-fit:cover; flex:none;
	border:2px solid color-mix(in srgb, var(--accent) 45%, transparent);
	background:color-mix(in srgb, var(--darkText) 8%, transparent);
}
.bm-player__id { flex:1; min-width:0; }
.bm-player__eyebrow { font:700 10px var(--mono); letter-spacing:.16em; color:var(--accent); }
.bm-player__name { font:700 40px/1.05 var(--display); letter-spacing:-.01em; color:var(--darkText); margin:10px 0 0; display:flex; align-items:center; gap:10px; }
.bm-player__trophy { color:var(--accent); font-size:20px; }
.bm-player__club { font:500 13px var(--mono); color:var(--darkMuted); margin-top:8px; }
.bm-player__stats { display:flex; gap:34px; flex:none; }
.bm-player__stat { text-align:right; }
.bm-player__statval { font:700 30px var(--mono); color:var(--accent); line-height:1; }
.bm-player__statlabel { font:700 10px var(--mono); letter-spacing:.12em; text-transform:uppercase; color:var(--darkMuted2); margin-top:8px; }

.bm-player__sectitle { font:700 18px var(--display); color:var(--ink); margin:34px 0 14px; }
.bm-player__card { background:var(--dark); border-radius:10px; overflow:hidden; box-shadow:0 18px 44px -22px rgba(0,0,0,.5); }

.bm-perf { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.bm-perf__item { background:var(--card); border:1px solid var(--line); border-radius:8px; padding:18px; }
.bm-perf__n { font:700 30px var(--mono); color:var(--ink); line-height:1; }
.bm-perf__bar { height:5px; border-radius:100px; background:var(--line2); margin:14px 0 12px; overflow:hidden; }
.bm-perf__bar span { display:block; height:100%; border-radius:100px; }
.bm-perf__label { font:600 10px var(--mono); letter-spacing:.06em; text-transform:uppercase; color:var(--muted); display:flex; align-items:center; gap:7px; }
.bm-perf__dot { width:10px; height:10px; border-radius:50%; flex:none; }

.bm-player__sub { font:600 11px var(--mono); letter-spacing:.04em; color:var(--muted); text-transform:none; margin-left:6px; }

/* Hole by hole (flyover parcours, integre a la scorecard) */
.bm [hidden] { display:none !important; } /* l'attribut hidden doit primer sur display:flex/block */
/* pas de padding-top ici : l'overlay (absolu, top:0) doit s'aligner sur le haut du stage */
.bm-dt__box .bm-holes { margin-top:30px; }
/* Trous detoures (fond transparent) sur un fond uniforme, identique a tous les trous. */
.bm-holes { position:relative; } /* contexte pour l'overlay (overlaye en desktop, barre en mobile) */
.bm-holes__stage { position:relative; height:320px; background:#1e1e0f; border-radius:10px; overflow:hidden; }
/* contain = trou entier (jamais tronque) ; hauteur de stage commune a tous les trous.
   width:82% = espace (fond du stage) a gauche/droite. */
.bm-holes__img { position:absolute; top:0; bottom:0; left:50%; transform:translateX(-50%); width:82%; height:100%; object-fit:contain; object-position:center; display:block; }
.bm-holes__placeholder { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font:600 12px var(--mono); letter-spacing:.12em; text-transform:uppercase; color:color-mix(in srgb, var(--darkText) 42%, transparent); }
.bm-holes__overlay { position:absolute; top:0; left:0; padding:24px 30px 26px; display:flex; flex-direction:column; gap:14px; background:linear-gradient(135deg, rgba(20,23,28,.82) 0%, rgba(20,23,28,.4) 55%, transparent 100%); border-radius:10px 0 22px 0; }
.bm-holes__num { font:700 66px/.9 var(--display); color:var(--darkText); text-shadow:0 2px 12px rgba(0,0,0,.55); }
.bm-holes__facts { display:flex; gap:26px; }
.bm-holes__fact { display:flex; flex-direction:column; gap:4px; }
.bm-holes__fact > span { font:700 9px var(--mono); letter-spacing:.16em; color:var(--accent); }
.bm-holes__fact b { font:700 22px var(--mono); color:var(--darkText); line-height:1; }
.bm-holes__tees { display:flex; flex-wrap:wrap; gap:8px; }
.bm-holes__tee { display:inline-flex; align-items:center; gap:6px; font:700 12px var(--mono); color:var(--darkText); background:rgba(0,0,0,.34); padding:5px 11px 5px 7px; border-radius:100px; }
.bm-holes__teedot { width:13px; height:13px; border-radius:50%; flex:none; box-shadow:0 0 0 1px rgba(255,255,255,.45); }
.bm-holes__teeu { font-weight:500; color:color-mix(in srgb, var(--darkText) 58%, transparent); margin-left:1px; }
/* En-tetes de trou de la scorecard = selecteur du flyover */
.scoreCard th.bm-h { cursor:pointer; transition:color .12s ease, background .12s ease, box-shadow .12s ease; }
.scoreCard th.bm-h:hover { color:var(--accent); }
/* trou en cours : anneau doré persistant ; trou selectionne : pastille pleine */
.bm-dt__box th.bm-h.is-current { box-shadow:inset 0 0 0 2px var(--accent); color:var(--accent); font-weight:700; border-radius:5px; }
.bm-dt__box th.bm-h.is-active { background:var(--accent) !important; color:var(--onAccent) !important; font-weight:700; box-shadow:none; }
/* Colonne entiere cliquable : survol = highlight de toute la colonne */
.bm-dt__box .bm-col { position:relative; cursor:pointer; }
.bm-dt__box .bm-col.is-col-hover::after { content:""; position:absolute; inset:0; border-radius:5px; background:color-mix(in srgb, var(--accent) 18%, transparent); pointer-events:none; }

/* Order of Merit */
.bm-oom { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.bm-oom__item { background:var(--card); border:1px solid var(--line); border-radius:8px; padding:20px 22px; }
.bm-oom__pos { font:700 30px var(--mono); color:var(--accent); line-height:1; }
.bm-oom__name { font:700 14px var(--display); color:var(--ink); margin:12px 0 5px; }
.bm-oom__meta { font:500 11px var(--mono); letter-spacing:.04em; color:var(--muted); }

/* Season results (carte sombre) */
.bm-results { padding:6px 26px 12px; }
.bm-results__row { display:grid; grid-template-columns:64px 1fr 120px; align-items:center; padding:13px 0; border-top:1px solid color-mix(in srgb, var(--darkText) 7%, transparent); color:var(--darkText); }
.bm-results__row--head { border-top:0; padding:12px 0; font:700 10px var(--mono); letter-spacing:.1em; color:color-mix(in srgb, var(--darkText) 50%, transparent); }
.bm-results .c-right { text-align:right; }
.bm-results__pos { font:700 14px var(--mono); color:var(--accent); }
.bm-results__name { font:600 13px var(--display); color:var(--darkText); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.bm-results__date { font:500 12px var(--mono); color:color-mix(in srgb, var(--darkText) 55%, transparent); }

@media (max-width:760px) {
	.bm-player__hero { flex-direction:column; align-items:flex-start; gap:18px; padding:24px; }
	.bm-player__name { font-size:30px; }
	.bm-player__stats { gap:24px; }
	.bm-player__stat { text-align:left; }
	.bm-perf { grid-template-columns:1fr 1fr; }
	.bm-oom { grid-template-columns:1fr; }
	.bm-results__row { grid-template-columns:50px 1fr 90px; }
	.bm-scsub-hint { display:none; }
	.bm-player__sectitle { font-size:16px; }
	/* mobile : on montre le trou ENTIER (ratio de l'image, pleine largeur) au lieu de
	   rogner les cotes ; pas de bandes laterales sur petit ecran */
	/* mobile : image a sa hauteur naturelle (trou entier, sans letterbox) ; infos en dessous */
	.bm-holes__stage { height:auto; aspect-ratio:auto; min-height:120px; display:flex; align-items:center; justify-content:center; }
	.bm-holes__img { position:static; left:auto; transform:none; width:100%; height:auto; }
	/* infos hors de l'image : barre sous la vue (n'empiete plus sur le trou) */
	.bm-holes__overlay { position:static; flex-direction:row; align-items:center; flex-wrap:wrap; gap:10px 22px; padding:14px 2px 2px; background:none; border-radius:0; }
	.bm-holes__num { font-size:30px; text-shadow:none; line-height:1; }
	.bm-holes__facts { gap:22px; }
	.bm-holes__fact { flex-direction:row; align-items:baseline; gap:7px; }
	.bm-holes__fact b { font-size:18px; }
	.bm-holes__tee { font-size:13px; background:none; padding:0; }
	/* scorecard : defilement horizontal fluide sur mobile */
	.bm-dt__box .scoreCard { -webkit-overflow-scrolling:touch; }
}

/* ============================================== PAGE ENTRY LIST =========== */
.bm-el__search { display:flex; align-items:center; gap:10px; border:1px solid var(--line); border-radius:3px; padding:10px 16px; background:var(--card); color:var(--muted); font:500 13px var(--mono); }
.bm-el__search input { border:0; outline:0; background:none; font:400 14px var(--body); color:var(--ink); min-width:180px; }
.bm-el__search input::placeholder { color:var(--muted); }
.bm-page__count { font:700 10px var(--mono); color:var(--muted); margin-left:5px; }
.bm-page__tab.is-active .bm-page__count { color:var(--accent); }

/* tableau sombre, aligne sur le leaderboard / palmares */
.bm-el { background:var(--dark); border-radius:10px; overflow:hidden; box-shadow:0 18px 44px -22px rgba(0,0,0,.5); }
.bm-el__head, .bm-el__row { display:grid; grid-template-columns:48px 1fr 90px 1.1fr; align-items:center; column-gap:12px; }
.bm-el__head { padding:14px 26px; background:var(--darkSoft); font:700 10px var(--mono); letter-spacing:.1em; color:color-mix(in srgb, var(--darkText) 50%, transparent); }
.bm-el__row { padding:14px 26px; border-top:1px solid color-mix(in srgb, var(--darkText) 7%, transparent); text-decoration:none; color:var(--darkText); transition:background .15s ease; }
.bm-el__row:hover { background:color-mix(in srgb, var(--darkText) 6%, transparent); }
.bm-el__num { font:500 13px var(--mono); color:color-mix(in srgb, var(--darkText) 55%, transparent); }
.bm-el__name { font:600 14px var(--display); color:var(--darkText); display:inline-flex; align-items:center; gap:7px; }
.bm-el__trophy { color:var(--accent); font-size:11px; }
.bm-el__hcp { font:500 12px var(--mono); color:color-mix(in srgb, var(--darkText) 55%, transparent); }
.bm-el__club { font:500 12px var(--mono); color:color-mix(in srgb, var(--darkText) 50%, transparent); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.bm-el__empty { padding:40px 24px; text-align:center; color:color-mix(in srgb, var(--darkText) 50%, transparent); font:600 13px var(--mono); }

@media (max-width:760px) {
	.bm-el__head, .bm-el__row { grid-template-columns:30px 1fr 60px; }
	/* masque CLUB : cellules ET en-tete (4e colonne) */
	.bm-el__club, .bm-el__head span:nth-child(4) { display:none; }
	.bm-el__search { width:100%; }
}

/* ================================================ PAGE NEWS — ARTICLE ===== */
.bm-article { max-width:900px; }
.bm-article__sheet { background:var(--card); border:1px solid var(--line); border-radius:14px; box-shadow:0 18px 44px -22px rgba(0,0,0,.28); padding:46px 50px; }
.bm-article__head { margin-bottom:24px; }
.bm-article__hero { display:block; width:auto; max-width:100%; max-height:560px; border-radius:10px; margin:0 auto 28px; box-shadow:0 18px 44px -22px rgba(0,0,0,.45); }
.bm-article__title { font:700 38px/1.12 var(--display); letter-spacing:-.01em; color:var(--ink); margin:10px 0 0; }
.bm-article__meta { font:500 12px var(--mono); letter-spacing:.04em; color:var(--muted); margin-top:12px; }
.bm-article__video { position:relative; padding-top:56.25%; border-radius:10px; overflow:hidden; margin-bottom:28px; background:var(--dark); box-shadow:0 18px 44px -22px rgba(0,0,0,.5); }
.bm-article__video iframe { position:absolute; inset:0; width:100%; height:100%; border:0; }
.bm-article__body { font-size:16px; line-height:1.7; color:var(--soft); }
.bm-article__body p { margin:0 0 18px; }
.bm-article__body a { color:var(--kicker); }
.bm-article__body img, .bm-article__img { max-width:100%; height:auto; border-radius:8px; margin:10px 0; }
.bm-article__body h2, .bm-article__body h3 { font-family:var(--display); color:var(--ink); margin:26px 0 12px; }
/* Citation : grand guillemet dore en filigrane, texte italique, sans cadre */
.bm-article__body blockquote { position:relative; margin:30px 0; padding-top:30px; font:italic 500 21px/1.55 var(--display); color:var(--ink); }
.bm-article__body blockquote::before { content:"\201C"; position:absolute; top:-8px; left:-4px; font:700 66px/1 var(--display); font-style:normal; color:var(--accent); }
.bm-article__body blockquote p { margin:0 0 8px; }
.bm-article__body blockquote p:last-child { margin:0; }

/* Album Google Photos integre (grille + liseuse) */
.bm-gphotos { margin:24px 0; }
.bm-gphotos__head { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px 16px; margin-bottom:12px; }
.bm-gphotos__brand { font:700 11px var(--mono); letter-spacing:.1em; text-transform:uppercase; color:var(--muted); display:inline-flex; align-items:center; gap:8px; }
.bm-gphotos__all { font:700 12px var(--display); color:var(--accent); text-decoration:none; }
.bm-gphotos__all:hover { text-decoration:underline; }
/* la grille reutilise .bm-photos / .bm-photos__item (meme style que la page Photo) */

@media (max-width:760px) {
	.bm-article__title { font-size:28px; }
	.bm-article__sheet { padding:26px 22px; border-radius:12px; }
	.bm-article__body blockquote { font-size:18px; padding-top:24px; }
	.bm-article__body blockquote::before { font-size:52px; }
}

/* ======================================== PAGE CHAMPIONSHIP (roll) ======== */
.bm-roll { background:var(--dark); border-radius:10px; overflow:hidden; box-shadow:0 18px 44px -22px rgba(0,0,0,.5); }
.bm-roll__head, .bm-roll__row { display:grid; grid-template-columns:96px 1fr 1fr 1fr; align-items:center; column-gap:16px; }
.bm-roll__head { padding:16px 32px; font:700 10px var(--mono); letter-spacing:.1em; color:var(--accent); }
.bm-roll__row { padding:18px 32px; border-top:1px solid color-mix(in srgb, var(--darkText) 10%, transparent); }
.bm-roll__year { font:700 18px var(--mono); color:var(--darkText); }
.bm-roll__row.is-latest .bm-roll__year { color:var(--accent); }
.bm-roll__name { font:600 16px var(--display); color:var(--darkText); }
.bm-roll__club { font:500 14px var(--display); color:var(--darkMuted); }

@media (max-width:760px) {
	.bm-roll__head, .bm-roll__row { grid-template-columns:50px 1fr 1fr; padding-left:18px; padding-right:18px; column-gap:10px; }
	.bm-roll__year { font-size:18px; }
	.bm-roll__name { font-size:13px; }
	.bm-roll__head span:nth-child(4), .bm-roll__club { display:none; }
}

/* ================================================ PAGE PHOTO (galerie) ==== */
.bm-gallery { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.bm-album { display:block; border:1px solid var(--line); border-radius:8px; overflow:hidden; background:var(--card); text-decoration:none; color:inherit; transition:border-color .15s ease, transform .15s ease; }
a.bm-album:hover { border-color:var(--accent); transform:translateY(-2px); }
.bm-album__thumb { position:relative; height:150px; background:repeating-linear-gradient(45deg, var(--phA) 0 12px, var(--phB) 12px 24px); }
.bm-album__badge { position:absolute; bottom:10px; right:10px; background:var(--dark); color:var(--darkText); font:600 9px var(--mono); padding:4px 8px; border-radius:2px; }
.bm-album__body { padding:14px 16px; }
.bm-album__title { font:600 15px var(--display); color:var(--ink); }

.bm-photos { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.bm-photos__item { display:block; width:100%; aspect-ratio:10/7; padding:0; border:1px solid var(--line); border-radius:6px; overflow:hidden; background:var(--phA); cursor:pointer; transition:transform .15s ease, border-color .15s ease; }
.bm-photos__item:hover { transform:translateY(-2px); border-color:var(--accent); }
.bm-photos__item img { width:100%; height:100%; object-fit:cover; display:block; }

/* Liseuse modale */
.bm-modal { position:fixed; inset:0; z-index:1000; background:rgba(16,18,22,.93); display:flex; align-items:center; justify-content:center; }
.bm-modal[hidden] { display:none; }
.bm-modal__stage { margin:0; max-width:92vw; max-height:88vh; display:flex; }
.bm-modal__img { display:block; max-width:92vw; max-height:88vh; object-fit:contain; border-radius:6px; box-shadow:0 30px 80px -20px rgba(0,0,0,.7); }
.bm-modal__close { position:absolute; top:18px; right:24px; background:none; border:0; color:#fff; font-size:34px; line-height:1; cursor:pointer; opacity:.8; }
.bm-modal__close:hover { opacity:1; }
.bm-modal__nav { position:absolute; top:50%; transform:translateY(-50%); width:52px; height:52px; border-radius:50%; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18); color:#fff; font-size:19px; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .15s ease, color .15s ease; }
.bm-modal__nav:hover { background:var(--accent); color:var(--onAccent); border-color:transparent; }
.bm-modal__nav--prev { left:24px; }
.bm-modal__nav--next { right:24px; }
.bm-modal__counter { position:absolute; bottom:20px; left:50%; transform:translateX(-50%); color:#fff; font:600 12px var(--mono); letter-spacing:.12em; opacity:.85; }
@media (max-width:600px) {
	.bm-modal__nav { width:42px; height:42px; }
	.bm-modal__nav--prev { left:10px; }
	.bm-modal__nav--next { right:10px; }
}

@media (max-width:900px) { .bm-gallery, .bm-photos { grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px) { .bm-gallery { grid-template-columns:1fr; } }

/* ====================================================== RESPONSIVE ======= */
@media (max-width:1000px) {
	.bm-hero__inner { grid-template-columns:1fr; gap:36px; padding:54px 24px 58px; }
	.bm-hero__title { font-size:64px; }
	.bm-lb { max-width:480px; }
	.bm-news-grid { grid-template-columns:repeat(2,1fr); }
	.bm-palmares__grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:760px) {
	.bm-nav { padding:16px 20px; position:relative; flex-wrap:wrap; }
	.bm-nav__burger { display:block; order:3; }
	.bm-nav__search { order:2; }
	.bm-nav__menu {
		order:4; flex-basis:100%; flex-direction:column; gap:0; position:static; transform:none;
		max-height:0; overflow:hidden; transition:max-height .25s ease;
	}
	.bm-nav.is-open .bm-nav__menu { max-height:420px; margin-top:12px; }
	.bm-nav__menu a { padding:13px 0; border-bottom:1px solid var(--line2); }
	.bm-nav__menu a.is-active { border-bottom:1px solid var(--accent); }

	.bm-hero__inner { padding:44px 20px 48px; }
	.bm-hero__title { font-size:50px; }
	.bm-info { flex-direction:column; }
	.bm-info__cell { border-right:0; border-bottom:1px solid var(--line2); }
	.bm-info__cell:last-child { border-bottom:0; }

	.bm-section, .bm-section--news, .bm-section--palmares { padding-left:20px; padding-right:20px; }
	.bm-section__title { font-size:28px; }
	.bm-news-grid { grid-template-columns:1fr; }
	.bm-palmares { padding:28px 22px; }
	.bm-palmares__grid { grid-template-columns:1fr; gap:18px; }
	.bm-sponsors__logos { gap:32px; }
	.bm-sponsors__logos img { height:56px; }
	.bm-footer { grid-template-columns:1fr; gap:28px; }

	/* Cibles tactiles confortables */
	.bm-tab, .bm-nav__menu a, .bm-btn, .bm-lb__foot { min-height:44px; }
	.bm-tab { display:inline-flex; align-items:center; }
}

/* Leaderboard (home) sur telephone : on degage de la place pour les noms */
@media (max-width:480px) {
	.bm-lb__head { padding:18px 16px 14px; }
	.bm-lb__tabs { padding:0 16px; gap:22px; }
	.bm-lb__body { padding:4px 16px 8px; }
	/* THRU masque (=F sur un classement termine ; dispo dans le classement complet) */
	.bm-lb__thru, .bm-lb__row--head span:nth-child(4) { display:none; }
	.bm-lb__row { grid-template-columns:26px 1fr 44px 48px; padding:11px 0; }
	.bm-lb__name { font-size:13.5px; line-height:1.25; }
	.bm-lb__today { font-size:12px; }
	.bm-lb__tot { font-size:14px; }
	.bm-lb__trophy { font-size:11px; }
}

/* ============================================ REELS (reseaux sociaux) ====== */
.bm-reels { display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; padding:8px 6px 42px; -webkit-overflow-scrolling:touch; }
.bm-reels::-webkit-scrollbar { height:6px; }
.bm-reels::-webkit-scrollbar-thumb { background:var(--line); border-radius:100px; }
.bm-reel-card { position:relative; flex:0 0 auto; width:152px; aspect-ratio:9/16; border:0; padding:0; border-radius:14px; overflow:hidden; cursor:pointer; scroll-snap-align:start; background:var(--dark) center/cover no-repeat; box-shadow:0 18px 44px -22px rgba(0,0,0,.45); color:#fff; transition:transform .15s ease; }
.bm-reel-card::after { content:''; position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.74) 0%, rgba(0,0,0,.04) 46%, rgba(0,0,0,.2) 100%); }
.bm-reel-card--noimg { background:linear-gradient(150deg,#2a2f38,var(--dark)); }
.bm-reel-card:hover { transform:translateY(-3px); }
.bm-reel-card__plat { position:absolute; top:9px; right:9px; z-index:2; width:26px; height:26px; display:flex; align-items:center; justify-content:center; border-radius:50%; background:rgba(0,0,0,.42); font-size:12px; }
.bm-reel-card__play { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); z-index:2; width:46px; height:46px; border-radius:50%; background:rgba(255,255,255,.94); }
.bm-reel-card__play::before { content:''; position:absolute; top:50%; left:54%; transform:translate(-50%,-50%); border-style:solid; border-width:9px 0 9px 15px; border-color:transparent transparent transparent var(--ink); }
.bm-reel-card__meta { position:absolute; left:12px; right:12px; bottom:11px; z-index:2; font:600 12.5px var(--display); line-height:1.25; text-shadow:0 1px 6px rgba(0,0,0,.55); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* Modale story plein ecran */
.bm-story { position:fixed; inset:0; z-index:1000; background:rgba(12,12,14,.94); display:flex; flex-direction:column; align-items:center; justify-content:center; }
.bm-story[hidden] { display:none; }
.bm-story__bar { position:absolute; top:14px; left:50%; transform:translateX(-50%); display:flex; gap:5px; width:min(420px,86vw); z-index:3; }
.bm-story__bar span { flex:1; height:3px; border-radius:100px; background:rgba(255,255,255,.28); }
.bm-story__bar span.is-done { background:rgba(255,255,255,.82); }
.bm-story__bar span.is-cur { background:#fff; }
.bm-story__close { position:absolute; top:22px; right:22px; z-index:6; width:42px; height:42px; border:0; border-radius:50%; background:rgba(255,255,255,.12); color:#fff; font-size:24px; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.bm-story__close:hover { background:rgba(255,255,255,.22); }
.bm-story__stage { width:min(440px,92vw); max-height:78vh; overflow:auto; border-radius:14px; }
.bm-story__stage .instagram-media, .bm-story__stage .fb-video { margin:0 auto !important; }
.bm-story__nav { position:absolute; top:0; bottom:0; width:20%; z-index:4; cursor:pointer; border:0; background:none; display:flex; align-items:center; padding:0 14px; }
.bm-story__nav--prev { left:0; justify-content:flex-start; }
.bm-story__nav--next { right:0; justify-content:flex-end; }
.bm-story__nav span { display:flex; align-items:center; justify-content:center; width:46px; height:46px; border-radius:50%; background:rgba(255,255,255,.16); color:#fff; font-size:20px; line-height:1; transition:background .15s ease; }
.bm-story__nav:hover span { background:rgba(255,255,255,.32); }
.bm-story__foot { position:absolute; bottom:20px; left:50%; transform:translateX(-50%); z-index:3; display:flex; gap:16px; align-items:center; color:#fff; font:600 13px var(--display); max-width:92vw; }
.bm-story__by { opacity:.92; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.bm-story__link { color:var(--accent); text-decoration:none; white-space:nowrap; }
@media (max-width:760px) {
	.bm-reel-card { width:134px; }
	.bm-story__stage { width:94vw; }
}

.bm-reels-block { margin:6px 0 32px; }

/* Embed Instagram recadre (iframe direct) : ne montre que la video, fond noir + spinner au chargement.
   Ajuster --ig-top (decalage haut pour cacher l'entete) et --ig-extra (hauteur en plus pour rogner le pied). */
.bm-ig { --ig-top:-54px; --ig-extra:230px; position:relative; width:min(340px,86vw); aspect-ratio:9/16; max-height:80vh; margin:0 auto; overflow:hidden; border-radius:12px; background:#000; }
.bm-ig__spin { position:absolute; z-index:1; top:50%; left:50%; width:38px; height:38px; margin:-19px 0 0 -19px; border-radius:50%; border:3px solid rgba(255,255,255,.25); border-top-color:#fff; animation:bm-spin .8s linear infinite; }
.bm-ig__frame { position:absolute; z-index:2; left:0; top:var(--ig-top); width:100%; height:calc(100% + var(--ig-extra)); border:0; opacity:0; transition:opacity .35s ease; }
.bm-ig.is-loaded .bm-ig__frame { opacity:1; }
@keyframes bm-spin { to { transform:rotate(360deg); } }

/* Consigne publique reels (Chantier 4) : moteur organique */
.bm-reels-cta { display:flex; align-items:center; gap:9px; flex-wrap:wrap; margin:0 0 14px; font:600 13px var(--display); color:var(--soft); }
.bm-reels-cta i { color:var(--kicker); font-size:15px; }
.bm-reels-cta a { color:var(--kicker); text-decoration:none; border-bottom:1px solid color-mix(in srgb, var(--kicker) 45%, transparent); white-space:nowrap; }
.bm-reels-cta a:hover { color:var(--accent); border-bottom-color:var(--accent); }
