xtablo-source/go-backend/static/styles.css
2026-05-09 20:18:24 +02:00

2442 lines
48 KiB
CSS

:root {
--background: hsl(0 0% 100%);
--foreground: hsl(0 0% 9%);
--muted-foreground: hsl(0 0% 43.5%);
--border: hsl(0 0% 90.9%);
--input: hsl(0 0% 90.9%);
--card: rgba(255, 255, 255, 0.8);
--accent: hsl(0 0% 96.1%);
--primary: #1e1b2e;
--primary-foreground: #ffffff;
--secondary: #804eec;
--ring: rgba(30, 27, 46, 0.35);
}
* {
box-sizing: border-box;
}
html,
body {
margin: 0;
min-height: 100%;
}
body {
background: var(--background);
color: var(--foreground);
font-family:
ui-sans-serif,
system-ui,
-apple-system,
BlinkMacSystemFont,
"Segoe UI",
sans-serif;
}
a {
color: inherit;
text-decoration: none;
}
button,
input {
font: inherit;
}
.light-only {
display: block;
}
.dark-only {
display: none;
}
.visually-hidden {
border: 0;
clip: rect(0 0 0 0);
height: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
width: 1px;
}
.app-shell,
.login-screen {
min-height: 100vh;
}
.app-shell {
background: var(--background);
}
.login-screen {
align-items: center;
background:
linear-gradient(135deg, rgba(128, 78, 236, 0.08), transparent 30%),
linear-gradient(160deg, rgba(30, 27, 46, 0.05), transparent 42%),
linear-gradient(to bottom right, rgba(30, 27, 46, 0.08), var(--background), rgba(128, 78, 236, 0.04));
display: flex;
justify-content: center;
overflow: hidden;
padding: 2rem 1rem;
position: relative;
}
.background-layer {
inset: 0;
overflow: hidden;
pointer-events: none;
position: absolute;
}
.background-logo {
position: absolute;
}
.logo-asset {
display: block;
height: auto;
object-fit: contain;
width: 100%;
}
.size-06 { width: 1.5rem; height: 1.5rem; }
.size-07 { width: 1.75rem; height: 1.75rem; }
.size-08 { width: 2rem; height: 2rem; }
.size-09 { width: 2.25rem; height: 2.25rem; }
.size-10 { width: 2.5rem; height: 2.5rem; }
.size-11 { width: 2.75rem; height: 2.75rem; }
.size-12 { width: 3rem; height: 3rem; }
.size-13 { width: 3.25rem; height: 3.25rem; }
.size-14 { width: 3.5rem; height: 3.5rem; }
.size-15 { width: 3.75rem; height: 3.75rem; }
.size-16 { width: 4rem; height: 4rem; }
.size-18 { width: 4.5rem; height: 4.5rem; }
.size-20 { width: 5rem; height: 5rem; }
.opacity-02 { opacity: 0.2; }
.opacity-03 { opacity: 0.3; }
.opacity-04 { opacity: 0.4; }
.opacity-05 { opacity: 0.5; }
.bg-01 { top: 25%; left: 0; }
.bg-02 { top: 33%; left: 0; }
.bg-03 { top: 50%; left: 0; }
.bg-04 { top: 66%; left: 0; }
.bg-05 { top: 75%; left: 0; }
.bg-06 { top: 0; left: 25%; }
.bg-07 { top: 0; left: 50%; }
.bg-08 { top: 0; left: 75%; }
.bg-09 { top: 0; left: 16.66%; }
.bg-10 { top: 0; left: 83.33%; }
.bg-11,
.bg-12,
.bg-13,
.bg-14,
.bg-15 {
left: 50%;
top: 50%;
}
.bg-16 { top: 25%; left: 0; }
.bg-17 { top: 50%; left: 0; }
.bg-18 { top: 75%; left: 0; }
.bg-19 { top: 0; left: 25%; }
.bg-20 { top: 0; left: 75%; }
.bg-21 { top: 16.66%; left: 33.33%; }
.bg-22 { top: 33.33%; left: 66.66%; }
.bg-23 { top: 66.66%; left: 25%; }
.bg-24 { top: 83.33%; left: 75%; }
.bg-25 { top: 12.5%; left: 0; }
.bg-26 { top: 37.5%; left: 0; }
.bg-27 { top: 62.5%; left: 0; }
.bg-28 { top: 87.5%; left: 0; }
.bg-29 { top: 0; left: 0; }
.bg-30 { top: 0; right: 0; }
.bg-31 { bottom: 0; left: 0; }
.bg-32 { bottom: 0; right: 0; }
.bg-33 { top: 20%; left: 20%; }
.bg-34 { top: 40%; left: 80%; }
.bg-35 { top: 80%; left: 40%; }
.card-wrap {
max-width: 32rem;
position: relative;
transition: transform 0.2s ease-out;
width: 100%;
z-index: 1;
}
.card-glow {
background: linear-gradient(to bottom right, rgba(30, 27, 46, 0.1), rgba(30, 27, 46, 0.05), rgba(128, 78, 236, 0.1));
border-radius: 1rem;
filter: blur(24px);
inset: 0;
position: absolute;
z-index: -1;
}
.auth-card-shell {
backdrop-filter: blur(12px);
background: var(--card);
border: 1px solid var(--border);
border-radius: 1rem;
box-shadow: 0 20px 45px rgba(0, 0, 0, 0.1);
padding: 1.25rem;
position: relative;
}
.auth-card-topbar {
align-items: center;
display: flex;
justify-content: space-between;
margin-bottom: 1.5rem;
}
.back-home-link {
align-items: center;
color: var(--muted-foreground);
display: inline-flex;
font-size: 0.875rem;
transition: color 0.2s ease;
}
.back-home-link:hover,
.theme-toggle-button:hover,
.signup-link:hover {
color: var(--foreground);
}
.back-home-icon {
height: 1rem;
margin-right: 0.5rem;
width: 1rem;
}
.theme-toggle-button {
align-items: center;
background: transparent;
border: 0;
border-radius: 0.5rem;
color: var(--muted-foreground);
cursor: pointer;
display: inline-flex;
height: 2.25rem;
justify-content: center;
padding: 0.5rem;
transition:
background-color 0.2s ease,
color 0.2s ease;
width: 2.25rem;
}
.theme-toggle-button:hover {
background: var(--accent);
}
.theme-toggle-icon {
height: 1.25rem;
width: 1.25rem;
}
.brand-header {
display: flex;
justify-content: center;
margin-bottom: 1.5rem;
}
.brand-logo {
display: block;
height: 4rem;
object-fit: contain;
width: 4rem;
}
.title-group {
margin-bottom: 1.5rem;
text-align: center;
}
.title-group h1 {
font-size: clamp(1.5rem, 4vw, 1.875rem);
font-weight: 700;
margin: 0;
}
.new-experience-link-wrap {
margin-bottom: 1.5rem;
text-align: center;
}
.new-experience-link {
color: #804eec;
display: inline-flex;
font-size: 0.875rem;
font-weight: 500;
transition: color 0.2s ease;
}
.new-experience-link:hover,
.forgot-password-link:hover {
color: #6f3fd4;
}
.auth-body {
align-items: center;
display: flex;
flex-direction: column;
gap: 1rem;
}
.login-form {
display: flex;
flex-direction: column;
gap: 1rem;
margin: 0 auto;
max-width: 28rem;
width: 100%;
}
.field-stack {
display: grid;
gap: 0.5rem;
}
.field-stack label {
font-size: 0.875rem;
font-weight: 500;
}
.field-stack input {
background: var(--background);
border: 1px solid var(--input);
border-radius: 0.375rem;
color: var(--foreground);
height: 2.5rem;
padding: 0.5rem 0.75rem;
width: 100%;
}
.field-stack input:focus {
box-shadow: 0 0 0 1px var(--ring);
outline: none;
}
.field-stack input::placeholder {
color: var(--muted-foreground);
}
.forgot-password-row {
display: flex;
justify-content: flex-end;
}
.forgot-password-link {
color: #7c3aed;
font-size: 0.875rem;
transition: color 0.2s ease;
}
.submit-button {
align-items: center;
background: var(--primary);
border: 0;
border-radius: 0.375rem;
color: var(--primary-foreground);
cursor: pointer;
display: inline-flex;
font-size: 0.875rem;
font-weight: 500;
height: 2.25rem;
justify-content: center;
padding: 0.5rem 1rem;
transition: opacity 0.2s ease;
width: 100%;
}
.submit-button:hover {
opacity: 0.9;
}
.divider-row {
align-items: center;
display: flex;
gap: 0.25rem;
margin: 0.5rem 0 0;
position: relative;
width: 100%;
}
.divider-line {
border-top: 1px solid var(--border);
flex: 1;
}
.divider-pill {
background: var(--background);
border-radius: 999px;
color: var(--muted-foreground);
font-size: 0.875rem;
font-weight: 500;
padding: 0.25rem 1rem;
position: relative;
z-index: 1;
}
.signup-copy {
color: var(--muted-foreground);
font-size: 0.875rem;
margin: 0;
text-align: center;
}
.signup-link {
border-radius: 0.375rem;
color: var(--foreground);
display: inline-block;
font-weight: 500;
margin-left: 0.2rem;
padding: 0.25rem 0.5rem;
transition:
color 0.2s ease,
background-color 0.2s ease;
}
.signup-link:hover {
background: var(--accent);
}
.status-slot {
min-height: 0.25rem;
}
.status-banner {
border: 1px solid;
border-radius: 0.5rem;
font-size: 0.875rem;
padding: 0.75rem 0.875rem;
}
.status-success {
background: hsl(143 85% 96%);
border-color: hsl(145 92% 87%);
color: hsl(140 100% 27%);
}
.status-error {
background: hsl(359 100% 97%);
border-color: hsl(359 100% 94%);
color: hsl(360 100% 45%);
}
.gsi-material-button {
-moz-user-select: none;
-ms-user-select: none;
-webkit-appearance: none;
-webkit-user-select: none;
background-color: #fff;
background-image: none;
border: 1px solid #747775;
border-radius: 20px;
box-sizing: border-box;
color: #1f1f1f;
cursor: pointer;
font-family: "Roboto", Arial, sans-serif;
font-size: 14px;
height: 40px;
letter-spacing: 0.25px;
max-width: 400px;
min-width: min-content;
outline: none;
overflow: hidden;
padding: 0 12px;
position: relative;
text-align: center;
transition:
background-color 0.218s,
border-color 0.218s,
box-shadow 0.218s;
vertical-align: middle;
white-space: nowrap;
width: 100%;
}
.gsi-material-button .gsi-material-button-icon {
height: 20px;
margin-right: 12px;
min-width: 20px;
width: 20px;
}
.gsi-material-button .gsi-material-button-content-wrapper {
align-items: center;
display: flex;
flex-direction: row;
flex-wrap: nowrap;
height: 100%;
justify-content: space-between;
position: relative;
width: 100%;
}
.gsi-material-button .gsi-material-button-contents {
flex-grow: 1;
font-family: "Roboto", Arial, sans-serif;
font-weight: 500;
overflow: hidden;
text-overflow: ellipsis;
vertical-align: top;
}
.gsi-material-button .gsi-material-button-state {
bottom: 0;
left: 0;
opacity: 0;
position: absolute;
right: 0;
top: 0;
transition: opacity 0.218s;
}
.gsi-material-button:not(:disabled):active .gsi-material-button-state,
.gsi-material-button:not(:disabled):focus .gsi-material-button-state {
background-color: #303030;
opacity: 0.12;
}
.gsi-material-button:not(:disabled):hover {
box-shadow:
0 1px 2px 0 rgba(60, 64, 67, 0.3),
0 1px 3px 1px rgba(60, 64, 67, 0.15);
}
.gsi-material-button:not(:disabled):hover .gsi-material-button-state {
background-color: #303030;
opacity: 0.08;
}
.home-shell {
background:
linear-gradient(135deg, rgba(128, 78, 236, 0.08), transparent 30%),
linear-gradient(160deg, rgba(30, 27, 46, 0.05), transparent 42%),
linear-gradient(to bottom right, rgba(30, 27, 46, 0.08), var(--background), rgba(128, 78, 236, 0.04));
min-height: 100vh;
}
.dashboard-shell {
background:
linear-gradient(135deg, rgba(128, 78, 236, 0.08), transparent 30%),
linear-gradient(160deg, rgba(30, 27, 46, 0.05), transparent 42%),
linear-gradient(to bottom right, rgba(30, 27, 46, 0.08), var(--background), rgba(128, 78, 236, 0.04));
color: var(--foreground);
display: grid;
grid-template-columns: minmax(16rem, 18rem) 1fr;
min-height: 100vh;
}
.dashboard-sidebar {
padding-left: env(safe-area-inset-left, 0px);
}
.sidebar-nav-shell {
background: rgba(255, 255, 255, 0.92);
border-right: 1px solid rgba(30, 27, 46, 0.08);
box-shadow: 20px 0 45px rgba(30, 27, 46, 0.06);
display: flex;
flex-direction: column;
height: 100vh;
overflow-x: hidden;
overflow-y: auto;
padding: env(safe-area-inset-top, 0px) 0.75rem env(safe-area-inset-bottom, 0px) 0;
position: sticky;
top: 0;
}
.sidebar-brand {
align-items: center;
display: flex;
justify-content: center;
padding: 0.75rem 0.5rem;
position: relative;
}
.sidebar-brand-link {
align-items: center;
display: flex;
flex-direction: column;
gap: 0.5rem;
width: 100%;
}
.sidebar-brand-logo {
border-radius: 0.75rem;
height: 4rem;
object-fit: cover;
width: 4rem;
}
.sidebar-brand-title {
color: #1f2937;
font-size: 1.125rem;
font-weight: 700;
margin: 0;
}
.sidebar-collapse-button {
align-items: center;
background: rgba(255, 255, 255, 0.95);
border: 0;
border-radius: 999px;
box-shadow: 0 10px 24px rgba(30, 27, 46, 0.14);
color: #6b7280;
cursor: pointer;
display: inline-flex;
height: 1.5rem;
justify-content: center;
padding: 0.25rem;
position: absolute;
right: 0.75rem;
top: 0.5rem;
width: 1.5rem;
}
.sidebar-collapse-button svg {
height: 1rem;
width: 1rem;
}
.sidebar-primary {
display: flex;
flex: 1;
flex-direction: column;
}
.sidebar-list {
display: grid;
gap: 0;
list-style: none;
margin: 0;
padding: 0.75rem 0 0;
}
.sidebar-divider {
margin: 0.5rem 0;
padding: 0 0.875rem;
}
.sidebar-divider hr,
.sidebar-projects hr {
border: 0;
border-top: 1px solid rgba(107, 114, 128, 0.22);
margin: 0;
}
.sidebar-nav-item {
border-radius: 0.9rem;
color: #6b7280;
font-weight: 500;
margin: 0 0.5rem;
padding: 0.15rem 0;
transition: background-color 0.2s ease, color 0.2s ease;
}
.sidebar-nav-item:hover {
background: rgba(30, 27, 46, 0.05);
color: #111827;
}
.sidebar-nav-item.is-active {
background: rgba(128, 78, 236, 0.14);
color: #804eec;
font-weight: 600;
}
.sidebar-nav-link {
display: block;
width: 100%;
}
.sidebar-nav-link-inner {
align-items: center;
display: flex;
gap: 0.75rem;
padding: 0.6rem 0.95rem;
}
.sidebar-nav-icon {
align-items: center;
display: inline-flex;
justify-content: center;
}
.sidebar-nav-icon svg {
height: 1.35rem;
width: 1.35rem;
}
.sidebar-nav-label {
font-size: 1rem;
}
.sidebar-projects {
margin-top: 0.4rem;
padding: 0 0.75rem 0.75rem;
}
.sidebar-section-label {
color: #6b7280;
font-size: 0.625rem;
font-weight: 700;
letter-spacing: 0.14em;
margin: 0.9rem 0 0.65rem;
padding: 0 0.5rem;
text-transform: uppercase;
}
.sidebar-project-list {
display: grid;
gap: 0.1rem;
list-style: none;
margin: 0;
padding: 0;
}
.sidebar-project-link {
align-items: center;
border-radius: 0.85rem;
color: #6b7280;
display: flex;
gap: 0.65rem;
padding: 0.48rem 0.5rem;
transition: background-color 0.2s ease, color 0.2s ease;
}
.sidebar-project-link:hover {
background: rgba(30, 27, 46, 0.05);
color: #111827;
}
.sidebar-project-icon {
align-items: center;
border: 1px solid rgba(107, 114, 128, 0.35);
border-radius: 999px;
display: inline-flex;
flex-shrink: 0;
height: 1.55rem;
justify-content: center;
width: 1.55rem;
}
.sidebar-project-icon svg {
height: 0.9rem;
width: 0.9rem;
}
.sidebar-project-label {
flex: 1;
font-size: 0.9rem;
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.sidebar-footer-links {
margin-top: auto;
padding-bottom: 0.25rem;
}
.sidebar-organization {
background: rgba(255, 255, 255, 0.92);
padding: 0 0.5rem 0.9rem;
}
.organization-button {
align-items: center;
background: transparent;
border: 0;
border-radius: 0.95rem;
cursor: pointer;
display: flex;
gap: 0.65rem;
padding: 0.55rem 0.65rem;
text-align: left;
transition: background-color 0.2s ease;
width: 100%;
}
.organization-button:hover {
background: rgba(30, 27, 46, 0.05);
}
.organization-avatar {
border-radius: 999px;
display: inline-flex;
flex-shrink: 0;
height: 1.75rem;
overflow: hidden;
width: 1.75rem;
}
.organization-avatar img {
aspect-ratio: 1;
height: 100%;
object-fit: cover;
width: 100%;
}
.organization-copy {
display: flex;
flex-direction: column;
min-width: 0;
}
.organization-name {
color: #374151;
font-size: 0.95rem;
font-weight: 600;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.organization-meta {
color: #6b7280;
font-size: 0.75rem;
}
.dashboard-main {
display: flex;
flex-direction: column;
gap: 1.5rem;
min-width: 0;
padding: 2rem;
}
.overview-page {
display: flex;
flex-direction: column;
gap: 1.5rem;
min-height: 100%;
}
.overview-header {
padding: 0 0 0.25rem;
}
.overview-date {
color: #475467;
font-size: 1rem;
font-weight: 500;
margin: 0 0 0.5rem;
}
.overview-header-row {
align-items: center;
display: flex;
flex-wrap: wrap;
gap: 1rem;
justify-content: space-between;
}
.overview-greeting {
color: #475467;
font-size: clamp(1.4rem, 2vw, 1.75rem);
font-weight: 500;
margin: 0;
}
.overview-greeting span {
color: #111827;
}
.overview-header-actions {
align-items: center;
display: flex;
flex-wrap: wrap;
gap: 0.75rem;
}
.overview-badge {
align-items: center;
background: linear-gradient(to right, #a855f7, #3b82f6);
border: 0;
border-radius: 999px;
color: #fff;
display: inline-flex;
font-size: 0.75rem;
font-weight: 600;
justify-content: center;
min-height: 1.85rem;
padding: 0.25rem 0.75rem;
}
.overview-logout-form {
margin: 0;
}
.overview-logout-button {
background: rgba(255, 255, 255, 0.92);
border: 1px solid rgba(234, 236, 240, 1);
border-radius: 0.85rem;
color: #475467;
cursor: pointer;
font-weight: 600;
min-height: 2.75rem;
padding: 0.65rem 1rem;
}
.overview-actions {
display: grid;
gap: 1rem;
grid-template-columns: repeat(4, minmax(0, 1fr));
}
.quick-action-card {
align-items: center;
background: #fff;
border: 1px solid #eaecf0;
border-radius: 1rem;
cursor: pointer;
display: flex;
gap: 0.9rem;
min-height: 5rem;
padding: 0.9rem;
text-align: left;
transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.quick-action-card:hover,
.project-card:hover {
box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
}
.quick-action-icon {
align-items: center;
background: #f4f3ff;
border-radius: 0.7rem;
color: #7f56d9;
display: inline-flex;
flex-shrink: 0;
height: 2.5rem;
justify-content: center;
width: 2.5rem;
}
.quick-action-icon svg {
height: 1.5rem;
width: 1.5rem;
}
.quick-action-copy {
flex: 1;
min-width: 0;
}
.quick-action-title {
color: #111827;
font-size: 1.05rem;
font-weight: 600;
line-height: 1.2;
}
.quick-action-copy p {
color: #6b7280;
font-size: 0.9rem;
margin: 0.25rem 0 0;
}
.overview-section {
padding: 0.25rem 0 0;
}
.overview-section-heading {
align-items: center;
display: flex;
justify-content: space-between;
margin-bottom: 1.5rem;
}
.overview-section-heading h3,
.tasks-section-header h3 {
color: #111827;
font-size: 1.6rem;
font-weight: 600;
margin: 0;
}
.project-grid {
display: grid;
gap: 1.25rem;
grid-template-columns: repeat(3, minmax(0, 1fr));
}
.project-card {
background: #fff;
border: 1px solid #eaecf0;
border-radius: 1rem;
cursor: pointer;
padding: 1rem;
transition: box-shadow 0.2s ease;
}
.project-card-top {
align-items: flex-start;
display: flex;
justify-content: space-between;
margin-bottom: 1rem;
}
.project-status,
.task-status {
border: 1px solid transparent;
border-radius: 999px;
display: inline-flex;
font-size: 0.75rem;
font-weight: 600;
padding: 0.25rem 0.7rem;
}
.tone-warning {
background: #fffbeb;
border-color: #fde68a;
color: #ca8a04;
}
.tone-info {
background: #eff6ff;
border-color: #bfdbfe;
color: #2563eb;
}
.tone-success {
background: #ecfdf3;
border-color: #bbf7d0;
color: #16a34a;
}
.ui-button {
align-items: center;
border: 0;
border-radius: 0.75rem;
cursor: pointer;
display: inline-flex;
font-weight: 600;
gap: 0.5rem;
justify-content: center;
line-height: 1;
min-height: 44px;
text-decoration: none;
transition:
background-color 0.2s ease,
color 0.2s ease,
box-shadow 0.2s ease,
opacity 0.2s ease;
}
.ui-button-icon,
.ui-button-icon svg {
height: 1rem;
width: 1rem;
}
.ui-button:focus-visible,
.ui-icon-button:focus-visible,
.borderless-icon-button:focus-visible {
box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.2);
outline: none;
}
.ui-button-sm {
font-size: 0.875rem;
min-height: 40px;
padding: 0.625rem 0.9rem;
}
.ui-button-md {
font-size: 0.95rem;
padding: 0.75rem 1.1rem;
}
.ui-button-lg {
font-size: 1rem;
padding: 0.9rem 1.25rem;
}
.ui-button-primary {
background: var(--secondary);
color: #fff;
}
.ui-button-primary:hover {
background: #6d28d9;
}
.ui-button-secondary {
background: #f3f4f6;
color: #111827;
}
.ui-button-secondary:hover {
background: #e5e7eb;
}
.ui-button-ghost {
background: transparent;
color: #4b5563;
}
.ui-button-ghost:hover {
background: #f9fafb;
color: #111827;
}
.ui-button-danger {
background: #dc2626;
color: #fff;
}
.ui-button-danger:hover {
background: #b91c1c;
}
.ui-badge {
border: 1px solid transparent;
border-radius: 999px;
display: inline-flex;
font-size: 0.75rem;
font-weight: 600;
line-height: 1.2;
padding: 0.3rem 0.75rem;
}
.ui-badge-info {
background: #eff6ff;
border-color: #bfdbfe;
color: #2563eb;
}
.ui-badge-warning {
background: #fff4e2;
border-color: #db9729;
color: #db9729;
}
.ui-badge-success {
background: #ecfdf3;
border-color: #bbf7d0;
color: #16a34a;
}
.ui-badge-danger {
background: #fef2f2;
border-color: #fecaca;
color: #dc2626;
}
.ui-input,
.ui-textarea {
appearance: none;
background: #fff;
border: 1px solid #eaecf0;
border-radius: 0.75rem;
color: #111827;
font: inherit;
line-height: 1.4;
width: 100%;
}
.ui-input {
min-height: 44px;
padding: 0.75rem 0.95rem;
}
.ui-textarea {
min-height: 7rem;
padding: 0.85rem 0.95rem;
resize: vertical;
}
.ui-input::placeholder,
.ui-textarea::placeholder {
color: #9ca3af;
}
.ui-input:focus,
.ui-textarea:focus {
border-color: #8b5cf6;
box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.16);
outline: none;
}
.ui-form-field {
display: grid;
gap: 0.5rem;
}
.ui-form-label {
color: #111827;
font-size: 0.95rem;
font-weight: 600;
}
.ui-form-hint {
color: #6b7280;
font-size: 0.875rem;
margin: 0;
}
.ui-form-error {
color: #dc2626;
font-size: 0.875rem;
margin: 0;
}
.ui-card {
background: #fff;
border: 1px solid #eaecf0;
border-radius: 1rem;
box-shadow: 0 10px 30px rgba(15, 23, 42, 0.06);
}
.ui-card-header,
.ui-card-body,
.ui-card-footer {
padding: 1.25rem 1.5rem;
}
.ui-card-header,
.ui-card-footer {
border-color: #eaecf0;
}
.ui-card-header {
border-bottom-style: solid;
border-bottom-width: 1px;
}
.ui-card-footer {
border-top-style: solid;
border-top-width: 1px;
}
.ui-table-shell {
overflow-x: auto;
width: 100%;
}
.ui-table {
border-collapse: collapse;
min-width: 100%;
width: 100%;
}
.ui-empty-state {
align-items: center;
border: 1px dashed #d0d5dd;
border-radius: 1rem;
color: #6b7280;
display: flex;
flex-direction: column;
gap: 0.75rem;
justify-content: center;
padding: 3rem 1.5rem;
text-align: center;
}
.ui-empty-state-title {
color: #111827;
font-size: 1.125rem;
font-weight: 700;
margin: 0;
}
.ui-empty-state-icon {
align-items: center;
background: #f3f4f6;
border-radius: 999px;
color: #9ca3af;
display: inline-flex;
height: 4rem;
justify-content: center;
width: 4rem;
}
.ui-empty-state-icon svg {
height: 2rem;
width: 2rem;
}
.ui-empty-state-description {
margin: 0;
max-width: 32rem;
}
.catalog-page {
margin: 0 auto;
max-width: 72rem;
padding: 3rem 1.5rem 4rem;
}
.catalog-nav {
align-items: center;
display: flex;
flex-wrap: wrap;
gap: 0.75rem 1rem;
margin-bottom: 1.5rem;
}
.catalog-home-link,
.catalog-nav-link {
border-radius: 999px;
color: #6b7280;
display: inline-flex;
font-size: 0.9rem;
font-weight: 600;
padding: 0.55rem 0.9rem;
transition:
background-color 0.2s ease,
color 0.2s ease;
}
.catalog-home-link:hover,
.catalog-nav-link:hover {
background: #f3f4f6;
color: #111827;
}
.catalog-nav-links {
display: flex;
flex-wrap: wrap;
gap: 0.5rem;
}
.catalog-nav-link.is-active {
background: #ede9fe;
color: #6d28d9;
}
.catalog-page-header {
margin-bottom: 2rem;
}
.catalog-page-header h1 {
color: #111827;
font-size: 2.25rem;
line-height: 1.1;
margin: 0 0 0.75rem;
}
.catalog-page-header p {
color: #6b7280;
margin: 0;
max-width: 42rem;
}
.catalog-eyebrow {
color: #7c3aed !important;
font-size: 0.8rem;
font-weight: 700;
letter-spacing: 0.08em;
margin-bottom: 0.75rem !important;
text-transform: uppercase;
}
.catalog-example-list,
.catalog-page-list {
display: grid;
gap: 1.25rem;
}
.catalog-example,
.catalog-page-link-card {
background: #fff;
border: 1px solid #eaecf0;
border-radius: 1rem;
box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
padding: 1.5rem;
}
.catalog-page-link-card {
display: block;
}
.catalog-example-copy h2,
.catalog-page-link-card h2 {
color: #111827;
font-size: 1.125rem;
margin: 0 0 0.5rem;
}
.catalog-example-copy p,
.catalog-page-link-card p {
color: #6b7280;
margin: 0;
}
.catalog-example-preview {
align-items: flex-start;
display: flex;
flex-wrap: wrap;
gap: 0.75rem;
margin-top: 1rem;
}
.catalog-inline {
display: inline-flex;
}
.catalog-example-snippet {
background: #111827;
border-radius: 0.875rem;
color: #f9fafb;
margin: 1rem 0 0;
overflow-x: auto;
padding: 1rem;
}
.catalog-example-snippet code {
font-family:
ui-monospace,
SFMono-Regular,
"SF Mono",
Menlo,
Monaco,
Consolas,
"Liberation Mono",
monospace;
font-size: 0.875rem;
}
.catalog-page-link {
color: #7c3aed !important;
font-family:
ui-monospace,
SFMono-Regular,
"SF Mono",
Menlo,
Monaco,
Consolas,
"Liberation Mono",
monospace;
font-size: 0.875rem;
margin-top: 1rem !important;
}
.ui-icon-button {
align-items: center;
appearance: none;
background: transparent;
border: 0;
border-radius: 0.5rem;
color: #6b7280;
cursor: pointer;
display: inline-flex;
justify-content: center;
min-height: 44px;
min-width: 44px;
padding: 0.5rem;
transition:
background-color 0.2s ease,
color 0.2s ease;
}
.ui-icon-button:hover {
background: #f9fafb;
color: #111827;
}
.ui-modal-backdrop {
align-items: center;
background: rgba(17, 24, 39, 0.52);
display: flex;
inset: 0;
justify-content: center;
padding: 1rem;
position: fixed;
z-index: 40;
}
.ui-modal-panel {
background: #fff;
border: 1px solid #eaecf0;
border-radius: 1rem;
box-shadow: 0 24px 48px rgba(15, 23, 42, 0.18);
max-width: 32rem;
width: min(100%, 32rem);
}
.ui-modal-header,
.ui-modal-body,
.ui-modal-actions {
padding-left: 1.5rem;
padding-right: 1.5rem;
}
.ui-modal-header {
border-bottom: 1px solid #eaecf0;
padding-bottom: 1rem;
padding-top: 1.25rem;
}
.ui-modal-header h2 {
color: #111827;
font-size: 1.125rem;
font-weight: 700;
margin: 0;
}
.ui-modal-body {
padding-bottom: 1.25rem;
padding-top: 1.25rem;
}
.ui-modal-actions {
border-top: 1px solid #eaecf0;
display: flex;
gap: 0.75rem;
justify-content: flex-end;
padding-bottom: 1rem;
padding-top: 1rem;
}
.borderless-icon-button {
background: transparent;
border: 0;
box-shadow: none;
appearance: none;
color: #9ca3af;
cursor: pointer;
outline: none;
}
.project-card-top .borderless-icon-button {
padding: 0;
}
.project-card-top .borderless-icon-button:hover {
color: #ef4444;
}
.borderless-icon-button svg,
.project-date-row svg,
.overview-more-button svg,
.tasks-add-button svg,
.task-check svg {
height: 1rem;
width: 1rem;
}
td.text-right .borderless-icon-button {
align-items: center;
border-radius: 0.25rem;
color: #9ca3af;
display: inline-flex;
justify-content: center;
min-height: 44px;
min-width: 44px;
padding: 0.5rem;
transition: color 0.2s;
}
td.text-right .borderless-icon-button:hover {
color: #ef4444;
}
.project-card-title-row {
align-items: center;
display: flex;
gap: 0.75rem;
margin-bottom: 1rem;
}
.project-avatar {
align-items: center;
border-radius: 0.85rem;
color: #fff;
display: inline-flex;
flex-shrink: 0;
font-size: 1.1rem;
font-weight: 700;
height: 3rem;
justify-content: center;
width: 3rem;
}
.project-accent-blue {
background: #3b82f6;
}
.project-accent-purple {
background: #a855f7;
}
.project-accent-red {
background: #ef4444;
}
.project-card-title-row h4 {
color: #111827;
flex: 1;
font-size: 1rem;
font-weight: 600;
margin: 0;
overflow: hidden;
text-overflow: ellipsis;
}
.project-date-row {
align-items: center;
color: #6b7280;
display: flex;
font-size: 0.875rem;
gap: 0.5rem;
margin-bottom: 1rem;
}
.project-progress-label {
align-items: center;
color: #6b7280;
display: flex;
font-size: 0.875rem;
justify-content: space-between;
margin-bottom: 0.5rem;
}
.project-progress-label strong {
color: #111827;
}
.project-progress-track {
background: #f3f4f6;
border-radius: 999px;
height: 0.5rem;
overflow: hidden;
}
.project-progress-bar {
border-radius: 999px;
height: 100%;
}
.overview-more-row {
display: flex;
justify-content: center;
margin-top: 1.5rem;
}
.overview-more-button {
align-items: center;
background: transparent;
border: 0;
color: #7c3aed;
cursor: pointer;
display: inline-flex;
font-size: 0.875rem;
font-weight: 600;
gap: 0.4rem;
}
.app-section-page {
min-height: 100vh;
padding: 2rem;
}
.app-section-surface {
background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, #ffffff 100%);
border: 1px solid #eaecf0;
border-radius: 1.5rem;
box-shadow: 0 24px 48px rgba(15, 23, 42, 0.08);
max-width: 52rem;
padding: 2rem;
}
.app-section-eyebrow {
color: #7c3aed;
font-size: 0.78rem;
font-weight: 700;
letter-spacing: 0.08em;
margin-bottom: 0.9rem;
text-transform: uppercase;
}
.app-section-surface h2 {
color: #111827;
font-size: clamp(1.8rem, 4vw, 2.6rem);
line-height: 1.05;
margin: 0;
}
.app-section-surface p {
color: #475467;
font-size: 1rem;
line-height: 1.8;
margin: 1rem 0 0;
max-width: 40rem;
}
.not-found-page {
align-items: center;
background:
radial-gradient(circle at top, rgba(124, 58, 237, 0.14), transparent 35%),
linear-gradient(180deg, #f8f7ff 0%, #f4f7fb 100%);
display: flex;
justify-content: center;
min-height: 100vh;
padding: 3rem 1.5rem;
}
.not-found-surface {
backdrop-filter: blur(18px);
background: rgba(255, 255, 255, 0.88);
border: 1px solid rgba(148, 163, 184, 0.22);
border-radius: 2rem;
box-shadow: 0 32px 70px rgba(15, 23, 42, 0.12);
padding: 3rem;
width: min(100%, 44rem);
}
.not-found-eyebrow {
align-items: center;
background: rgba(124, 58, 237, 0.1);
border-radius: 999px;
color: #7c3aed;
display: inline-flex;
font-size: 0.78rem;
font-weight: 700;
letter-spacing: 0.08em;
padding: 0.45rem 0.85rem;
text-transform: uppercase;
}
.not-found-code {
color: #111827;
font-size: clamp(4.75rem, 11vw, 7.5rem);
font-weight: 800;
letter-spacing: -0.08em;
line-height: 0.95;
margin-top: 1.4rem;
}
.not-found-surface h2 {
color: #111827;
font-size: clamp(1.9rem, 4vw, 2.8rem);
line-height: 1.05;
margin: 1rem 0 0;
}
.not-found-surface p {
color: #475467;
font-size: 1rem;
line-height: 1.75;
margin: 1rem 0 0;
max-width: 36rem;
}
.not-found-actions {
display: flex;
flex-wrap: wrap;
gap: 0.9rem;
margin-top: 2rem;
}
.not-found-primary,
.not-found-secondary {
align-items: center;
border: 1px solid transparent;
border-radius: 0.95rem;
display: inline-flex;
font-size: 0.95rem;
font-weight: 600;
justify-content: center;
min-height: 2.9rem;
padding: 0.85rem 1.25rem;
text-decoration: none;
transition:
transform 0.18s ease,
box-shadow 0.18s ease,
background-color 0.18s ease,
border-color 0.18s ease;
}
.not-found-primary {
background: linear-gradient(135deg, #7c3aed 0%, #2563eb 100%);
box-shadow: 0 18px 35px rgba(124, 58, 237, 0.25);
color: #fff;
}
.not-found-primary:hover,
.not-found-secondary:hover {
transform: translateY(-1px);
}
.not-found-secondary-form {
margin: 0;
}
.not-found-secondary {
background: rgba(255, 255, 255, 0.9);
border-color: rgba(148, 163, 184, 0.3);
color: #344054;
cursor: pointer;
}
.not-found-meta {
align-items: center;
color: #667085;
display: flex;
font-size: 0.95rem;
gap: 0.5rem;
margin-top: 1.5rem;
}
.not-found-meta strong {
color: #111827;
}
.tasks-section {
background: #fff;
border: 1px solid #eaecf0;
border-radius: 1rem;
overflow: hidden;
}
.tasks-section-header {
align-items: center;
border-bottom: 1px solid #e5e7eb;
display: flex;
justify-content: space-between;
padding: 1.2rem 1rem;
}
.tasks-add-button {
align-items: center;
background: #fff;
border: 1px solid #e5e7eb;
border-radius: 0.7rem;
color: #475467;
cursor: pointer;
display: inline-flex;
font-weight: 500;
gap: 0.5rem;
min-height: 2.75rem;
padding: 0.7rem 1rem;
}
.task-list {
display: flex;
flex-direction: column;
}
.task-row {
align-items: center;
border-bottom: 1px solid #e5e7eb;
cursor: pointer;
display: flex;
gap: 0.75rem;
padding: 0.9rem 1rem;
transition: background-color 0.2s ease;
}
.task-row:hover {
background: rgba(249, 250, 251, 0.9);
}
.task-check {
align-items: center;
background: #fff;
border: 2px solid #d1d5db;
border-radius: 999px;
color: #fff;
cursor: pointer;
display: inline-flex;
flex-shrink: 0;
height: 2rem;
justify-content: center;
width: 2rem;
}
.task-check.is-complete {
background: #7c3aed;
border-color: #7c3aed;
}
.task-body {
flex: 1;
min-width: 0;
}
.task-body p {
color: #111827;
font-size: 0.95rem;
font-weight: 500;
margin: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.task-row.is-complete .task-body p {
color: #9ca3af;
text-decoration: line-through;
}
.task-meta {
align-items: center;
color: #6b7280;
display: flex;
flex-wrap: wrap;
font-size: 0.75rem;
gap: 0.45rem;
margin-top: 0.3rem;
}
.task-project-badge {
align-items: center;
border-radius: 0.35rem;
color: #fff;
display: inline-flex;
font-size: 0.5rem;
font-weight: 700;
height: 1rem;
justify-content: center;
width: 1rem;
}
.task-date {
white-space: nowrap;
}
.home-card {
backdrop-filter: blur(12px);
background: var(--card);
border: 1px solid var(--border);
border-radius: 1rem;
box-shadow: 0 20px 45px rgba(0, 0, 0, 0.1);
max-width: 28rem;
padding: 2rem;
text-align: center;
width: 100%;
}
.home-card h1 {
margin: 0 0 0.75rem;
}
.home-card p {
color: var(--muted-foreground);
margin: 0;
}
.home-logo {
display: block;
height: 4rem;
margin: 0 auto 1rem;
object-fit: contain;
width: 4rem;
}
.logout-form {
margin-top: 1.5rem;
}
.logout-button {
max-width: 14rem;
width: 100%;
}
@media (max-width: 980px) {
.dashboard-shell {
grid-template-columns: 1fr;
}
.sidebar-nav-shell {
border-bottom: 1px solid rgba(30, 27, 46, 0.08);
border-right: 0;
box-shadow: 0 12px 30px rgba(30, 27, 46, 0.08);
height: auto;
position: static;
}
.overview-actions,
.project-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
}
@media (max-width: 720px) {
.dashboard-main {
padding: 1rem;
}
.overview-header-row,
.tasks-section-header {
align-items: flex-start;
flex-direction: column;
}
.overview-actions,
.project-grid {
grid-template-columns: 1fr;
}
.task-row {
align-items: flex-start;
flex-wrap: wrap;
}
.task-status {
margin-left: 2.75rem;
}
.not-found-surface {
border-radius: 1.5rem;
padding: 2rem;
}
.not-found-actions {
flex-direction: column;
}
.not-found-primary,
.not-found-secondary,
.not-found-secondary-form {
width: 100%;
}
.app-section-page {
padding: 1rem;
}
.app-section-surface {
padding: 1.5rem;
}
}
@keyframes move-right-slow {
from { transform: translateX(-6rem); }
to { transform: translateX(calc(100vw + 6rem)); }
}
@keyframes move-right-medium {
from { transform: translateX(-5rem); }
to { transform: translateX(calc(100vw + 5rem)); }
}
@keyframes move-right-fast {
from { transform: translateX(-7rem); }
to { transform: translateX(calc(100vw + 7rem)); }
}
@keyframes move-down-slow {
from { transform: translateY(-6rem); }
to { transform: translateY(calc(100vh + 6rem)); }
}
@keyframes move-down-medium {
from { transform: translateY(-5rem); }
to { transform: translateY(calc(100vh + 5rem)); }
}
@keyframes move-diagonal-1 {
from { transform: translate(-4rem, -4rem); }
to { transform: translate(52vw, 70vh); }
}
@keyframes move-diagonal-2 {
from { transform: translate(0, -4rem); }
to { transform: translate(-18vw, 76vh); }
}
@keyframes move-diagonal-3 {
from { transform: translate(0, -4rem); }
to { transform: translate(12vw, 72vh); }
}
@keyframes orbit-1 {
from { transform: translate(-50%, -50%) rotate(0deg) translateX(11rem); }
to { transform: translate(-50%, -50%) rotate(360deg) translateX(11rem); }
}
@keyframes orbit-2 {
from { transform: translate(-50%, -50%) rotate(0deg) translateX(7rem); }
to { transform: translate(-50%, -50%) rotate(-360deg) translateX(7rem); }
}
@keyframes orbit-3 {
from { transform: translate(-50%, -50%) rotate(0deg) translateX(5rem); }
to { transform: translate(-50%, -50%) rotate(360deg) translateX(5rem); }
}
@keyframes orbit-4 {
from { transform: translate(-50%, -50%) rotate(0deg) translateX(15rem); }
to { transform: translate(-50%, -50%) rotate(360deg) translateX(15rem); }
}
@keyframes orbit-5 {
from { transform: translate(-50%, -50%) rotate(0deg) translateX(8rem); }
to { transform: translate(-50%, -50%) rotate(-360deg) translateX(8rem); }
}
@keyframes zigzag-1 {
0% { transform: translateX(-6rem) translateY(0); }
25% { transform: translateX(25vw) translateY(-3rem); }
50% { transform: translateX(50vw) translateY(3rem); }
75% { transform: translateX(75vw) translateY(-2rem); }
100% { transform: translateX(calc(100vw + 6rem)) translateY(1rem); }
}
@keyframes zigzag-2 {
0% { transform: translateX(-5rem) translateY(0); }
25% { transform: translateX(25vw) translateY(2rem); }
50% { transform: translateX(50vw) translateY(-3rem); }
75% { transform: translateX(75vw) translateY(1.5rem); }
100% { transform: translateX(calc(100vw + 5rem)) translateY(0); }
}
@keyframes zigzag-3 {
0% { transform: translateX(-7rem) translateY(0); }
20% { transform: translateX(20vw) translateY(-4rem); }
40% { transform: translateX(40vw) translateY(4rem); }
60% { transform: translateX(60vw) translateY(-2rem); }
80% { transform: translateX(80vw) translateY(3rem); }
100% { transform: translateX(calc(100vw + 7rem)) translateY(0); }
}
@keyframes spiral-1 {
0% { transform: translate(0, 0) rotate(0deg) scale(0.6); }
100% { transform: translate(90vw, 90vh) rotate(360deg) scale(1.3); }
}
@keyframes spiral-2 {
0% { transform: translate(0, 0) rotate(0deg) scale(1.4); }
100% { transform: translate(-70vw, 90vh) rotate(-360deg) scale(0.7); }
}
@keyframes float-random-1 {
0%, 100% { transform: translate(0, 0); }
50% { transform: translate(1.4rem, -1rem); }
}
@keyframes float-random-2 {
0%, 100% { transform: translate(0, 0); }
50% { transform: translate(-1.2rem, 1.1rem); }
}
@keyframes float-random-3 {
0%, 100% { transform: translate(0, 0); }
50% { transform: translate(0.9rem, -1.4rem); }
}
@keyframes float-random-4 {
0%, 100% { transform: translate(0, 0); }
50% { transform: translate(-1rem, 0.8rem); }
}
@keyframes wave-1 {
from { transform: translateX(-4rem); }
to { transform: translateX(calc(100vw + 4rem)); }
}
@keyframes wave-2 {
from { transform: translateX(-5rem); }
to { transform: translateX(calc(100vw + 5rem)); }
}
@keyframes wave-3 {
from { transform: translateX(-4rem); }
to { transform: translateX(calc(100vw + 4rem)); }
}
@keyframes wave-4 {
from { transform: translateX(-6rem); }
to { transform: translateX(calc(100vw + 6rem)); }
}
@keyframes corner-shoot-1 {
from { transform: translate(0, 0); }
to { transform: translate(110vw, 110vh); }
}
@keyframes corner-shoot-2 {
from { transform: translate(0, 0); }
to { transform: translate(-110vw, 110vh); }
}
@keyframes corner-shoot-3 {
from { transform: translate(0, 0); }
to { transform: translate(110vw, -110vh); }
}
@keyframes corner-shoot-4 {
from { transform: translate(0, 0); }
to { transform: translate(-110vw, -110vh); }
}
@keyframes bounce-ball-1 {
0%, 100% { transform: translateY(0) translateX(0); }
50% { transform: translateY(-5rem) translateX(2rem); }
}
@keyframes bounce-ball-2 {
0%, 100% { transform: translateY(0) translateX(0); }
50% { transform: translateY(4rem) translateX(-2rem); }
}
@keyframes bounce-ball-3 {
0%, 100% { transform: translateY(0) translateX(0); }
50% { transform: translateY(-4rem) translateX(1.5rem); }
}
@keyframes spin-slow {
from { transform: rotate(0deg); }
to { transform: rotate(360deg); }
}
@keyframes spin-reverse {
from { transform: rotate(0deg); }
to { transform: rotate(-360deg); }
}
@keyframes bounce-gentle {
0%, 100% { transform: translateY(0); }
50% { transform: translateY(-0.6rem); }
}
@keyframes pulse-gentle {
0%, 100% { transform: scale(1); opacity: 1; }
50% { transform: scale(1.08); opacity: 0.85; }
}
@keyframes wiggle {
0%, 100% { transform: rotate(0deg); }
25% { transform: rotate(-4deg); }
75% { transform: rotate(4deg); }
}
@keyframes float-gentle {
0%, 100% { transform: translateY(0); }
50% { transform: translateY(-0.8rem); }
}
@keyframes scale-gentle {
0%, 100% { transform: scale(1); }
50% { transform: scale(1.12); }
}
@keyframes rotate-gentle {
0%, 100% { transform: rotate(0deg); }
50% { transform: rotate(12deg); }
}
@keyframes bounce-soft {
0%, 100% { transform: translateY(0); }
50% { transform: translateY(-0.9rem); }
}
@keyframes sway {
0%, 100% { transform: translateX(0); }
50% { transform: translateX(0.8rem); }
}
@keyframes spin-fast {
from { transform: rotate(0deg); }
to { transform: rotate(360deg); }
}
@keyframes pulse-fast {
0%, 100% { transform: scale(1); }
50% { transform: scale(1.2); }
}
@keyframes wobble {
0%, 100% { transform: translateX(0); }
15% { transform: translateX(-0.35rem) rotate(-5deg); }
30% { transform: translateX(0.25rem) rotate(4deg); }
45% { transform: translateX(-0.2rem) rotate(-2deg); }
60% { transform: translateX(0.12rem) rotate(1deg); }
}
@keyframes shake {
0%, 100% { transform: translateX(0); }
25% { transform: translateX(-0.12rem); }
75% { transform: translateX(0.12rem); }
}
@keyframes bounce-crazy {
0%, 100% { transform: translateY(0) scale(1); }
25% { transform: translateY(-0.5rem) scale(1.05); }
75% { transform: translateY(0.2rem) scale(0.98); }
}
@keyframes spin-wobble {
0% { transform: rotate(0deg) scale(1); }
50% { transform: rotate(180deg) scale(1.12); }
100% { transform: rotate(360deg) scale(1); }
}
@keyframes flip {
0%, 100% { transform: rotateY(0deg); }
50% { transform: rotateY(180deg); }
}
@keyframes twirl {
0%, 100% { transform: rotate(0deg) scale(1); }
50% { transform: rotate(180deg) scale(1.15); }
}
@keyframes dance {
0%, 100% { transform: translateY(0) rotate(0deg); }
25% { transform: translateY(-0.3rem) rotate(-6deg); }
75% { transform: translateY(0.3rem) rotate(6deg); }
}
@keyframes jiggle {
0%, 100% { transform: translateX(0); }
25% { transform: translateX(-0.18rem); }
50% { transform: translateX(0.18rem); }
75% { transform: translateX(-0.1rem); }
}
@keyframes vibrate {
0%, 100% { transform: translate(0); }
20% { transform: translate(-1px, 1px); }
40% { transform: translate(1px, -1px); }
60% { transform: translate(-1px, -1px); }
80% { transform: translate(1px, 1px); }
}
@keyframes swing {
0%, 100% { transform: rotate(0deg); }
50% { transform: rotate(10deg); }
}
@keyframes pendulum {
0%, 100% { transform: rotate(-8deg); }
50% { transform: rotate(8deg); }
}
@keyframes elastic {
0%, 100% { transform: scale(1); }
30% { transform: scale(1.15, 0.9); }
60% { transform: scale(0.95, 1.08); }
}
@keyframes rubber {
0%, 100% { transform: scale(1); }
35% { transform: scale(1.2, 0.9); }
65% { transform: scale(0.9, 1.15); }
}
@keyframes rocket {
0%, 100% { transform: translateY(0) rotate(-8deg); }
50% { transform: translateY(-0.8rem) rotate(-12deg); }
}
@keyframes comet {
0%, 100% { transform: translateX(0) rotate(12deg); }
50% { transform: translateX(0.8rem) rotate(18deg); }
}
@keyframes meteor {
0%, 100% { transform: translateY(0) rotate(8deg); }
50% { transform: translateY(-0.7rem) rotate(14deg); }
}
@keyframes blast {
0%, 100% { transform: scale(1); }
50% { transform: scale(1.2) rotate(10deg); }
}
@keyframes spin-bounce {
0%, 100% { transform: rotate(0deg) translateY(0); }
50% { transform: rotate(180deg) translateY(-0.5rem); }
}
@keyframes flip-bounce {
0%, 100% { transform: rotateY(0deg) translateY(0); }
50% { transform: rotateY(180deg) translateY(-0.5rem); }
}
@keyframes scale-bounce {
0%, 100% { transform: scale(1) translateY(0); }
50% { transform: scale(1.14) translateY(-0.55rem); }
}
.animate-move-right-slow { animation: move-right-slow 25s linear infinite; }
.animate-move-right-medium { animation: move-right-medium 20s linear infinite; }
.animate-move-right-fast { animation: move-right-fast 15s linear infinite; }
.animate-move-down-slow { animation: move-down-slow 30s linear infinite; }
.animate-move-down-medium { animation: move-down-medium 25s linear infinite; }
.animate-move-diagonal-1 { animation: move-diagonal-1 35s linear infinite; }
.animate-move-diagonal-2 { animation: move-diagonal-2 28s linear infinite; }
.animate-move-diagonal-3 { animation: move-diagonal-3 32s linear infinite; }
.animate-orbit-1 { animation: orbit-1 20s linear infinite; }
.animate-orbit-2 { animation: orbit-2 25s linear infinite reverse; }
.animate-orbit-3 { animation: orbit-3 15s linear infinite; }
.animate-orbit-4 { animation: orbit-4 22s linear infinite; }
.animate-orbit-5 { animation: orbit-5 18s linear infinite; }
.animate-zigzag-1 { animation: zigzag-1 18s linear infinite; }
.animate-zigzag-2 { animation: zigzag-2 22s linear infinite; }
.animate-zigzag-3 { animation: zigzag-3 16s linear infinite; }
.animate-spiral-1 { animation: spiral-1 30s linear infinite; }
.animate-spiral-2 { animation: spiral-2 25s linear infinite; }
.animate-float-random-1 { animation: float-random-1 8s ease-in-out infinite; }
.animate-float-random-2 { animation: float-random-2 10s ease-in-out infinite; }
.animate-float-random-3 { animation: float-random-3 12s ease-in-out infinite; }
.animate-float-random-4 { animation: float-random-4 9s ease-in-out infinite; }
.animate-wave-1 { animation: wave-1 20s linear infinite; }
.animate-wave-2 { animation: wave-2 24s linear infinite; }
.animate-wave-3 { animation: wave-3 18s linear infinite; }
.animate-wave-4 { animation: wave-4 26s linear infinite; }
.animate-corner-shoot-1 { animation: corner-shoot-1 15s linear infinite; }
.animate-corner-shoot-2 { animation: corner-shoot-2 18s linear infinite; }
.animate-corner-shoot-3 { animation: corner-shoot-3 20s linear infinite; }
.animate-corner-shoot-4 { animation: corner-shoot-4 16s linear infinite; }
.animate-bounce-ball-1 { animation: bounce-ball-1 12s ease-in-out infinite; }
.animate-bounce-ball-2 { animation: bounce-ball-2 14s ease-in-out infinite; }
.animate-bounce-ball-3 { animation: bounce-ball-3 10s ease-in-out infinite; }
.animate-spin-slow { animation: spin-slow 8s linear infinite; }
.animate-spin-reverse { animation: spin-reverse 6s linear infinite; }
.animate-bounce-gentle { animation: bounce-gentle 3s ease-in-out infinite; }
.animate-bounce-soft { animation: bounce-soft 4s ease-in-out infinite; }
.animate-pulse-gentle { animation: pulse-gentle 4s ease-in-out infinite; }
.animate-wiggle { animation: wiggle 2s ease-in-out infinite; }
.animate-float-gentle { animation: float-gentle 5s ease-in-out infinite; }
.animate-scale-gentle { animation: scale-gentle 6s ease-in-out infinite; }
.animate-rotate-gentle { animation: rotate-gentle 8s ease-in-out infinite; }
.animate-sway { animation: sway 3s ease-in-out infinite; }
.animate-spin-fast { animation: spin-fast 2s linear infinite; }
.animate-pulse-fast { animation: pulse-fast 1.5s ease-in-out infinite; }
.animate-wobble { animation: wobble 2s ease-in-out infinite; }
.animate-shake { animation: shake 0.5s ease-in-out infinite; }
.animate-bounce-crazy { animation: bounce-crazy 1s ease-in-out infinite; }
.animate-spin-wobble { animation: spin-wobble 4s ease-in-out infinite; }
.animate-flip { animation: flip 3s ease-in-out infinite; }
.animate-twirl { animation: twirl 5s ease-in-out infinite; }
.animate-dance { animation: dance 3s ease-in-out infinite; }
.animate-jiggle { animation: jiggle 1s ease-in-out infinite; }
.animate-vibrate { animation: vibrate 0.3s ease-in-out infinite; }
.animate-swing { animation: swing 2.8s ease-in-out infinite; }
.animate-pendulum { animation: pendulum 2.4s ease-in-out infinite; }
.animate-elastic { animation: elastic 2.2s ease-in-out infinite; }
.animate-rubber { animation: rubber 2.5s ease-in-out infinite; }
.animate-rocket { animation: rocket 1.8s ease-in-out infinite; }
.animate-comet { animation: comet 2s ease-in-out infinite; }
.animate-meteor { animation: meteor 1.7s ease-in-out infinite; }
.animate-blast { animation: blast 2.2s ease-in-out infinite; }
.animate-spin-bounce { animation: spin-bounce 2.4s ease-in-out infinite; }
.animate-flip-bounce { animation: flip-bounce 2.6s ease-in-out infinite; }
.animate-scale-bounce { animation: scale-bounce 2.1s ease-in-out infinite; }
@media (max-width: 640px) {
.login-screen {
padding: 2rem 1rem;
}
.auth-card-shell {
padding: 1.25rem;
}
}