/* Workstation — utiliza tokens del sistema */
.ws-stage{
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  background: var(--color-onyx);
}

.ws-frame{
  width: min(1300px, 98vw);
  border: 1px solid rgba(230,228,223,0.10);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
  box-shadow: 0 18px 48px rgba(0,0,0,0.55);
  color: var(--text-main);
  overflow: hidden;
}

.ws-rail{
  height: 54px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 18px;
  border-bottom: 1px solid rgba(230,228,223,0.10);
  background: rgba(0,0,0,0.18);
}
.ws-rail-left{ display:flex; align-items:center; gap:12px; min-width:240px; }
.ws-sigil{
  width:12px; height:12px; border-radius:50%;
  background: var(--color-green);
  box-shadow: 0 0 0 3px rgba(47,93,80,0.18);
}
.ws-rail-title{
  font-family: var(--font-display);
  font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; opacity:.9; white-space:nowrap;
}
.ws-rail-center{
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.06em; opacity:.78; text-align:center; flex:1;
}
.ws-rail-right{
  display:flex; align-items:center; gap:12px; min-width:240px; justify-content:flex-end;
  font-family: var(--font-display);
  font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; opacity:.75;
}
.ws-pill{ border:1px solid rgba(230,228,223,0.16); padding:6px 10px; border-radius:999px; }

.ws-shell{
  position: relative;
  min-height: 640px;
}

/* Viewport & transitions */
.ws-viewport{ position:relative; height: calc(100% - 0px); overflow:hidden; }
.ws-view{ position:absolute; inset:0; padding:18px; opacity:0; transform:translateY(10px); pointer-events:none; transition: opacity 240ms var(--ease-out), transform 240ms var(--ease-out); }
.ws-view.is-active{ opacity:1; transform:translateY(0); pointer-events:auto; }
.ws-view.is-leaving{ opacity:0; transform:translateY(-6px); }

/* Ensure desktop view is a positioning context for shortcuts */
.ws-view--desktop{ position:relative; }

/* App window show/hide */
.app-window{ transition: opacity var(--duration-2) var(--ease-out), transform var(--duration-2) var(--ease-out); }
.app-window.is-hidden{ opacity:0; pointer-events:none; transform:scale(0.98); }
.app-window.is-maximized{ position:absolute; inset: 64px 18px 74px 18px; z-index: 5; }
.app-window .retro-window{ width:100%; }
.app-window.is-maximized .retro-window{ height:100%; }
.app-window.is-maximized .retro-content{ overflow:auto; }

/* Desktop grid: dos columnas para ventanas */
.ws-desktop{ display:grid; grid-template-columns: 1fr 1fr; gap:14px; align-content:start; position:relative; }
@media (max-width:980px){ .ws-desktop{ grid-template-columns: 1fr; } }

.ws-folder{
  text-align:left;
  border:1px solid rgba(230,228,223,0.10);
  border-radius:16px;
  background: rgba(0,0,0,0.12);
  padding:14px;
  display:flex; align-items:center; gap:14px;
  cursor:pointer;
  transition: transform 180ms var(--ease-out), border-color 180ms var(--ease-out), background 180ms var(--ease-out);
  color: inherit;
}
.ws-folder:hover{ transform: translateY(-1px); border-color: rgba(201,162,77,0.40); background: rgba(0,0,0,0.16); }
.ws-folder-icon{ width:26px; height:20px; position:relative; border:1px solid rgba(230,228,223,0.16); border-radius:6px; background: rgba(47,93,80,0.12); overflow:hidden; }
.ws-folder-icon .tab{ position:absolute; left:2px; top:0; width:40%; height:6px; background: rgba(201,162,77,0.35); border-bottom:1px solid rgba(230,228,223,0.08); }
.ws-folder-text{ flex:1; display:flex; flex-direction:column; gap:2px; min-width:0; }
.ws-folder-name{ font-family: var(--font-display); font-size:12px; letter-spacing:0.14em; text-transform:uppercase; margin:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; opacity:.92; }
.ws-folder-desc{ font-family: var(--font-mono); font-size:12px; margin:0; color: rgba(230,228,223,0.68); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ws-badge{ font-family: var(--font-mono); font-size:11px; padding:4px 8px; border-radius:999px; border:1px solid rgba(230,228,223,0.10); opacity:.8; }

/* Folder panel */
.ws-panel{ height:100%; border:1px solid rgba(230,228,223,0.10); border-radius:18px; background: rgba(0,0,0,0.12); overflow:hidden; }
.ws-panel-bar{ display:flex; align-items:center; justify-content:space-between; padding:12px 14px; border-bottom:1px solid rgba(230,228,223,0.10); background: rgba(0,0,0,0.18); }
.ws-panel-title{ display:flex; align-items:center; gap:10px; font-family: var(--font-display); letter-spacing:.14em; text-transform:uppercase; font-size:12px; }
.ws-panel-dot{ width:10px; height:10px; border-radius:50%; background: rgba(201,162,77,0.60); box-shadow: 0 0 0 3px rgba(201,162,77,0.12); }
.ws-panel-body{ padding:14px; position:relative; height: calc(100% - 54px); }
.ws-folder-page{ opacity:0; transform:translateY(8px); pointer-events:none; transition: opacity 220ms var(--ease-out), transform 220ms var(--ease-out); position:absolute; inset: 0; }
.ws-folder-page.is-page-active{ opacity:1; transform:translateY(0); pointer-events:auto; position:relative; }

/* Explorer views (grid/list) inside retro window */
.explorer-view{ display:none; height:100%; }
.explorer-view.is-active{ display:block; }
.explorer-view--list{ padding:10px; font-family: var(--font-mono); color: rgba(230,228,223,0.86); }
.list-header{
  display:grid; grid-template-columns:1.6fr 0.7fr 1fr 0.8fr 0.6fr; gap:12px; padding:10px 12px;
  border:1px solid var(--line); border-radius:12px; background: rgba(0,0,0,0.10); letter-spacing:.06em; font-size:12px; margin-bottom:10px;
}
.list-rows{ border:1px solid var(--line-soft); border-radius:12px; overflow:hidden; background: rgba(0,0,0,0.06); }
.file-row{ display:grid; grid-template-columns:1.6fr 0.7fr 1fr 0.8fr 0.6fr; gap:12px; padding:10px 12px; border-top:1px solid rgba(255,255,255,0.05); cursor:pointer; transition: background 160ms var(--ease-out), border-color 160ms var(--ease-out); }
.file-row:first-child{ border-top:0; }
.file-row:hover{ background: rgba(0,0,0,0.14); }
.file-row.is-selected{ background: rgba(0,0,0,0.18); outline:1px solid rgba(201,162,77,0.35); }
.file-name{ display:flex; align-items:center; gap:10px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.file-dot{ width:10px; height:10px; border-radius:3px; border:1px solid var(--line); background: rgba(230,228,223,0.85); box-shadow:0 0 0 3px rgba(230,228,223,0.06); }

/* Notepad content */
.ws-notepad{
  margin: 0;
  padding: 16px 18px;
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.7;
  color: var(--text-main);
  white-space: pre-wrap;
  overflow: auto;
  min-height: 320px;
  max-height: 70vh; /* scroll interno para TXT largos */
  /* Firefox fallback */
  scrollbar-width: thin;
  scrollbar-color: rgba(201,162,77,0.35) rgba(0,0,0,0.08);
}

/* Notepad window content layout */
#notepad-window .retro-content{ grid-template-columns: 1fr; }

/* Custom scrollbar (Chromium/WebKit) */
.ws-notepad::-webkit-scrollbar{
  width: 16px;
  background: transparent;
}
.ws-notepad::-webkit-scrollbar-track{
  background: rgba(0,0,0,0.08);
  border-left: 1px solid var(--line);
}
.ws-notepad::-webkit-scrollbar-thumb{
  background: rgba(0,0,0,0.18);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.02);
}
/* Top/Bottom buttons */
.ws-notepad::-webkit-scrollbar-button:single-button{
  height: 18px;
  background: rgba(0,0,0,0.08);
  border-left: 1px solid var(--line);
}
.ws-notepad::-webkit-scrollbar-button:single-button:vertical:decrement{
  background:
    linear-gradient(180deg, transparent 40%, rgba(201,162,77,0.92) 40%, rgba(201,162,77,0.92) 60%, transparent 60%) center 6px/6px 6px no-repeat,
    rgba(0,0,0,0.08);
}
.ws-notepad::-webkit-scrollbar-button:single-button:vertical:increment{
  background:
    linear-gradient(0deg, transparent 40%, rgba(201,162,77,0.92) 40%, rgba(201,162,77,0.92) 60%, transparent 60%) center 10px/6px 6px no-repeat,
    rgba(0,0,0,0.08);
}
/* Taskbar */
.ws-taskbar{ border-top:1px solid rgba(230,228,223,0.10); padding:12px 18px; display:flex; justify-content:space-between; gap:12px; font-family: var(--font-mono); font-size:12px; color: rgba(230,228,223,0.72); background: rgba(0,0,0,0.14); }
.ws-tb-left{ display:flex; align-items:center; gap:12px; }
.ws-tb-right{ display:flex; align-items:center; gap:12px; }
.ws-start{ display:flex; align-items:center; gap:8px; font-family: var(--font-display); letter-spacing:.14em; text-transform:uppercase; font-size:12px; }
.ws-start-dot{ width:8px; height:8px; border-radius:50%; background: var(--color-green); box-shadow: 0 0 0 2px rgba(47,93,80,0.18); }
.ws-search{ display:flex; align-items:center; gap:8px; }
.ws-search input{ background: transparent; border:1px solid rgba(230,228,223,0.10); color: var(--text-main); padding:6px 10px; border-radius:999px; font-family: var(--font-mono); font-size:12px; outline: none; }
.ws-search input::placeholder{ color: rgba(230,228,223,0.55); }

/* Left */
.ws-index{ border-right: 1px solid rgba(230,228,223,0.10); padding: 18px; }
@media (max-width:900px){ .ws-index{ border-right:none; border-bottom:1px solid rgba(230,228,223,0.10); } }
.ws-index-head{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; margin-bottom:14px; }
.ws-index-title{ font-family: var(--font-display); font-weight:500; font-size:18px; letter-spacing:-0.01em; margin:0; }
.ws-index-meta{ font-family: var(--font-mono); font-size:12px; opacity:.7; white-space:nowrap; }
.ws-tree{ display:flex; flex-direction:column; gap:10px; margin-top:16px; }
.ws-node{
  display:flex; align-items:center; gap:12px; padding:10px 12px;
  border:1px solid rgba(230,228,223,0.10); border-radius:12px; background: rgba(0,0,0,0.10);
  transition: transform 180ms var(--ease-out), border-color 180ms var(--ease-out), background 180ms var(--ease-out);
  color: inherit; cursor:pointer;
}
.ws-node:hover{ transform: translateY(-1px); border-color: rgba(201,162,77,0.45); background: rgba(0,0,0,0.16); }
.ws-icon{ width:26px; height:20px; position:relative; border:1px solid rgba(230,228,223,0.16); border-radius:6px; background: rgba(47,93,80,0.12); overflow:hidden; }
.ws-icon::before{ content:""; position:absolute; left:0; top:0; width:40%; height:6px; background: rgba(201,162,77,0.35); border-bottom:1px solid rgba(230,228,223,0.08); }
.ws-node-label{ flex:1; display:flex; flex-direction:column; gap:2px; min-width:0; }
.ws-node-name{ font-family: var(--font-display); font-size:12px; letter-spacing:0.14em; text-transform:uppercase; margin:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; opacity:.92; }
.ws-node-desc{ font-family: var(--font-mono); font-size:12px; margin:0; color: rgba(230,228,223,0.68); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ws-node-badge{ font-family: var(--font-mono); font-size:11px; padding:4px 8px; border-radius:999px; border:1px solid rgba(230,228,223,0.10); opacity:.8; }

/* Right */
.ws-desk{ padding:18px; display:grid; grid-template-columns: 1fr 1fr; gap:14px; align-content:start; }
@media (max-width:1100px){ .ws-desk{ grid-template-columns:1fr; } }
.ws-window{ border:1px solid rgba(230,228,223,0.10); border-radius:14px; background: rgba(0,0,0,0.14); overflow:hidden; box-shadow: 0 10px 28px rgba(0,0,0,0.35); }
.ws-winbar{ display:flex; align-items:center; justify-content:space-between; padding:10px 12px; border-bottom:1px solid rgba(230,228,223,0.10); background: rgba(0,0,0,0.22); }
.ws-win-title{ display:flex; align-items:center; gap:10px; min-width:0; }
.ws-win-dot{ width:10px; height:10px; border-radius:50%; background: rgba(201,162,77,0.55); box-shadow: 0 0 0 3px rgba(201,162,77,0.12); }
.ws-win-name{ font-family: var(--font-display); font-size:12px; letter-spacing:0.14em; text-transform:uppercase; margin:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ws-win-actions{ display:flex; gap:8px; opacity:.7; }
.ws-btn-ghost{ border:1px solid rgba(230,228,223,0.10); background:transparent; color:var(--text-main); padding:6px 10px; border-radius:999px; font-family: var(--font-display); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; cursor:pointer; transition: border-color 180ms var(--ease-out), transform 180ms var(--ease-out), opacity 180ms var(--ease-out); opacity:.85; }
.ws-btn-ghost:hover{ transform: translateY(-1px); border-color: rgba(47,93,80,0.55); opacity:1; }
.ws-content{ padding:14px 14px 16px; }
.ws-mono{ font-family: var(--font-mono); font-size:13px; line-height:1.7; color: rgba(230,228,223,0.68); margin:0; }
.ws-kv{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:12px; }
@media (max-width:520px){ .ws-kv{ grid-template-columns:1fr; } }
.ws-k{ border:1px solid rgba(230,228,223,0.10); border-radius:12px; padding:10px 12px; background: rgba(0,0,0,0.10); }
.ws-k-label{ font-family: var(--font-display); font-size:11px; letter-spacing:0.16em; text-transform:uppercase; opacity:.75; margin:0 0 6px; }
.ws-k-value{ font-family: var(--font-mono); font-size:13px; margin:0; color: var(--text-main); }
.ws-terminal{ border:1px solid rgba(230,228,223,0.10); border-radius:12px; background: rgba(0,0,0,0.22); padding:12px; margin-top:12px; font-family: var(--font-mono); font-size:12px; line-height:1.7; color: rgba(230,228,223,0.80); }
.ws-prompt{ color: rgba(201,162,77,0.75); }
.ws-ok{ color: rgba(47,93,80,0.95); }
.ws-dim{ color: rgba(230,228,223,0.55); }

.ws-foot{ border-top: 1px solid rgba(230,228,223,0.10); padding:12px 18px; display:flex; justify-content:space-between; gap:12px; font-family: var(--font-mono); font-size:12px; color: rgba(230,228,223,0.72); background: rgba(0,0,0,0.14); }


