Files
cal-diy-oidc/apps/scheduler/app/globals.css
T
ZachariahSharma e6fc365278
Create PR containing updated CHANGELOG.md and release packages to NPM once PR is merged / Release (push) Has been cancelled
Run i18n AI automation / Run i18n (push) Has been cancelled
Next.js Bundle Analysis / analyze (push) Has been cancelled
Remove scheduler connections and meeting extras
2026-06-15 15:10:39 -06:00

934 lines
19 KiB
CSS

/* ================================================================
OBSIDIAN — Vynte Scheduler Design System
Palette: deep charcoal · sage accent · warm off-white text
Type: DM Serif Display · DM Sans · JetBrains Mono
================================================================ */
*, *::before, *::after { box-sizing: border-box; }
p { margin: 0; }
html {
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
font-size: 14px;
}
:root {
/* Backgrounds */
--bg: #0c0e10;
--surface-0: #131517;
--surface-1: #191c1f;
--surface-2: #1f2327;
/* Borders */
--border-subtle: #1e2226;
--border: #272c33;
--border-strong: #353c45;
/* Text */
--text: #ddd8d2;
--text-2: #808890;
--text-3: #4d545d;
/* Accent — sage green */
--accent: #52b583;
--accent-hover: #63c994;
--accent-bg: rgba(82, 181, 131, 0.10);
--accent-bg-hover: rgba(82, 181, 131, 0.16);
--accent-border: rgba(82, 181, 131, 0.28);
--accent-text: #c8edd9;
--accent-glow: rgba(82, 181, 131, 0.35);
/* States */
--error: #e05858;
--error-bg: rgba(224, 88, 88, 0.10);
--warn: #d49055;
--warn-bg: rgba(212, 144, 85, 0.10);
/* Typography */
--font-display: var(--font-serif, Georgia, 'Times New Roman', serif);
--font-sans: var(--font-dm-sans, system-ui, sans-serif);
--font-mono: var(--font-jb-mono, 'Courier New', monospace);
/* Radii */
--radius-sm: 5px;
--radius: 8px;
--radius-lg: 12px;
--radius-xl: 16px;
}
body {
margin: 0;
background: var(--bg);
color: var(--text);
font-family: var(--font-sans);
font-size: 13px;
line-height: 1.55;
min-height: 100vh;
}
button, input, select, textarea { font: inherit; }
a { color: inherit; text-decoration: none; }
input[type="checkbox"] {
accent-color: var(--accent);
width: 14px;
height: 14px;
cursor: pointer;
}
input[type="time"]::-webkit-calendar-picker-indicator { filter: invert(0.5); }
input[type="number"]::-webkit-inner-spin-button { filter: invert(0.5); }
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-3); }
/* ================================================================
APP SHELL
================================================================ */
.app-frame {
min-height: 100vh;
display: grid;
grid-template-columns: 200px minmax(0, 1fr);
background: var(--bg);
}
.sidebar {
min-height: 100vh;
background: var(--surface-0);
border-right: 1px solid var(--border-subtle);
padding: 18px 8px;
display: flex;
flex-direction: column;
position: sticky;
top: 0;
height: 100vh;
overflow-y: auto;
}
.brand {
font-family: var(--font-display);
font-size: 17px;
font-weight: 400;
letter-spacing: -0.02em;
color: var(--text);
padding: 4px 12px 22px;
opacity: 0.92;
display: flex;
align-items: center;
gap: 9px;
}
.nav-list { display: grid; gap: 2px; }
.nav-item {
display: block;
padding: 8px 14px;
border-radius: var(--radius-sm);
color: var(--text-2);
font-size: 13px;
font-weight: 500;
letter-spacing: 0.008em;
transition: color 0.14s, background 0.14s;
position: relative;
}
.nav-item:hover {
color: var(--text);
background: rgba(255, 255, 255, 0.04);
}
.nav-item[data-active="true"] {
color: var(--accent-text);
background: var(--accent-bg);
font-weight: 600;
}
.nav-item[data-active="true"]::before {
content: '';
position: absolute;
left: 0;
top: 50%;
transform: translateY(-50%);
width: 3px;
height: 18px;
background: var(--accent);
border-radius: 0 3px 3px 0;
box-shadow: 2px 0 8px var(--accent-glow);
}
.profile-block {
margin-top: auto;
border-top: 1px solid var(--border-subtle);
padding: 16px 12px 4px;
display: grid;
gap: 12px;
}
.profile-block strong {
display: block;
font-size: 12px;
font-weight: 600;
color: var(--text);
margin-bottom: 4px;
letter-spacing: 0.01em;
}
.profile-block span {
font-size: 10.5px;
color: var(--text-3);
font-family: var(--font-mono);
letter-spacing: 0.04em;
}
.session-button {
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 32px;
border: 1px solid var(--border);
border-radius: var(--radius-sm);
color: var(--text-2);
background: rgba(255, 255, 255, 0.02);
font-size: 11px;
font-weight: 700;
letter-spacing: 0.08em;
text-transform: uppercase;
transition: color 0.14s, border-color 0.14s, background 0.14s;
}
.session-button:hover {
color: var(--text);
border-color: var(--accent-border);
background: var(--accent-bg);
}
.main-surface {
padding: 28px 26px;
min-width: 0;
min-height: 0;
animation: surface-in 0.28s ease-out;
}
@keyframes surface-in {
from { opacity: 0; transform: translateY(5px); }
to { opacity: 1; transform: translateY(0); }
}
/* ================================================================
SHARED PRIMITIVES
================================================================ */
.panel-header {
display: flex;
align-items: baseline;
justify-content: space-between;
gap: 12px;
margin-bottom: 22px;
}
.panel-header h1 {
font-family: var(--font-display);
font-size: 23px;
font-weight: 400;
letter-spacing: -0.03em;
margin: 0;
color: var(--text);
}
.panel-header h2 { margin: 0; }
.muted {
color: var(--text-2);
font-size: 12px;
}
/* Buttons */
.primary-button {
display: inline-flex;
align-items: center;
background: var(--accent);
color: #0a1f10;
border: none;
border-radius: var(--radius);
padding: 9px 18px;
font-size: 13px;
font-weight: 700;
cursor: pointer;
letter-spacing: 0.01em;
transition: background 0.14s, box-shadow 0.14s, transform 0.09s;
}
.primary-button:hover:not(:disabled) {
background: var(--accent-hover);
box-shadow: 0 0 20px rgba(82, 181, 131, 0.28);
}
.primary-button:active:not(:disabled) { transform: scale(0.975); }
.primary-button:disabled { opacity: 0.35; cursor: not-allowed; }
.secondary-button {
display: inline-flex;
align-items: center;
background: transparent;
color: var(--text-2);
border: 1px solid var(--border);
border-radius: var(--radius-sm);
padding: 6px 12px;
font-size: 12px;
font-weight: 500;
cursor: pointer;
transition: color 0.14s, border-color 0.14s, background 0.14s;
}
.secondary-button:hover {
color: var(--text);
border-color: var(--border-strong);
background: rgba(255, 255, 255, 0.04);
}
.secondary-button[data-active="true"] {
border-color: var(--accent-border);
color: var(--accent-text);
background: var(--accent-bg);
}
.icon-button {
display: inline-grid;
place-items: center;
width: 34px;
height: 34px;
border: 1px solid var(--accent-border);
border-radius: var(--radius);
background: var(--accent-bg);
color: var(--accent);
cursor: pointer;
font-size: 22px;
line-height: 1;
font-weight: 400;
transition: background 0.14s, border-color 0.14s, color 0.14s, transform 0.09s;
}
.icon-button:hover {
color: var(--accent-text);
border-color: rgba(82, 181, 131, 0.46);
background: var(--accent-bg-hover);
}
.icon-button:active { transform: scale(0.96); }
/* Notices */
.notice {
font-size: 12px;
margin: 10px 0 0;
padding: 8px 12px;
border-radius: var(--radius-sm);
border-left: 2px solid transparent;
}
.notice-error { color: var(--error); background: var(--error-bg); border-left-color: var(--error); }
.notice-warn { color: var(--warn); background: var(--warn-bg); border-left-color: var(--warn); }
.notice-ok { color: var(--accent); background: var(--accent-bg); border-left-color: var(--accent); }
/* Fields */
.field {
display: grid;
gap: 6px;
margin: 14px 0;
}
.field > span {
font-size: 10.5px;
font-weight: 700;
letter-spacing: 0.08em;
text-transform: uppercase;
color: var(--text-3);
}
.field input {
background: var(--surface-2);
border: 1px solid var(--border);
border-radius: var(--radius);
padding: 9px 12px;
color: var(--text);
font-size: 13px;
font-family: var(--font-sans);
transition: border-color 0.14s, box-shadow 0.14s;
}
.field input:focus {
outline: none;
border-color: var(--accent-border);
box-shadow: 0 0 0 3px var(--accent-bg);
}
.field input::placeholder { color: var(--text-3); }
.field-inline {
display: flex;
align-items: center;
gap: 10px;
font-size: 13px;
margin: 12px 0;
cursor: pointer;
color: var(--text-2);
}
.field-inline:hover { color: var(--text); }
/* ================================================================
AUTH
================================================================ */
.auth-screen {
min-height: 100vh;
display: grid;
place-items: center;
padding: 24px;
background:
radial-gradient(circle at 50% 0%, rgba(82, 181, 131, 0.13), transparent 34rem),
var(--bg);
}
.auth-card {
width: min(100%, 390px);
background: var(--surface-1);
border: 1px solid var(--border-subtle);
border-radius: var(--radius-xl);
padding: 30px;
box-shadow: 0 24px 80px rgba(0, 0, 0, 0.32);
}
.auth-mark {
width: 46px;
height: 46px;
display: grid;
place-items: center;
border: 1px solid var(--border);
border-radius: 14px;
background: var(--surface-0);
margin-bottom: 24px;
}
.auth-kicker {
color: var(--accent);
font-family: var(--font-mono);
font-size: 10px;
font-weight: 700;
letter-spacing: 0.14em;
text-transform: uppercase;
margin-bottom: 8px;
}
.auth-card h1 {
font-family: var(--font-display);
font-size: 32px;
font-weight: 400;
letter-spacing: -0.04em;
line-height: 1;
margin: 0 0 12px;
}
.auth-copy {
color: var(--text-2);
font-size: 13px;
margin-bottom: 26px;
}
.auth-primary,
.auth-secondary {
display: flex;
align-items: center;
justify-content: center;
width: 100%;
min-height: 42px;
border-radius: var(--radius);
font-size: 13px;
font-weight: 700;
}
.auth-primary {
color: #0a1f10;
background: var(--accent);
border: 0;
cursor: pointer;
box-shadow: 0 0 24px rgba(82, 181, 131, 0.18);
}
.auth-primary:hover {
background: var(--accent-hover);
}
.auth-secondary {
margin-top: 10px;
color: var(--text-2);
border: 1px solid var(--border);
}
.auth-secondary:hover {
color: var(--text);
border-color: var(--border-strong);
}
/* ================================================================
CALENDAR
================================================================ */
.calendar-layout {
display: grid;
grid-template-columns: minmax(0, 1fr) 288px;
gap: 16px;
align-items: stretch;
height: calc(100vh - 56px);
min-height: 620px;
}
.calendar-panel {
background: var(--surface-1);
border: 1px solid var(--border-subtle);
border-radius: var(--radius-xl);
padding: 20px;
overflow: hidden;
min-height: 0;
display: flex;
flex-direction: column;
}
.week-scroller {
min-height: 0;
overflow: auto;
border: 1px solid var(--border-subtle);
border-radius: var(--radius);
background: rgba(255, 255, 255, 0.01);
}
.week-grid {
display: grid;
grid-template-columns: 46px repeat(5, minmax(0, 1fr));
gap: 0;
min-width: 720px;
}
.time-gutter {
padding-top: 30px;
position: sticky;
left: 0;
z-index: 4;
background: var(--surface-1);
}
.hour-label {
font-size: 9.5px;
font-family: var(--font-mono);
color: var(--text-3);
border-top: 1px solid var(--border-subtle);
padding: 3px 6px 0;
letter-spacing: 0.06em;
}
.day-column {
border-left: 1px solid var(--border-subtle);
min-width: 0;
}
.day-heading {
position: sticky;
top: 0;
z-index: 3;
font-size: 10px;
font-weight: 600;
text-align: center;
padding: 5px 0 9px;
color: var(--text-3);
letter-spacing: 0.1em;
text-transform: uppercase;
background: var(--surface-1);
border-bottom: 1px solid var(--border-subtle);
}
.day-body {
position: relative;
background: transparent;
}
.day-body::after {
content: '';
position: absolute;
inset: 0;
background: repeating-linear-gradient(
to bottom,
transparent,
transparent calc(48px - 1px),
var(--border-subtle) calc(48px - 1px),
var(--border-subtle) 48px
);
pointer-events: none;
z-index: 0;
}
.busy-block {
position: absolute;
left: 3px;
right: 3px;
z-index: 1;
background: var(--surface-2);
border: 1px solid var(--border);
border-radius: 4px;
font-size: 9.5px;
padding: 3px 5px;
overflow: hidden;
color: var(--text-3);
font-family: var(--font-mono);
letter-spacing: 0.04em;
}
.busy-block[data-own="true"] {
background: rgba(82, 181, 131, 0.06);
border-color: rgba(82, 181, 131, 0.18);
color: rgba(82, 181, 131, 0.45);
}
.mutual-slot {
position: absolute;
left: 3px;
right: 3px;
z-index: 2;
background: var(--accent-bg);
border: 1px solid var(--accent-border);
border-radius: 4px;
font-size: 9.5px;
color: var(--accent);
cursor: pointer;
padding: 3px 5px;
font-family: var(--font-mono);
font-weight: 500;
letter-spacing: 0.04em;
transition: background 0.12s, box-shadow 0.12s, border-color 0.12s;
}
.mutual-slot:hover {
background: var(--accent-bg-hover);
border-color: rgba(82, 181, 131, 0.45);
box-shadow: 0 0 10px rgba(82, 181, 131, 0.18);
}
.mutual-slot[data-selected="true"] {
background: var(--accent);
color: #0a1f10;
border-color: var(--accent);
box-shadow: 0 0 16px rgba(82, 181, 131, 0.4);
font-weight: 700;
}
/* ================================================================
COMPOSER
================================================================ */
.composer {
background: var(--surface-1);
border: 1px solid var(--border-subtle);
border-radius: var(--radius-xl);
padding: 20px;
position: sticky;
top: 28px;
max-height: calc(100vh - 56px);
overflow: auto;
}
.composer h2 {
font-family: var(--font-display);
font-size: 17px;
font-weight: 400;
letter-spacing: -0.02em;
margin: 0 0 16px;
color: var(--text);
}
.composer-group {
border: 1px solid var(--border);
border-radius: var(--radius);
padding: 11px 13px;
margin: 0 0 14px;
background: var(--surface-2);
}
.composer-group legend {
font-size: 9.5px;
font-weight: 700;
color: var(--text-3);
padding: 0 6px;
letter-spacing: 0.12em;
text-transform: uppercase;
}
.attendee-row {
display: flex;
align-items: center;
gap: 10px;
font-size: 13px;
padding: 5px 0;
cursor: pointer;
color: var(--text-2);
transition: color 0.12s;
}
.attendee-row:hover { color: var(--text); }
.duration-presets {
display: flex;
flex-wrap: wrap;
gap: 6px;
align-items: center;
}
.duration-custom {
width: 58px;
background: var(--surface-0);
border: 1px solid var(--border);
border-radius: var(--radius-sm);
padding: 6px 8px;
color: var(--text);
font-family: var(--font-mono);
font-size: 12px;
transition: border-color 0.14s;
}
.duration-custom:focus {
outline: none;
border-color: var(--accent-border);
}
.selected-slot {
font-size: 13px;
margin: 12px 0 14px;
padding: 10px 13px;
border-radius: var(--radius);
background: var(--surface-2);
border: 1px solid var(--border-subtle);
min-height: 40px;
display: flex;
align-items: center;
}
.selected-slot > span:not(.muted) {
font-family: var(--font-mono);
font-size: 11.5px;
color: var(--accent);
letter-spacing: 0.04em;
}
/* ================================================================
AVAILABILITY + SETTINGS
================================================================ */
.availability-layout {
display: grid;
gap: 16px;
max-width: 600px;
}
.settings-card {
background: var(--surface-1);
border: 1px solid var(--border-subtle);
border-radius: var(--radius-xl);
padding: 22px;
}
.settings-card h2 {
font-family: var(--font-display);
font-size: 17px;
font-weight: 400;
letter-spacing: -0.02em;
margin: 0 0 4px;
color: var(--text);
}
.settings-card-heading {
display: flex;
align-items: start;
justify-content: space-between;
gap: 14px;
}
.weekly-rows {
display: grid;
gap: 0;
margin-top: 14px;
}
.weekly-row {
display: flex;
align-items: center;
gap: 16px;
padding: 10px 0;
border-top: 1px solid var(--border-subtle);
transition: opacity 0.2s;
}
.weekly-row[data-enabled="false"] { opacity: 0.38; }
.weekly-toggle {
min-width: 136px;
color: var(--text);
font-weight: 500;
font-size: 13px;
gap: 10px !important;
margin: 0 !important;
}
.time-range {
display: flex;
align-items: center;
gap: 8px;
}
.time-range input {
background: var(--surface-2);
border: 1px solid var(--border);
border-radius: var(--radius-sm);
padding: 5px 8px;
color: var(--text);
font-family: var(--font-mono);
font-size: 11.5px;
letter-spacing: 0.04em;
transition: border-color 0.14s;
}
.time-range input:focus {
outline: none;
border-color: var(--accent-border);
box-shadow: 0 0 0 2px var(--accent-bg);
}
.dash {
color: var(--text-3);
font-size: 11px;
font-family: var(--font-mono);
}
.unavailable-label {
font-style: italic;
color: var(--text-3);
font-size: 12px;
}
.override-list {
list-style: none;
margin: 12px 0 0;
padding: 0;
display: grid;
gap: 0;
}
.override-row {
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
padding: 10px 0;
border-top: 1px solid var(--border-subtle);
font-size: 13px;
}
.override-row > span:first-child {
display: grid;
gap: 2px;
}
.override-row strong {
color: var(--text);
font-size: 13px;
font-weight: 600;
}
.override-editor {
display: grid;
gap: 12px;
margin-top: 16px;
padding: 14px;
border: 1px solid var(--border);
border-radius: var(--radius);
background: var(--surface-2);
}
.override-date { margin: 0; }
.override-date-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 10px;
}
.override-mode-row,
.override-actions {
display: flex;
align-items: center;
gap: 8px;
flex-wrap: wrap;
}
.override-actions {
padding-top: 2px;
}
.override-unavailable { margin: 0; }
.override-time-range { margin-bottom: 1px; }
.override-add { margin-bottom: 1px; }
.save-bar {
display: flex;
align-items: center;
gap: 12px;
padding-top: 4px;
}
/* ================================================================
RESPONSIVE
================================================================ */
@media (max-width: 960px) {
.calendar-layout {
grid-template-columns: 1fr;
height: auto;
min-height: 0;
}
.calendar-panel { max-height: min(680px, calc(100vh - 220px)); }
.week-scroller { max-height: 560px; }
.composer {
position: static;
max-height: none;
}
}
@media (max-width: 860px) {
.app-frame { grid-template-columns: 1fr; }
.sidebar { min-height: auto; height: auto; position: static; border-right: 0; border-bottom: 1px solid var(--border-subtle); }
}
@media (max-width: 640px) {
.main-surface { padding: 18px 14px; }
.panel-header {
align-items: start;
flex-direction: column;
gap: 4px;
}
.weekly-row {
display: grid;
grid-template-columns: 1fr;
gap: 8px;
}
.weekly-toggle { min-width: 0; }
.weekly-row .time-range {
padding-left: 24px;
min-width: 0;
}
.weekly-row .time-range input {
width: min(112px, calc((100vw - 112px) / 2));
}
.override-date-grid { grid-template-columns: 1fr; }
.settings-card-heading { align-items: center; }
}