/* ═══════════════════════════════════════════════════════════════════════════
   Intranet File Manager Pro — Styles v4
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
    --ifmp-primary:      #1A3E6E;
    --ifmp-primary-light:#2155A0;
    --ifmp-accent:       #C9A84C;
    --ifmp-bg:           #f0f4f9;
    --ifmp-surface:      #ffffff;
    --ifmp-border:       #e0e7ef;
    --ifmp-text:         #1e293b;
    --ifmp-text-muted:   #64748b;
    --ifmp-shadow:       0 1px 3px rgba(0,0,0,.08);
    --ifmp-shadow-md:    0 4px 16px rgba(0,0,0,.12);
    --ifmp-radius:       10px;
    --ifmp-radius-sm:    6px;
    --ifmp-font:         'Segoe UI', system-ui, -apple-system, sans-serif;
    --ifmp-sidebar-w:    220px;
    --ifmp-header-h:     60px;
}

/* ── Reset ──────────────────────────────────────────────────────────────────── */
.ifmp-app *, .ifmp-app *::before, .ifmp-app *::after { box-sizing: border-box; margin: 0; padding: 0; }
.ifmp-app a { text-decoration: none; color: inherit; }
.ifmp-app ul, .ifmp-app ol { list-style: none; }
.ifmp-app button { cursor: pointer; font-family: var(--ifmp-font); }

/* ── App wrapper ────────────────────────────────────────────────────────────── */
.ifmp-app {
    font-family: var(--ifmp-font);
    font-size: 14px;
    color: var(--ifmp-text);
    background: var(--ifmp-bg);
    border-radius: var(--ifmp-radius);
    overflow: visible; /* NE PAS mettre hidden — coupe les boutons d'action */
    box-shadow: var(--ifmp-shadow-md);
    min-height: 600px;
    display: flex;
    flex-direction: column;
}

/* ── Header ─────────────────────────────────────────────────────────────────── */
.ifmp-header {
    height: var(--ifmp-header-h);
    background: var(--ifmp-primary);
    display: flex;
    align-items: center;
    padding: 0 20px;
    gap: 16px;
    border-radius: var(--ifmp-radius) var(--ifmp-radius) 0 0;
    box-shadow: 0 2px 8px rgba(0,0,0,.20);
    flex-shrink: 0;
}
.ifmp-header-left { flex: 0 0 auto; }
.ifmp-header-center { flex: 1 1 auto; max-width: 560px; }
.ifmp-header-right { flex: 0 0 auto; display: flex; align-items: center; gap: 10px; margin-left: auto; }
.ifmp-logo { color:#fff; font-size:17px; font-weight:700; display:flex; align-items:center; gap:8px; white-space:nowrap; }
.ifmp-logo i { color: var(--ifmp-accent); font-size:20px; }

.ifmp-search-bar {
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 24px;
    display: flex; align-items: center; padding: 0 14px; gap: 8px;
    transition: background .2s;
}
.ifmp-search-bar:focus-within { background: rgba(255,255,255,.22); }
.ifmp-search-bar i { color: rgba(255,255,255,.65); font-size:13px; }
.ifmp-search-bar input { background:transparent; border:none; outline:none; color:#fff; font-size:14px; width:100%; padding:8px 0; }
.ifmp-search-bar input::placeholder { color: rgba(255,255,255,.55); }

.ifmp-btn { display:inline-flex; align-items:center; gap:6px; padding:7px 16px; border:none; border-radius:20px; font-size:13px; font-weight:600; transition:all .2s; white-space:nowrap; }
.ifmp-btn-primary { background: var(--ifmp-accent); color:#fff; }
.ifmp-btn-primary:hover { background:#dab96a; transform:translateY(-1px); }
.ifmp-btn-ghost { background:rgba(255,255,255,.15); color:#fff; border:1px solid rgba(255,255,255,.25); }
.ifmp-btn-ghost:hover { background:rgba(255,255,255,.25); }
.ifmp-user-badge { color:rgba(255,255,255,.85); font-size:13px; display:flex; align-items:center; gap:6px; padding:6px 12px; background:rgba(255,255,255,.1); border-radius:20px; white-space:nowrap; }

/* ── Body ───────────────────────────────────────────────────────────────────── */
.ifmp-body { display:flex; min-height:540px; flex:1; }

/* ── Sidebar ────────────────────────────────────────────────────────────────── */
.ifmp-sidebar { width:var(--ifmp-sidebar-w); background:var(--ifmp-surface); border-right:1px solid var(--ifmp-border); padding:16px 0; overflow-y:auto; flex-shrink:0; }
.ifmp-sidebar-nav { padding:0 10px 12px; border-bottom:1px solid var(--ifmp-border); margin-bottom:12px; }
.ifmp-nav-item { display:flex; align-items:center; gap:10px; padding:9px 12px; border-radius:var(--ifmp-radius-sm); color:var(--ifmp-text-muted); font-size:13.5px; font-weight:500; transition:all .15s; }
.ifmp-nav-item i { width:16px; text-align:center; }
.ifmp-nav-item:hover { background:var(--ifmp-bg); color:var(--ifmp-primary); }
.ifmp-nav-item.active { background:rgba(26,62,110,.08); color:var(--ifmp-primary); font-weight:600; }
.ifmp-tree-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.8px; color:var(--ifmp-text-muted); padding:0 22px 8px; }
.ifmp-folder-tree { padding:0 10px; }
.ifmp-folder-tree > li > a, .ifmp-subtree a { display:flex; align-items:center; gap:8px; padding:7px 12px; border-radius:var(--ifmp-radius-sm); font-size:13px; color:var(--ifmp-text-muted); transition:all .15s; }
.ifmp-folder-tree > li > a:hover, .ifmp-subtree a:hover { background:var(--ifmp-bg); color:var(--ifmp-text); }
.ifmp-folder-tree > li > a.active, .ifmp-subtree a.active { background:rgba(26,62,110,.08); color:var(--ifmp-primary); font-weight:600; }
.ifmp-folder-tree .ifmp-folder-mac, .ifmp-subtree .ifmp-folder-mac { width:18px !important; height:18px !important; flex-shrink:0; filter:none; }
.ifmp-folder-tree a:hover .ifmp-folder-mac, .ifmp-subtree a:hover .ifmp-folder-mac { transform:none; filter:none; }
.ifmp-folder-tree svg, .ifmp-subtree svg { flex-shrink:0; }
.ifmp-subtree { padding-left:16px; }

/* ── Main ───────────────────────────────────────────────────────────────────── */
.ifmp-main { flex:1; padding:20px 24px; overflow-y:auto; background:var(--ifmp-bg); }

/* ── Breadcrumb ─────────────────────────────────────────────────────────────── */
.ifmp-breadcrumb { display:flex; align-items:center; flex-wrap:wrap; gap:4px; margin-bottom:18px; font-size:13px; color:var(--ifmp-text-muted); }
.ifmp-breadcrumb a { color:var(--ifmp-primary-light); font-weight:500; }
.ifmp-breadcrumb a:hover { text-decoration:underline; }
.ifmp-bc-sep { color:var(--ifmp-border); font-size:11px; }

/* ── Dropzone ───────────────────────────────────────────────────────────────── */
.ifmp-dropzone { border:2px dashed var(--ifmp-border); border-radius:var(--ifmp-radius); padding:24px; text-align:center; color:var(--ifmp-text-muted); margin-bottom:20px; transition:all .2s; background:var(--ifmp-surface); }
.ifmp-dropzone.drag-over { border-color:var(--ifmp-primary); background:rgba(26,62,110,.04); color:var(--ifmp-primary); }
.ifmp-dropzone i { font-size:28px; margin-bottom:8px; display:block; color:var(--ifmp-border); }
.ifmp-dropzone.drag-over i { color:var(--ifmp-primary); }
.ifmp-dropzone p { font-size:13px; }

/* ── Progress ───────────────────────────────────────────────────────────────── */
#ifmp-upload-progress { margin-bottom:16px; }
.ifmp-progress-bar { background:var(--ifmp-border); border-radius:4px; height:6px; overflow:hidden; margin-bottom:6px; }
.ifmp-progress-fill { height:100%; background:linear-gradient(90deg, var(--ifmp-primary), var(--ifmp-accent)); border-radius:4px; width:0; transition:width .3s; }
#ifmp-progress-text { font-size:12px; color:var(--ifmp-text-muted); }

/* ── Section title ──────────────────────────────────────────────────────────── */
.ifmp-section-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.8px; color:var(--ifmp-text-muted); margin-bottom:12px; margin-top:8px; }

/* ── Grid ───────────────────────────────────────────────────────────────────── */
.ifmp-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(140px, 1fr)); gap:14px; margin-bottom:24px; }

/* ═══════════════════════════════════════════════════════════════════════════
   ITEM CARD — Design macOS Finder
   Carte = icône + nom + taille + boutons toujours en bas
   ═══════════════════════════════════════════════════════════════════════════ */
.ifmp-item {
    background: var(--ifmp-surface);
    border: 1px solid var(--ifmp-border);
    border-radius: 12px;
    overflow: visible; /* JAMAIS hidden */
    display: flex;
    flex-direction: column;
    transition: box-shadow .18s, transform .18s, border-color .18s;
    position: relative;
}
.ifmp-item:hover {
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    transform: translateY(-2px);
    border-color: rgba(26,62,110,.25);
}

/* Zone cliquable (icône + nom) */
.ifmp-item-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 16px 10px 10px;
    gap: 8px;
    cursor: pointer;
    user-select: none;
    border-radius: 12px 12px 0 0;
    flex: 1;
}
.ifmp-item-inner:hover { background: rgba(26,62,110,.02); }

/* ── Icône ──────────────────────────────────────────────────────────────────── */
.ifmp-item-icon {
    width: 64px;
    height: 64px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    overflow: hidden;
    flex-shrink: 0;
}

/* Dossier macOS */
.ifmp-icon-folder {
    background: transparent !important;
    border-radius: 0 !important;
    width: 68px;
    height: 68px;
}
.ifmp-folder-mac {
    width: 68px;
    height: 68px;
    display: block;
    filter: drop-shadow(0 4px 8px rgba(200,130,0,.35));
    transition: filter .2s, transform .2s;
}
.ifmp-item:hover .ifmp-folder-mac {
    filter: drop-shadow(0 6px 14px rgba(200,130,0,.55));
    transform: translateY(-3px) scale(1.06);
}
.ifmp-icon-folder > i { display: none; }

/* ── Icônes fichier style macOS ──────────────────────────────────────────────
   Chaque type a son propre look SVG-like via CSS
   ────────────────────────────────────────────────────────────────────────── */
.ifmp-icon-file {
    position: relative;
    border-radius: 10px;
}

/* Base bleue (doc) */
.ifmp-color-doc   { background: linear-gradient(145deg, #2b6cb0, #1e4e8c); color: #fff; }
/* Rouge (pdf) */
.ifmp-color-pdf   { background: linear-gradient(145deg, #e53e3e, #c0392b); color: #fff; }
/* Vert (xls) */
.ifmp-color-xls   { background: linear-gradient(145deg, #38a169, #276749); color: #fff; }
/* Orange (ppt) */
.ifmp-color-ppt   { background: linear-gradient(145deg, #ed8936, #c05621); color: #fff; }
/* Violet (img) */
.ifmp-color-img   { background: transparent; color: #6b46c1; padding: 0; border-radius: 10px; overflow: hidden; }
/* Rose (vid) */
.ifmp-color-vid   { background: linear-gradient(145deg, #d53f8c, #b83280); color: #fff; }
/* Marron (zip) */
.ifmp-color-zip   { background: linear-gradient(145deg, #975a16, #744210); color: #fff; }
/* Gris (défaut) */
.ifmp-color-default { background: linear-gradient(145deg, #718096, #4a5568); color: #fff; }

/* Reflet brillant macOS sur les icônes fichiers colorées */
.ifmp-icon-file::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 50%;
    background: linear-gradient(180deg, rgba(255,255,255,.18) 0%, transparent 100%);
    border-radius: 10px 10px 0 0;
    pointer-events: none;
}
.ifmp-color-img::after { display: none; } /* pas de reflet sur les photos */

/* Miniature photo */
.ifmp-thumb {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 10px;
    display: block;
}

/* ── Texte sous l'icône ─────────────────────────────────────────────────────── */
.ifmp-item-meta { display:flex; flex-direction:column; align-items:center; gap:2px; width:100%; }
.ifmp-item-name {
    font-size: 12px;
    font-weight: 500;
    text-align: center;
    color: var(--ifmp-text);
    line-height: 1.3;
    word-break: break-word;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    max-width: 100%;
}
.ifmp-item-date { font-size:10.5px; color:var(--ifmp-text-muted); }

/* ── Context menu clic droit ────────────────────────────────────────────────── */
#ifmp-ctx-menu {
    position: fixed;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    box-shadow: 0 8px 30px rgba(0,0,0,.18), 0 2px 8px rgba(0,0,0,.10);
    padding: 6px;
    min-width: 190px;
    z-index: 99999;
    font-family: var(--ifmp-font);
    font-size: 13.5px;
    animation: ifmpCtxIn .1s ease;
}
@keyframes ifmpCtxIn { from{opacity:0;transform:scale(.96)} to{opacity:1;transform:scale(1)} }

.ifmp-ctx-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 14px;
    border-radius: 7px;
    cursor: pointer;
    color: #1e293b;
    transition: background .1s;
    white-space: nowrap;
    user-select: none;
}
.ifmp-ctx-item i {
    width: 16px;
    text-align: center;
    font-size: 13px;
    color: #64748b;
    flex-shrink: 0;
}
.ifmp-ctx-item:hover { background: #f1f5f9; }
.ifmp-ctx-item:hover i { color: var(--ifmp-primary); }
.ifmp-ctx-item.danger { color: #dc2626; }
.ifmp-ctx-item.danger i { color: #dc2626; }
.ifmp-ctx-item.danger:hover { background: #fef2f2; }
.ifmp-ctx-sep {
    height: 1px;
    background: #e2e8f0;
    margin: 4px 6px;
}

/* Supprimer la zone de boutons en bas des cartes */
.ifmp-item-actions { display: none !important; }

/* Indiquer visuellement qu'un clic droit est possible */
.ifmp-item { cursor: context-menu; }
.ifmp-item-inner { cursor: pointer; }

/* Surbrillance quand menu contextuel ouvert sur cet item */
.ifmp-item.ifmp-ctx-active {
    outline: 2px solid var(--ifmp-primary);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px rgba(26,62,110,.12);
}

/* ── Empty state ────────────────────────────────────────────────────────────── */
.ifmp-empty-state { text-align:center; padding:60px 20px; color:var(--ifmp-text-muted); }
.ifmp-empty-state i { font-size:48px; margin-bottom:14px; display:block; color:var(--ifmp-border); }
.ifmp-empty-state p { font-size:14px; margin-top:6px; }

/* ── Toasts ─────────────────────────────────────────────────────────────────── */
#ifmp-toast-container { position:fixed; bottom:24px; right:24px; display:flex; flex-direction:column; gap:8px; z-index:9999; }
.ifmp-toast { display:flex; align-items:center; gap:10px; padding:12px 18px; border-radius:var(--ifmp-radius-sm); background:var(--ifmp-text); color:#fff; font-size:13px; box-shadow:var(--ifmp-shadow-md); animation:ifmpSlideIn .25s ease; max-width:320px; }
.ifmp-toast.success { background:#166534; }
.ifmp-toast.error   { background:#991b1b; }
@keyframes ifmpSlideIn { from{transform:translateX(40px);opacity:0} to{transform:translateX(0);opacity:1} }

/* ── Modal preview ──────────────────────────────────────────────────────────── */
.ifmp-modal { position:fixed; inset:0; z-index:9998; display:flex; align-items:center; justify-content:center; }
.ifmp-modal-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.65); backdrop-filter:blur(6px); }
.ifmp-modal-inner {
    position: relative;
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 24px 64px rgba(0,0,0,.35);
    display: flex;
    flex-direction: column;
    max-width: 92vw;
    max-height: 92vh;
    overflow: hidden;
    z-index: 1;
    min-width: 340px;
}
.ifmp-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 18px;
    border-bottom: 1px solid #e2e8f0;
    background: #f8fafc;
    border-radius: 14px 14px 0 0;
    flex-shrink: 0;
    gap: 12px;
}
.ifmp-modal-title {
    font-size: 14px;
    font-weight: 600;
    color: #1e293b;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
}
.ifmp-modal-actions { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.ifmp-modal-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    border-radius: 8px;
    font-size: 12.5px;
    font-weight: 600;
    text-decoration: none;
    background: #1A3E6E;
    color: #fff;
    transition: all .15s;
    white-space: nowrap;
}
.ifmp-modal-btn:hover { background: #2155A0; color: #fff; }
.ifmp-modal-btn-gdocs { background: #4285f4; }
.ifmp-modal-btn-gdocs:hover { background: #3367d6; }
.ifmp-modal-close {
    width: 32px; height: 32px;
    border-radius: 8px;
    border: 1px solid #e2e8f0;
    background: #fff;
    color: #64748b;
    display: flex; align-items: center; justify-content: center;
    font-size: 14px; cursor: pointer; flex-shrink: 0;
    transition: all .12s;
}
.ifmp-modal-close:hover { background: #fee2e2; color: #dc2626; border-color: #fca5a5; }
#ifmp-preview-content {
    overflow: auto;
    flex: 1;
}
#ifmp-preview-content img { max-width:85vw; max-height:78vh; border-radius:8px; display:block; }
#ifmp-preview-content iframe { display:block; }

/* Boutons dans le contenu de la modale */
.ifmp-preview-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 24px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition: all .15s;
    cursor: pointer;
}
.ifmp-btn-blue { background: #1A3E6E; color: #fff; }
.ifmp-btn-blue:hover { background: #2155A0; color: #fff; }
.ifmp-btn-gray { background: #f1f5f9; color: #1e293b; border: 1px solid #e2e8f0; }
.ifmp-btn-gray:hover { background: #e2e8f0; color: #1e293b; }

/* ── Login / error ──────────────────────────────────────────────────────────── */
.ifmp-login-notice, .ifmp-error { padding:20px 24px; background:var(--ifmp-surface); border:1px solid var(--ifmp-border); border-radius:var(--ifmp-radius); color:var(--ifmp-text-muted); font-size:14px; }
.ifmp-login-notice a, .ifmp-error a { color:var(--ifmp-primary); }

/* ── Search results ─────────────────────────────────────────────────────────── */
#ifmp-search-results h3 { font-size:14px; color:var(--ifmp-text-muted); margin-bottom:14px; font-weight:600; }

/* ── Responsive ─────────────────────────────────────────────────────────────── */
@media (max-width:768px) {
    .ifmp-sidebar { display:none; }
    .ifmp-header-center { display:none; }
    .ifmp-grid { grid-template-columns:repeat(auto-fill, minmax(120px,1fr)); }
    .ifmp-main { padding:14px; }
}
