2026-01-03 22:36:41 +00:00
|
|
|
/* ═══════════════════════════════════════════════════════════════════════════
|
|
|
|
|
BUTTON COMPONENT STYLES - FUSION DESIGN SYSTEM
|
|
|
|
|
6 Variants: Primary (Neon), Secondary (Outline), Gaming, Terminal, Nature, Graffiti
|
|
|
|
|
═══════════════════════════════════════════════════════════════════════════ */
|
|
|
|
|
|
|
|
|
|
.btn-veza {
|
2026-01-13 18:47:57 +00:00
|
|
|
position: relative;
|
|
|
|
|
display: inline-flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
gap: var(--space-2);
|
|
|
|
|
padding: var(--space-3) var(--space-6);
|
|
|
|
|
font-family: var(--font-heading);
|
|
|
|
|
font-size: var(--text-sm);
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
text-transform: uppercase;
|
|
|
|
|
letter-spacing: 0.1em;
|
|
|
|
|
border: none;
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
transition: all var(--duration-fast) var(--ease-out);
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
isolation: isolate;
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza:disabled {
|
2026-01-13 18:47:57 +00:00
|
|
|
opacity: 0.5;
|
|
|
|
|
cursor: not-allowed;
|
|
|
|
|
pointer-events: none;
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ─────────────────────────────────────────────────────────────────────────
|
|
|
|
|
VARIANT: PRIMARY (Neon Cyber)
|
|
|
|
|
───────────────────────────────────────────────────────────────────────── */
|
|
|
|
|
|
|
|
|
|
.btn-veza--primary {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: linear-gradient(
|
|
|
|
|
135deg,
|
|
|
|
|
var(--veza-cyan-dim) 0%,
|
|
|
|
|
var(--veza-cyan) 100%
|
|
|
|
|
);
|
|
|
|
|
color: var(--veza-void);
|
|
|
|
|
clip-path: var(--clip-manga);
|
|
|
|
|
box-shadow: var(--glow-cyan);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--primary::before {
|
2026-01-13 18:47:57 +00:00
|
|
|
content: '';
|
|
|
|
|
position: absolute;
|
|
|
|
|
inset: 0;
|
|
|
|
|
background: linear-gradient(
|
|
|
|
|
135deg,
|
|
|
|
|
transparent 0%,
|
|
|
|
|
rgba(255, 255, 255, 0.2) 50%,
|
|
|
|
|
transparent 100%
|
|
|
|
|
);
|
|
|
|
|
transform: translateX(-100%);
|
|
|
|
|
transition: transform var(--duration-normal) var(--ease-out);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--primary:hover {
|
2026-01-13 18:47:57 +00:00
|
|
|
transform: translateY(-2px);
|
|
|
|
|
box-shadow:
|
|
|
|
|
0 0 30px var(--veza-cyan),
|
|
|
|
|
0 0 60px rgba(0, 255, 247, 0.4);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--primary:hover::before {
|
2026-01-13 18:47:57 +00:00
|
|
|
transform: translateX(100%);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--primary:active {
|
2026-01-13 18:47:57 +00:00
|
|
|
transform: translateY(0);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ─────────────────────────────────────────────────────────────────────────
|
|
|
|
|
VARIANT: SECONDARY (Outline Neon)
|
|
|
|
|
───────────────────────────────────────────────────────────────────────── */
|
|
|
|
|
|
|
|
|
|
.btn-veza--secondary {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: transparent;
|
|
|
|
|
color: var(--veza-magenta);
|
|
|
|
|
border: 2px solid var(--veza-magenta);
|
|
|
|
|
clip-path: var(--clip-manga);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--secondary::before {
|
2026-01-13 18:47:57 +00:00
|
|
|
content: '';
|
|
|
|
|
position: absolute;
|
|
|
|
|
inset: 0;
|
|
|
|
|
background: var(--veza-magenta);
|
|
|
|
|
transform: scaleX(0);
|
|
|
|
|
transform-origin: left;
|
|
|
|
|
transition: transform var(--duration-normal) var(--ease-out);
|
|
|
|
|
z-index: -1;
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--secondary:hover {
|
2026-01-13 18:47:57 +00:00
|
|
|
color: var(--veza-void);
|
|
|
|
|
box-shadow: var(--glow-magenta);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--secondary:hover::before {
|
2026-01-13 18:47:57 +00:00
|
|
|
transform: scaleX(1);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ─────────────────────────────────────────────────────────────────────────
|
|
|
|
|
VARIANT: GAMING (XP/Achievement Style)
|
|
|
|
|
───────────────────────────────────────────────────────────────────────── */
|
|
|
|
|
|
|
|
|
|
.btn-veza--gaming {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: linear-gradient(180deg, #2a2a2a 0%, #1a1a1a 100%);
|
|
|
|
|
color: var(--veza-xp-gold);
|
|
|
|
|
border: 2px solid var(--veza-xp-gold);
|
|
|
|
|
border-radius: var(--radius-sm);
|
|
|
|
|
box-shadow:
|
|
|
|
|
inset 0 1px 0 rgba(255, 255, 255, 0.1),
|
|
|
|
|
inset 0 -2px 0 rgba(0, 0, 0, 0.3),
|
|
|
|
|
0 2px 8px rgba(0, 0, 0, 0.5);
|
|
|
|
|
text-shadow: 0 0 10px var(--veza-xp-gold);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--gaming:hover {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: linear-gradient(180deg, #3a3a3a 0%, #2a2a2a 100%);
|
|
|
|
|
box-shadow:
|
|
|
|
|
inset 0 1px 0 rgba(255, 255, 255, 0.1),
|
|
|
|
|
inset 0 -2px 0 rgba(0, 0, 0, 0.3),
|
|
|
|
|
0 0 20px rgba(255, 215, 0, 0.4);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--gaming:active {
|
2026-01-13 18:47:57 +00:00
|
|
|
transform: translateY(2px);
|
|
|
|
|
box-shadow:
|
|
|
|
|
inset 0 2px 4px rgba(0, 0, 0, 0.5),
|
|
|
|
|
0 1px 2px rgba(0, 0, 0, 0.3);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ─────────────────────────────────────────────────────────────────────────
|
|
|
|
|
VARIANT: TERMINAL (Matrix/Hacker Style)
|
|
|
|
|
───────────────────────────────────────────────────────────────────────── */
|
|
|
|
|
|
|
|
|
|
.btn-veza--terminal {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: var(--veza-matrix);
|
|
|
|
|
color: var(--veza-terminal-green);
|
|
|
|
|
border: 1px solid var(--veza-terminal-green);
|
|
|
|
|
font-family: var(--font-mono);
|
|
|
|
|
border-radius: var(--radius-sm);
|
|
|
|
|
text-shadow: var(--glow-terminal);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--terminal::before {
|
2026-01-13 18:47:57 +00:00
|
|
|
content: '> ';
|
|
|
|
|
opacity: 0.7;
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--terminal:hover {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: rgba(0, 255, 0, 0.1);
|
|
|
|
|
box-shadow: var(--glow-terminal);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ─────────────────────────────────────────────────────────────────────────
|
|
|
|
|
VARIANT: NATURE (Organic/Botanical)
|
|
|
|
|
───────────────────────────────────────────────────────────────────────── */
|
|
|
|
|
|
|
|
|
|
.btn-veza--nature {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: linear-gradient(
|
|
|
|
|
135deg,
|
|
|
|
|
var(--veza-moss) 0%,
|
|
|
|
|
var(--veza-leaf) 100%
|
|
|
|
|
);
|
|
|
|
|
color: var(--veza-white);
|
|
|
|
|
border-radius: var(--radius-2xl);
|
|
|
|
|
border: none;
|
|
|
|
|
box-shadow:
|
|
|
|
|
0 4px 15px rgba(45, 90, 61, 0.4),
|
|
|
|
|
inset 0 1px 0 rgba(255, 255, 255, 0.2);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--nature:hover {
|
2026-01-13 18:47:57 +00:00
|
|
|
transform: scale(1.02);
|
|
|
|
|
box-shadow:
|
|
|
|
|
0 6px 25px rgba(45, 90, 61, 0.5),
|
|
|
|
|
inset 0 1px 0 rgba(255, 255, 255, 0.2);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ─────────────────────────────────────────────────────────────────────────
|
|
|
|
|
VARIANT: GRAFFITI (Spray Paint Effect)
|
|
|
|
|
───────────────────────────────────────────────────────────────────────── */
|
|
|
|
|
|
|
|
|
|
.btn-veza--graffiti {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: var(--gradient-sunset);
|
|
|
|
|
color: var(--veza-white);
|
|
|
|
|
font-family: var(--font-display);
|
|
|
|
|
font-weight: 900;
|
|
|
|
|
letter-spacing: 0.2em;
|
|
|
|
|
clip-path: polygon(5% 0, 95% 5%, 100% 95%, 0% 100%);
|
|
|
|
|
text-shadow: 2px 2px 0 rgba(0, 0, 0, 0.3);
|
|
|
|
|
position: relative;
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--graffiti::after {
|
2026-01-13 18:47:57 +00:00
|
|
|
content: '';
|
|
|
|
|
position: absolute;
|
|
|
|
|
inset: -2px;
|
|
|
|
|
background: inherit;
|
|
|
|
|
clip-path: inherit;
|
|
|
|
|
filter: blur(8px);
|
|
|
|
|
opacity: 0.5;
|
|
|
|
|
z-index: -1;
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--graffiti:hover {
|
2026-01-13 18:47:57 +00:00
|
|
|
animation: graffiti-shake 0.3s ease-in-out;
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ─────────────────────────────────────────────────────────────────────────
|
|
|
|
|
VARIANT: GHOST (Minimal)
|
|
|
|
|
───────────────────────────────────────────────────────────────────────── */
|
|
|
|
|
|
|
|
|
|
.btn-veza--ghost {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: transparent;
|
|
|
|
|
color: var(--veza-text-muted);
|
|
|
|
|
border: 1px solid transparent;
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--ghost:hover {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: var(--veza-linen);
|
|
|
|
|
color: var(--veza-text);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.dark .btn-veza--ghost:hover {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: var(--veza-slate);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ─────────────────────────────────────────────────────────────────────────
|
|
|
|
|
VARIANT: OUTLINE (Clean)
|
|
|
|
|
───────────────────────────────────────────────────────────────────────── */
|
|
|
|
|
|
|
|
|
|
.btn-veza--outline {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: transparent;
|
|
|
|
|
border: 1px solid var(--veza-stone);
|
|
|
|
|
color: var(--veza-text);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--outline:hover {
|
2026-01-13 18:47:57 +00:00
|
|
|
border-color: var(--veza-sage);
|
|
|
|
|
background: var(--veza-mint-light);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ─────────────────────────────────────────────────────────────────────────
|
|
|
|
|
VARIANT: DESTRUCTIVE (Error/Delete)
|
|
|
|
|
───────────────────────────────────────────────────────────────────────── */
|
|
|
|
|
|
|
|
|
|
.btn-veza--destructive {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: linear-gradient(
|
|
|
|
|
135deg,
|
|
|
|
|
var(--veza-error) 0%,
|
|
|
|
|
var(--veza-error-soft) 100%
|
|
|
|
|
);
|
|
|
|
|
color: var(--veza-white);
|
|
|
|
|
clip-path: var(--clip-manga);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--destructive:hover {
|
2026-01-13 18:47:57 +00:00
|
|
|
transform: translateY(-2px);
|
|
|
|
|
box-shadow: 0 0 20px rgba(255, 23, 68, 0.4);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ─────────────────────────────────────────────────────────────────────────
|
|
|
|
|
SIZE VARIANTS
|
|
|
|
|
───────────────────────────────────────────────────────────────────────── */
|
|
|
|
|
|
|
|
|
|
.btn-veza--sm {
|
2026-01-13 18:47:57 +00:00
|
|
|
padding: var(--space-2) var(--space-4);
|
|
|
|
|
font-size: var(--text-xs);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--md {
|
2026-01-13 18:47:57 +00:00
|
|
|
padding: var(--space-3) var(--space-6);
|
|
|
|
|
font-size: var(--text-sm);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--lg {
|
2026-01-13 18:47:57 +00:00
|
|
|
padding: var(--space-4) var(--space-8);
|
|
|
|
|
font-size: var(--text-base);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--xl {
|
2026-01-13 18:47:57 +00:00
|
|
|
padding: var(--space-5) var(--space-10);
|
|
|
|
|
font-size: var(--text-lg);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* ─────────────────────────────────────────────────────────────────────────
|
|
|
|
|
ICON BUTTON
|
|
|
|
|
───────────────────────────────────────────────────────────────────────── */
|
|
|
|
|
|
|
|
|
|
.btn-veza--icon {
|
2026-01-13 18:47:57 +00:00
|
|
|
width: 44px;
|
|
|
|
|
height: 44px;
|
|
|
|
|
padding: 0;
|
|
|
|
|
border-radius: var(--radius-md);
|
|
|
|
|
background: var(--veza-slate);
|
|
|
|
|
color: var(--veza-grey-200);
|
|
|
|
|
border: 1px solid var(--veza-steel);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--icon:hover {
|
2026-01-13 18:47:57 +00:00
|
|
|
background: var(--veza-steel);
|
|
|
|
|
color: var(--veza-cyan);
|
|
|
|
|
border-color: var(--veza-cyan);
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--icon.btn-veza--sm {
|
2026-01-13 18:47:57 +00:00
|
|
|
width: 36px;
|
|
|
|
|
height: 36px;
|
2026-01-03 22:36:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.btn-veza--icon.btn-veza--lg {
|
2026-01-13 18:47:57 +00:00
|
|
|
width: 52px;
|
|
|
|
|
height: 52px;
|
|
|
|
|
}
|