Files
brahman/crates/apps/gioser-web/styles.css
T

458 lines
9.1 KiB
CSS
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/* ===================================================
GioSer · Estilos de Portada (Chakana 2×2)
=================================================== */
*,
*::before,
*::after {
margin: 0;
padding: 0;
box-sizing: border-box;
}
:root {
--bg: #0c0c0c;
--bg-alt: #111;
--fg: #c8c8c8;
--fg-dim: #666;
--fg-bright: #e0e0e0;
--accent: #a0a0a0;
--font: 'SF Mono', 'JetBrains Mono', 'Fira Code', 'Cascadia Code', monospace;
--font-ui: -apple-system, 'Inter', 'Segoe UI', sans-serif;
}
html, body {
height: 100%;
width: 100%;
overflow: hidden;
background: var(--bg);
color: var(--fg);
font-family: var(--font);
font-size: 14px;
line-height: 1.4;
-webkit-font-smoothing: antialiased;
}
/* ===================================================
PORTADA — grid 2×2
=================================================== */
.portada {
position: fixed;
inset: 0;
display: grid;
grid-template-columns: 1fr 1fr;
grid-template-rows: 1fr 1fr;
z-index: 10;
background: var(--bg);
}
/* ===================================================
RETÍCULA — pseudoelemento con líneas + círculo
=================================================== */
.portada::before {
content: '';
position: absolute;
top: 0; left: 0; right: 0; bottom: 0;
z-index: 30;
pointer-events: none;
transition: all 0.35s ease;
background:
/* línea vertical */
linear-gradient(90deg, transparent calc(50% - 1.5px), #666 calc(50% - 1.5px), #777 calc(50% + 1.5px), transparent calc(50% + 1.5px)),
/* línea horizontal */
linear-gradient(0deg, transparent calc(50% - 1.5px), #666 calc(50% - 1.5px), #777 calc(50% + 1.5px), transparent calc(50% + 1.5px)),
/* círculo centro */
radial-gradient(circle at 50% 50%, transparent calc(14px), #888 calc(14px), #888 calc(17px), transparent calc(17px));
}
.portada-hover::before {
background:
linear-gradient(90deg, transparent calc(50% - 1.5px), rgba(200,200,200,0.5) calc(50% - 1.5px), rgba(200,200,200,0.5) calc(50% + 1.5px), transparent calc(50% + 1.5px)),
linear-gradient(0deg, transparent calc(50% - 1.5px), rgba(200,200,200,0.5) calc(50% - 1.5px), rgba(200,200,200,0.5) calc(50% + 1.5px), transparent calc(50% + 1.5px)),
radial-gradient(circle at 50% 50%, transparent calc(14px), rgba(200,200,200,0.6) calc(14px), rgba(200,200,200,0.6) calc(17px), transparent calc(17px)),
radial-gradient(circle at 50% 50%, rgba(200,200,200,0.06) 40%, transparent 70%);
}
/* ===================================================
CUADRANTES
=================================================== */
.cuadrante {
position: relative;
background: transparent;
border: none;
cursor: pointer;
z-index: 5;
overflow: hidden;
transition: background 0.3s ease;
text-align: left;
font-family: var(--font);
color: var(--fg);
padding: 0;
}
.cuadrante:hover {
background: rgba(192, 192, 192, 0.15);
}
/* Borde iluminado en hover */
.cuadrante-border {
position: absolute;
inset: -1px;
border: 1px solid transparent;
transition: border-color 0.3s ease;
pointer-events: none;
}
.cuadrante:hover .cuadrante-border {
border-color: #666;
}
/* Contenido */
.cuadrante-content {
position: absolute;
inset: 0;
display: flex;
flex-direction: column;
justify-content: center;
padding: 40px 32px;
opacity: 0.7;
transition: opacity 0.3s ease;
}
.cuadrante:hover .cuadrante-content {
opacity: 1;
}
/* Alineación: izquierda mira a la derecha, derecha mira a la izquierda */
.cuadrante-01 .cuadrante-content,
.cuadrante-02 .cuadrante-content {
align-items: flex-end;
text-align: right;
padding-right: 40px;
padding-left: 20px;
}
.cuadrante-00 .cuadrante-content,
.cuadrante-03 .cuadrante-content {
align-items: flex-start;
text-align: left;
padding-left: 40px;
padding-right: 20px;
}
.cuadrante-hex {
font-size: 11px;
font-weight: 600;
color: var(--fg-dim);
letter-spacing: 0.15em;
margin-bottom: 6px;
font-family: var(--font);
}
.cuadrante-title {
font-size: 17px;
font-weight: 600;
color: var(--fg-bright);
letter-spacing: 0.06em;
margin-bottom: 12px;
font-family: var(--font-ui);
}
.cuadrante-context {
font-size: 13px;
color: var(--fg-dim);
line-height: 1.6;
margin-bottom: 16px;
max-width: 70%;
font-family: var(--font-ui);
}
.cuadrante-01 .cuadrante-context,
.cuadrante-02 .cuadrante-context {
text-align: right;
}
.cuadrante-00 .cuadrante-context,
.cuadrante-03 .cuadrante-context {
text-align: left;
}
.cuadrante-meta {
display: flex;
align-items: center;
gap: 14px;
margin-bottom: 12px;
}
.cuadrante-01 .cuadrante-meta,
.cuadrante-02 .cuadrante-meta {
flex-direction: row-reverse;
}
.cuadrante-00 .cuadrante-meta,
.cuadrante-03 .cuadrante-meta {
flex-direction: row;
}
.meta-cta {
font-size: 11px;
font-weight: 600;
color: var(--accent);
font-family: var(--font);
letter-spacing: 0.05em;
border: 1px solid #333;
padding: 2px 8px;
border-radius: 2px;
transition: border-color 0.3s ease, color 0.3s ease;
}
.cuadrante:hover .meta-cta {
border-color: var(--fg-bright);
color: var(--fg-bright);
}
.meta-stat {
font-size: 10px;
color: var(--fg-dim);
letter-spacing: 0.08em;
font-family: var(--font);
opacity: 0;
transition: opacity 0.4s ease;
}
.cuadrante:hover .meta-stat {
opacity: 0.7;
}
.cuadrante-crates {
list-style: none;
font-size: 11px;
color: var(--fg-dim);
font-family: var(--font);
line-height: 1.6;
margin: 0;
opacity: 0;
transition: opacity 0.4s ease;
}
.cuadrante:hover .cuadrante-crates {
opacity: 0.6;
}
.cuadrante-crates li::before {
content: '◆ ';
color: var(--fg-dim);
font-size: 7px;
opacity: 0.4;
}
/* ===================================================
TRANSICIÓN CIERRE PORTADA
=================================================== */
.portada-closing {
animation: portadaFade 0.6s ease forwards;
}
@keyframes portadaFade {
0% {
opacity: 1;
pointer-events: auto;
}
100% {
opacity: 0;
pointer-events: none;
}
}
/* ===================================================
DECK (páginas md, mismo estilo de antes)
=================================================== */
.deck {
position: fixed;
inset: 0;
z-index: 20;
background: var(--bg);
opacity: 0;
transition: opacity 0.5s ease;
}
.deck:not([aria-hidden]) {
opacity: 1;
}
.deck-strip {
height: 100%;
width: 100%;
display: flex;
overflow-x: auto;
overflow-y: hidden;
scroll-snap-type: x mandatory;
-webkit-overflow-scrolling: touch;
}
/* ===================================================
CONTROLES DE PÁGINA
=================================================== */
.page-controls {
position: fixed;
top: 12px;
right: 12px;
display: flex;
gap: 8px;
z-index: 100;
transition: opacity 0.3s ease;
}
.page-control-btn {
width: 32px;
height: 32px;
background: rgba(255,255,255,0.04);
border: 1px solid #333;
border-radius: 4px;
color: var(--fg);
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
transition: background 0.2s ease, border-color 0.2s ease;
}
.page-control-btn:hover {
background: rgba(255,255,255,0.08);
border-color: #666;
}
.page-close {
font-size: 18px;
font-family: var(--font-ui);
font-weight: 300;
}
/* ===================================================
TASKBAR
=================================================== */
.taskbar {
position: fixed;
bottom: 0;
left: 0;
right: 0;
height: 40px;
background: rgba(12, 12, 12, 0.92);
border-top: 1px solid #333;
display: flex;
align-items: center;
gap: 6px;
padding: 0 10px;
z-index: 200;
backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
font-family: var(--font);
font-size: 12px;
}
.taskbar-home,
.taskbar-brand {
display: flex;
align-items: center;
gap: 4px;
color: var(--fg);
cursor: pointer;
text-decoration: none;
background: transparent;
border: none;
font-family: var(--font);
font-size: 12px;
padding: 4px 8px;
border-radius: 3px;
transition: background 0.2s ease;
}
.taskbar-home:hover,
.taskbar-brand:hover {
background: rgba(255,255,255,0.06);
}
.taskbar-home-glyph {
width: 16px;
height: 16px;
}
.brand-dot {
color: var(--fg-dim);
margin: 0 1px;
}
.taskbar-divider {
width: 1px;
height: 20px;
background: #333;
margin: 0 4px;
}
.taskbar-list {
display: flex;
gap: 2px;
list-style: none;
margin: 0;
padding: 0;
max-width: 60vw;
overflow-x: auto;
}
.taskbar-list::-webkit-scrollbar {
height: 0;
}
.taskbar-spacer {
flex: 1;
}
.taskbar-credit {
color: var(--fg-dim);
text-decoration: none;
display: flex;
align-items: center;
gap: 4px;
padding: 4px 8px;
border-radius: 3px;
transition: color 0.2s ease;
font-size: 11px;
}
.taskbar-credit:hover {
color: var(--fg);
}
.copyleft-mark {
font-size: 11px;
}
/* ===================================================
SCROLLBAR
=================================================== */
::-webkit-scrollbar {
width: 6px;
height: 6px;
}
::-webkit-scrollbar-track {
background: transparent;
}
::-webkit-scrollbar-thumb {
background: #333;
border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
background: #666;
}