/* ═══════════════════════════════════════════════════════
   ORION — DRIVE v2  |  Desktop + Mobile
   ═══════════════════════════════════════════════════════ */

@keyframes drv-in  { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:translateY(0)} }
@keyframes drv-pop { from{opacity:0;transform:scale(.95)}      to{opacity:1;transform:scale(1)} }

#drive-container { animation: drv-in .22s ease; }

.drv-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  height: calc(100vh - 56px);
  overflow: hidden;
}
.drv-sidebar {
  background: var(--surface);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  overflow-y: auto; padding: 16px 0;
}
.drv-sidebar::-webkit-scrollbar { width:3px; }
.drv-sidebar::-webkit-scrollbar-thumb { background:var(--border); }
.drv-sidebar-section {
  font-size: 9px; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--text2); padding:12px 16px 4px;
}
.drv-sidebar-item {
  display:flex; align-items:center; gap:8px;
  padding:7px 16px; font-size:12px; color:var(--text2);
  cursor:pointer; transition:all .15s;
  border-left:2px solid transparent; user-select:none;
}
.drv-sidebar-item:hover { color:var(--text); background:rgba(255,255,255,.03); }
.drv-sidebar-item.active { color:var(--accent); border-left-color:var(--accent); background:rgba(0,212,255,.05); }
.drv-sidebar-item.trash:hover  { color:var(--danger); background:rgba(239,68,68,.05); }
.drv-sidebar-item.trash.active { color:var(--danger); border-left-color:var(--danger); background:rgba(239,68,68,.05); }
.drv-sidebar-icon { font-size:13px; width:16px; text-align:center; flex-shrink:0; }
.drv-sidebar-count {
  margin-left:auto; font-size:9px;
  background:var(--surface2); border:1px solid var(--border);
  border-radius:3px; padding:1px 5px; color:var(--text2);
}
.drv-pasta-node {
  display:flex; align-items:center; gap:6px;
  padding:5px 16px 5px 28px; font-size:11px; color:var(--text2);
  cursor:pointer; transition:all .15s;
  border-left:2px solid transparent; user-select:none;
}
.drv-pasta-node:hover { color:var(--text); background:rgba(255,255,255,.03); }
.drv-pasta-node.active { color:var(--accent); border-left-color:var(--accent); background:rgba(0,212,255,.05); }
.drv-pasta-node-name { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

.drv-main { display:flex; flex-direction:column; overflow:hidden; background:var(--bg); }

.drv-toolbar {
  display:flex; align-items:center; gap:10px;
  padding:11px 20px; border-bottom:1px solid var(--border);
  background:var(--surface); flex-wrap:wrap;
}
.drv-breadcrumb {
  display:flex; align-items:center; gap:4px;
  font-size:12px; color:var(--text2); flex:1;
  min-width:0; overflow:hidden;
}
.drv-bc-item { cursor:pointer; padding:2px 4px; border-radius:3px; white-space:nowrap; transition:color .15s; }
.drv-bc-item:hover { color:var(--accent); }
.drv-bc-item.current { color:var(--text); cursor:default; }
.drv-bc-sep { color:var(--border); font-size:10px; }
.drv-toolbar-acts { display:flex; gap:8px; align-items:center; }

.drv-btn {
  padding:7px 14px; border-radius:6px; font-size:11px;
  font-family:'DM Mono',monospace; letter-spacing:.4px;
  cursor:pointer; border:1px solid var(--border);
  background:var(--surface2); color:var(--text);
  transition:all .15s; white-space:nowrap;
  display:flex; align-items:center; gap:5px;
}
.drv-btn:hover { border-color:var(--accent); color:var(--accent); }
.drv-btn.primary { background:var(--accent); color:var(--bg); border-color:var(--accent); font-weight:600; }
.drv-btn.primary:hover { background:rgba(0,212,255,.8); }
.drv-btn.danger { border-color:var(--danger); color:var(--danger); }
.drv-btn.danger:hover { background:rgba(239,68,68,.08); }
.drv-btn.sm { padding:5px 10px; font-size:10px; }

.drv-search-wrap { position:relative; flex:1; min-width:160px; max-width:300px; }
.drv-search {
  width:100%; padding:7px 14px 7px 30px;
  background:var(--surface2); border:1px solid var(--border);
  border-radius:6px; color:var(--text);
  font-family:'DM Mono',monospace; font-size:11px;
  outline:none; transition:border-color .15s;
}
.drv-search:focus { border-color:var(--accent); }
.drv-search-ico { position:absolute; left:9px; top:50%; transform:translateY(-50%); font-size:11px; color:var(--text2); pointer-events:none; }
.drv-view-toggle { display:flex; background:var(--surface2); border:1px solid var(--border); border-radius:6px; overflow:hidden; }
.drv-vt-btn { padding:6px 10px; font-size:13px; cursor:pointer; background:transparent; border:none; color:var(--text2); transition:all .15s; }
.drv-vt-btn.active { background:var(--accent); color:var(--bg); }

.drv-sel-bar {
  display:none; align-items:center; gap:10px;
  padding:7px 20px; background:rgba(0,212,255,.07);
  border-bottom:1px solid rgba(0,212,255,.2);
  font-size:11px; color:var(--accent);
}
.drv-sel-bar.on { display:flex; }

.drv-content {
  flex:1; overflow-y:auto; padding:20px; position:relative;
}
.drv-content::-webkit-scrollbar { width:4px; }
.drv-content::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px; }

.drv-kpis { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:18px; }
.drv-kpi { background:var(--surface); border:1px solid var(--border); border-radius:8px; padding:12px 14px; position:relative; overflow:hidden; }
.drv-kpi::before { content:''; position:absolute; top:0;left:0;right:0; height:2px; }
.drv-kpi.blue::before   { background:linear-gradient(90deg,var(--accent),transparent); }
.drv-kpi.green::before  { background:linear-gradient(90deg,var(--accent3),transparent); }
.drv-kpi.purple::before { background:linear-gradient(90deg,var(--accent2),transparent); }
.drv-kpi.warn::before   { background:linear-gradient(90deg,var(--warn),transparent); }
.drv-kpi-l { font-size:9px; letter-spacing:1.5px; text-transform:uppercase; color:var(--text2); margin-bottom:4px; }
.drv-kpi-v { font-family:'Syne',sans-serif; font-size:20px; font-weight:800; line-height:1; }
.drv-kpi-s { font-size:9px; color:var(--text2); margin-top:3px; }

.drv-section-label { font-size:10px; letter-spacing:1px; text-transform:uppercase; color:var(--text2); margin:0 0 10px; }

.drv-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(155px,1fr)); gap:12px; }

.drv-folder-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:10px; padding:14px; cursor:pointer;
  transition:all .15s; user-select:none; position:relative;
}
.drv-folder-card:hover { border-color:rgba(0,212,255,.3); background:var(--surface2); }
.drv-folder-card.selected { border-color:var(--accent); background:rgba(0,212,255,.06); }
.drv-folder-card.drag-over { border-color:var(--accent); background:rgba(0,212,255,.1); border-style:dashed; }
.drv-folder-icon { font-size:30px; margin-bottom:8px; display:block; }
.drv-folder-name { font-size:11px; color:var(--text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.drv-folder-meta { font-size:9px; color:var(--text2); margin-top:3px; }

.drv-file-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:10px; overflow:hidden; cursor:pointer;
  transition:all .15s; user-select:none; position:relative;
}
.drv-file-card:hover { border-color:rgba(0,212,255,.3); transform:translateY(-1px); }
.drv-file-card.selected { border-color:var(--accent); background:rgba(0,212,255,.04); }
.drv-file-card.dragging { opacity:.4; }
.drv-file-preview {
  width:100%; height:96px; background:var(--surface2);
  display:flex; align-items:center; justify-content:center;
  font-size:30px; border-bottom:1px solid var(--border);
  overflow:hidden; position:relative;
}
.drv-file-preview img  { width:100%; height:100%; object-fit:cover; }
.drv-file-preview video{ width:100%; height:100%; object-fit:cover; }
.drv-play-ico {
  position:absolute; inset:0; background:rgba(0,0,0,.4);
  display:flex; align-items:center; justify-content:center;
  font-size:20px; opacity:0; transition:opacity .15s;
}
.drv-file-card:hover .drv-play-ico { opacity:1; }
.drv-file-info { padding:8px 10px; }
.drv-file-name { font-size:11px; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-bottom:2px; }
.drv-file-size { font-size:9px; color:var(--text2); }

.drv-check {
  position:absolute; top:7px; left:7px;
  width:15px; height:15px; border:1.5px solid var(--border);
  border-radius:3px; background:var(--surface);
  display:flex; align-items:center; justify-content:center;
  font-size:9px; opacity:0; transition:opacity .15s; z-index:2;
}
.drv-folder-card:hover .drv-check,
.drv-file-card:hover   .drv-check,
.drv-folder-card.selected .drv-check,
.drv-file-card.selected   .drv-check { opacity:1; }
.drv-folder-card.selected .drv-check,
.drv-file-card.selected   .drv-check { background:var(--accent); border-color:var(--accent); color:var(--bg); }

.drv-list { display:flex; flex-direction:column; gap:2px; }
.drv-list-head {
  display:grid; grid-template-columns:20px 28px 1fr 110px 90px 75px 32px;
  align-items:center; gap:10px; padding:5px 12px;
  font-size:10px; letter-spacing:1px; text-transform:uppercase;
  color:var(--text2); border-bottom:1px solid var(--border); margin-bottom:4px;
}
.drv-list-row {
  display:grid; grid-template-columns:20px 28px 1fr 110px 90px 75px 32px;
  align-items:center; gap:10px; padding:8px 12px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:7px; font-size:11px; cursor:pointer;
  transition:all .12s; user-select:none;
}
.drv-list-row:hover { border-color:rgba(0,212,255,.25); background:var(--surface2); }
.drv-list-row.selected { border-color:var(--accent); background:rgba(0,212,255,.05); }
.drv-list-ico  { font-size:17px; text-align:center; }
.drv-list-name { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--text); }
.drv-list-tipo { color:var(--text2); font-size:10px; }
.drv-list-tam  { color:var(--text2); }
.drv-list-data { color:var(--text2); }

.drv-drop-zone {
  position:absolute; inset:0;
  background:rgba(0,212,255,.06); border:2px dashed var(--accent);
  border-radius:10px; display:none; align-items:center;
  justify-content:center; font-size:14px; color:var(--accent);
  z-index:50; pointer-events:none; flex-direction:column; gap:8px;
}
.drv-drop-zone.on { display:flex; }
.drv-drop-ico { font-size:40px; opacity:.4; }

.drv-ctx {
  position:fixed; background:var(--surface); border:1px solid var(--border);
  border-radius:9px; padding:5px; z-index:3000; min-width:175px;
  box-shadow:0 12px 32px rgba(0,0,0,.5); animation:drv-pop .12s ease;
}
.drv-ctx-item {
  display:flex; align-items:center; gap:9px;
  padding:8px 12px; font-size:12px; color:var(--text);
  cursor:pointer; border-radius:5px; transition:background .12s;
  font-family:'DM Mono',monospace;
}
.drv-ctx-item:hover { background:var(--surface2); }
.drv-ctx-item.danger { color:var(--danger); }
.drv-ctx-item.danger:hover { background:rgba(239,68,68,.08); }
.drv-ctx-sep { height:1px; background:var(--border); margin:4px 8px; }
.drv-ctx-ico { font-size:12px; width:15px; text-align:center; }

.drv-empty { padding:60px 20px; text-align:center; color:var(--text2); pointer-events:none; }
.drv-empty-ico   { font-size:42px; opacity:.2; margin-bottom:10px; }
.drv-empty-title { font-family:'Syne',sans-serif; font-size:14px; color:var(--text3); margin-bottom:5px; }
.drv-empty-sub   { font-size:11px; }

.drv-backdrop {
  position:fixed; inset:0; background:rgba(0,0,0,.7);
  z-index:2000; display:flex; align-items:center;
  justify-content:center; padding:20px;
}
.drv-modal {
  background:var(--surface); border:1px solid var(--border);
  border-radius:14px; width:100%; max-width:480px;
  max-height:90vh; overflow-y:auto; padding:26px;
  position:relative; animation:drv-pop .15s ease;
}
.drv-modal-title { font-family:'Syne',sans-serif; font-size:15px; font-weight:700; margin-bottom:18px; }
.drv-modal-close {
  position:absolute; top:18px; right:18px;
  background:none; border:none; color:var(--text2); font-size:16px;
  cursor:pointer; padding:4px 8px; border-radius:4px; transition:color .15s;
}
.drv-modal-close:hover { color:var(--text); }
.drv-modal-foot { display:flex; gap:8px; justify-content:flex-end; margin-top:18px; }

.drv-dz {
  border:2px dashed var(--border); border-radius:10px;
  padding:30px 20px; text-align:center; cursor:pointer;
  transition:all .18s; margin-bottom:14px; position:relative;
}
.drv-dz:hover,.drv-dz.over { border-color:var(--accent); background:rgba(0,212,255,.03); }
.drv-dz input[type=file] { position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%; }
.drv-dz-ico   { font-size:26px; margin-bottom:7px; opacity:.4; }
.drv-dz-title { font-size:12px; color:var(--text); margin-bottom:2px; }
.drv-dz-sub   { font-size:10px; color:var(--text2); }

.drv-up-list { display:flex; flex-direction:column; gap:5px; margin-bottom:12px; max-height:180px; overflow-y:auto; }
.drv-up-item { display:flex; align-items:center; gap:8px; padding:6px 10px; background:var(--surface2); border:1px solid var(--border); border-radius:6px; font-size:11px; }
.drv-up-name { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--text); }
.drv-up-size { color:var(--text2); white-space:nowrap; }
.drv-up-rm   { background:none; border:none; color:var(--text2); cursor:pointer; font-size:13px; padding:2px 5px; border-radius:3px; }
.drv-up-rm:hover { color:var(--danger); }
.drv-prog-wrap { background:var(--surface2); border-radius:4px; height:5px; margin-top:4px; overflow:hidden; }
.drv-prog-bar  { height:100%; background:linear-gradient(90deg,var(--accent),var(--accent2)); border-radius:4px; transition:width .3s; }

.drv-fg  { margin-bottom:12px; }
.drv-fl  { font-size:10px; letter-spacing:1px; text-transform:uppercase; color:var(--text2); margin-bottom:5px; display:block; }
.drv-fi,.drv-fs,.drv-fta {
  width:100%; padding:8px 11px;
  background:var(--surface2); border:1px solid var(--border);
  border-radius:6px; color:var(--text);
  font-family:'DM Mono',monospace; font-size:12px;
  outline:none; transition:border-color .15s;
}
.drv-fi:focus,.drv-fs:focus,.drv-fta:focus { border-color:var(--accent); }
.drv-fta { resize:vertical; min-height:56px; }

.drv-det-preview { width:100%; max-height:200px; background:var(--surface2); border-radius:8px; overflow:hidden; display:flex; align-items:center; justify-content:center; margin-bottom:12px; font-size:50px; }
.drv-det-preview img  { width:100%; max-height:200px; object-fit:contain; }
.drv-det-preview video{ width:100%; max-height:200px; }
.drv-det-url { background:var(--surface2); border:1px solid var(--border); border-radius:6px; padding:8px 12px; font-size:11px; color:var(--accent); word-break:break-all; cursor:pointer; margin-bottom:12px; transition:border-color .15s; }
.drv-det-url:hover { border-color:var(--accent); }
.drv-det-rows { display:flex; flex-direction:column; gap:5px; margin-bottom:14px; }
.drv-det-row  { display:flex; gap:10px; font-size:11px; }
.drv-det-key  { color:var(--text2); min-width:76px; flex-shrink:0; }
.drv-det-val  { color:var(--text); word-break:break-all; }

.drv-notify {
  position:fixed; bottom:24px; right:24px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:8px; padding:10px 15px;
  font-size:12px; z-index:9999;
  animation:drv-in .2s ease; max-width:280px;
  display:flex; align-items:center; gap:8px;
  box-shadow:0 8px 24px rgba(0,0,0,.3);
}
.drv-notify.ok  { border-left:3px solid var(--accent3); }
.drv-notify.err { border-left:3px solid var(--danger); }

@media(max-width:900px){
  .drv-layout { grid-template-columns:1fr; }
  .drv-sidebar { display:none; }
  .drv-kpis { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:600px){
  .drv-grid { grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:8px; }
  .drv-content { padding:12px; }
  .drv-toolbar { padding:8px 12px; }
  .drv-list-head,.drv-list-row { grid-template-columns:20px 28px 1fr 70px 32px; }
  .drv-list-tipo,.drv-list-tam { display:none; }
}

/* ── ÍCONES SVG NOS CARDS ────────────────────────────── */
.drv-file-preview svg,
.drv-list-ico svg,
.drv-up-item svg {
  width: 40px;
  height: 40px;
}
.drv-list-ico svg {
  width: 22px;
  height: 22px;
}
.drv-up-item svg {
  width: 20px;
  height: 20px;
}
