﻿:root {
  --font-family: system-ui, -apple-system, "Segoe UI", Roboto, Inter, Arial, sans-serif;
  --font-size: 16px;
  --font-size-base: 16px;
  --font-size-sm: 14px;
  --font-size-lg: 20px;

  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-5: 1.25rem;
  --sp-6: 1.5rem;
  --space-1: 6px;
  --space-2: 8px;
  --space-3: 10px;
  --space-4: 12px;
  --space-5: 14px;
  --space-6: 16px;
  --space-7: 18px;
  --space-8: 20px;
  --space-9: 24px;
  --spacer: 1rem;
  --spacer-sm: 0.5rem;
  --spacer-lg: 2rem;

  --radius: 12px;
  --radius-sm: 8px;
  --border-radius: 4px;
  --border-radius-sm: 2px;
  --border-radius-lg: 8px;

  --container: 1100px;
  --topbar-h: 56px;
  --footer-z: 3000;
  --footer-bar-h: 48px;
  --footer-space: var(--footer-bar-h);
  --sidebar-w: 420px;
  --grid-h: 26px;
  --gutter-w: 260px;
  --h: 72vh;
  --lane-gap: 10px;
  --lane-h: 28px;
  --pad: 12px;

  --dropdown-min-w: 220px;
  --dropdown-max-w: clamp(240px, 60vw, 420px);
  --dropdown-max-h: min(68vh, 520px);
  --menu-font: 14px;
  --menu-max-h: calc(100dvh - var(--topbar-h));
  --menu-max-w: clamp(240px, 60vw, 420px);

  --easing: cubic-bezier(0.4, 0, 0.2, 1);
  --timing: 220ms var(--easing);
  --transition: all 0.25s var(--easing);

  --white: #ffffff;
  --black: #000000;

  --bg: #f7f7f9;
  --paper: #ffffff;
  --card: #ffffff;
  --card-bg: color-mix(in srgb, var(--card) 95%, transparent);
  --surface: var(--card);
  --surface-0: #ffffff;
  --surface-1: #f8f8fb;
  --surface-2: #f0f2f5;
  --surface-elevated: #ffffff;
  --input: #ffffff;
  --input-bg: var(--input);

  --text: #1f2937;
  --text-color: var(--text);
  --text-1: #2e2e2e;
  --text-2: #5f6672;
  --text-muted: #6b7280;
  --text-inverse: #ffffff;
  --ink: var(--text);
  --muted: #6b7280;

  --primary: #c00000;
  --primary-color: var(--primary);
  --accent: #1c78cf;
  --accent-color: var(--accent);
  --accent-hover: color-mix(in srgb, var(--accent) 85%, var(--black) 15%);
  --accent-h: 207;
  --accent-s: 76%;
  --accent-l: 46%;
  --brand-h: var(--accent-h);
  --brand-s: var(--accent-s);
  --brand-l: var(--accent-l);
  --border: #d4d9e2;
  --bg-dropdown: color-mix(in srgb, var(--black) 5%, transparent);

  --success: #22c55e;
  --ok: var(--success);
  --warning: #f59e0b;
  --warn: var(--warning);
  --danger: #ef4444;
  --info: #3b82f6;

  --btn-text: #ffffff;
  --btn-primary-text: #ffffff;
  --btn-secondary-text: #ffffff;
  --btn-bg-main: color-mix(in srgb, var(--accent) 92%, var(--black) 8%);
  --btn-bg-main-hover: color-mix(in srgb, var(--btn-bg-main) 88%, var(--white) 12%);
  --btn-bg-primary: color-mix(in srgb, var(--accent) 82%, var(--black) 18%);
  --btn-bg-primary-hover: color-mix(in srgb, var(--btn-bg-primary) 88%, var(--white) 12%);
  --btn-bg-secondary: #4b5563;
  --btn-bg-secondary-hover: color-mix(in srgb, var(--btn-bg-secondary) 88%, var(--white) 12%);
  --btn-bg-success: var(--success);
  --btn-bg-success-hover: color-mix(in srgb, var(--btn-bg-success) 88%, var(--white) 12%);
  --btn-bg-warning: var(--warning);
  --btn-bg-warning-hover: color-mix(in srgb, var(--btn-bg-warning) 88%, var(--white) 12%);
  --btn-bg-danger: var(--danger);
  --btn-bg-danger-hover: color-mix(in srgb, var(--btn-bg-danger) 88%, var(--white) 12%);
  --btn-bg-info: var(--info);
  --btn-bg-info-hover: color-mix(in srgb, var(--btn-bg-info) 88%, var(--white) 12%);

  --checkbox-checked-color: var(--accent);
  --checkbox-border-color: color-mix(in srgb, var(--accent) 65%, var(--black) 35%);

  --shadow-s: 0 2px 8px color-mix(in srgb, var(--black) 10%, transparent);
  --shadow-m: 0 12px 28px color-mix(in srgb, var(--black) 16%, transparent);
  --shadow: 0 16px 32px color-mix(in srgb, var(--black) 18%, transparent);
  --shadow-1: 0 6px 14px color-mix(in srgb, var(--black) 10%, transparent);
  --shadow-2: 0 10px 24px color-mix(in srgb, var(--black) 14%, transparent);
  --shadow-hover: 0 12px 32px color-mix(in srgb, var(--black) 18%, transparent);
  --ring: 0 0 0 3px color-mix(in srgb, var(--accent) 28%, transparent);

  --footer-bg: var(--card);
  --footer-ink: var(--text);
  --footer-muted: var(--muted);
  --footer-border: var(--border);
  --footer-radius: 12px;
  --footer-shadow: 0 12px 28px color-mix(in srgb, var(--black) 10%, transparent);

  --gradient-start: color-mix(in srgb, var(--accent) 90%, var(--white) 10%);
  --gradient-end: color-mix(in srgb, var(--primary) 75%, var(--accent) 25%);

  --modalFeedback-bg: color-mix(in srgb, var(--black) 55%, transparent);
  --modalFeedback-radius: 12px;
  --modalFeedback-max-width: 640px;
  --calendarcalendarModal-bg: color-mix(in srgb, var(--black) 55%, transparent);
  --pdf-backdrop: color-mix(in srgb, var(--black) 72%, transparent);
  --pdf-chrome-h: 56px;
  --pdf-gap: 24px;
  --pdf-pad: 20px;
  --pdf-radius: 12px;
  --pdf-shadow: 0 20px 50px color-mix(in srgb, var(--black) 35%, transparent);
  --svg-w: 1200px;
  --svg-h: 600px;
  --value: 40%;

  --timeline-bg: var(--bg);
  --timeline-card: var(--card);
  --timeline-highlight: color-mix(in srgb, var(--accent) 16%, transparent);
  --timeline-line: color-mix(in srgb, var(--black) 10%, transparent);
  --timeline-dot-border: var(--accent);

  --tip-bg: var(--card);
  --tip-border: var(--border);
  --tip-ink: var(--text);
  --tip-muted: var(--muted);

  --status-ok-bg: #ecfdf5;
  --status-ok-border: #a7f3d0;
  --status-ok-text: #065f46;
  --status-warn-bg: #fff3cd;
  --status-warn-border: #fde68a;
  --status-warn-text: #856404;
  --status-err-bg: #fef2f2;
  --status-err-border: #fecaca;
  --status-err-text: #991b1b;

  --danger-soft-bg: #fef2f2;
  --danger-soft-border: #fecaca;
  --danger-soft-text: #7a1212;
  --warning-soft-bg: #fffbeb;
  --warning-soft-border: #fde68a;
  --warning-soft-text: #7a4c00;
  --success-soft-bg: #ecfdf5;
  --success-soft-border: #a7f3d0;
  --success-soft-text: #176b3a;

  --code-bg: #0f172a;
  --code-text: #e2e8f0;
  --code-border: #1e293b;
  --code-button-bg: #111827;
  --code-button-border: #334155;
  --code-button-text: #e5e7eb;
  --shimmer: #f6f7f8;
  --shine: #ededed;

  --tooltip-z: 50;
}

[data-theme="Day"] {
  --bg: #f7f7f9;
  --paper: #ffffff;
  --card: #ffffff;
  --surface-0: #ffffff;
  --surface-1: #f8f8fb;
  --surface-2: #f0f2f5;
  --surface-elevated: #ffffff;

  --text: #202020;
  --text-1: #2e2e2e;
  --text-2: #585858;
  --text-muted: #6b7280;
  --muted: #6b7280;
  --ink: #202020;
  --text-inverse: #ffffff;

  --accent: #1c78cf;
  --accent-color: var(--accent);
  --primary: #c00000;
  --primary-color: var(--primary);
  --border: color-mix(in srgb, var(--black) 12%, transparent);

  --success: #22c55e;
  --warning: #f59e0b;
  --danger: #ef4444;
  --info: #3b82f6;

  --btn-bg-main: #1c78cf;
  --btn-bg-primary: #155ea2;
  --btn-bg-secondary: #4b5563;
  --btn-bg-success: var(--success);
  --btn-bg-warning: var(--warning);
  --btn-bg-danger: var(--danger);
  --btn-bg-info: var(--info);
}

[data-theme="Ocean"] {
  --bg: #f2f7fa;
  --paper: #f8fbfd;
  --card: #ffffff;
  --surface-0: #f8fbfd;
  --surface-1: #ecf4f9;
  --surface-2: #ddeaf3;
  --surface-elevated: #ffffff;

  --text: #1f2a36;
  --text-1: #18222d;
  --text-2: #5c6b79;
  --text-muted: #768897;
  --muted: #768897;
  --ink: #1f2a36;
  --text-inverse: #ffffff;

  --accent: #0f7abf;
  --accent-color: var(--accent);
  --primary: #0a9ca4;
  --primary-color: var(--primary);
  --border: #c6d6e1;

  --success: #22b48c;
  --warning: #f5c35a;
  --danger: #d25a5a;
  --info: #3098dc;

  --btn-bg-main: #1086cc;
  --btn-bg-primary: #0f6ea8;
  --btn-bg-secondary: #41586f;
  --btn-bg-success: #22b48c;
  --btn-bg-warning: #f5c35a;
  --btn-bg-danger: #d25a5a;
  --btn-bg-info: #3098dc;

  --footer-bg: #ecf4f9;
  --footer-ink: #0f5aa0;
  --footer-muted: #7d90a0;
  --footer-border: #b4c8d6;
}

[data-theme="Night"] {
  --bg: #16181c;
  --paper: #1f2227;
  --card: #1c1f24;
  --surface-0: #1f2227;
  --surface-1: #242830;
  --surface-2: #2b3038;
  --surface-elevated: #242830;

  --text: #e6e8eb;
  --text-1: #f2f4f6;
  --text-2: #a5aab2;
  --text-muted: #8c929c;
  --muted: #8c929c;
  --ink: #e6e8eb;
  --text-inverse: #16181c;

  --accent: #78aaff;
  --accent-color: var(--accent);
  --primary: #d74646;
  --primary-color: var(--primary);
  --border: #3e424a;
  --bg-dropdown: color-mix(in srgb, var(--white) 5%, transparent);

  --success: #48ba70;
  --warning: #ffc542;
  --danger: #e85f5f;
  --info: #4696d7;

  --btn-bg-main: #38414d;
  --btn-bg-primary: #4a5566;
  --btn-bg-secondary: #313742;
  --btn-bg-success: #2f8f59;
  --btn-bg-warning: #d29a2f;
  --btn-bg-danger: #b84f4f;
  --btn-bg-info: #3b7cb3;

  --ring: 0 0 0 3px color-mix(in srgb, var(--accent) 24%, transparent);
  --shadow-s: 0 2px 8px color-mix(in srgb, var(--black) 42%, transparent);
  --shadow-m: 0 12px 28px color-mix(in srgb, var(--black) 48%, transparent);
  --shadow: 0 16px 32px color-mix(in srgb, var(--black) 52%, transparent);
  --shadow-1: 0 6px 14px color-mix(in srgb, var(--black) 40%, transparent);
  --shadow-2: 0 10px 24px color-mix(in srgb, var(--black) 50%, transparent);
  --shadow-hover: 0 12px 32px color-mix(in srgb, var(--black) 56%, transparent);

  --footer-bg: #1a1c20;
  --footer-ink: #b9cdff;
  --footer-muted: #878e9a;
  --footer-border: #464a54;
}
