188 lines
6.2 KiB
CSS
188 lines
6.2 KiB
CSS
@import "tailwindcss";
|
||
|
||
@theme {
|
||
--color-background: hsl(var(--background));
|
||
--color-foreground: hsl(var(--foreground));
|
||
|
||
--color-card: hsl(var(--card));
|
||
--color-card-foreground: hsl(var(--card-foreground));
|
||
|
||
--color-popover: hsl(var(--popover));
|
||
--color-popover-foreground: hsl(var(--popover-foreground));
|
||
|
||
--color-primary: hsl(var(--primary));
|
||
--color-primary-foreground: hsl(var(--primary-foreground));
|
||
|
||
--color-secondary: hsl(var(--secondary));
|
||
--color-secondary-foreground: hsl(var(--secondary-foreground));
|
||
|
||
--color-muted: hsl(var(--muted));
|
||
--color-muted-foreground: hsl(var(--muted-foreground));
|
||
|
||
--color-accent: hsl(var(--accent));
|
||
--color-accent-foreground: hsl(var(--accent-foreground));
|
||
|
||
--color-destructive: hsl(var(--destructive));
|
||
--color-destructive-foreground: hsl(var(--destructive-foreground));
|
||
|
||
--color-border: hsl(var(--border));
|
||
--color-input: hsl(var(--input));
|
||
--color-ring: hsl(var(--ring));
|
||
|
||
--radius-lg: var(--radius);
|
||
--radius-md: calc(var(--radius) - 2px);
|
||
--radius-sm: calc(var(--radius) - 4px);
|
||
}
|
||
|
||
@layer base {
|
||
:root {
|
||
--background: 0 0% 100%;
|
||
--foreground: 222.2 84% 4.9%;
|
||
--card: 0 0% 100%;
|
||
--card-foreground: 222.2 84% 4.9%;
|
||
--popover: 0 0% 100%;
|
||
--popover-foreground: 222.2 84% 4.9%;
|
||
--primary: 222.2 47.4% 11.2%;
|
||
--primary-foreground: 210 40% 98%;
|
||
--secondary: 210 40% 96.1%;
|
||
--secondary-foreground: 222.2 47.4% 11.2%;
|
||
--muted: 210 40% 96.1%;
|
||
--muted-foreground: 215.4 16.3% 46.9%;
|
||
--accent: 210 40% 96.1%;
|
||
--accent-foreground: 222.2 47.4% 11.2%;
|
||
--destructive: 0 84.2% 60.2%;
|
||
--destructive-foreground: 210 40% 98%;
|
||
--border: 214.3 31.8% 91.4%;
|
||
--input: 214.3 31.8% 91.4%;
|
||
--ring: 222.2 84% 4.9%;
|
||
--radius: 0.5rem;
|
||
}
|
||
|
||
.dark {
|
||
--background: 222.2 84% 4.9%;
|
||
--foreground: 210 40% 98%;
|
||
--card: 222.2 84% 4.9%;
|
||
--card-foreground: 210 40% 98%;
|
||
--popover: 222.2 84% 4.9%;
|
||
--popover-foreground: 210 40% 98%;
|
||
--primary: 210 40% 98%;
|
||
--primary-foreground: 222.2 47.4% 11.2%;
|
||
--secondary: 217.2 32.6% 17.5%;
|
||
--secondary-foreground: 210 40% 98%;
|
||
--muted: 217.2 32.6% 17.5%;
|
||
--muted-foreground: 215 20.2% 65.1%;
|
||
--accent: 217.2 32.6% 17.5%;
|
||
--accent-foreground: 210 40% 98%;
|
||
--destructive: 0 62.8% 30.6%;
|
||
--destructive-foreground: 210 40% 98%;
|
||
--border: 217.2 32.6% 17.5%;
|
||
--input: 217.2 32.6% 17.5%;
|
||
--ring: 212.7 26.8% 83.9%;
|
||
}
|
||
}
|
||
|
||
@layer base {
|
||
* {
|
||
@apply border-border;
|
||
}
|
||
|
||
body {
|
||
@apply bg-background text-foreground;
|
||
}
|
||
}
|
||
|
||
/* ── Calendar component ───────────────────────────────────────────────── */
|
||
@layer components {
|
||
.cal-dow {
|
||
@apply text-xs font-medium text-muted-foreground py-1;
|
||
}
|
||
|
||
.cal-day {
|
||
@apply h-9 w-full rounded-md text-sm text-center
|
||
text-foreground bg-transparent
|
||
hover:bg-accent hover:text-accent-foreground
|
||
focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring
|
||
transition-colors cursor-pointer;
|
||
}
|
||
|
||
.cal-day-selected {
|
||
@apply bg-primary text-primary-foreground hover:bg-primary hover:text-primary-foreground;
|
||
}
|
||
|
||
.cal-day-today {
|
||
@apply font-semibold underline underline-offset-2;
|
||
}
|
||
|
||
.cal-nav {
|
||
@apply text-lg leading-none;
|
||
}
|
||
|
||
/* ── Month / year quick-pick grid ── */
|
||
.cal-view-btn {
|
||
@apply h-9 w-full rounded-md text-sm text-center
|
||
text-foreground bg-transparent
|
||
hover:bg-accent hover:text-accent-foreground
|
||
focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring
|
||
transition-colors cursor-pointer;
|
||
}
|
||
|
||
.cal-view-btn-selected {
|
||
@apply bg-primary text-primary-foreground hover:bg-primary hover:text-primary-foreground;
|
||
}
|
||
|
||
/* ── CalendarRange day states ── */
|
||
.calr-day {
|
||
@apply h-9 w-full text-sm text-center text-foreground
|
||
transition-colors cursor-pointer focus-visible:outline-none
|
||
focus-visible:ring-2 focus-visible:ring-ring;
|
||
}
|
||
|
||
/* Plain days (no range involvement) */
|
||
.calr-day-plain {
|
||
@apply rounded-md hover:bg-accent hover:text-accent-foreground;
|
||
}
|
||
|
||
/* Start cap — primary, rounded left only */
|
||
.calr-day-start {
|
||
@apply rounded-l-md bg-primary text-primary-foreground
|
||
hover:bg-primary;
|
||
}
|
||
|
||
/* End cap — primary, rounded right only */
|
||
.calr-day-end {
|
||
@apply rounded-r-md bg-primary text-primary-foreground
|
||
hover:bg-primary;
|
||
}
|
||
|
||
/* Days strictly between start and end */
|
||
.calr-day-mid {
|
||
@apply rounded-none bg-accent text-accent-foreground
|
||
hover:bg-accent;
|
||
}
|
||
}
|
||
|
||
/* ── Select – custom caret via background SVG ─────────────────────────── */
|
||
@layer components {
|
||
select.appearance-none {
|
||
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
|
||
background-repeat: no-repeat;
|
||
background-position: right 0.75rem center;
|
||
padding-right: 2.25rem;
|
||
}
|
||
}
|
||
|
||
/* ── TimePicker – hide number spinner arrows ──────────────────────────── */
|
||
@layer utilities {
|
||
input[type=number].timepicker-hour,
|
||
input[type=number].timepicker-minute {
|
||
-moz-appearance: textfield;
|
||
}
|
||
input[type=number].timepicker-hour::-webkit-outer-spin-button,
|
||
input[type=number].timepicker-hour::-webkit-inner-spin-button,
|
||
input[type=number].timepicker-minute::-webkit-outer-spin-button,
|
||
input[type=number].timepicker-minute::-webkit-inner-spin-button {
|
||
-webkit-appearance: none;
|
||
margin: 0;
|
||
}
|
||
}
|