/* ===========================================================
   MAPFORGE — Front (battlemap)  •  Charte La Tablée Onirique
   =========================================================== */

:root{
	--mph-or:#FFBE7A;       --mph-or2:#F2A663;
	--mph-creme:#F2E4C9;    --mph-beige:#CBBFA2;
	--mph-bg:#0A131C;       --mph-bg2:#0D1A26;
	--mph-mid:#1F3A4A;      --mph-deep:#0D2633;
	--mph-line:rgba(255,190,122,.18);
	--mph-shadow:0 18px 48px rgba(0,0,0,.55);
	--mph-radius:14px;
	--mph-tf:"Marcellus SC",serif;
	--mph-bf:"Inter",system-ui,sans-serif;
}

#mapforge-app, #mapforge-app *{box-sizing:border-box}
#mapforge-app{
	font-family:var(--mph-bf);
	color:var(--mph-creme);
	position:relative;
	background:var(--mph-bg);
	border-radius:var(--mph-radius);
	overflow:hidden;
	min-height:78vh;
	box-shadow:var(--mph-shadow);
	border:1px solid var(--mph-line);
}
.mapforge-locked{
	font-family:"Inter",sans-serif;background:#0D1A26;color:#F2E4C9;
	padding:2rem;border-radius:12px;text-align:center;border:1px solid rgba(255,190,122,.25);
}

#mapforge-app h1,#mapforge-app h2,#mapforge-app h3{font-family:var(--mph-tf);font-weight:400;letter-spacing:.5px;margin:0}
#mapforge-app .iconify{vertical-align:-.12em}

/* ---------- Écrans ---------- */
.mph-screen{display:none;position:absolute;inset:0}
.mph-screen.is-active{display:block}
.mph-game.is-active{display:flex;flex-direction:column}

/* ---------- Accueil ---------- */
.mph-home{
	background:
		radial-gradient(900px 500px at 50% -10%,rgba(255,190,122,.12),transparent 60%),
		linear-gradient(160deg,var(--mph-bg2),var(--mph-bg));
	overflow:auto;
}
.mph-home-inner{max-width:980px;margin:0 auto;padding:3rem 1.5rem 4rem}
.mph-brand{text-align:center;margin-bottom:2.4rem}
.mph-brand-ic{font-size:3.2rem;color:var(--mph-or);filter:drop-shadow(0 0 14px rgba(255,190,122,.4))}
.mph-brand h1{font-size:2.6rem;color:var(--mph-or);margin:.3rem 0 .2rem}
.mph-brand p{color:var(--mph-beige);font-size:.95rem;letter-spacing:.4px}
.mph-home-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
@media(max-width:740px){.mph-home-cols{grid-template-columns:1fr}}
.mph-home-single{max-width:560px;margin:0 auto}

.mph-account{display:flex;align-items:center;gap:.8rem;max-width:560px;margin:0 auto 1.4rem;
	background:linear-gradient(160deg,rgba(31,58,74,.5),rgba(13,26,38,.8));border:1px solid var(--mph-line);
	border-radius:50px;padding:.6rem .9rem}
.mph-account .av{width:42px;height:42px;border-radius:50%;object-fit:cover;background:var(--mph-mid);
	border:2px solid var(--mph-beige);display:flex;align-items:center;justify-content:center;color:var(--mph-or);flex:0 0 auto}
.mph-account .meta{flex:1;min-width:0}
.mph-account .meta b{display:block;color:var(--mph-creme);font-size:.95rem}
.mph-account .meta small{color:var(--mph-beige);font-size:.76rem}
.mph-account .mph-btn{padding:.5rem 1rem;font-size:.84rem}

.mph-card{
	background:linear-gradient(160deg,rgba(31,58,74,.55),rgba(13,26,38,.85));
	border:1px solid var(--mph-line);border-radius:var(--mph-radius);
	padding:1.4rem;position:relative;overflow:hidden;
}
.mph-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;
	background:linear-gradient(90deg,transparent,var(--mph-or),transparent)}
.mph-card h2{color:var(--mph-or);font-size:1.3rem;display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}
.mph-card h2 .iconify{font-size:1.4rem}

.mph-gm-list,.mph-scene-list{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1rem;min-height:40px}
.mph-pick{
	display:flex;align-items:center;gap:.8rem;padding:.7rem .9rem;cursor:pointer;
	background:rgba(13,38,51,.6);border:1px solid var(--mph-line);border-radius:10px;
	transition:.18s;
}
.mph-pick:hover{border-color:var(--mph-or);transform:translateX(3px)}
.mph-pick.is-sel{border-color:var(--mph-or);box-shadow:0 0 0 1px var(--mph-or) inset}
.mph-pick-av{width:38px;height:38px;border-radius:50%;object-fit:cover;background:var(--mph-mid);
	border:2px solid var(--mph-beige);display:flex;align-items:center;justify-content:center;color:var(--mph-or);flex:0 0 auto}
.mph-pick-meta{flex:1;min-width:0}
.mph-pick-meta b{display:block;color:var(--mph-creme);font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mph-pick-meta small{color:var(--mph-beige);font-size:.78rem}
.mph-pick-edit,.mph-pick-del{background:none;border:none;color:var(--mph-beige);cursor:pointer;font-size:1.05rem;padding:.2rem}
.mph-pick-edit:hover{color:var(--mph-or)}
.mph-pick-del:hover{color:#E98C7A}

/* ---------- Boutons ---------- */
.mph-btn{
	font-family:var(--mph-bf);font-weight:600;font-size:.92rem;cursor:pointer;
	background:var(--mph-creme);color:#152635;border:none;border-radius:50px;
	padding:.7rem 1.3rem;transition:.18s;display:inline-flex;align-items:center;gap:.4rem;
}
.mph-btn:hover{background:var(--mph-or)}
.mph-btn--ghost{background:transparent;color:var(--mph-creme);border:1px solid var(--mph-line)}
.mph-btn--ghost:hover{background:rgba(255,190,122,.12);color:var(--mph-or);border-color:var(--mph-or)}
.mph-btn--danger{background:#8B2E2E;color:#fff}
.mph-btn--danger:hover{background:#a83a3a}
.mph-btn[disabled]{opacity:.4;cursor:not-allowed}

/* ---------- Barre supérieure ---------- */
.mph-topbar{
	display:flex;align-items:center;gap:.7rem;padding:.5rem .8rem;flex:0 0 auto;
	background:linear-gradient(90deg,var(--mph-deep),var(--mph-mid));
	border-bottom:1px solid var(--mph-line);position:relative;z-index:30;
}
.mph-scene-title{font-family:var(--mph-tf);color:var(--mph-or);font-size:1.05rem;margin-right:auto;white-space:nowrap}
.mph-topbar-tools{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:flex-end}
.mph-tool{
	background:rgba(13,26,38,.6);border:1px solid var(--mph-line);color:var(--mph-creme);
	border-radius:10px;padding:.45rem .55rem;cursor:pointer;display:flex;flex-direction:column;
	align-items:center;gap:.1rem;min-width:52px;transition:.16s;
}
.mph-tool .iconify{font-size:1.25rem;color:var(--mph-or)}
.mph-tool em{font-style:normal;font-size:.62rem;color:var(--mph-beige)}
.mph-tool:hover{border-color:var(--mph-or);background:rgba(255,190,122,.1)}
.mph-tool.is-on{border-color:var(--mph-or);background:rgba(255,190,122,.18)}
#mph-back .iconify{font-size:1.3rem}

/* ---------- Surface de jeu ---------- */
.mph-stage{
	flex:1;position:relative;overflow:hidden;background:
		radial-gradient(1200px 700px at 50% 40%,#0e1f2b,#070d14);
	touch-action:none;cursor:grab;
}
.mph-stage.is-panning{cursor:grabbing}
.mph-stage.is-placing{cursor:crosshair}
.mph-stage.is-measuring{cursor:crosshair}
.mph-world{position:absolute;top:0;left:0;transform-origin:0 0;will-change:transform}
.mph-map-img{display:block;max-width:none;user-select:none;-webkit-user-drag:none}
.mph-grid,.mph-fog{position:absolute;top:0;left:0;pointer-events:none}
.mph-light{position:absolute;top:0;left:0;pointer-events:none;z-index:5;mix-blend-mode:screen}
.mph-fog{z-index:8}
.mph-tokens{position:absolute;top:0;left:0;z-index:6}
.mph-measure{position:absolute;top:0;left:0;pointer-events:none;z-index:12;overflow:visible}

/* Sources de lumière */
.mph-lightsrc{position:absolute;z-index:7;display:flex;align-items:center;justify-content:center;
	border-radius:50%;cursor:grab;color:#FFD9A0;background:radial-gradient(circle,rgba(255,180,90,.95),rgba(220,120,40,.6));
	box-shadow:0 0 14px 4px rgba(255,170,70,.65);border:2px solid rgba(255,210,150,.8)}
.mph-lightsrc.is-dragging{cursor:grabbing;z-index:50}
.mph-lightsrc .iconify{font-size:1rem;filter:drop-shadow(0 0 3px rgba(0,0,0,.6))}

/* Monstre caché visible par le MJ (fantôme) */
.mph-tok.ghost{opacity:.42;border-style:dashed}

/* Effets de statut : halo pulsant + pastilles d'icônes */
.mph-tok.has-eff{box-shadow:0 0 0 3px var(--eff,#FFBE7A),0 0 14px 3px var(--eff,#FFBE7A),0 4px 12px rgba(0,0,0,.5);
	animation:mph-eff-pulse 1.6s ease-in-out infinite}
@keyframes mph-eff-pulse{0%,100%{box-shadow:0 0 0 2px var(--eff,#FFBE7A),0 0 8px 2px var(--eff,#FFBE7A),0 4px 12px rgba(0,0,0,.5)}
	50%{box-shadow:0 0 0 4px var(--eff,#FFBE7A),0 0 20px 6px var(--eff,#FFBE7A),0 4px 12px rgba(0,0,0,.5)}}
.mph-tok-effs{position:absolute;top:calc(-1 * (var(--mph-eff-size,18px) + 8px));left:50%;transform:translateX(-50%);display:flex;gap:2px;z-index:14}
.mph-tok-effs .e{width:var(--mph-eff-size,18px);height:var(--mph-eff-size,18px);border-radius:50%;display:flex;align-items:center;justify-content:center;
	background:rgba(10,19,28,.9);border:1px solid rgba(0,0,0,.5);font-size:calc(var(--mph-eff-size,18px) * .62)}
.mph-tok-effs .e .iconify{font-size:calc(var(--mph-eff-size,18px) * .72)}
/* Mort */
.mph-tok.dead{filter:grayscale(1) brightness(.55);border-color:#6b6b6b !important;animation:none !important;box-shadow:0 4px 12px rgba(0,0,0,.5) !important}
.mph-tok-skull{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#e8e8e8;text-shadow:0 1px 3px #000;z-index:13;pointer-events:none}

/* Règle de mesure */
.mph-measure .ln{stroke:var(--mph-or);stroke-width:2;stroke-dasharray:6 5}
.mph-measure .pt{fill:var(--mph-or)}

/* Picker d'effets (panneau token) */
.mph-eff-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem;margin:.5rem 0}
.mph-eff-pick{display:flex;flex-direction:column;align-items:center;gap:2px;background:rgba(10,19,28,.6);
	border:1px solid var(--mph-line);border-radius:9px;padding:.4rem .2rem;cursor:pointer;font-size:.58rem;color:var(--mph-beige);text-align:center}
.mph-eff-pick .iconify{font-size:1.15rem}
.mph-eff-pick.on{border-color:var(--mph-or);background:rgba(255,190,122,.14);color:var(--mph-creme)}

/* Zone dangereuse (options table) */
.mph-danger{margin:1rem 1.2rem;padding-top:1rem;border-top:1px solid rgba(217,75,75,.4)}
.mph-danger .mph-btn{width:100%}

.mph-sp-sub{font-size:.78rem;color:var(--mph-beige);margin:.8rem 0 .2rem;border-top:1px solid var(--mph-line);padding-top:.7rem}

/* ---------- Tokens ---------- */
.mph-tok{
	position:absolute;border-radius:50%;display:flex;align-items:center;justify-content:center;
	cursor:grab;background-size:cover;background-position:center;user-select:none;
	border:3px solid var(--mph-beige);box-shadow:0 4px 12px rgba(0,0,0,.5);
	color:#fff;font-weight:700;font-size:.8rem;text-shadow:0 1px 3px #000;transition:box-shadow .15s;
}
.mph-tok.is-dragging{cursor:grabbing;z-index:50;box-shadow:0 0 0 3px var(--mph-or),0 8px 22px rgba(0,0,0,.6)}
.mph-tok.k-hero{border-color:#4A9EFF}
.mph-tok.k-pnj{border-color:var(--mph-creme)}
.mph-tok.invis{visibility:hidden}
.mph-tok-hp{
	position:absolute;bottom:-10px;left:8%;width:84%;height:6px;border-radius:4px;
	background:rgba(0,0,0,.55);overflow:hidden;border:1px solid rgba(0,0,0,.6)
}
.mph-tok-hp i{display:block;height:100%;background:linear-gradient(90deg,#d24b4b,#4caf6e);transition:width .25s}
.mph-tok-hpval{position:absolute;bottom:-27px;left:50%;transform:translateX(-50%);font-size:.66rem;
	background:rgba(13,26,38,.9);border:1px solid var(--mph-line);padding:0 5px;border-radius:6px;white-space:nowrap;color:var(--mph-creme);z-index:12}
.mph-tok-name{position:absolute;bottom:-24px;left:50%;transform:translateX(-50%);font-size:.66rem;
	white-space:nowrap;color:var(--mph-creme);background:rgba(10,19,28,.7);padding:1px 6px;border-radius:6px;font-weight:500}
.mph-tok.has-hpbar .mph-tok-name{bottom:-28px}
.mph-tok.has-hpval .mph-tok-name{bottom:-46px}

/* ---------- Mini-toolbar / distance ---------- */
.mph-minibar{position:absolute;right:14px;bottom:14px;display:flex;flex-direction:column;gap:.35rem;z-index:25}
.mph-mini{width:42px;height:42px;border-radius:50%;background:rgba(13,38,51,.9);border:1px solid var(--mph-line);
	color:var(--mph-or);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s}
.mph-mini:hover{background:var(--mph-mid);border-color:var(--mph-or)}
.mph-zoom-lbl{text-align:center;font-size:.72rem;color:var(--mph-beige);background:rgba(10,19,28,.7);border-radius:6px;padding:1px 4px}
.mph-dist-lbl{position:absolute;left:14px;bottom:14px;z-index:25;font-size:.82rem;color:var(--mph-creme);
	background:rgba(13,38,51,.85);border:1px solid var(--mph-line);border-radius:8px;padding:.35rem .6rem;display:none;align-items:center;gap:.3rem}
.mph-dist-lbl.is-show{display:flex}
.mph-dist-lbl .iconify{color:var(--mph-or)}

/* ---------- Panneau latéral ---------- */
.mph-side{
	position:absolute;top:0;right:0;bottom:0;width:300px;max-width:86%;z-index:40;
	background:linear-gradient(180deg,var(--mph-deep),var(--mph-bg2));
	border-left:1px solid var(--mph-line);box-shadow:-12px 0 32px rgba(0,0,0,.5);
	transform:translateX(105%);transition:transform .25s;display:flex;flex-direction:column;
}
.mph-side.is-open{transform:translateX(0)}
.mph-side header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--mph-line)}
.mph-side header h3{color:var(--mph-or);font-size:1.1rem}
.mph-side-body{padding:1rem;overflow:auto;flex:1}

/* ---------- Initiative ---------- */
.mph-init{
	position:absolute;left:0;right:0;bottom:0;z-index:35;height:84px;
	background:linear-gradient(180deg,rgba(13,38,51,.4),var(--mph-deep));
	border-top:1px solid var(--mph-line);transform:translateY(105%);transition:transform .25s;
	display:flex;flex-direction:column;
}
.mph-init.is-open{transform:translateY(0)}
.mph-init-hd{display:flex;align-items:center;justify-content:space-between;padding:.3rem .8rem;font-size:.82rem;color:var(--mph-or)}
.mph-init-list{flex:1;display:flex;gap:.5rem;overflow-x:auto;padding:0 .8rem .5rem;align-items:center}
.mph-init-chip{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:.15rem;
	background:rgba(13,26,38,.7);border:1px solid var(--mph-line);border-radius:10px;padding:.3rem .5rem;min-width:60px}
.mph-init-chip.is-active{border-color:var(--mph-or);box-shadow:0 0 0 1px var(--mph-or) inset}
.mph-init-chip img,.mph-init-chip .ph{width:30px;height:30px;border-radius:50%;object-fit:cover;background:var(--mph-mid)}
.mph-init-chip small{font-size:.6rem;color:var(--mph-beige);max-width:58px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mph-init-chip b{font-size:.78rem;color:var(--mph-or)}

/* ---------- Visionneuse de scène ---------- */
.mph-scene-viewer{position:fixed;inset:0;z-index:9999;background:rgba(5,9,14,.96);
	display:none;align-items:center;justify-content:center}
.mph-scene-viewer.is-open{display:flex}
.mph-scene-viewer img{max-width:94vw;max-height:92vh;border-radius:8px;box-shadow:0 0 60px rgba(0,0,0,.8)}
.mph-sv-close{position:absolute;top:18px;right:18px;width:48px;height:48px;border-radius:50%;
	background:rgba(13,38,51,.9);border:1px solid var(--mph-line);color:var(--mph-or);font-size:1.5rem;cursor:pointer}

/* ---------- Météo ---------- */
.mph-weather{position:absolute;inset:0;pointer-events:none;z-index:20;overflow:hidden}

/* ---------- Modales ---------- */
.mph-modal{position:absolute;inset:0;z-index:60;background:rgba(5,9,14,.72);
	display:none;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(3px)}
.mph-modal.is-open{display:flex}
.mph-modal-box{
	width:440px;max-width:100%;max-height:88vh;overflow:auto;
	background:linear-gradient(170deg,var(--mph-deep),var(--mph-bg2));
	border:1px solid var(--mph-line);border-radius:var(--mph-radius);box-shadow:var(--mph-shadow);position:relative;
}
.mph-modal-box::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;
	background:linear-gradient(90deg,transparent,var(--mph-or),transparent)}
.mph-modal-box header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.2rem;border-bottom:1px solid var(--mph-line)}
.mph-modal-box header h3{color:var(--mph-or);font-size:1.2rem;display:flex;align-items:center;gap:.5rem}
.mph-modal-box > .mph-field,.mph-modal-box > .mph-upload,.mph-modal-box > .mph-toggles,
.mph-modal-box > .mph-tabs,.mph-modal-box > .mph-tokform,.mph-modal-box > p,.mph-modal-box > .mph-lib{margin:1rem 1.2rem}
.mph-modal-acts{display:flex;justify-content:flex-end;gap:.6rem;padding:1rem 1.2rem;border-top:1px solid var(--mph-line)}
.mph-x{background:none;border:none;color:var(--mph-beige);font-size:1.3rem;cursor:pointer;line-height:1}
.mph-x:hover{color:var(--mph-or)}

/* ---------- Champs ---------- */
.mph-field{display:flex;flex-direction:column;gap:.35rem}
.mph-field label{font-size:.82rem;color:var(--mph-beige);font-weight:500}
.mph-field input,.mph-field select,.mph-tokform input,.mph-tokform select{
	background:rgba(10,19,28,.7);border:1px solid var(--mph-line);color:var(--mph-creme);
	border-radius:9px;padding:.6rem .7rem;font-family:var(--mph-bf);font-size:.9rem;width:100%}
.mph-field input:focus,.mph-field select:focus,.mph-tokform input:focus{outline:none;border-color:var(--mph-or)}
.mph-field input[type=range]{padding:0;accent-color:var(--mph-or)}
.mph-field input[type=color]{height:42px;padding:3px;cursor:pointer}
.mph-hint{font-size:.8rem;color:var(--mph-beige);line-height:1.5}

.mph-upload{display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;
	background:rgba(255,190,122,.08);border:1px dashed var(--mph-or);color:var(--mph-or);
	border-radius:10px;padding:.8rem;font-weight:600;font-size:.88rem;transition:.15s}
.mph-upload:hover{background:rgba(255,190,122,.16)}
.mph-upload--sm{padding:.55rem;font-size:.82rem}

.mph-toggles{display:flex;flex-direction:column;gap:.6rem}
.mph-toggle{display:flex;align-items:center;gap:.6rem;font-size:.88rem;color:var(--mph-creme);cursor:pointer}
.mph-toggle input{width:auto;accent-color:var(--mph-or);transform:scale(1.2)}

/* ---------- Tabs token ---------- */
.mph-tabs{display:flex;gap:.4rem}
.mph-tab{flex:1;background:rgba(10,19,28,.6);border:1px solid var(--mph-line);color:var(--mph-beige);
	border-radius:9px;padding:.55rem;cursor:pointer;font-size:.82rem;display:flex;align-items:center;justify-content:center;gap:.3rem}
.mph-tab .iconify{font-size:1.1rem}
.mph-tab.is-active{border-color:var(--mph-or);color:var(--mph-or);background:rgba(255,190,122,.12)}
.mph-tokform{display:flex;flex-direction:column;gap:.8rem}

/* ---------- Bibliothèques ---------- */
.mph-lib{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;max-height:280px;overflow:auto;padding-top:.3rem}
.mph-lib-item{position:relative;cursor:pointer;border:1px solid var(--mph-line);border-radius:10px;overflow:hidden;
	background:rgba(10,19,28,.6);aspect-ratio:1;display:flex;align-items:flex-end;transition:.15s}
.mph-lib-item:hover{border-color:var(--mph-or)}
.mph-lib-item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.mph-lib-item span{position:relative;z-index:2;width:100%;font-size:.66rem;padding:3px 5px;color:#fff;
	background:linear-gradient(transparent,rgba(0,0,0,.85));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mph-lib-del{position:absolute;top:3px;right:3px;z-index:3;width:22px;height:22px;border-radius:50%;
	background:rgba(139,46,46,.9);border:none;color:#fff;cursor:pointer;font-size:.8rem;display:none}
.mph-lib-item:hover .mph-lib-del{display:block}

/* Liste de scènes : noms seulement, pas d'aperçu */
.mph-lib--names{display:flex;flex-direction:column;grid-template-columns:none;gap:.4rem}
.mph-lib--names .mph-name-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;
	background:rgba(13,38,51,.6);border:1px solid var(--mph-line);border-radius:9px;padding:.6rem .8rem;transition:.15s}
.mph-lib--names .mph-name-item:hover{border-color:var(--mph-or);transform:translateX(3px)}
.mph-lib--names .mph-name-item .iconify{color:var(--mph-or)}
.mph-lib--names .mph-name-item b{flex:1;font-weight:500;font-size:.9rem;color:var(--mph-creme)}
.mph-lib--names .mph-lib-del{position:static;display:block;background:none;color:var(--mph-beige)}
.mph-lib--names .mph-lib-del:hover{color:#E98C7A}

/* ---------- Notifications ---------- */
.mph-notif{position:absolute;top:14px;left:50%;transform:translateX(-50%) translateY(-20px);z-index:9999;
	background:var(--mph-deep);border:1px solid var(--mph-or);color:var(--mph-creme);padding:.7rem 1.2rem;
	border-radius:50px;font-size:.88rem;opacity:0;pointer-events:none;transition:.25s;box-shadow:var(--mph-shadow)}
.mph-notif.is-show{opacity:1;transform:translateX(-50%) translateY(0)}

#maphoria-app:fullscreen,#mapforge-app:fullscreen{min-height:100vh;height:100vh;border-radius:0;border:none}
#mapforge-app:fullscreen .mph-screen.mph-game.is-active{height:100vh}

.mph-empty{color:var(--mph-beige);font-size:.85rem;text-align:center;padding:1rem;font-style:italic}

.mph-sso{display:inline-flex;align-items:center;gap:.45rem;margin-top:1rem;font-size:.82rem;
	color:var(--mph-creme);background:rgba(255,190,122,.1);border:1px solid var(--mph-line);
	border-radius:50px;padding:.4rem .9rem}
.mph-sso .iconify{color:var(--mph-or)}
.mph-sso b{color:var(--mph-or)}

/* ===== Écran de connexion ===== */
.mph-login{display:none;align-items:center;justify-content:center;min-height:60vh;padding:2rem 1rem}
.mph-login.is-active{display:flex}
.mph-login-box{width:100%;max-width:380px;background:linear-gradient(160deg,rgba(31,58,74,.55),rgba(13,26,38,.85));
	border:1px solid var(--mph-or);border-radius:14px;padding:1.6rem 1.4rem;box-shadow:0 18px 50px rgba(0,0,0,.5)}
.mph-login-box .mph-brand{margin-bottom:1.2rem}
.mph-login-box .mph-field{margin:.6rem 0}
.mph-login-box .mph-btn{width:100%;margin-top:.4rem}
.mph-login-err{color:#ff9d9d;font-size:.84rem;min-height:1em;margin:.3rem 0;text-align:center}
.mph-login-hint,.mph-hint{color:var(--mph-beige);font-size:.78rem;text-align:center;margin-top:.7rem}

/* ===== Sliders au thème ===== */
.mph-side input[type=range], .mph-modal input[type=range]{
	-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:50px;outline:none;margin:.5rem 0;
	background:linear-gradient(90deg,var(--mph-or),var(--mph-beige));box-shadow:inset 0 0 0 1px rgba(0,0,0,.3)}
.mph-side input[type=range]::-webkit-slider-thumb,.mph-modal input[type=range]::-webkit-slider-thumb{
	-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;cursor:pointer;
	background:radial-gradient(circle at 35% 30%,#fff7ea,var(--mph-or));border:2px solid #152635;box-shadow:0 2px 6px rgba(0,0,0,.5)}
.mph-side input[type=range]::-moz-range-thumb,.mph-modal input[type=range]::-moz-range-thumb{
	width:20px;height:20px;border-radius:50%;cursor:pointer;background:radial-gradient(circle at 35% 30%,#fff7ea,var(--mph-or));border:2px solid #152635;box-shadow:0 2px 6px rgba(0,0,0,.5)}
.mph-side input[type=range]::-moz-range-track,.mph-modal input[type=range]::-moz-range-track{height:6px;border-radius:50px;background:transparent}

/* Le panneau latéral défile à la molette */
.mph-side{overflow-y:auto;overscroll-behavior:contain}

/* ===== Panneau Calques ===== */
.mph-layers{position:absolute;top:64px;right:14px;z-index:30;width:300px;max-width:88vw;max-height:72vh;overflow-y:auto;
	overscroll-behavior:contain;background:linear-gradient(160deg,rgba(13,38,51,.97),rgba(10,19,28,.97));
	border:1px solid var(--mph-or);border-radius:14px;box-shadow:0 18px 50px rgba(0,0,0,.55);padding:.8rem;display:none}
.mph-layers.is-open{display:block}
.mph-layers-hd{display:flex;align-items:center;justify-content:space-between;color:var(--mph-or);
	font-family:"Marcellus SC",serif;margin-bottom:.6rem}
.mph-layers-hd .iconify{margin-right:.3rem}
.mph-layer-row{display:flex;align-items:center;gap:.5rem;padding:.5rem .6rem;border:1px solid var(--mph-line);
	border-radius:10px;margin-bottom:.4rem;cursor:pointer;background:rgba(10,19,28,.5);transition:.15s}
.mph-layer-row:hover{border-color:var(--mph-or)}
.mph-layer-row.is-active{border-color:var(--mph-or);background:rgba(255,190,122,.12)}
.mph-layer-row .iconify{color:var(--mph-or);font-size:1.2rem;flex:0 0 auto}
.mph-layer-row b{color:var(--mph-creme);font-size:.9rem}
.mph-layer-row small{color:var(--mph-beige);font-size:.72rem}
.mph-layer-tools{margin-left:auto;display:flex;gap:.3rem;flex:0 0 auto}
.mph-layer-btn{width:28px;height:28px;border-radius:8px;border:1px solid var(--mph-line);background:rgba(10,19,28,.6);
	color:var(--mph-beige);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.mph-layer-btn:hover{border-color:var(--mph-or);color:var(--mph-creme)}
.mph-layer-btn.danger{border-color:rgba(217,75,75,.5);color:#ff9d9d}

/* ===== Modale large (Options) ===== */
.mph-modal-box--wide{max-width:760px;width:94vw}
.mph-opts-scroll{max-height:64vh;overflow-y:auto;overscroll-behavior:contain;padding-right:.3rem}
.mph-opts-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 1.6rem}
@media(max-width:680px){.mph-opts-grid{grid-template-columns:1fr}}
.mph-opts-scroll h4{color:var(--mph-or);font-family:"Marcellus SC",serif;font-size:.92rem;margin:.9rem 0 .4rem;
	border-bottom:1px solid var(--mph-line);padding-bottom:.25rem}
.mph-hp-table{width:100%;border-collapse:collapse;margin:.3rem 0 .6rem;font-size:.82rem}
.mph-hp-table th,.mph-hp-table td{padding:.35rem .3rem;text-align:center;border-bottom:1px solid rgba(203,191,162,.14)}
.mph-hp-table thead th{color:var(--mph-beige);font-weight:600;font-size:.72rem;vertical-align:bottom}
.mph-hp-table tbody th{text-align:left;color:var(--mph-creme)}
.mph-hp-table input[type=checkbox]{width:18px;height:18px;accent-color:var(--mph-or);cursor:pointer}
/* boutons toujours visibles : la zone scrolle, les actions restent sous la modale */
.mph-modal-box--wide .mph-modal-acts{position:sticky;bottom:0;background:linear-gradient(180deg,transparent,var(--mph-bg2,#0d1a26) 40%);padding-top:.6rem}

.mph-tool--link{text-decoration:none}

/* Galeries Cartes/Scènes élargies (beaucoup de fichiers) */
.mph-modal-box--wide .mph-lib{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));max-height:60vh}
.mph-modal-box--wide .mph-lib-item{aspect-ratio:4/3}
.mph-modal-box--wide .mph-lib.mph-lib--names{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}

/* ===== Import de tokens (réintégration) ===== */
#mph-m-reint .mph-modal-box{max-width:460px;width:92vw}
#mph-reint-body{max-height:56vh;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;padding:.2rem}
#mph-reint-body .mph-pick{width:100%;box-sizing:border-box}
#mph-reint-body .mph-pick-meta{min-width:0}
#mph-reint-body .mph-pick-meta b{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
