/* =====================================================================
   HARMONIA — Front (La Tablée Onirique)  ·  Soundboard MJ
   ===================================================================== */
.oni-harmonia, .oni-harmonia *{ box-sizing:border-box; }
.oni-harmonia{
	--gold:#FFBE7A; --gold2:#F2A663; --cream:#F2E4C9; --beige:#CBBFA2;
	--bg:#0a131c; --bg2:#0D1A26; --panel:#0D2633; --mid:#1F3A4A;
	--btn-bg:#F2E4C9; --btn-tx:#152635; --btn-hover:#FFBE7A;
	--ok:#9FD6C9; --love:#FF6B81;
	--radius:14px;
	position:relative;
	font-family:'Inter',system-ui,sans-serif;
	color:var(--cream);
	background:radial-gradient(1200px 600px at 50% -10%, #11283a 0%, var(--bg) 70%);
	border:1px solid rgba(255,190,122,.18);
	border-radius:18px;
	overflow:hidden;
	display:flex;
	flex-direction:column;
	height:78vh;
	min-height:560px;
	max-height:900px;
	box-shadow:0 24px 60px rgba(0,0,0,.45);
	-webkit-tap-highlight-color:transparent;
}
.oni-harmonia h1,.oni-harmonia h2,.oni-harmonia h3,.oni-harmonia .ttl{ font-family:'Marcellus SC',serif; color:var(--gold); margin:0; font-weight:400; }
.oni-harmonia .iconify{ vertical-align:-.15em; }

/* ---- Loading ---- */
.oni-h-loading{ display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;flex:1;min-height:560px;color:var(--gold); }
.oni-h-loading .iconify{ animation:oni-h-pulse 1.4s ease-in-out infinite; }
@keyframes oni-h-pulse{ 0%,100%{opacity:.45;transform:scale(.96)} 50%{opacity:1;transform:scale(1.04)} }

/* ============================  LOGIN  ============================ */
.oni-h-login{ display:flex;align-items:center;justify-content:center;flex:1;min-height:0;padding:24px; }
.oni-h-login-card{
	width:100%;max-width:380px;text-align:center;
	background:linear-gradient(180deg, rgba(31,58,74,.55), rgba(13,38,51,.65));
	border:1px solid rgba(255,190,122,.22);border-radius:var(--radius);padding:30px 26px;position:relative;
	box-shadow:0 18px 40px rgba(0,0,0,.45);
}
.oni-h-login-card::before{ content:"";position:absolute;left:18%;right:18%;top:-1px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);border-radius:2px; }
.oni-h-login-card .seal{ width:64px;height:64px;margin:0 auto 14px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 30% 30%, rgba(255,190,122,.25), rgba(255,190,122,.05));border:1.5px solid var(--gold);color:var(--gold);font-size:34px; }
.oni-h-login-card h2{ font-size:24px;margin-bottom:4px; }
.oni-h-login-card .sub{ color:var(--beige);font-size:13px;margin:0 0 22px; }
.oni-h-field{ text-align:left;margin-bottom:14px; }
.oni-h-field label{ display:block;font-size:12px;letter-spacing:.04em;color:var(--beige);margin-bottom:6px;text-transform:uppercase; }
.oni-harmonia input[type=text],
.oni-harmonia input[type=password],
.oni-harmonia input[type=search],
.oni-harmonia input[type=email]{
	width:100%;background:rgba(10,19,28,.7);border:1px solid rgba(203,191,162,.28);
	color:var(--cream);border-radius:10px;padding:11px 13px;font-size:15px;font-family:inherit;outline:none;transition:.15s;
}
.oni-harmonia input:focus{ border-color:var(--gold);box-shadow:0 0 0 3px rgba(255,190,122,.15); }
.oni-h-colorin{ width:60px;height:38px;padding:2px;background:transparent;border:1px solid rgba(203,191,162,.3);border-radius:8px;cursor:pointer; }
.oni-h-btn{
	display:inline-flex;align-items:center;justify-content:center;gap:8px;
	background:var(--btn-bg);color:var(--btn-tx);border:none;border-radius:50px;
	padding:11px 20px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:.15s;text-decoration:none;
}
.oni-h-btn:hover{ background:var(--btn-hover); }
.oni-h-btn.full{ width:100%; }
.oni-h-btn.ghost{ background:transparent;color:var(--gold);border:1px solid rgba(255,190,122,.4); }
.oni-h-btn.ghost:hover{ background:rgba(255,190,122,.1); }
.oni-h-error{ background:rgba(255,107,129,.12);border:1px solid rgba(255,107,129,.4);color:#ffd2d8;border-radius:10px;padding:10px 12px;font-size:13px;margin-bottom:14px;display:none; }
.oni-h-error.show{ display:block; }

/* ============================  APP SHELL  ======================== */
.oni-h-app{ display:none;flex-direction:column;flex:1;min-height:0; }
.oni-h-app.show{ display:flex; }

.oni-h-topbar{
	display:flex;align-items:center;gap:14px;padding:14px 18px;
	background:linear-gradient(180deg, rgba(13,38,51,.9), rgba(13,26,38,.5));
	border-bottom:1px solid rgba(255,190,122,.14);position:sticky;top:0;z-index:5;
}
.oni-h-logo{ display:flex;align-items:center;gap:9px;font-family:'Marcellus SC',serif;color:var(--gold);font-size:20px;white-space:nowrap; }
.oni-h-search{ flex:1;position:relative;min-width:0; }
.oni-h-search .iconify{ position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--beige);font-size:18px; }
.oni-h-search input{ padding-left:38px !important; }
.oni-h-user{ display:flex;align-items:center;gap:8px;white-space:nowrap; }
.oni-h-user .who{ font-size:13px;color:var(--beige);max-width:120px;overflow:hidden;text-overflow:ellipsis; }
.oni-h-iconbtn{ background:rgba(255,190,122,.1);border:1px solid rgba(255,190,122,.25);color:var(--gold);width:38px;height:38px;border-radius:10px;display:grid;place-items:center;cursor:pointer;font-size:19px;transition:.15s; }
.oni-h-iconbtn:hover{ background:rgba(255,190,122,.2); }

.oni-h-body{ display:flex;flex:1;min-height:0;overflow:hidden; }

/* Nav latérale */
.oni-h-nav{ width:212px;flex-shrink:0;padding:14px 12px;border-right:1px solid rgba(255,190,122,.1);overflow-y:auto;min-height:0; }
.oni-h-navsec{ font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--beige);opacity:.7;margin:14px 8px 6px; }
.oni-h-navsec:first-child{ margin-top:2px; }
.oni-h-navitem{ display:flex;align-items:center;gap:10px;padding:8px 11px;border-radius:10px;cursor:pointer;color:var(--cream);font-size:13.5px;transition:.12s;border:1px solid transparent;position:relative; }
.oni-h-navitem .iconify{ font-size:18px;color:var(--gold);flex-shrink:0; }
.oni-h-navitem .lbl{ overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.oni-h-navitem:hover{ background:rgba(255,190,122,.08); }
.oni-h-navitem.active{ background:rgba(255,190,122,.14);border-color:rgba(255,190,122,.3); }
.oni-h-navitem .count{ margin-left:auto;font-size:11.5px;color:var(--beige);background:rgba(10,19,28,.6);padding:1px 8px;border-radius:20px; }
.oni-h-navitem .del{ margin-left:auto;opacity:0;color:var(--love);font-size:17px;line-height:1;transition:.12s;padding:0 4px; }
.oni-h-navitem:hover .del{ opacity:.7; }
.oni-h-navitem .del:hover{ opacity:1; }
.oni-h-newpl{ margin-top:8px;width:100%;justify-content:flex-start;gap:8px;font-size:13px;padding:9px 12px; }
.oni-h-uploadbtn{ margin-top:8px;width:100%;justify-content:flex-start;gap:8px;font-size:13px;padding:9px 12px; }

/* Contenu principal */
.oni-h-main{ flex:1;min-width:0;padding:18px 20px 24px;overflow-y:auto;min-height:0; }
.oni-h-viewhead{ display:flex;align-items:center;gap:12px;margin-bottom:16px; }
.oni-h-viewhead .vicon{ width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:24px;border:1px solid rgba(255,190,122,.3);background:rgba(255,190,122,.08);color:var(--gold);flex-shrink:0; }
.oni-h-viewhead .vmeta{ min-width:0; }
.oni-h-viewhead h2{ font-size:22px; }
.oni-h-viewhead .vsub{ font-size:12.5px;color:var(--beige); }
.oni-h-headacts{ margin-left:auto;display:flex;gap:8px;flex-shrink:0; }
.oni-h-headbtn{ width:38px;height:38px;border-radius:10px;display:grid;place-items:center;cursor:pointer;font-size:18px;background:rgba(255,190,122,.1);border:1px solid rgba(255,190,122,.25);color:var(--gold);transition:.12s; }
.oni-h-headbtn:hover{ background:rgba(255,190,122,.2); }
.oni-h-headbtn.danger{ background:rgba(255,107,129,.1);border-color:rgba(255,107,129,.3);color:var(--love); }
.oni-h-headbtn.danger:hover{ background:rgba(255,107,129,.2); }

.oni-h-cat-title{ display:flex;align-items:center;gap:9px;font-family:'Marcellus SC',serif;color:var(--gold);font-size:16px;margin:20px 0 11px;padding-bottom:7px;border-bottom:1px solid rgba(255,190,122,.12); }
.oni-h-cat-title .iconify{ font-size:19px; }

/* Grille de sons — cartes compactes (soundboard) */
.oni-h-grid{ display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:10px; }
.oni-h-tile{
	position:relative;text-align:center;
	background:linear-gradient(155deg, rgba(31,58,74,.5), rgba(13,38,51,.6));
	border:1px solid rgba(255,190,122,.16);border-radius:12px;padding:12px 10px 9px;transition:.14s;
}
.oni-h-tile:hover{ border-color:rgba(255,190,122,.4);box-shadow:0 8px 20px rgba(0,0,0,.4); }
.oni-h-tile.playing{ border-color:var(--c,#FFBE7A);box-shadow:0 0 0 1px var(--c,#FFBE7A),0 8px 20px rgba(0,0,0,.45);background:linear-gradient(155deg, rgba(31,58,74,.7), rgba(13,38,51,.75)); }
.oni-h-tile .snd{ position:relative;width:100%;border:none;background:none;cursor:pointer;display:flex;justify-content:center;padding:0; }
.oni-h-tile .ic{ width:50px;height:50px;border-radius:50%;display:grid;place-items:center;font-size:25px;color:var(--c,#FFBE7A);background:rgba(255,190,122,.14);background:color-mix(in srgb, var(--c,#FFBE7A) 14%, transparent);border:1px solid rgba(255,190,122,.45);border:1px solid color-mix(in srgb, var(--c,#FFBE7A) 45%, transparent);transition:.14s; }
.oni-h-tile:hover .ic{ background:rgba(255,190,122,.22);background:color-mix(in srgb, var(--c,#FFBE7A) 22%, transparent); }
.oni-h-tile.playing .ic{ background:var(--c,#FFBE7A);color:#152635; }
/* pastille play/stop au survol */
.oni-h-tile .ic::after{ content:"";position:absolute;inset:0;margin:auto;width:50px;height:50px;border-radius:50%;background:rgba(13,26,38,.55);opacity:0;display:grid;transition:.14s; }
.oni-h-tile .eq{ position:absolute;top:0;left:50%;transform:translateX(-50%);width:50px;height:50px;border-radius:50%;display:none;align-items:flex-end;justify-content:center;gap:2px;padding-bottom:14px;background:rgba(13,26,38,.35); }
.oni-h-tile.playing .eq{ display:flex; }
.oni-h-tile.playing .ic .iconify{ display:none; }
.oni-h-tile .eq i{ width:3px;background:#152635;border-radius:2px;animation:oni-h-eq .9s ease-in-out infinite; }
.oni-h-tile .eq i:nth-child(2){ animation-delay:.2s } .oni-h-tile .eq i:nth-child(3){ animation-delay:.4s } .oni-h-tile .eq i:nth-child(4){ animation-delay:.1s }
@keyframes oni-h-eq{ 0%,100%{height:5px} 50%{height:20px} }
.oni-h-tile .nm{ font-size:12.5px;font-weight:600;color:var(--cream);line-height:1.25;margin-top:9px;
	display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:31px;word-break:break-word; }
.oni-h-tile .tools{ display:flex;justify-content:center;gap:5px;margin-top:7px; }
.oni-h-tile .t{ width:27px;height:27px;border-radius:8px;display:grid;place-items:center;background:rgba(10,19,28,.4);border:1px solid rgba(203,191,162,.18);color:var(--beige);font-size:15px;cursor:pointer;transition:.12s; }
.oni-h-tile .t:hover{ color:var(--gold);border-color:rgba(255,190,122,.4); }
.oni-h-tile .t.fav.on{ color:var(--love);border-color:rgba(255,107,129,.5);background:rgba(255,107,129,.12); }

.oni-h-empty{ text-align:center;color:var(--beige);padding:40px 16px;font-size:14px; }
.oni-h-empty .iconify{ font-size:40px;color:rgba(255,190,122,.4);display:block;margin:0 auto 10px; }

/* ============================  MIXER BAR  ====================== */
.oni-h-mixer{
	flex-shrink:0;
	background:linear-gradient(180deg, rgba(13,38,51,.94), rgba(8,16,24,.98));
	border-top:1px solid rgba(255,190,122,.22);
	display:none;flex-direction:column;
	max-height:42%;
}
.oni-h-mixer.show{ display:flex; }
.mix-master{ display:flex;align-items:center;gap:14px;padding:9px 16px;border-bottom:1px solid rgba(255,190,122,.12);flex-shrink:0; }
.mix-stopall{ display:inline-flex;align-items:center;gap:6px;background:rgba(255,107,129,.14);border:1px solid rgba(255,107,129,.4);color:#ffd2d8;border-radius:50px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:.12s; }
.mix-stopall:hover{ background:rgba(255,107,129,.24); }
.mix-stopall .iconify{ font-size:16px; }
.mix-mvol{ display:flex;align-items:center;gap:8px;width:180px; }
.mix-mvol .iconify{ color:var(--gold);font-size:18px; }
.mix-count{ margin-left:auto;font-size:12px;color:var(--beige);white-space:nowrap; }

.mix-tracks{ display:flex;flex-wrap:wrap;gap:10px;padding:11px 16px;overflow-y:auto;min-height:0; }
.mix-chip{ flex:0 0 auto;width:300px;display:flex;flex-direction:column;gap:8px;background:rgba(10,19,28,.5);border:1px solid rgba(255,190,122,.35);border:1px solid color-mix(in srgb, var(--c,#FFBE7A) 35%, transparent);border-radius:12px;padding:10px 12px; }
.mc-head{ display:flex;align-items:center;gap:10px; }
.mc-ico{ width:36px;height:36px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;color:#152635;font-size:19px; }
.mc-t{ flex:1;min-width:0;font-size:13px;font-weight:600;color:var(--cream);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.mc-btn{ width:32px;height:32px;flex-shrink:0;border-radius:8px;display:grid;place-items:center;background:rgba(255,190,122,.08);border:1px solid rgba(255,190,122,.2);color:var(--beige);font-size:16px;cursor:pointer;transition:.12s; }
.mc-btn:hover{ color:var(--gold);border-color:rgba(255,190,122,.45); }
.mc-btn.on{ color:var(--gold);background:rgba(255,190,122,.2);border-color:rgba(255,190,122,.5); }
.mc-btn.stop:hover{ color:var(--love);border-color:rgba(255,107,129,.5);background:rgba(255,107,129,.12); }
.mc-seekrow{ display:flex;align-items:center;gap:9px; }
.mc-time{ font-size:11px;color:var(--beige);width:38px;flex-shrink:0;font-variant-numeric:tabular-nums; }
.mc-time.mc-dur{ text-align:right; }
.mc-volrow{ display:flex;align-items:center;gap:9px; }
.mc-vico{ color:var(--beige);font-size:17px;flex-shrink:0; }

/* Range commun */
.oni-h-range{ -webkit-appearance:none;appearance:none;height:5px;border-radius:5px;background:rgba(203,191,162,.25);outline:none;cursor:pointer;width:100%; }
.oni-h-range::-webkit-slider-thumb{ -webkit-appearance:none;width:13px;height:13px;border-radius:50%;background:var(--gold);cursor:pointer;box-shadow:0 0 0 3px rgba(255,190,122,.2); }
.oni-h-range::-moz-range-thumb{ width:13px;height:13px;border:none;border-radius:50%;background:var(--gold);cursor:pointer; }

/* ============================  POPUP  =========================== */
.oni-h-overlay{ position:absolute;inset:0;z-index:20;background:rgba(5,10,16,.7);display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(3px); }
.oni-h-overlay.show{ display:flex; }
.oni-h-modal{ width:100%;max-width:380px;background:linear-gradient(180deg, var(--panel), var(--bg2));border:1px solid rgba(255,190,122,.28);border-radius:var(--radius);padding:22px;box-shadow:0 24px 60px rgba(0,0,0,.6);position:relative; }
.oni-h-modal::before{ content:"";position:absolute;left:18%;right:18%;top:-1px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent); }
.oni-h-modal h3{ font-size:19px;margin-bottom:14px;display:flex;align-items:center;gap:8px; }
.oni-h-modal .x{ position:absolute;top:14px;right:14px;color:var(--beige);cursor:pointer;font-size:22px; }
.oni-h-modal .x:hover{ color:var(--gold); }
.oni-h-pl-list{ display:flex;flex-direction:column;gap:8px;max-height:240px;overflow-y:auto;margin-bottom:14px; }
.oni-h-pl-opt{ display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:11px;background:rgba(10,19,28,.5);border:1px solid rgba(203,191,162,.18);cursor:pointer;transition:.12s;font-size:14px; }
.oni-h-pl-opt:hover{ border-color:var(--gold);background:rgba(255,190,122,.08); }
.oni-h-pl-opt .iconify{ font-size:19px; }
.oni-h-pl-opt.added{ opacity:.55; }
.oni-h-pl-opt.added .iconify.chk{ color:var(--ok); }
.oni-h-newrow{ display:flex;gap:8px;margin-top:6px; }
.oni-h-newrow input{ flex:1; }
.oni-harmonia .oni-h-select{ width:100%;background:rgba(10,19,28,.7);border:1px solid rgba(203,191,162,.28);color:var(--cream);border-radius:10px;padding:11px 13px;font-size:15px;font-family:inherit;outline:none;cursor:pointer; }
.oni-harmonia .oni-h-select:focus{ border-color:var(--gold); }
.oni-harmonia .oni-h-filein{ width:100%;background:rgba(10,19,28,.6);border:1px dashed rgba(203,191,162,.4);color:var(--cream);border-radius:10px;padding:11px 13px;font-size:13.5px;cursor:pointer; }
.oni-h-checkrow{ display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--cream);margin:6px 0 4px;cursor:pointer; }
.oni-h-checkrow input{ width:auto; }

/* Toast */
.oni-h-toast{ position:absolute;left:50%;bottom:24px;transform:translateX(-50%) translateY(10px);z-index:30;background:rgba(13,38,51,.96);border:1px solid rgba(255,190,122,.4);color:var(--cream);padding:10px 16px;border-radius:30px;font-size:13.5px;opacity:0;pointer-events:none;transition:.25s;display:flex;align-items:center;gap:8px;box-shadow:0 8px 24px rgba(0,0,0,.4); }
.oni-h-toast.show{ opacity:1;transform:translateX(-50%) translateY(0); }
.oni-h-toast .iconify{ color:var(--gold); }

::-webkit-scrollbar{ width:8px;height:8px; }
.oni-harmonia ::-webkit-scrollbar-thumb{ background:rgba(255,190,122,.25);border-radius:6px; }
.oni-harmonia ::-webkit-scrollbar-track{ background:transparent; }

/* ============================  RESPONSIVE  ====================== */
@media (max-width:760px){
	.oni-harmonia{ border-radius:14px;min-height:540px; }
	.oni-h-topbar{ flex-wrap:wrap;gap:10px;padding:12px 14px; }
	.oni-h-logo{ font-size:18px; }
	.oni-h-search{ order:3;flex-basis:100%; }
	.oni-h-user .who{ display:none; }
	.oni-h-body{ flex-direction:column; }
	.oni-h-nav{ width:100%;display:flex;gap:8px;overflow-x:auto;padding:12px;border-right:none;border-bottom:1px solid rgba(255,190,122,.1);flex-wrap:nowrap; }
	.oni-h-navsec{ display:none; }
	.oni-h-navitem{ flex-direction:column;gap:4px;min-width:74px;text-align:center;font-size:11px;padding:8px 8px;flex-shrink:0; }
	.oni-h-navitem .count,.oni-h-navitem .del{ display:none; }
	.oni-h-navitem .lbl{ max-width:64px; }
	.oni-h-navitem .iconify{ font-size:20px; }
	.oni-h-newpl,.oni-h-uploadbtn{ flex-direction:row;min-width:auto;white-space:nowrap; }
	.oni-h-main{ padding:16px 14px 20px; }
	.oni-h-viewhead h2{ font-size:19px; }
	.oni-h-grid{ grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:9px; }
	.oni-h-tile{ padding:11px 8px 8px; }
	.oni-h-tile .ic{ width:46px;height:46px;font-size:23px; }
	.oni-h-tile .nm{ font-size:11.5px; }
	/* Mixer mobile */
	.oni-h-mixer{ max-height:50%; }
	.mix-master{ flex-wrap:wrap;gap:10px;padding:9px 12px; }
	.mix-mvol{ width:140px; }
	.mix-count{ flex-basis:100%;margin-left:0;text-align:center;order:3; }
	.mix-tracks{ padding:10px 12px; }
	.mix-chip{ width:100%; }
	.oni-h-toast{ bottom:20px; }
}
