289 lines
7.4 KiB
CSS
289 lines
7.4 KiB
CSS
@import 'tailwindcss';
|
|
@import 'tw-animate-css';
|
|
|
|
@custom-variant dark (&:is(.dark *));
|
|
|
|
@font-face {
|
|
font-family: 'DIN Next';
|
|
font-weight: 900;
|
|
src: url('../assets/fonts/din-next/din-next-black.otf') format('woff');
|
|
}
|
|
|
|
@font-face {
|
|
font-family: 'DIN Next';
|
|
font-weight: 700;
|
|
src: url('../assets/fonts/din-next/din-next-bold.otf') format('woff');
|
|
}
|
|
|
|
@font-face {
|
|
font-family: 'DIN Next';
|
|
font-weight: 600;
|
|
src: url('../assets/fonts/din-next/din-next-medium.otf') format('woff');
|
|
}
|
|
|
|
@font-face {
|
|
font-family: 'DIN Next';
|
|
font-weight: 400;
|
|
src: url('../assets/fonts/din-next/din-next-regular.otf') format('woff');
|
|
}
|
|
|
|
@font-face {
|
|
font-family: 'DIN Next';
|
|
font-weight: 300;
|
|
src: url('../assets/fonts/din-next/din-next-light.otf') format('woff');
|
|
}
|
|
|
|
@font-face {
|
|
font-family: 'DIN Next';
|
|
font-weight: 200;
|
|
src: url('../assets/fonts/din-next/din-next-ultra-light.otf') format('woff');
|
|
}
|
|
|
|
@theme inline {
|
|
--radius-sm: calc(var(--radius) - 4px);
|
|
--radius-md: calc(var(--radius) - 2px);
|
|
--radius-lg: var(--radius);
|
|
--radius-xl: calc(var(--radius) + 4px);
|
|
--color-background: var(--background);
|
|
--color-foreground: var(--foreground);
|
|
--color-card: var(--card);
|
|
--color-card-foreground: var(--card-foreground);
|
|
--color-popover: var(--popover);
|
|
--color-popover-foreground: var(--popover-foreground);
|
|
--color-primary: var(--primary);
|
|
--color-primary-foreground: var(--primary-foreground);
|
|
--color-secondary: var(--secondary);
|
|
--color-secondary-foreground: var(--secondary-foreground);
|
|
--color-muted: var(--muted);
|
|
--color-muted-foreground: var(--muted-foreground);
|
|
--color-accent: var(--accent);
|
|
--color-accent-foreground: var(--accent-foreground);
|
|
--color-destructive: var(--destructive);
|
|
--color-border: var(--border);
|
|
--color-input: var(--input);
|
|
--color-ring: var(--ring);
|
|
--color-chart-1: var(--chart-1);
|
|
--color-chart-2: var(--chart-2);
|
|
--color-chart-3: var(--chart-3);
|
|
--color-chart-4: var(--chart-4);
|
|
--color-chart-5: var(--chart-5);
|
|
--color-sidebar: var(--sidebar);
|
|
--color-sidebar-foreground: var(--sidebar-foreground);
|
|
--color-sidebar-primary: var(--sidebar-primary);
|
|
--color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
|
|
--color-sidebar-accent: var(--sidebar-accent);
|
|
--color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
|
|
--color-sidebar-border: var(--sidebar-border);
|
|
--color-sidebar-ring: var(--sidebar-ring);
|
|
}
|
|
|
|
:root {
|
|
--font-sans: 'DIN Next', sans-serif;
|
|
|
|
--bigstone-50: #f2f7fd;
|
|
--bigstone-100: #e3edfb;
|
|
--bigstone-200: #c1dcf6;
|
|
--bigstone-300: #8bbfee;
|
|
--bigstone-400: #4d9ee3;
|
|
--bigstone-500: #2682d1;
|
|
--bigstone-600: #1866b1;
|
|
--bigstone-700: #145190;
|
|
--bigstone-800: #154677;
|
|
--bigstone-900: #173b63;
|
|
--bigstone-950: #0e233d;
|
|
|
|
/* Cores usadas pelos gráficos */
|
|
--color-desktop: var(--bigstone-500);
|
|
--color-mobile: var(--bigstone-300);
|
|
|
|
--color-chrome: var(--bigstone-500);
|
|
--color-safari: var(--bigstone-600);
|
|
--color-firefox: var(--bigstone-700);
|
|
--color-edge: var(--bigstone-800);
|
|
--color-other: var(--bigstone-300);
|
|
|
|
--chart-1: var(--bigstone-500);
|
|
--chart-2: var(--bigstone-400);
|
|
--chart-3: var(--bigstone-600);
|
|
--chart-4: var(--bigstone-700);
|
|
--chart-5: var(--bigstone-300);
|
|
|
|
--radius: 0.625rem;
|
|
--background: oklch(1 0 0);
|
|
--foreground: oklch(0.145 0 0);
|
|
--card: oklch(1 0 0);
|
|
--card-foreground: oklch(0.145 0 0);
|
|
--popover: oklch(1 0 0);
|
|
--popover-foreground: oklch(0.145 0 0);
|
|
--primary: #0e233d;
|
|
--primary-foreground: oklch(0.985 0 0);
|
|
--secondary: #febb01;
|
|
--secondary-foreground: oklch(0.205 0 0);
|
|
--muted: oklch(0.97 0 0);
|
|
--muted-foreground: oklch(0.556 0 0);
|
|
--accent: oklch(0.97 0 0);
|
|
--accent-foreground: oklch(0.205 0 0);
|
|
--destructive: oklch(0.577 0.245 27.325);
|
|
--border: oklch(0.922 0 0);
|
|
--input: oklch(0.922 0 0);
|
|
--ring: oklch(0.708 0 0);
|
|
--chart-1: oklch(0.646 0.222 41.116);
|
|
--chart-2: oklch(0.6 0.118 184.704);
|
|
--chart-3: oklch(0.398 0.07 227.392);
|
|
--chart-4: oklch(0.828 0.189 84.429);
|
|
--chart-5: oklch(0.769 0.188 70.08);
|
|
--sidebar: oklch(0.985 0 0);
|
|
--sidebar-foreground: oklch(0.145 0 0);
|
|
--sidebar-primary: oklch(0.205 0 0);
|
|
--sidebar-primary-foreground: oklch(0.985 0 0);
|
|
--sidebar-accent: oklch(0.97 0 0);
|
|
--sidebar-accent-foreground: oklch(0.205 0 0);
|
|
--sidebar-border: oklch(0.922 0 0);
|
|
--sidebar-ring: oklch(0.708 0 0);
|
|
}
|
|
|
|
.dark {
|
|
--background: oklch(0.145 0 0);
|
|
--foreground: oklch(0.985 0 0);
|
|
--card: oklch(0.205 0 0);
|
|
--card-foreground: oklch(0.985 0 0);
|
|
--popover: oklch(0.205 0 0);
|
|
--popover-foreground: oklch(0.985 0 0);
|
|
--primary: oklch(0.922 0 0);
|
|
--primary-foreground: oklch(0.205 0 0);
|
|
--secondary: oklch(0.269 0 0);
|
|
--secondary-foreground: oklch(0.985 0 0);
|
|
--muted: oklch(0.269 0 0);
|
|
--muted-foreground: oklch(0.708 0 0);
|
|
--accent: oklch(0.269 0 0);
|
|
--accent-foreground: oklch(0.985 0 0);
|
|
--destructive: oklch(0.704 0.191 22.216);
|
|
--border: oklch(1 0 0 / 10%);
|
|
--input: oklch(1 0 0 / 15%);
|
|
--ring: oklch(0.556 0 0);
|
|
--chart-1: oklch(0.488 0.243 264.376);
|
|
--chart-2: oklch(0.696 0.17 162.48);
|
|
--chart-3: oklch(0.769 0.188 70.08);
|
|
--chart-4: oklch(0.627 0.265 303.9);
|
|
--chart-5: oklch(0.645 0.246 16.439);
|
|
--sidebar: oklch(0.205 0 0);
|
|
--sidebar-foreground: oklch(0.985 0 0);
|
|
--sidebar-primary: oklch(0.488 0.243 264.376);
|
|
--sidebar-primary-foreground: oklch(0.985 0 0);
|
|
--sidebar-accent: oklch(0.269 0 0);
|
|
--sidebar-accent-foreground: oklch(0.985 0 0);
|
|
--sidebar-border: oklch(1 0 0 / 10%);
|
|
--sidebar-ring: oklch(0.556 0 0);
|
|
}
|
|
|
|
@layer base {
|
|
* {
|
|
@apply border-border outline-ring/50;
|
|
}
|
|
body {
|
|
@apply bg-background text-foreground;
|
|
}
|
|
}
|
|
|
|
@keyframes slidein {
|
|
from {
|
|
opacity: 0;
|
|
transform: translateY(-10px);
|
|
}
|
|
to {
|
|
opacity: 1;
|
|
transform: translateY(0);
|
|
}
|
|
}
|
|
|
|
.animate-slidein {
|
|
animation: slidein 1s ease forwards;
|
|
}
|
|
.animate-slidein300 {
|
|
animation: slidein 1s ease 300ms forwards;
|
|
}
|
|
.animate-slidein500 {
|
|
animation: slidein 1s ease 500ms forwards;
|
|
}
|
|
.animate-slidein700 {
|
|
animation: slidein 1s ease 700ms forwards;
|
|
}
|
|
|
|
/* Greeting pill (avatar header) */
|
|
.greeting-pill {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 0.5rem;
|
|
padding: 0.125rem 0.5rem;
|
|
border-radius: 9999px;
|
|
transition: transform 160ms ease, box-shadow 160ms ease;
|
|
user-select: none;
|
|
}
|
|
|
|
.greeting-pill:hover {
|
|
transform: translateY(-3px);
|
|
}
|
|
|
|
.greeting-icon {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
line-height: 0;
|
|
}
|
|
|
|
.greeting-text {
|
|
font-size: 0.75rem;
|
|
font-weight: 600;
|
|
color: inherit;
|
|
display: none; /* esconder em telas muito pequenas */
|
|
}
|
|
|
|
@media (min-width: 640px) {
|
|
.greeting-text {
|
|
display: inline-block;
|
|
}
|
|
}
|
|
|
|
/* Animations */
|
|
@keyframes float-y {
|
|
0% {
|
|
transform: translateY(0);
|
|
}
|
|
50% {
|
|
transform: translateY(-3px);
|
|
}
|
|
100% {
|
|
transform: translateY(0);
|
|
}
|
|
}
|
|
|
|
@keyframes slow-rotate {
|
|
0% {
|
|
transform: rotate(0deg);
|
|
}
|
|
100% {
|
|
transform: rotate(360deg);
|
|
}
|
|
}
|
|
|
|
.greeting-pill .greeting-icon {
|
|
animation: float-y 3.6s ease-in-out infinite;
|
|
}
|
|
|
|
.greeting-pill.day .greeting-icon svg {
|
|
filter: drop-shadow(0 1px 6px rgba(255, 180, 60, 0.12));
|
|
}
|
|
|
|
.greeting-pill.night .greeting-icon svg {
|
|
filter: drop-shadow(0 2px 8px rgba(96, 165, 250, 0.08));
|
|
}
|
|
|
|
.greeting-pill.day .greeting-icon.animate-rotate {
|
|
animation: slow-rotate 8s linear infinite, float-y 3.6s ease-in-out infinite;
|
|
}
|
|
|
|
/* small touch: slightly scale on active */
|
|
.greeting-pill:active {
|
|
transform: translateY(-1px) scale(0.995);
|
|
}
|