/* MSC Tracker — CSS comun a todas las paginas */ :root { --bg: #0d0e10; --bg-card: #16181c; --fg: #d6d6d6; --fg-dim: #8a8d92; --accent: #7fdbca; --accent2: #ff9d4d; --fail: #ff5d5d; --win: #5dd39e; --code-bg: #0a0b0d; --border: #23262b; } * { box-sizing: border-box; } html, body { margin: 0; padding: 0; background: var(--bg); color: var(--fg); font-family: ui-monospace, SFMono-Regular, "JetBrains Mono", Menlo, Consolas, monospace; font-size: 14px; line-height: 1.55; } a { color: var(--accent); text-decoration: none; } a:hover { color: #fff; } code { background: var(--code-bg); padding: 1px 6px; border-radius: 3px; border: 1px solid var(--border); font-size: 0.92em; color: var(--accent); } pre { background: var(--code-bg); border: 1px solid var(--border); border-radius: 6px; padding: 14px 16px; overflow-x: auto; font-size: 0.88em; line-height: 1.45; color: #cfcfcf; margin: 10px 0; } button, .btn { background: var(--bg-card); color: var(--fg); border: 1px solid var(--border); padding: 6px 12px; border-radius: 4px; cursor: pointer; font: inherit; } button:hover { border-color: var(--accent); } button.primary, .btn-primary { background: var(--accent); color: #000; border-color: var(--accent); } button.primary:hover { background: #fff; } button.danger { color: var(--fail); border-color: var(--fail); } button.danger:hover { background: var(--fail); color: #000; } input, select { background: var(--code-bg); color: var(--fg); border: 1px solid var(--border); padding: 6px 10px; border-radius: 4px; font: inherit; } input:focus, select:focus { outline: none; border-color: var(--accent); } /* --- Top nav (sticky) --- */ .topnav { position: sticky; top: 0; z-index: 999; background: rgba(13, 14, 16, 0.92); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-bottom: 1px solid var(--border); font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; } .topnav-inner { max-width: 1200px; margin: 0 auto; padding: 0 20px; display: flex; align-items: center; gap: 18px; height: 52px; } .topnav-brand { font-size: 1.0em; font-weight: 700; color: var(--accent); letter-spacing: 0.01em; text-decoration: none; margin-right: 4px; transition: color 0.15s ease; } .topnav-brand:hover { color: #fff; } .topnav-links { display: flex; gap: 2px; flex: 1; align-items: center; } .topnav-links > .topnav-item, .topnav-links > a { display: inline-flex; align-items: center; height: 32px; color: var(--fg-dim); padding: 0 14px; border-radius: 5px; text-decoration: none; font-size: 0.93em; font-weight: 500; line-height: 1; transition: background 0.15s ease, color 0.15s ease; } .topnav-links > .topnav-item:hover, .topnav-links > a:hover { color: var(--fg); background: rgba(127,219,202,0.08); } .topnav-links > .topnav-item.active > a, .topnav-links > a.active { color: var(--accent); background: rgba(127,219,202,0.13); } .nav-user { display: flex; align-items: center; gap: 8px; padding-left: 14px; border-left: 1px solid var(--border); margin-left: 4px; } .nav-user-name { color: var(--fg); font-size: 0.9em; font-weight: 500; } .nav-user-role { display: inline-block; padding: 2px 7px; border-radius: 3px; font-size: 0.65em; font-weight: 700; background: var(--code-bg); color: var(--accent2); border: 1px solid var(--accent2); text-transform: uppercase; letter-spacing: 0.04em; } .nav-btn-primary, .nav-btn-secondary { font-size: 0.83em; padding: 5px 11px; font-weight: 500; border-radius: 4px; cursor: pointer; font-family: inherit; transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease; } .nav-btn-primary { background: var(--accent); color: #000; border: 1px solid var(--accent); } .nav-btn-primary:hover { background: #7fe0c3; } .nav-btn-secondary { background: transparent; color: var(--fg-dim); border: 1px solid var(--border); } .nav-btn-secondary:hover { color: var(--fg); border-color: var(--fg-dim); background: rgba(255,255,255,0.03); } /* --- Page container --- */ .page { max-width: 1100px; margin: 0 auto; padding: 32px 24px 60px; } h1 { font-size: 1.8em; margin: 0 0 8px; color: var(--fg); } h2 { font-size: 1.3em; margin: 36px 0 12px; padding-bottom: 4px; border-bottom: 1px solid var(--border); } h3 { font-size: 1.1em; margin: 20px 0 8px; color: var(--accent); } h4 { font-size: 1em; margin: 16px 0 6px; color: var(--fg); } .lead { color: var(--fg-dim); font-size: 1.05em; margin: 0 0 24px; } .card { background: var(--bg-card); border: 1px solid var(--border); border-radius: 6px; padding: 16px 20px; margin: 14px 0; } .card-header { display: flex; justify-content: space-between; align-items: center; margin: -16px -20px 12px; padding: 12px 20px; border-bottom: 1px solid var(--border); } .card-header h3 { margin: 0; color: var(--accent); } .grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; } @media (max-width: 720px) { .grid { grid-template-columns: 1fr; } } .doc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; margin: 20px 0; } .doc-card { background: var(--bg-card); border: 1px solid var(--border); border-left: 3px solid var(--accent); border-radius: 6px; padding: 16px 20px; text-decoration: none; display: block; color: var(--fg); } .doc-card:hover { border-left-color: #fff; border-color: var(--accent); } .doc-card h3 { margin: 0 0 8px; color: var(--accent); } .doc-card p { margin: 0; color: var(--fg-dim); font-size: 0.92em; } table.data, table.ref { width: 100%; border-collapse: collapse; font-size: 0.9em; margin: 14px 0; } table.data th, table.data td, table.ref th, table.ref td { padding: 8px 12px; border: 1px solid var(--border); text-align: left; vertical-align: top; } table.data th, table.ref th { background: var(--code-bg); color: var(--accent); } table.data code, table.ref code { font-size: 0.95em; } .badge { display: inline-block; padding: 1px 6px; border-radius: 3px; font-size: 0.75em; background: var(--code-bg); color: var(--fg-dim); border: 1px solid var(--border); } .badge.ok { color: var(--win); border-color: var(--win); } .badge.bad { color: var(--fail); border-color: var(--fail); } .badge.warn { color: var(--accent2); border-color: var(--accent2); } .toast { position: fixed; bottom: 24px; right: 24px; background: var(--bg-card); border: 1px solid var(--accent); border-radius: 6px; padding: 10px 16px; box-shadow: 0 4px 12px rgba(0,0,0,0.5); z-index: 1000; max-width: 400px; } .toast.error { border-color: var(--fail); } .toast.hidden { display: none; } .modal-bg { position: fixed; inset: 0; background: rgba(0,0,0,0.7); display: flex; align-items: center; justify-content: center; z-index: 999; } .modal-bg.hidden { display: none; } .modal { background: var(--bg); border: 1px solid var(--border); border-radius: 6px; padding: 20px 24px; max-width: 600px; width: 90%; } .modal h3 { margin: 0 0 12px; } .modal .close { float: right; cursor: pointer; color: var(--fg-dim); } .modal label { display: block; margin: 10px 0 4px; font-size: 0.9em; } .modal input { width: 100%; } .modal button { margin-top: 14px; width: 100%; } .modal #pw-err { color: var(--fail); margin-top: 8px; font-size: 0.9em; } .code-block { position: relative; } .code-block .copy-btn { position: absolute; top: 6px; right: 6px; background: var(--code-bg); color: var(--fg-dim); border: 1px solid var(--border); padding: 3px 8px; font-size: 0.75em; cursor: pointer; border-radius: 3px; z-index: 1; } .code-block .copy-btn:hover { color: var(--accent); border-color: var(--accent); } .code-block .copy-btn.copied { color: var(--win); border-color: var(--win); } ol.steps { padding-left: 22px; } ol.steps li { margin: 6px 0; } .note { background: rgba(127,219,202,0.08); border-left: 3px solid var(--accent); padding: 10px 14px; margin: 14px 0; border-radius: 0 4px 4px 0; } .warn { background: rgba(255,157,77,0.08); border-left: 3px solid var(--accent2); padding: 10px 14px; margin: 14px 0; border-radius: 0 4px 4px 0; } .danger { background: rgba(255,93,93,0.08); border-left: 3px solid var(--fail); padding: 10px 14px; margin: 14px 0; border-radius: 0 4px 4px 0; } .hidden { display: none; } /* --- Dropdowns --- */ .topnav-item { position: relative; display: inline-flex; } .topnav-item.has-dropdown > a::after { content: "▾"; font-size: 0.65em; opacity: 0.55; margin-left: 5px; display: inline-block; transition: transform 0.2s ease, opacity 0.15s ease; } .topnav-item.has-dropdown:hover > a::after { opacity: 0.9; transform: rotate(180deg); } .dropdown { position: absolute; top: calc(100% + 2px); left: 0; min-width: 240px; max-width: min(420px, calc(100vw - 24px)); background-color: #0d0e10; background-image: linear-gradient(180deg, #141519 0%, #0d0e10 100%); border: 1px solid #2a2d33; border-radius: 6px; padding: 5px 0; z-index: 9999; display: none; box-shadow: 0 12px 32px rgba(0,0,0,0.7), 0 2px 8px rgba(0,0,0,0.4); isolation: isolate; } /* Si el topnav-item está cerca del borde derecho, alineamos el dropdown al borde derecho */ .topnav-item.has-dropdown.align-right .dropdown { left: auto; right: 0; } /* En mobile/estrecho, los dropdowns se alinean al borde derecho del topnav */ @media (max-width: 600px) { .topnav-item.has-dropdown .dropdown { left: auto; right: 0; } } .dropdown.hidden-by-default { display: none; } .topnav-item.has-dropdown:hover .dropdown, .topnav-item.has-dropdown:focus-within .dropdown { display: block; animation: dropdown-in 0.12s ease-out; } @keyframes dropdown-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } } .dropdown a { display: block; padding: 9px 16px; color: var(--fg-dim); font-size: 0.9em; border-bottom: 1px solid rgba(255,255,255,0.04); text-decoration: none; transition: background 0.12s ease, color 0.12s ease; line-height: 1.3; } .dropdown a:last-child { border-bottom: 0; } .dropdown a:hover { background: rgba(127,219,202,0.10); color: var(--fg); } .dropdown a.active { color: var(--accent); background: rgba(127,219,202,0.12); } .dropdown-sep { height: 1px; background: var(--border); margin: 5px 0; border: 0; }