:root{
  --bg:#070a12;
  --bg2:#0d1220;
  --panel:rgba(17,24,39,.86);
  --panel2:rgba(11,18,32,.92);
  --line:rgba(255,255,255,.10);
  --text:#eef4ff;
  --muted:#9ba9c2;
  --muted2:#6e7b93;
  --accent:#ffcc33;
  --accent2:#8b5cf6;
  --accent3:#06b6d4;
  --danger:#ef4444;
  --ok:#22c55e;
  --warn:#f59e0b;
  --shadow:0 24px 80px rgba(0,0,0,.45);
  --radius:22px;
  --radius2:14px;
  --font:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0;font-family:var(--font);background:radial-gradient(circle at top left,rgba(139,92,246,.25),transparent 30%),radial-gradient(circle at top right,rgba(6,182,212,.14),transparent 35%),linear-gradient(135deg,#070a12,#0e1022 55%,#080b13);color:var(--text);overflow:hidden}
button,input,select{font:inherit}
button{cursor:pointer}
a{color:inherit}
.hidden{display:none!important}
.app-shell{height:100%;display:grid;grid-template-columns:300px 1fr;gap:0;position:relative}
.sidebar{height:100%;padding:22px 18px;background:rgba(3,7,18,.72);border-right:1px solid var(--line);backdrop-filter:blur(20px);display:flex;flex-direction:column;gap:18px;min-width:0}
.brand{display:flex;align-items:center;gap:12px;padding:6px 4px 16px;border-bottom:1px solid var(--line)}
.brand-logo{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,#ff2d55,#ffcc33);box-shadow:0 12px 40px rgba(255,45,85,.25);font-size:24px;font-weight:900;color:white}
.brand-title{font-size:20px;font-weight:900;letter-spacing:.2px}
.brand-sub{font-size:12px;color:var(--muted);margin-top:2px}
.nav-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}
.nav-btn{width:100%;display:flex;align-items:center;gap:12px;padding:12px;border:0;border-radius:14px;background:transparent;color:var(--text);text-align:left;font-weight:700;transition:.16s}
.nav-btn:hover,.nav-btn.active{background:rgba(255,255,255,.08);transform:translateX(2px)}
.nav-btn .ico{width:28px;height:28px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.08);flex:0 0 auto}
.user-card{margin-top:auto;background:linear-gradient(135deg,rgba(139,92,246,.22),rgba(6,182,212,.10));border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.user-row{display:flex;align-items:center;gap:12px;min-width:0}
.avatar{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent2),var(--accent3));font-weight:900;color:white;flex:0 0 auto}
.user-meta{min-width:0;flex:1}
.user-name{font-weight:900;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-role{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}
.storage-meter{margin-top:14px}
.storage-label{display:flex;justify-content:space-between;gap:10px;color:var(--muted);font-size:12px;margin-bottom:8px}
.progress{height:8px;background:rgba(255,255,255,.10);border-radius:999px;overflow:hidden}
.progress>span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent2),var(--accent3),var(--accent));border-radius:999px;transition:width .25s}
.logout-btn{width:100%;margin-top:14px;border:1px solid var(--line);border-radius:14px;padding:11px 12px;background:rgba(255,255,255,.08);color:var(--text);font-weight:800}
.logout-btn:hover{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.35)}
.main{height:100%;display:flex;flex-direction:column;min-width:0}
.topbar{padding:20px 26px 14px;border-bottom:1px solid var(--line);background:rgba(7,10,18,.55);backdrop-filter:blur(20px);display:flex;align-items:center;gap:14px;min-height:92px}
.mobile-menu{display:none;width:44px;height:44px;border-radius:15px;border:1px solid var(--line);background:rgba(255,255,255,.08);color:var(--text);padding:0}
.search-box{height:48px;min-width:280px;max-width:560px;flex:1;display:flex;align-items:center;gap:12px;border:1px solid var(--line);background:rgba(255,255,255,.06);border-radius:16px;padding:0 14px;min-height:48px}
.search-box input{width:100%;border:0;background:transparent;outline:0;color:var(--text);font-weight:600}
.search-box input::placeholder{color:var(--muted2)}
.top-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.btn{border:0;border-radius:15px;padding:12px 16px;font-weight:900;color:#101320;background:var(--text);display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:44px;transition:.15s;white-space:nowrap;max-width:100%}
.btn:hover{transform:translateY(-1px);filter:brightness(1.05)}
.btn.primary{background:linear-gradient(135deg,var(--accent),#fff3a3)}
.btn.purple{background:linear-gradient(135deg,var(--accent2),#c4b5fd);color:white}
.btn.cyan{background:linear-gradient(135deg,var(--accent3),#a5f3fc);color:#06101b}
.btn.ghost{background:rgba(255,255,255,.08);color:var(--text);border:1px solid var(--line)}
.btn.danger{background:linear-gradient(135deg,#ef4444,#fb7185);color:white}
.btn.small{min-height:34px;padding:8px 10px;border-radius:12px;font-size:13px}
.icon-svg{width:18px;height:18px;display:inline-grid;place-items:center;flex:0 0 auto}
.icon-svg svg,.ico svg,.search-icon svg,.mobile-menu svg,.empty-art svg{width:100%;height:100%;display:block}
.btn .icon-svg{width:18px;height:18px}
.nav-btn .ico svg{width:16px;height:16px}
.search-icon{width:18px;height:18px;display:grid;place-items:center;color:var(--muted)}
.mobile-menu svg{width:20px;height:20px;margin:auto}
.crumb{display:inline-flex;align-items:center;gap:8px}
.item-icon svg{width:20px;height:20px}
.item-actions .btn,.view-actions .btn,.admin-user-actions .btn{gap:8px}
.empty-art{width:62px;height:62px;margin:0 auto 12px;color:rgba(255,255,255,.88)}
.tree-btn .icon-svg,.admin-badge .icon-svg{width:16px;height:16px}

.content{flex:1;overflow:auto;padding:22px 26px 30px;position:relative}
.drop-zone{border:1px dashed rgba(255,255,255,.16);border-radius:var(--radius);padding:18px;background:rgba(255,255,255,.035);transition:.16s;min-height:100%}
.drop-zone.dragover{border-color:var(--accent);background:rgba(255,204,51,.10);box-shadow:0 0 0 4px rgba(255,204,51,.08) inset}
.breadcrumbs{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:0 0 16px;color:var(--muted)}
.crumb{border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--text);border-radius:999px;padding:8px 12px;font-weight:800;display:inline-flex;align-items:center;gap:8px}
.crumb:hover{background:rgba(255,255,255,.11)}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px}
.section-title{font-size:22px;font-weight:950;letter-spacing:.2px}
.view-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.table-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel2);box-shadow:var(--shadow);overflow:hidden;-webkit-overflow-scrolling:touch}
table{width:100%;min-width:0;border-collapse:collapse;table-layout:fixed}
th,td{text-align:left;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.07);vertical-align:middle;min-width:0}
th{font-size:12px;color:var(--muted);font-weight:900;letter-spacing:.08em;text-transform:uppercase;background:rgba(255,255,255,.035);user-select:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
th.sortable{cursor:pointer}
th.sortable:hover{color:var(--text)}
th:nth-child(2),td:nth-child(2){width:96px}
th:nth-child(3),td:nth-child(3){width:160px}
th:nth-child(4),td:nth-child(4){width:86px}
th:nth-child(5),td:nth-child(5){width:340px;text-align:right}
tr:last-child td{border-bottom:0}
tbody tr{transition:.14s;cursor:default;-webkit-user-select:none;user-select:none}
tbody tr:hover{background:rgba(255,255,255,.055)}
.item-name{display:flex;align-items:center;gap:12px;min-width:0;font-weight:850;cursor:default;-webkit-user-select:none;user-select:none}
.item-icon{width:38px;height:38px;border-radius:13px;display:grid;place-items:center;background:rgba(255,255,255,.08);flex:0 0 auto;color:#dbeafe}
.item-icon.folder{background:linear-gradient(135deg,rgba(255,204,51,.26),rgba(245,158,11,.18))}
.item-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:default;-webkit-user-select:none;user-select:none}
.item-actions{display:flex;gap:7px;justify-content:flex-end;flex-wrap:wrap;min-width:0}
.empty{padding:50px 20px;text-align:center;color:var(--muted)}
.empty .big{font-size:62px;margin-bottom:12px;filter:drop-shadow(0 10px 30px rgba(255,255,255,.1));display:grid;place-items:center}
.empty-title{font-weight:950;color:var(--text);font-size:20px;margin-bottom:6px}
.login-page{height:100%;display:grid;place-items:center;padding:20px;position:relative;overflow:hidden}
.login-page:before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(255,204,51,.20),transparent 62%);top:-120px;right:-140px;pointer-events:none}
.login-card{width:min(440px,100%);background:rgba(13,18,32,.82);border:1px solid var(--line);border-radius:30px;box-shadow:var(--shadow);padding:28px;backdrop-filter:blur(22px);position:relative;z-index:1}
.login-card .brand{border-bottom:0;padding:0;margin-bottom:18px;justify-content:center;text-align:left}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.field label{font-size:13px;font-weight:900;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}
.input,.select{width:100%;height:46px;border:1px solid var(--line);border-radius:15px;background:rgba(255,255,255,.07);color:var(--text);outline:0;padding:0 14px;font-weight:700}
.input:focus,.select:focus{border-color:rgba(255,204,51,.55);box-shadow:0 0 0 4px rgba(255,204,51,.08)}
.select option{background:#111827;color:white}
.error{background:rgba(239,68,68,.14);border:1px solid rgba(239,68,68,.35);color:#fecaca;padding:11px 13px;border-radius:14px;margin-bottom:14px;font-weight:800}
.success{background:rgba(34,197,94,.14);border:1px solid rgba(34,197,94,.35);color:#bbf7d0;padding:11px 13px;border-radius:14px;margin-bottom:14px;font-weight:800}
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.62);display:grid;place-items:center;z-index:1000;padding:18px;backdrop-filter:blur(10px)}
.modal{width:min(560px,100%);max-height:88vh;overflow:auto;background:linear-gradient(135deg,rgba(17,24,39,.98),rgba(9,13,24,.98));border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);padding:20px}
.modal.big{width:min(920px,100%)}
.modal-head{display:flex;justify-content:space-between;gap:14px;align-items:center;margin-bottom:14px}
.modal-title{font-size:20px;font-weight:950}
.close-btn{width:40px;height:40px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.08);color:var(--text);font-size:22px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px;flex-wrap:wrap}
.folder-tree{max-height:360px;overflow:auto;border:1px solid var(--line);border-radius:18px;padding:10px;background:rgba(255,255,255,.04)}
.tree-btn{width:100%;border:0;background:transparent;color:var(--text);padding:9px 10px;border-radius:12px;text-align:left;font-weight:800;display:flex;gap:9px;align-items:center}
.tree-btn:hover,.tree-btn.active{background:rgba(255,255,255,.09)}
.preview-box{display:grid;place-items:center;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:18px;min-height:240px;overflow:hidden}
.preview-box img,.preview-box video{max-width:100%;max-height:64vh;border-radius:14px}
.preview-box audio{width:min(100%,620px)}
.preview-frame{width:100%;height:65vh;border:0;background:white;border-radius:14px}
.upload-box{display:flex;flex-direction:column;gap:14px}
.upload-summary{color:var(--muted);font-weight:800;line-height:1.6}
.upload-destination-card{border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.05);padding:14px}
.upload-destination-title{font-size:13px;font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
.upload-destination-path{font-weight:800;word-break:break-word}
.link-action{border:0;background:transparent;color:var(--text);font-weight:900;text-decoration:underline;padding:0;align-self:flex-start}
.inline-create{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.inline-create .input{flex:1;min-width:220px}
.tree-icon svg{width:16px;height:16px}
.admin-badge{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900;color:var(--muted);margin-top:6px}
.admin-wrap{height:100%;display:flex;flex-direction:column;overflow:auto;padding:24px;background:radial-gradient(circle at 20% 0,rgba(139,92,246,.18),transparent 28%),radial-gradient(circle at 80% 0,rgba(255,204,51,.12),transparent 30%)}
.admin-top{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:20px}
.admin-title{display:flex;align-items:center;gap:13px}
.admin-title h1{margin:0;font-size:28px}
.admin-sub{color:var(--muted);font-weight:700;margin-top:3px}
.admin-grid{display:grid;grid-template-columns:360px 1fr;gap:18px;min-height:0}
.panel-card{background:rgba(13,18,32,.84);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;min-width:0}
.user-list-admin{display:grid;gap:12px}
.admin-user-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.04);padding:14px}
.admin-badge{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:999px;padding:5px 9px;font-size:12px;font-weight:900;color:var(--muted);margin-top:6px}
.admin-user-actions{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.full{grid-column:1/-1}
.checkbox-line{display:flex;align-items:center;gap:10px;font-weight:900;color:var(--text);padding:10px 0}
.checkbox-line input{width:18px;height:18px;accent-color:#ffcc33}
.toast-wrap{position:fixed;right:18px;bottom:18px;display:grid;gap:10px;z-index:2000}
.toast{background:rgba(17,24,39,.95);border:1px solid var(--line);border-left:4px solid var(--accent);box-shadow:var(--shadow);border-radius:16px;padding:12px 14px;max-width:380px;font-weight:800;color:var(--text)}
.toast.error{border-left-color:var(--danger);color:#fecaca;margin:0}
.toast.success{border-left-color:var(--ok);color:#bbf7d0;margin:0}

@media (max-width:1300px){
  th:nth-child(2),td:nth-child(2){width:86px}
  th:nth-child(3),td:nth-child(3){width:145px}
  th:nth-child(4),td:nth-child(4){width:70px}
  th:nth-child(5),td:nth-child(5){width:220px}
  .item-actions .btn{width:36px;height:34px;min-height:34px;padding:7px;border-radius:11px}
  .item-actions .btn span:not(.icon-svg){display:none}
  .item-actions .btn .icon-svg{width:18px;height:18px}
}
@media (max-width:1120px){
  .app-shell{grid-template-columns:280px 1fr}
  .sidebar{padding:18px 12px}
  .topbar{padding:14px 16px;gap:10px}
  .content{padding:16px}
  .search-box{min-width:220px}
  th:nth-child(3),td:nth-child(3){width:132px}
}
@media (max-width:980px){
  html,body{overflow:auto}
  .app-shell{grid-template-columns:1fr;height:auto;min-height:100%}
  .sidebar{position:fixed;z-index:900;inset:0 auto 0 0;width:300px;transform:translateX(-105%);transition:.2s}
  .sidebar.open{transform:translateX(0)}
  .mobile-menu{display:grid;place-items:center}
  .main{min-height:100vh}
  .topbar{padding:14px;flex-wrap:wrap;min-height:auto}
  .search-box{order:2;min-width:100%;max-width:none}
  .top-actions{order:3;width:100%;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
  .top-actions .btn{width:100%;min-width:0}
  .content{padding:14px}
  .drop-zone{padding:12px}
  .section-head{align-items:flex-start;flex-direction:column}
  .view-actions{width:100%}
  .btn{padding:11px 12px;font-size:14px}
  th:nth-child(3),td:nth-child(3){display:none}
  th,td{padding:12px 10px}
  .item-actions .btn{min-height:32px;font-size:12px;padding:7px 8px}
  table{min-width:0}
  .admin-grid{grid-template-columns:1fr}
  .admin-wrap{padding:14px}
  .admin-top{flex-direction:column;align-items:flex-start}
  .form-grid{grid-template-columns:1fr}
}

@media (max-width:760px){
  .table-card{background:transparent;border:0;box-shadow:none;overflow:visible}
  table,thead,tbody,tr,td{display:block;width:100%!important}
  table{border-collapse:separate;table-layout:auto}
  thead{display:none}
  tbody{display:grid;gap:12px}
  tbody tr{border:1px solid var(--line);border-radius:18px;background:var(--panel2);box-shadow:var(--shadow);overflow:hidden}
  tbody tr:hover{background:var(--panel2)}
  td{border-bottom:1px solid rgba(255,255,255,.07);padding:11px 14px}
  td:first-child{padding-top:14px}
  td:nth-child(2),td:nth-child(3),td:nth-child(4){display:flex!important;align-items:center;justify-content:space-between;gap:12px;color:var(--muted);font-weight:800}
  td:nth-child(2)::before{content:"Taille";font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted2)}
  td:nth-child(3)::before{content:"Modification";font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted2)}
  td:nth-child(4)::before{content:"Type";font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted2)}
  td:last-child{border-bottom:0;text-align:left;padding:12px 14px 14px}
  .item-actions{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;justify-content:stretch}
  .item-actions .btn{width:100%;height:38px;min-height:38px;padding:8px}
  .item-actions .btn span:not(.icon-svg){display:none}
}
@media (max-width:620px){
  .topbar{gap:10px}
  .top-actions{grid-template-columns:repeat(3,minmax(0,1fr))}
  .top-actions .btn{flex-direction:column;gap:6px;min-height:70px;padding:10px 8px;border-radius:16px}
  .top-actions .btn .txt{display:block;font-size:12px;line-height:1.1;white-space:normal;text-align:center}
  .search-box{height:46px;padding:0 12px}
  .view-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
  .view-actions .btn{width:100%;justify-content:center}
  table{min-width:0}
  .item-actions{min-width:0}
  .login-card{padding:22px;border-radius:24px}
  .admin-user-row{grid-template-columns:1fr}
  .admin-user-actions{justify-content:flex-start}
}
@media (max-width:420px){
  .brand-title{font-size:18px}
  .top-actions{grid-template-columns:1fr}
  .top-actions .btn{flex-direction:row;justify-content:center;min-height:46px}
  .top-actions .btn .txt{font-size:13px;white-space:nowrap}
}


.btn:disabled{opacity:.48;cursor:not-allowed;filter:saturate(.6)}
.btn:disabled:hover{transform:none;filter:saturate(.6)}
.drop-zone.is-trash{border-style:solid;background:rgba(255,255,255,.025)}
.item-subtext{-webkit-user-select:none;user-select:none;cursor:default;font-size:12px;color:var(--muted2);font-weight:700;margin-top:3px;white-space:normal;word-break:break-word}
.context-menu{position:fixed;z-index:2500;min-width:220px;border:1px solid var(--line);border-radius:16px;background:rgba(17,24,39,.98);box-shadow:var(--shadow);padding:8px;backdrop-filter:blur(14px)}
.context-menu button{width:100%;border:0;background:transparent;color:var(--text);border-radius:12px;padding:10px 12px;display:flex;align-items:center;gap:10px;font-weight:900;text-align:left}
.context-menu button:hover{background:rgba(255,255,255,.08)}
.duplicate-box{display:grid;gap:12px;color:var(--muted)}
.duplicate-intro{line-height:1.6;font-weight:800;color:var(--text)}
.duplicate-intro span{color:var(--muted)}
.duplicate-choice{width:100%;border:1px solid transparent;border-radius:18px;background:rgba(255,255,255,.045);padding:14px;text-align:left;color:var(--text);transition:.15s}
.duplicate-choice:hover{border-color:rgba(255,204,51,.36);background:rgba(255,204,51,.08);transform:translateY(-1px)}
.duplicate-title{font-size:18px;font-weight:950;color:#ff6b6b;margin-bottom:6px}
.duplicate-desc{color:var(--muted);font-weight:800;line-height:1.45;margin-bottom:12px}
.duplicate-file{display:flex;align-items:center;gap:12px;color:var(--text)}
.duplicate-file svg{width:42px;height:42px;flex:0 0 auto;background:rgba(255,255,255,.10);border-radius:12px;padding:8px;color:var(--muted)}
.duplicate-file b{display:block;font-weight:900;word-break:break-word}
.duplicate-file span{display:block;color:var(--muted);font-size:13px;margin-top:3px;font-weight:700}
@media (max-width:760px){
  .duplicate-title{font-size:16px}
  .duplicate-choice{padding:12px}
  .duplicate-file svg{width:38px;height:38px}
  .context-menu{max-width:calc(100vw - 20px)}
}

/* Correctif corbeille : onglet conservé + boutons sans scroll horizontal */
.drop-zone.is-trash .table-card{overflow:hidden}
.drop-zone.is-trash table{min-width:0;table-layout:fixed;width:100%}
.drop-zone.is-trash th:nth-child(5),.drop-zone.is-trash td:nth-child(5){width:220px;text-align:right}
.drop-zone.is-trash .item-actions{justify-content:flex-end;min-width:0}
.drop-zone.is-trash .item-actions .btn{max-width:100%}
@media (max-width:760px){
  .drop-zone.is-trash .item-actions{grid-template-columns:repeat(2,minmax(0,1fr))}
  .drop-zone.is-trash .item-actions .btn{width:100%}
}
@media (max-width:420px){
  .drop-zone.is-trash .item-actions{grid-template-columns:1fr}
}

/* Sélection + barre d'actions propre */
th:nth-child(5),td:nth-child(5){width:74px;text-align:right}
.selection-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin:0 0 14px;padding:10px 12px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.055);box-shadow:0 16px 50px rgba(0,0,0,.25)}
.selection-pill{display:inline-flex;align-items:center;max-width:min(420px,100%);border-radius:999px;padding:8px 12px;background:rgba(139,0,0,.42);color:#fff;font-weight:950;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.selection-pill span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.selection-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.toolbar-btn{min-height:38px;border:1px solid var(--line);border-radius:13px;background:rgba(255,255,255,.07);color:var(--text);display:inline-flex;align-items:center;gap:8px;padding:8px 11px;font-weight:900;transition:.15s}
.toolbar-btn:hover{background:rgba(255,255,255,.12);transform:translateY(-1px)}
.toolbar-btn.danger{color:#fecaca;border-color:rgba(239,68,68,.30);background:rgba(239,68,68,.10)}
.toolbar-btn.icon-only{width:38px;padding:8px;justify-content:center}
.select-mark{width:22px;height:22px;border:1px solid rgba(255,255,255,.36);border-radius:6px;display:grid;place-items:center;flex:0 0 auto;font-size:14px;font-weight:950;background:rgba(255,255,255,.05)}
.selected-row{background:rgba(255,255,255,.10)!important;box-shadow:inset 4px 0 0 var(--accent)}
.selected-row .select-mark{background:var(--accent);color:#101320;border-color:var(--accent)}
.row-menu-btn{width:36px;height:36px;border:1px solid var(--line);border-radius:11px;background:rgba(255,255,255,.06);color:var(--text);display:inline-grid;place-items:center;padding:0}
.row-menu-btn:hover{background:rgba(255,255,255,.13)}
.compact-actions{display:flex!important;justify-content:flex-end!important;min-width:0!important}
.context-menu.action-menu{min-width:260px;padding:8px}
.context-menu .danger-line{color:#fecaca}
.share-panel{display:grid;gap:14px}
.share-target{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.045);padding:12px}
.share-target-name{font-weight:950;word-break:break-word}
.share-target-sub{font-size:12px;color:var(--muted);font-weight:800;margin-top:3px}
.share-link-row{display:flex;gap:10px;align-items:center}
.share-link-row .input{flex:1}
.share-note{border:1px solid rgba(34,197,94,.25);background:rgba(34,197,94,.10);color:#bbf7d0;border-radius:14px;padding:10px 12px;font-weight:800}
.share-page{min-height:100%;overflow:auto;padding:28px;background:radial-gradient(circle at top left,rgba(139,92,246,.22),transparent 30%),linear-gradient(135deg,#070a12,#0e1022)}
.share-public-card{width:min(1050px,100%);margin:0 auto;background:rgba(13,18,32,.84);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:22px}
.share-public-brand{border-bottom:1px solid var(--line);margin-bottom:18px}
.share-public-head{margin-top:6px}
.share-locked{width:min(480px,100%);margin:30px auto 10px;padding:22px;border:1px solid var(--line);border-radius:24px;background:rgba(255,255,255,.04)}
.share-locked h1{margin:0 0 10px;font-size:24px}
.share-locked p{color:var(--muted);font-weight:800;line-height:1.5}
.share-preview{border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.04);padding:16px;min-height:260px;display:grid;place-items:center;overflow:auto}
.share-preview img,.share-preview video{max-width:100%;max-height:68vh;border-radius:14px}
.share-preview audio{width:min(100%,620px)}
@media (max-width:980px){
  .selection-toolbar{align-items:flex-start;flex-direction:column}
  .selection-actions{width:100%;justify-content:flex-start}
  .toolbar-btn span:not(.icon-svg){display:none}
  .toolbar-btn{width:40px;height:40px;justify-content:center;padding:8px}
  .toolbar-btn.icon-only{width:40px;height:40px}
  th:nth-child(5),td:nth-child(5){width:60px}
}
@media (max-width:760px){
  tbody tr.selected-row{box-shadow:inset 4px 0 0 var(--accent),var(--shadow)}
  td:last-child{display:block!important;text-align:right;padding:10px 14px 14px}
  .compact-actions{justify-content:flex-end!important}
  .selection-pill{max-width:100%}
  .share-link-row{flex-direction:column;align-items:stretch}
  .share-public-card{padding:14px;border-radius:22px}
  .share-page{padding:14px}
}

/* Ajustements sélection, multi-sélection et personnalisation */
.brand-logo{overflow:hidden}
.brand-logo img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}
.item-name,.item-text,.item-title-line,.item-subtext{cursor:default;-webkit-user-select:none;user-select:none}
.item-title-line{display:flex;align-items:center;gap:8px;min-width:0}
.item-title-line>span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.select-mark{appearance:none;-webkit-appearance:none;cursor:pointer;color:inherit}
.select-mark:hover{border-color:var(--accent);background:rgba(255,204,51,.12)}
.share-badges{display:inline-flex;align-items:center;gap:4px;flex:0 0 auto}
.share-badge{width:22px;height:22px;border:1px solid rgba(34,197,94,.35);border-radius:999px;display:grid;place-items:center;color:#bbf7d0;background:rgba(34,197,94,.10)}
.share-badge.locked{border-color:rgba(255,204,51,.45);color:#fde68a;background:rgba(255,204,51,.12)}
.share-badge svg{width:13px;height:13px}
.drop-zone.has-selection .section-head{margin-bottom:8px}
.selection-toolbar{margin:-2px 0 8px;padding:7px 9px;border-radius:15px;min-height:46px;box-shadow:0 10px 32px rgba(0,0,0,.20)}
.selection-pill{padding:6px 10px;font-size:14px;max-width:min(360px,100%)}
.selection-actions{gap:6px}
.toolbar-btn{min-height:34px;padding:7px 10px;border-radius:12px;font-size:13px}
.toolbar-btn.icon-only{width:34px;height:34px;padding:7px}
.settings-card{grid-column:1/-1}
.settings-card .form-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.settings-card .field.full{grid-column:1/-1}
@media (max-width:1180px){.settings-card .form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:760px){
  .settings-card .form-grid{grid-template-columns:1fr}
  .selection-toolbar{margin:0 0 8px;align-items:stretch}
  .selection-actions{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;width:100%}
  .toolbar-btn,.toolbar-btn.icon-only{width:100%;height:36px;min-height:36px}
}

/* Correctif final : bandeau de sélection très compact + case tout sélectionner */
.name-head{display:flex;align-items:center;gap:12px;min-width:0}
.name-head>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
th .select-mark{margin:0;vertical-align:middle}
.select-all-mark{width:22px;height:22px;min-width:22px;border-radius:6px;background:rgba(255,255,255,.05);color:var(--text)}
.select-all-mark:disabled{opacity:.45;cursor:default}
.select-all-mark.is-all,.select-all-mark.is-partial{background:var(--accent);border-color:var(--accent);color:#101320}
.drop-zone.has-selection .section-head{margin-bottom:6px!important}
.selection-toolbar{display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:space-between!important;flex-wrap:nowrap!important;gap:8px!important;margin:-4px 0 6px!important;padding:5px 8px!important;min-height:38px!important;border-radius:14px!important;overflow:visible!important}
.selection-pill{max-width:220px!important;min-width:0!important;padding:5px 9px!important;font-size:13px!important;line-height:1.15!important;flex:1 1 auto!important}
.selection-actions{display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:flex-end!important;flex-wrap:nowrap!important;gap:5px!important;width:auto!important;min-width:0!important;flex:0 0 auto!important}
.toolbar-btn,.toolbar-btn.icon-only{width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important;padding:6px!important;border-radius:11px!important;justify-content:center!important;font-size:0!important;line-height:1!important;flex:0 0 auto!important}
.toolbar-btn span:not(.icon-svg){display:none!important}
.toolbar-btn .icon-svg{width:17px!important;height:17px!important}
.toolbar-btn .icon-svg svg{width:17px!important;height:17px!important}
@media (max-width:760px){
  .selection-toolbar{align-items:center!important;flex-direction:row!important;flex-wrap:nowrap!important;margin:-3px 0 6px!important;padding:5px 7px!important}
  .selection-actions{display:flex!important;grid-template-columns:none!important;width:auto!important;overflow-x:auto!important;max-width:calc(100% - 132px)!important;padding-bottom:1px!important}
  .selection-pill{max-width:126px!important;font-size:12px!important}
  .toolbar-btn,.toolbar-btn.icon-only{width:30px!important;height:30px!important;min-width:30px!important;min-height:30px!important;padding:5px!important}
}

/* Panel admin en onglets + personnalisation auto */
.admin-tabs-shell{display:flex;flex-direction:column;gap:16px;min-height:0}
.admin-tabs{display:flex;gap:10px;align-items:center;flex-wrap:wrap;border:1px solid var(--line);border-radius:var(--radius);background:rgba(13,18,32,.74);box-shadow:var(--shadow);padding:10px}
.admin-tab-btn{border:1px solid var(--line);border-radius:15px;background:rgba(255,255,255,.055);color:var(--text);display:inline-flex;align-items:center;gap:9px;min-height:44px;padding:10px 14px;font-weight:950;transition:.15s}
.admin-tab-btn:hover{background:rgba(255,255,255,.10);transform:translateY(-1px)}
.admin-tab-btn.active{background:linear-gradient(135deg,rgba(255,204,51,.24),rgba(139,92,246,.18));border-color:rgba(255,204,51,.38);box-shadow:0 12px 34px rgba(0,0,0,.22)}
.admin-tab-panel{display:none}
.admin-tab-panel.active{display:block}
.admin-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.admin-panel-sub{color:var(--muted);font-weight:800;margin-top:4px;font-size:13px}
.admin-tabs-shell .settings-card{grid-column:auto}
.admin-tabs-shell .settings-card .form-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.admin-tabs-shell .settings-card .field.full{grid-column:1/-1}
@media (max-width:1180px){.admin-tabs-shell .settings-card .form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:760px){
  .admin-tabs{display:grid;grid-template-columns:1fr;gap:8px}
  .admin-tab-btn{width:100%;justify-content:flex-start}
  .admin-tabs-shell .settings-card .form-grid{grid-template-columns:1fr}
}

/* Corrections panel : bouton compact + upload logo/icône */
.create-user-submit-row{display:flex;justify-content:center;margin-top:14px}
.create-user-submit{width:auto!important;min-width:220px;max-width:100%;padding:11px 22px!important}
.setting-asset-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}
.setting-upload-btn{min-width:150px;white-space:nowrap}
@media (max-width:760px){
  .setting-asset-row{grid-template-columns:1fr}
  .setting-upload-btn{width:100%;min-width:0}
  .create-user-submit{width:100%!important;min-width:0}
}

/* Upload en arrière-plan : fermer la fenêtre ne coupe plus l'envoi */
.background-upload-wrap{position:fixed;right:18px;bottom:18px;z-index:2100;display:grid;gap:10px;width:min(390px,calc(100vw - 36px));pointer-events:none}
.background-upload-card{pointer-events:auto;border:1px solid var(--line);border-radius:18px;background:linear-gradient(135deg,rgba(17,24,39,.98),rgba(9,13,24,.98));box-shadow:var(--shadow);padding:14px;transition:.22s}
.background-upload-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
.background-upload-title{font-weight:950;color:var(--text);font-size:15px}
.background-upload-sub{color:var(--muted);font-weight:800;font-size:12px;margin-top:3px;line-height:1.35}
.background-upload-close{width:32px;height:32px;border:1px solid var(--line);border-radius:11px;background:rgba(255,255,255,.08);color:var(--text);font-size:20px;line-height:1;display:grid;place-items:center}
.background-upload-close:hover{background:rgba(255,255,255,.14)}
.background-upload-progress{height:10px;margin-top:4px}
.background-upload-percent{font-weight:950;color:var(--muted);font-size:12px;margin-top:7px}
.background-upload-card.done{border-color:rgba(34,197,94,.38)}
.background-upload-card.done .background-upload-percent{color:#bbf7d0}
.background-upload-card.error{border-color:rgba(239,68,68,.42)}
.background-upload-card.error .background-upload-percent{color:#fecaca}
.select-mark svg{width:14px;height:14px;display:block;pointer-events:none}
.select-all-mark svg{width:14px;height:14px;display:block;pointer-events:none}
.selection-toolbar.hidden{display:none!important}
.drop-zone:not(.has-selection) .selection-toolbar{display:none!important}
@media (max-width:620px){.background-upload-wrap{right:10px;bottom:10px;width:calc(100vw - 20px)}}

/* Inscription, compte et stockage membres */
.profile-btn{margin-top:10px;background:rgba(255,255,255,.055)}
.account-delete-zone{margin-top:14px;border:1px solid rgba(239,68,68,.32);border-radius:16px;background:rgba(239,68,68,.08);padding:13px 14px;color:#fecaca;font-weight:850;line-height:1.45;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.account-delete-zone .btn{margin-left:auto}
.setting-checkbox{align-self:end;border:1px solid var(--line);border-radius:15px;background:rgba(255,255,255,.045);padding:12px 14px;margin:0;min-height:46px}
.admin-badges-row{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-top:6px}
.admin-badge.expired{color:#fecaca;border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.08)}
.storage-mini{border:1px solid var(--line);border-radius:15px;background:rgba(255,255,255,.045);padding:12px 14px;color:var(--muted);font-weight:800;line-height:1.5}
.storage-summary-card{border:1px solid var(--line);border-radius:17px;background:rgba(255,255,255,.045);padding:14px;margin-bottom:12px;color:var(--muted);font-weight:800;line-height:1.55}
.storage-tree-modal{max-height:430px;overflow:auto;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.035);padding:8px}
.storage-tree-row{display:flex;align-items:center;gap:9px;border-radius:12px;padding:9px 10px;color:var(--text);font-weight:800}
.storage-tree-row:hover{background:rgba(255,255,255,.06)}
.storage-tree-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.storage-tree-size{color:var(--muted);font-size:12px;font-weight:900;white-space:nowrap}
@media (max-width:760px){.admin-badges-row{align-items:flex-start}.storage-tree-row{font-size:13px}.storage-tree-size{display:none}}
.field-help{color:var(--muted);font-size:12px;font-weight:800;line-height:1.35;margin-top:4px}


/* Quota Mo / Go + téléchargement stockage admin */
.quota-control{display:grid;grid-template-columns:minmax(0,1fr) 96px;gap:10px;align-items:center}
.storage-download-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);border-radius:11px;background:rgba(255,255,255,.07);color:var(--text);font-size:12px;font-weight:900;text-decoration:none;padding:7px 9px;white-space:nowrap}
.storage-download-btn:hover{background:rgba(255,255,255,.13)}
.storage-download-btn svg{width:15px;height:15px;display:block}
@media (max-width:760px){.quota-control{grid-template-columns:1fr}.storage-download-btn span{display:none}.storage-download-btn{padding:7px}}

/* Correctif : notifications au-dessus des uploads, annulation upload, aperçu stockage admin */
.toast-wrap{bottom:var(--toast-bottom,18px)!important;z-index:2300!important;transition:bottom .18s ease}
.background-upload-wrap{z-index:2100!important}
.background-upload-card{position:relative;overflow:hidden}
.background-upload-head{align-items:center!important;margin-bottom:10px!important}
.background-upload-copy{min-width:0;flex:1}
.background-upload-actions{display:flex;align-items:center;gap:7px;flex:0 0 auto}
.background-upload-minimize,.background-upload-cancel{width:30px;height:30px;border:1px solid var(--line);border-radius:11px;background:rgba(255,255,255,.08);color:var(--text);display:grid;place-items:center;padding:0;transition:.16s}
.background-upload-minimize svg,.background-upload-cancel svg{width:16px;height:16px;display:block}
.background-upload-minimize:hover{background:rgba(255,255,255,.14)}
.background-upload-cancel{border-color:rgba(239,68,68,.36);color:#fecaca;background:rgba(239,68,68,.10);opacity:0;transform:scale(.92);pointer-events:none}
.background-upload-card:hover .background-upload-cancel,.background-upload-card.done .background-upload-cancel,.background-upload-card.error .background-upload-cancel,.background-upload-card.cancelled .background-upload-cancel{opacity:1;transform:scale(1);pointer-events:auto}
.background-upload-cancel:hover{background:rgba(239,68,68,.20);border-color:rgba(239,68,68,.55)}
.background-upload-body{transition:.16s}
.background-upload-card.is-minimized{padding:11px 12px;max-width:280px;justify-self:end}
.background-upload-card.is-minimized .background-upload-head{margin-bottom:0!important}
.background-upload-card.is-minimized .background-upload-body{display:none}
.background-upload-card.is-minimized .background-upload-title{font-size:13px}
.background-upload-card.is-minimized .background-upload-sub{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.background-upload-card.cancelled{border-color:rgba(239,68,68,.42)}
.background-upload-card.cancelled .background-upload-percent{color:#fecaca}
.storage-preview-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);border-radius:11px;background:rgba(255,255,255,.07);color:var(--text);font-size:12px;font-weight:900;text-decoration:none;padding:7px 9px;white-space:nowrap}
.storage-preview-btn:hover{background:rgba(255,255,255,.13)}
.storage-preview-btn svg{width:15px;height:15px;display:block}
@media (max-width:760px){.storage-preview-btn span,.storage-download-btn span{display:none}.storage-preview-btn{padding:7px}.toast-wrap{right:10px!important;left:10px!important;bottom:var(--toast-bottom,10px)!important}.toast{max-width:none}}

/* Correctif : aperçu stockage admin au-dessus de la modal stockage */
.preview-modal-backdrop{z-index:1120}
.preview-modal{box-shadow:0 28px 90px rgba(0,0,0,.55)}
.preview-modal-body{min-width:0}

/* Correctif : aucun soulignement sur les liens affichés comme des boutons */
a.btn,a.btn:hover,a.btn:focus,a.btn:visited,
.btn,.btn:hover,.btn:focus,
a.toolbar-btn,a.toolbar-btn:hover,a.toolbar-btn:focus,a.toolbar-btn:visited,
.toolbar-btn,.toolbar-btn:hover,.toolbar-btn:focus,
a.storage-download-btn,a.storage-download-btn:hover,a.storage-download-btn:focus,a.storage-download-btn:visited,
a.storage-preview-btn,a.storage-preview-btn:hover,a.storage-preview-btn:focus,a.storage-preview-btn:visited,
.storage-download-btn,.storage-download-btn:hover,.storage-download-btn:focus,
.storage-preview-btn,.storage-preview-btn:hover,.storage-preview-btn:focus,
a.admin-tab,a.admin-tab:hover,a.admin-tab:focus,a.admin-tab:visited,
.admin-tab,.admin-tab:hover,.admin-tab:focus,
a.sidebar-link,a.sidebar-link:hover,a.sidebar-link:focus,a.sidebar-link:visited,
a[role="button"],a[role="button"]:hover,a[role="button"]:focus,a[role="button"]:visited{text-decoration:none!important}

/* Correctif : barre d'outils permanente et stable */
.drop-zone .section-head,
.drop-zone.has-selection .section-head{margin-bottom:14px!important}
#selectionToolbar.selection-toolbar,
#selectionToolbar.selection-toolbar.hidden,
.drop-zone:not(.has-selection) #selectionToolbar.selection-toolbar{display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:space-between!important;flex-wrap:nowrap!important;gap:8px!important;margin:0 0 8px!important;padding:5px 8px!important;min-height:38px!important;height:38px!important;border-radius:14px!important;overflow:hidden!important;position:sticky;top:0;z-index:30;box-sizing:border-box}
#selectionToolbar .selection-pill{display:flex!important;align-items:center!important;min-width:0!important;flex:0 0 220px!important;max-width:220px!important;height:28px!important;padding:5px 9px!important;overflow:hidden!important;white-space:nowrap!important;text-overflow:ellipsis!important;box-sizing:border-box!important}
#selectionToolbar #selectionName{display:block!important;min-width:0!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}
#selectionToolbar:not(.has-selected-items) .selection-pill{visibility:hidden!important;pointer-events:none!important}
#selectionToolbar .selection-actions{display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:flex-end!important;flex-wrap:nowrap!important;gap:5px!important;width:auto!important;min-width:0!important;flex:0 0 auto!important;overflow:visible!important}
#selectionToolbar .toolbar-btn.hidden{display:inline-flex!important;visibility:hidden!important;opacity:0!important;pointer-events:none!important}
@media (max-width:760px){
  #selectionToolbar.selection-toolbar,
  #selectionToolbar.selection-toolbar.hidden,
  .drop-zone:not(.has-selection) #selectionToolbar.selection-toolbar{height:38px!important;min-height:38px!important;margin:0 0 8px!important;padding:5px 7px!important}
  #selectionToolbar .selection-pill{flex:0 0 126px!important;max-width:126px!important;height:28px!important;font-size:12px!important}
  #selectionToolbar .selection-actions{max-width:calc(100% - 134px)!important;overflow-x:auto!important;padding-bottom:1px!important}
}

/* Correctif : scroll des dossiers avec beaucoup de fichiers */
@media (min-width:761px){
  .app-shell{height:100vh!important;min-height:0!important;overflow:hidden!important}
  .main{min-height:0!important;overflow:hidden!important}
  .content{min-height:0!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;scrollbar-gutter:stable}
  .drop-zone{height:auto!important;min-height:100%!important}
}
