934 lines
19 KiB
CSS
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; }
|
|
}
|