/*
 * Generated no-dependency frontend CSS bundle.
 * Source owner files stay in frontend/styles.css and frontend/styles/**.
 * Regenerate with: node scripts/build-frontend-css-bundle.mjs
 */

/* bundled from styles.css */
/*
 * ROOT STYLESHEET CONTRACT
 *
 * This file is an import hub only.
 * Do not add selectors, media queries, route styles, or one-off overrides here.
 *
 * Add styles to the smallest owned stylesheet instead:
 * - ./styles/base.css for app primitives
 * - ./styles/components/*.css for reusable UI primitives
 * - ./styles/routes/*.css for user-facing route surfaces
 * - ./styles/admin/*.css for admin-owned route surfaces
 * - ./styles/equipment-picker.css for equipment picker surfaces
 */
/* bundled from styles/base.css */
/*
 * BASE STYLESHEET CONTRACT
 *
 * This file is an import hub for app primitives only.
 * Do not add route, feature, auth, or shell selectors here.
 */
/* bundled from styles/base/tokens.css */
:root {
  /* Brand palette */
  --color-brand-ku-crimson-900: #641a26;
  --color-brand-ku-crimson-800: #741f2d;
  --color-brand-ku-crimson-700: #862633;
  --color-brand-ku-crimson-100: #f7edf0;
  --color-brand-ku-crimson-150: #edd5dc;
  --color-brand-ku-crimson-200: #e4b8c1;
  --color-brand-ku-crimson-250: #d8aeb9;

  /* Neutral palette */
  --color-neutral-0: #ffffff;
  --color-neutral-25: #fffafb;
  --color-neutral-50: #f8f5f6;
  --color-neutral-75: #f3eff1;
  --color-neutral-100: #f1f1f2;
  --color-neutral-300: #e6dce0;
  --color-neutral-400: #d8c7cd;
  --color-neutral-600: #74666a;
  --color-neutral-700: #5f5558;
  --color-neutral-800: #3f3538;
  --color-neutral-900: #1d1719;

  /* Status palette */
  --color-state-green-700: #15803d;
  --color-state-green-650: #059669;
  --color-state-green-600: #16a34a;
  --color-state-green-100: #ecfdf5;
  --color-state-green-50: #f0fdf4;
  --color-state-green-200: #bbf7d0;
  --color-state-orange-700: #c2410c;
  --color-state-orange-650: #ea580c;
  --color-state-orange-600: #d97706;
  --color-state-orange-100: #ffedd5;
  --color-state-orange-50: #fff7ed;
  --color-state-orange-200: #fed7aa;
  --color-state-purple-700: #6d28d9;
  --color-state-purple-650: #7e22ce;
  --color-state-purple-100: #f3e8ff;
  --color-state-purple-50: #f5f3ff;
  --color-state-purple-200: #ddd6fe;
  --color-state-red-700: #be123c;
  --color-state-red-600: #dc2626;
  --color-state-red-50: #fff1f5;
  --color-state-red-75: #fff7f8;
  --color-state-red-100: #fef2f2;
  --color-state-red-150: #fee2e2;
  --color-state-red-200: #fecaca;
  --color-state-blue-600: #2563eb;
  --color-state-blue-700: #1d4ed8;
  --color-state-blue-100: #dbeafe;
  --color-state-blue-50: #eff6ff;
  --color-state-blue-200: #bfdbfe;
  --color-state-teal-700: #0f766e;
  --color-state-teal-50: #f7fbfa;
  --color-state-teal-200: #9bd3c7;

  /* Semantic surfaces, text, borders, actions, focus, and overlays */
  --color-bg-app: #f8f5f6;
  --color-bg-surface: #ffffff;
  --color-bg-surface-muted: #f3eff1;
  --color-bg-subtle: #fffafb;
  --color-text-primary: #1d1719;
  --color-text-body: #3f3538;
  --color-text-muted: #74666a;
  --color-text-on-action: #ffffff;
  --color-border-default: #e6dce0;
  --color-border-strong: #d8c7cd;
  --color-action-primary-bg: var(--color-brand-ku-crimson-700);
  --color-action-primary-hover: var(--color-brand-ku-crimson-800);
  --color-brand-tint-bg-subtle: rgba(151, 34, 52, 0.035);
  --color-brand-tint-bg: rgba(151, 34, 52, 0.06);
  --color-brand-tint-border: rgba(151, 34, 52, 0.32);
  --color-hover-neutral-bg: var(--color-bg-surface-muted);
  --color-hover-neutral-border: var(--color-border-strong);
  --color-focus-ring: var(--color-brand-ku-crimson-700);
  --color-focus-ring-soft: rgba(134, 38, 51, 0.16);
  --color-overlay-backdrop: rgba(29, 23, 25, 0.34);
  --color-role-renter-bg: var(--color-state-teal-50);
  --color-role-renter-border: var(--color-state-teal-200);
  --color-role-renter-text: var(--color-state-teal-700);
  --color-role-admin-bg: var(--color-state-blue-50);
  --color-role-admin-border: var(--color-state-blue-200);
  --color-role-admin-text: var(--color-state-blue-700);
  --color-role-owner-bg: var(--color-state-purple-50);
  --color-role-owner-border: var(--color-state-purple-200);
  --color-role-owner-text: var(--color-state-purple-700);

  /* App shell and fallback surfaces */
  --color-app-topbar-bg: rgba(255, 255, 255, 0.98);
  --color-startup-failure-bg: var(--color-route-surface-red-25);
  --color-startup-failure-border: #fecdd3;
  --color-startup-failure-text: var(--color-route-text-red-700);
  --color-diagnostic-panel-bg: rgba(255, 255, 255, 0.96);
  --color-diagnostic-panel-border: var(--color-route-text-red-800);
  --color-diagnostic-panel-text: var(--color-route-slate-800);
  --shadow-diagnostic-panel: 0 16px 40px rgba(15, 23, 42, 0.18);

  /* Admin and route semantic colors */
  --color-route-surface-soft-pink: #fbf8f9;
  --color-admin-tone-archive-bg: #f7f7f5;
  --color-admin-tone-archive-border: #d6d3cd;
  --color-admin-tone-archive-badge-bg: #ebe7e4;
  --color-admin-tone-archive-badge-text: var(--color-neutral-700);
  --color-admin-tone-settings-bg: #f7fbfa;
  --color-admin-tone-settings-border: #9bd3c7;
  --color-admin-tone-settings-accent: #0f766e;
  --color-admin-tone-settings-badge-bg: #ccfbf1;
  --color-admin-tone-settings-badge-text: #115e59;
  --color-settings-disclosure-border: rgba(222, 207, 214, 0.58);
  --color-settings-disclosure-bg: rgba(255, 250, 251, 0.42);
  --shadow-photo-thumb: 0 1px 3px rgba(68, 22, 32, 0.24);

  /* Equipment and admin info */
  --color-admin-info-text: #075985;
  --color-equipment-info-text: #1e3a8a;
  --color-admin-danger-border-dashed: #fca5a5;
  --color-equipment-card-muted-bg: #f4f2f3;
  --color-equipment-card-muted-text: #75696d;
  --color-overlay-scrim-strong: rgba(17, 17, 17, 0.42);
  --shadow-equipment-workstation-modal: 0 24px 80px rgba(31, 22, 25, 0.22);

  /* Rental and event summary */
  --color-rental-date-warning-text: #9f2a36;
  --shadow-chapter-summary-hover: 0 6px 18px rgba(15, 23, 42, 0.07);
  --color-event-summary-period-muted-text: #b7a8ae;
  --color-event-summary-period-label-text: #8f8087;
  --color-event-summary-weekday-text: #786b71;
  --color-event-summary-weekday-saturday-text: #2f6fd6;
  --color-event-summary-weekday-sunday-text: #c6542d;

  /* My rentals */
  --color-rental-row-selected-border: rgba(151, 34, 52, 0.3);
  --color-rental-row-active-bg: #f1e7eb;
  --color-rental-row-hover-bg: #f6f1f3;
  --color-rental-row-border-subtle: rgba(86, 58, 68, 0.14);
  --shadow-rental-detail-card: 0 16px 36px rgba(68, 22, 32, 0.14);
  --color-photo-success-soft-bg: #f8fffb;

  /* Calendar and notifications */
  --color-account-dashboard-focus-outline: rgba(156, 32, 50, 0.2);
  --color-calendar-disabled-day-bg: #fafafa;
  --color-calendar-conflict-warning-ring: rgba(217, 119, 6, 0.18);
  --color-calendar-toolbar-disabled-text: rgba(63, 53, 56, 0.32);
  --color-notification-type-default-bg: rgba(151, 36, 57, 0.1);
  --color-notification-type-approval-bg: rgba(37, 99, 235, 0.1);
  --color-notification-type-project-bg: rgba(124, 58, 237, 0.1);
  --color-notification-type-project-text: #7c3aed;
  --color-admin-members-soft-bg: #f4eff1;
  --shadow-admin-member-card: 0 1px 4px rgba(30, 20, 24, 0.08);
  --color-admin-filter-selected-border: rgba(154, 31, 55, 0.34);
  --color-focus-ring-faint: rgba(134, 38, 51, 0.1);
  --color-project-action-danger-border: #fecdd3;

  /* Migration aliases for legacy route/admin raw colors. */
  --color-route-surface-white: var(--color-neutral-0);
  --color-route-surface-warm: #fffdfd;
  --color-route-surface-pink-25: #fffbfd;
  --color-route-surface-pink-50: #fff7f9;
  --color-route-surface-pink-75: #fff4f6;
  --color-route-surface-red-25: #fff1f2;
  --color-route-surface-red-100: #ffe4e6;
  --color-route-surface-neutral-25: #faf7f8;
  --color-route-surface-neutral-50: #f7f2f4;
  --color-route-surface-neutral-75: #f7f2f3;
  --color-route-surface-neutral-100: #f7f7f7;
  --color-route-surface-slate-50: #f8fafc;
  --color-route-surface-slate-100: #f1f5f9;
  --color-route-surface-blue-25: #f4f9ff;
  --color-route-surface-indigo-50: #ede9fe;
  --color-route-surface-indigo-25: #f8f3ff;
  --color-route-surface-blue-50: #e0f2fe;
  --color-route-surface-green-100: #dcfce7;
  --color-route-surface-green-50: #ecfdf3;
  --color-route-surface-rose-100: #f0e8ec;
  --color-route-border-pink-100: #f4c2cc;
  --color-route-border-pink-150: #fecdd8;
  --color-route-border-pink-200: #ead4db;
  --color-route-border-neutral-100: #d7cfd3;
  --color-route-border-neutral-200: #d8dee7;
  --color-route-border-neutral-300: #d9dee5;
  --color-route-border-neutral-400: #c8d0da;
  --color-route-border-blue-200: #9cc9f5;
  --color-route-border-orange-200: #fdba74;
  --color-route-border-green-200: #86efac;
  --color-route-border-indigo-200: #c4b5fd;
  --color-route-text-red-700: #991b1b;
  --color-route-text-red-650: #b91c1c;
  --color-route-text-red-800: #9f1239;
  --color-route-text-orange-750: #b45309;
  --color-route-text-orange-800: #9a3412;
  --color-route-text-orange-900: #92400e;
  --color-route-text-green-700: #166534;
  --color-route-text-green-650: #047857;
  --color-route-text-indigo-700: #5b21b6;
  --color-route-text-blue-900: #1f3a5f;
  --color-route-text-neutral-850: #3f3a3d;
  --color-route-text-slate-700: #334155;
  --color-route-text-slate-400: #6b7280;
  --color-route-text-slate-200: #e5e7eb;
  --color-route-text-muted-500: #9d9297;
  --color-route-text-muted-600: #8a737b;
  --color-route-text-muted-700: #8f7d83;
  --color-route-border-danger: #be123c;
  --color-route-danger-bg: #e11d48;
  --color-route-warning-bg: #f59e0b;
  --color-route-neutral-line: #e5dce0;
  --color-route-slate-800: #1f2937;
  --color-route-slate-900: #111827;
  --color-route-slate-700: #374151;
  --color-route-slate-600: #4b5563;
  --color-route-slate-950: #0f172a;
  --color-route-mask-solid: #000;
  --color-route-overlay-deep: rgba(43, 24, 32, 0.32);
  --color-route-overlay-modal: rgba(29, 23, 25, 0.36);
  --color-route-shadow-modal-strong: rgba(29, 23, 25, 0.24);
  --color-route-shadow-admin: rgba(68, 22, 32, 0.16);
  --color-route-shadow-admin-soft: rgba(68, 22, 32, 0.12);
  --color-route-shadow-admin-faint: rgba(68, 22, 32, 0.1);
  --color-route-shadow-admin-subtle: rgba(68, 22, 32, 0.08);
  --color-route-shadow-admin-micro: rgba(68, 22, 32, 0.06);
  --color-route-shadow-admin-hairline: rgba(68, 22, 32, 0.04);
  --color-route-shadow-neutral: rgba(45, 31, 38, 0.24);
  --color-route-shadow-calendar: rgba(46, 22, 28, 0.14);
  --color-route-shadow-picker: rgba(28, 21, 24, 0.14);
  --color-route-shadow-picker-strong: rgba(28, 21, 24, 0.18);
  --color-route-shadow-page: rgba(15, 23, 42, 0.08);
  --color-route-brand-tint-035: rgba(151, 34, 52, 0.035);
  --color-route-brand-tint-06: rgba(151, 34, 52, 0.06);
  --color-route-brand-tint-08: rgba(151, 34, 52, 0.08);
  --color-route-brand-tint-12: rgba(151, 34, 52, 0.12);
  --color-route-brand-tint-14: rgba(134, 38, 51, 0.14);
  --color-route-brand-tint-16: rgba(134, 38, 51, 0.16);
  --color-route-brand-tint-22: rgba(134, 38, 51, 0.22);
  --color-route-brand-tint-24: rgba(134, 38, 51, 0.24);
  --color-route-brand-tint-28: rgba(151, 28, 47, 0.28);
  --color-route-brand-tint-32: rgba(151, 34, 52, 0.32);
  --color-route-brand-tint-34: rgba(151, 34, 52, 0.34);
  --color-route-brand-tint-36: rgba(151, 34, 52, 0.36);
  --color-route-brand-tint-42: rgba(151, 34, 52, 0.42);
  --color-route-brand-tint-45: rgba(151, 34, 52, 0.45);
  --color-route-brand-tint-48: rgba(151, 28, 47, 0.48);
  --color-route-brand-alt-tint-08: rgba(151, 28, 47, 0.08);
  --color-route-brand-alt-tint-12: rgba(151, 28, 47, 0.12);
  --color-route-brand-alt-tint-20: rgba(151, 28, 47, 0.2);
  --color-route-brand-alt-tint-22: rgba(151, 28, 47, 0.22);
  --color-route-brand-alt-tint-42: rgba(151, 36, 55, 0.42);
  --color-route-brand-alt-tint-32: rgba(151, 36, 55, 0.32);
  --color-route-green-tint-42: rgba(22, 163, 74, 0.42);
  --color-route-green-tint-55: rgba(22, 163, 74, 0.55);
  --color-route-neutral-tint-10: rgba(68, 61, 65, 0.1);
  --color-route-neutral-tint-16: rgba(86, 58, 68, 0.16);
  --color-route-surface-glass: rgba(255, 255, 255, 0.78);
  --color-route-surface-glass-soft: rgba(255, 255, 255, 0.62);
  --color-route-surface-frosted: rgba(248, 246, 247, 0.54);
  --color-route-surface-slate-glass: rgba(248, 250, 252, 0.72);

  /* Semantic status colors */
  --color-state-info-bg: var(--color-state-blue-50);
  --color-state-info-border: var(--color-state-blue-200);
  --color-state-info-text: var(--color-state-blue-600);
  --color-state-warning-bg: var(--color-state-orange-50);
  --color-state-warning-border: var(--color-state-orange-200);
  --color-state-warning-text: var(--color-state-orange-700);
  --color-state-success-bg: var(--color-state-green-50);
  --color-state-success-border: var(--color-state-green-200);
  --color-state-success-text: var(--color-state-green-650);
  --color-state-danger-bg: var(--color-state-red-100);
  --color-state-danger-border: var(--color-state-red-200);
  --color-state-danger-text: var(--color-state-red-600);
  --color-status-reserved-bg: var(--color-state-blue-50);
  --color-status-reserved-border: var(--color-state-blue-200);
  --color-status-reserved-text: var(--color-state-blue-600);
  --color-status-checkout-bg: var(--color-state-orange-50);
  --color-status-checkout-border: var(--color-state-orange-200);
  --color-status-checkout-text: var(--color-state-orange-700);
  --color-status-return-bg: var(--color-state-purple-50);
  --color-status-return-border: var(--color-state-purple-200);
  --color-status-return-text: var(--color-state-purple-700);
  --color-status-active-bg: var(--color-state-green-50);
  --color-status-active-border: var(--color-state-green-200);
  --color-status-active-text: var(--color-state-green-700);
  --color-status-approval-bg: var(--color-state-red-50);
  --color-status-approval-border: var(--color-state-red-200);
  --color-status-approval-text: var(--color-state-red-700);
  --color-status-neutral-bg: var(--color-neutral-100);
  --color-status-neutral-border: var(--color-neutral-400);
  --color-status-neutral-text: var(--color-neutral-800);

  /* Typography */
  --font-family-sans: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-size-xs: 11px;
  --font-size-sm: 12px;
  --font-size-md: 13px;
  --font-size-lg: 14px;
  --font-size-xl: 16px;
  --font-size-2xl: 18px;
  --font-size-3xl: 22px;
  --font-size-title-sm: 20px;
  --font-size-title-md: var(--font-size-3xl);
  --font-size-title-lg: 24px;
  --line-height-tight: 1.1;
  --line-height-snug: 1.2;
  --line-height-normal: 1.45;
  --line-height-relaxed: 1.6;
  --font-weight-regular: 400;
  --font-weight-medium: 700;
  --font-weight-strong: 800;
  --font-weight-emphasis: 850;

  /* Spacing */
  --space-0: 0;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-7: 28px;
  --space-8: 32px;
  --space-9: 36px;
  --space-10: 40px;
  --space-12: 48px;
  --space-14: 56px;
  --space-16: 64px;
  --space-control-gap: 10px;
  --space-panel-gap-sm: 10px;
  --space-panel-gap-md: 14px;
  --space-panel-padding-sm: 10px;
  --space-panel-padding-md: 14px;
  --space-account-layout-padding: var(--space-4);
  --space-account-layout-gap: var(--space-3);
  --space-account-card-padding: var(--space-panel-padding-md);
  --space-account-card-gap: var(--space-3);
  --space-project-section-gap: var(--space-3);
  --space-project-panel-gap: var(--space-panel-gap-sm);
  --space-project-modal-gap: var(--space-panel-gap-md);
  --space-project-modal-padding: 18px 20px 20px;
  --space-project-directory-row-margin: 0 0 10px 14px;
  --space-project-directory-row-padding: 10px 12px 10px 14px;
  --space-event-summary-grid-gap: var(--space-3);
  --space-event-summary-card-padding: var(--space-3);
  --space-event-summary-section-padding: var(--space-panel-padding-sm);
  --space-photo-flow-card-padding: 11px;
  --space-photo-flow-card-gap: var(--space-panel-gap-sm);
  --space-photo-step-summary-padding: 11px 12px;
  --space-photo-step-summary-gap: 9px;
  --space-photo-row-padding: 7px;
  --space-photo-row-gap: var(--space-2);
  --space-photo-action-gap: 9px;
  --space-photo-proof-padding: var(--space-2);
  --space-photo-upload-row-padding: var(--space-panel-padding-sm);

  /* Radius */
  --radius-0: 0;
  --radius-1: 4px;
  --radius-2: 6px;
  --radius-3: 8px;
  --radius-4: 10px;
  --radius-5: 12px;
  --radius-control: 8px;
  --radius-control-small: 7px;
  --radius-panel: 8px;
  --radius-sm: var(--radius-2);
  --radius-pill: 999px;

  /* Component sizing and rhythm */
  --control-padding-block-compact: var(--space-0);
  --control-padding-inline-compact: var(--space-3);
  --control-height-compact: 30px;
  --control-height-filter: 32px;
  --control-height-small: 34px;
  --control-height-search: 38px;
  --control-size-icon-sm: var(--control-height-compact);
  --control-size-icon-filter: var(--control-height-filter);
  --control-size-icon-compact: var(--control-height-small);
  --control-size-icon-md: var(--control-height-search);
  --control-size-floating: var(--space-14);
  --control-search-radius: var(--radius-control-small);
  --button-radius: var(--radius-control);
  --chip-radius: var(--radius-control-small);
  --modal-panel-radius: var(--radius-panel);
  --field-radius: var(--radius-control);
  --field-focus-ring: var(--color-focus-ring-soft);
  --filter-bar-radius: var(--radius-panel);
  --state-block-radius: var(--radius-control);
  --icon-size-sm: 16px;
  --icon-size-md: 18px;
  --icon-size-lg: 20px;
  --row-height-compact: 42px;
  --row-height-regular: 48px;
  --filter-chip-gap: 6px;
  --filter-chip-icon-size: 15px;
  --sort-toggle-gap: 7px;
  --status-chip-padding-block: var(--space-1);
  --status-chip-padding-inline: 7px;
  --status-chip-min-height: 24px;
  --status-chip-radius: var(--radius-control-small);
  --count-badge-padding-block: 2px;
  --count-badge-padding-inline: 7px;
  --count-badge-radius: var(--radius-pill);
  --preview-panel-gap: var(--space-3);
  --preview-row-gap: var(--space-3);
  --preview-row-padding-block: 14px;
  --preview-row-padding-inline: var(--space-3);
  --preview-row-min-height: 68px;
  --preview-row-hover-bg: var(--color-hover-neutral-bg);
  --control-hover-bg: var(--color-hover-neutral-bg);

  /* Elevation */
  --shadow-0: none;
  --shadow-control: 0 1px 2px rgba(15, 23, 42, 0.08);
  --shadow-modal: 0 18px 44px rgba(68, 22, 32, 0.16);
  --shadow-panel-raised: 0 12px 26px rgba(29, 23, 25, 0.08);
  --shadow-panel-hover: 0 10px 22px rgba(68, 22, 32, 0.08);
  --shadow-resource-card-hover: 0 8px 20px rgba(68, 22, 32, 0.08);

  /* Dashboard and attention tokens */
  --color-dashboard-metric-blue-bg: var(--color-state-blue-100);
  --color-dashboard-metric-blue-text: var(--color-state-blue-600);
  --color-dashboard-metric-orange-bg: var(--color-state-orange-100);
  --color-dashboard-metric-orange-text: var(--color-state-orange-650);
  --color-dashboard-metric-approval-bg: var(--color-status-approval-bg);
  --color-dashboard-metric-approval-text: var(--color-status-approval-text);
  --color-dashboard-metric-danger-bg: var(--color-state-red-150);
  --color-dashboard-metric-danger-text: var(--color-state-red-600);
  --color-dashboard-metric-purple-bg: var(--color-dashboard-metric-approval-bg);
  --color-dashboard-metric-purple-text: var(--color-dashboard-metric-approval-text);
  --color-dashboard-metric-red-bg: var(--color-dashboard-metric-danger-bg);
  --color-dashboard-metric-red-text: var(--color-dashboard-metric-danger-text);
  --color-attention-dot-bg: var(--color-state-red-600);
  --color-attention-dot-ring: rgba(220, 38, 38, 0.1);
  --color-resource-disabled-bg: var(--color-neutral-75);
  --color-equipment-thumb-bg: var(--color-neutral-25);
  --equipment-thumb-empty-bg:
    linear-gradient(135deg, rgba(36, 25, 29, 0.04), rgba(255, 255, 255, 0.88)),
    var(--color-equipment-thumb-bg);

  /* Legacy compatibility aliases. Prefer semantic/component tokens for new work. */
  --ku-crimson: var(--color-brand-ku-crimson-700);
  --ku-crimson-dark: var(--color-brand-ku-crimson-900);
  --ku-crimson-hover: var(--color-brand-ku-crimson-800);
  --ku-crimson-soft: var(--color-brand-ku-crimson-100);
  --ku-crimson-soft-strong: var(--color-brand-ku-crimson-150);
  --ku-crimson-border: var(--color-brand-ku-crimson-250);
  --canvas: var(--color-bg-app);
  --surface: var(--color-bg-surface);
  --surface-muted: var(--color-bg-surface-muted);
  --ink: var(--color-text-primary);
  --body: var(--color-text-body);
  --muted: var(--color-text-muted);
  --hairline: var(--color-border-default);
  --hairline-strong: var(--color-border-strong);
  --primary: var(--color-action-primary-bg);
  --primary-hover: var(--color-action-primary-hover);
  --focus: var(--color-focus-ring);
  --available: var(--color-state-green-600);
  --photo-needed: var(--color-state-orange-600);
  --return-photo-needed: var(--color-status-return-text);
  --weekend-sunday: var(--color-state-orange-700);
  --weekend-saturday: var(--color-state-blue-600);

  /* Route sizing and responsive source policy */
  --calendar-side-panel-width: 430px;
  --calendar-side-panel-min-width: 408px;
  --calendar-side-panel-max-width: 680px;
  --calendar-main-min-width: 448px;
  --content-max-width-operational: 1200px;
  --content-max-width-readable: 1180px;
  --danger: var(--color-state-red-600);
  --archive: var(--color-neutral-700);
  --calendar-selected-border: var(--color-action-primary-hover);
  --shadow: 0 1px 2px rgba(68, 22, 32, 0.04);

  /* Motion */
  --motion-fast: 140ms;
  --motion-micro: 160ms;
  --motion-control: 180ms;
  --motion-base: 220ms;
  --motion-panel-slide: 300ms;
  --motion-calendar-pulse: 300ms;
  --motion-calendar-fade: 360ms;
  --motion-photo-step-enter: 420ms;
  --motion-photo-step-track: 520ms;
  --motion-photo-step-fade: 360ms;
  --motion-slow: 460ms;
  --motion-ease: cubic-bezier(0.45, 0, 0.25, 1);
  --motion-spring-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --motion-sidebar-ease: cubic-bezier(0.2, 0.8, 0.2, 1);
  --motion-sidebar-label-delay: 45ms;

  /* Scrollbars */
  --scrollbar-size: 5px;
  --scrollbar-thumb: rgba(92, 85, 89, 0.24);
  --scrollbar-thumb-hover: rgba(92, 85, 89, 0.36);
  --scrollbar-track: transparent;

  /* Responsive source policy: mobile <=520, tablet 521-1023, desktop source >=1024. */
  --source-mobile-max: 520px;
  --source-tablet-min: 521px;
  --source-desktop-min: 1024px;
  --topbar-height-desktop: 58px;
  --topbar-height-wide-tablet: 64px;
  --topbar-height-tablet: 56px;
  --topbar-height-mobile: 52px;
  --topbar-brand-mark-desktop: 36px;
  --topbar-brand-mark-wide-tablet: 40px;
  --topbar-brand-mark-tablet: 36px;
  --topbar-brand-mark-mobile: 34px;
  font-family: var(--font-family-sans);
  font-synthesis: none;
  color: var(--ink);
  background: var(--canvas);
}

/* bundled from styles/base/reset.css */
* {
  box-sizing: border-box;
}

body {
  min-width: 320px;
  margin: 0;
  background: var(--canvas);
  color: var(--body);
  overflow-x: hidden;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

button,
input,
textarea {
  font: inherit;
}

button {
  cursor: pointer;
}

button:disabled,
input:disabled {
  cursor: not-allowed;
  opacity: 0.58;
}

/* bundled from styles/base/scrollbars.css */
:where(
  .workspace,
  .resource-list,
  .calendar-surface,
  .calendar-side-panel,
  .project-modal-panel .project-management-list,
  .ledger-card,
  .compact-resource-list,
  .rental-drawer,
  .side-rental-form,
  .modal-submit-column .selection-summary,
  .day-timeline,
  .event-summary-body,
  .side-resource-list,
  .profile-settings-view,
  .profile-menu,
  .project-choice-list,
  .my-rentals-project-list,
  .desktop-upcoming-rental-list,
  .workspace.is-admin-shell .admin-review-list,
  .workspace.is-admin-shell .equipment-admin-list,
  .workspace.is-admin-shell .member-approval-list,
  .workspace.is-admin-shell .member-admin-list,
  .workspace.is-admin-shell .violation-case-grid
) {
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

:where(
  .workspace,
  .resource-list,
  .calendar-surface,
  .calendar-side-panel,
  .project-modal-panel .project-management-list,
  .ledger-card,
  .compact-resource-list,
  .rental-drawer,
  .side-rental-form,
  .modal-submit-column .selection-summary,
  .day-timeline,
  .event-summary-body,
  .side-resource-list,
  .profile-settings-view,
  .profile-menu,
  .project-choice-list,
  .my-rentals-project-list,
  .desktop-upcoming-rental-list,
  .workspace.is-admin-shell .admin-review-list,
  .workspace.is-admin-shell .equipment-admin-list,
  .workspace.is-admin-shell .member-approval-list,
  .workspace.is-admin-shell .member-admin-list,
  .workspace.is-admin-shell .violation-case-grid
)::-webkit-scrollbar {
  width: var(--scrollbar-size);
  height: var(--scrollbar-size);
}

:where(
  .workspace,
  .resource-list,
  .calendar-surface,
  .calendar-side-panel,
  .project-modal-panel .project-management-list,
  .ledger-card,
  .compact-resource-list,
  .rental-drawer,
  .side-rental-form,
  .modal-submit-column .selection-summary,
  .day-timeline,
  .event-summary-body,
  .side-resource-list,
  .profile-settings-view,
  .profile-menu,
  .project-choice-list,
  .my-rentals-project-list,
  .desktop-upcoming-rental-list,
  .workspace.is-admin-shell .admin-review-list,
  .workspace.is-admin-shell .equipment-admin-list,
  .workspace.is-admin-shell .member-approval-list,
  .workspace.is-admin-shell .member-admin-list,
  .workspace.is-admin-shell .violation-case-grid
)::-webkit-scrollbar-track {
  background: var(--scrollbar-track);
}

:where(
  .workspace,
  .resource-list,
  .calendar-surface,
  .calendar-side-panel,
  .project-modal-panel .project-management-list,
  .ledger-card,
  .compact-resource-list,
  .rental-drawer,
  .side-rental-form,
  .modal-submit-column .selection-summary,
  .day-timeline,
  .event-summary-body,
  .side-resource-list,
  .profile-settings-view,
  .profile-menu,
  .project-choice-list,
  .my-rentals-project-list,
  .desktop-upcoming-rental-list,
  .workspace.is-admin-shell .admin-review-list,
  .workspace.is-admin-shell .equipment-admin-list,
  .workspace.is-admin-shell .member-approval-list,
  .workspace.is-admin-shell .member-admin-list,
  .workspace.is-admin-shell .violation-case-grid
)::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: 999px;
}

:where(
  .workspace,
  .resource-list,
  .calendar-surface,
  .calendar-side-panel,
  .project-modal-panel .project-management-list,
  .ledger-card,
  .compact-resource-list,
  .rental-drawer,
  .side-rental-form,
  .modal-submit-column .selection-summary,
  .day-timeline,
  .event-summary-body,
  .side-resource-list,
  .profile-settings-view,
  .profile-menu,
  .project-choice-list,
  .my-rentals-project-list,
  .desktop-upcoming-rental-list,
  .workspace.is-admin-shell .admin-review-list,
  .workspace.is-admin-shell .equipment-admin-list,
  .workspace.is-admin-shell .member-approval-list,
  .workspace.is-admin-shell .member-admin-list,
  .workspace.is-admin-shell .violation-case-grid
)::-webkit-scrollbar-thumb:hover {
  background: var(--scrollbar-thumb-hover);
}

/* bundled from styles/auth.css */
.is-auth-checking .auth-screen,
.is-auth-checking .app-shell {
  display: none;
}

.is-auth-gated .app-shell {
  display: none;
}

.is-authenticated .auth-screen {
  display: none;
}

.auth-screen {
  min-height: 100vh;
  padding: 24px;
  background: var(--canvas);
  display: grid;
  place-items: center;
}

.auth-layout {
  width: min(1160px, 100%);
  min-height: min(720px, calc(100dvh - 48px));
  border: 1px solid var(--hairline);
  border-radius: 8px;
  background: var(--surface);
  display: grid;
  grid-template-columns: minmax(320px, 0.92fr) minmax(360px, 1fr);
  grid-template-areas: "product auth";
  overflow: hidden;
  box-shadow: var(--shadow);
}

.auth-product-panel {
  grid-area: product;
  border-right: 1px solid var(--hairline);
  background: var(--surface-muted);
  padding: 22px;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 20px;
}

.auth-brand {
  align-items: center;
}

.auth-brand .brand-mark + div {
  min-height: var(--topbar-brand-mark-desktop);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.auth-brand .brand-title {
  line-height: 1;
}

.auth-brand .brand-subtitle {
  margin-top: 0;
  line-height: 1;
}

.auth-route-map {
  display: grid;
  align-content: center;
  min-height: 400px;
}

.auth-guide-carousel {
  border: 1px solid var(--hairline);
  border-radius: 8px;
  background: var(--surface);
  min-height: 360px;
  padding: 18px;
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 14px;
}

.auth-guide-slide {
  min-height: 270px;
  display: grid;
  align-content: center;
  gap: 14px;
}

.auth-guide-step strong,
.auth-pending-panel strong {
  display: block;
  color: var(--ink);
  font-size: 22px;
  line-height: 1.35;
}

.auth-guide-step p,
.auth-copy p,
.auth-pending-panel p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}

.auth-guide-step p {
  font-weight: var(--font-weight-medium);
  line-height: 1.65;
}

.auth-guide-list {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
  list-style: none;
}

.auth-guide-list li {
  border: 1px solid var(--hairline);
  border-radius: 8px;
  background: var(--color-bg-subtle);
  color: var(--body);
  padding: 9px 10px;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.35;
}

.auth-guide-controls {
  border-top: 1px solid var(--hairline);
  padding-top: 12px;
  display: grid;
  grid-template-columns: 34px 1fr 34px;
  align-items: center;
  gap: 10px;
}

.auth-guide-nav {
  width: 34px;
  height: 34px;
}

.auth-guide-dots {
  display: flex;
  justify-content: center;
  gap: 7px;
}

.auth-guide-dot {
  width: 8px;
  height: 8px;
  border: 0;
  border-radius: 999px;
  background: var(--hairline-strong);
  padding: 0;
}

.auth-guide-dot.is-active {
  width: 22px;
  background: var(--primary);
}

.auth-panel {
  grid-area: auth;
  padding: 28px;
  display: grid;
  align-content: center;
  gap: 18px;
}

.auth-character-strip {
  margin: 0 auto 2px;
  width: min(100%, 520px);
  display: grid;
  justify-items: center;
}

.auth-character-strip img {
  display: block;
  width: 100%;
  max-height: 98px;
  object-fit: contain;
}

.auth-mode-tabs.ui-segmented-switch {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 3px;
  padding: 3px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-control);
  background: var(--surface-muted);
}

.auth-mode-tabs.ui-segmented-switch::before {
  border-radius: calc(var(--radius-control) - 3px);
}

.auth-mode-tabs.ui-segmented-switch .auth-mode-button {
  min-height: 34px;
  border-radius: calc(var(--radius-control) - 3px);
  font-size: 13px;
  font-weight: 800;
}

.auth-mode-tabs.ui-segmented-switch .auth-mode-button.is-active {
  color: var(--ink);
}

.auth-form {
  display: grid;
  gap: 16px;
}

.auth-form.is-signup-form {
  margin-top: -4px;
}

.auth-copy h1 {
  margin: 3px 0 0;
  color: var(--ink);
  font-size: 28px;
  line-height: 1.2;
}

.auth-fields {
  display: grid;
  gap: 12px;
}

.signup-onboarding-flow {
  display: grid;
  gap: 14px;
  min-height: 0;
}

.signup-step-frame {
  min-height: 0;
  display: grid;
}

.signup-onboarding-flow.is-step-forward .signup-step-frame {
  animation: signupStepForward var(--motion-base) ease-out both;
}

.signup-onboarding-flow.is-step-backward .signup-step-frame {
  animation: signupStepBackward var(--motion-base) ease-out both;
}

.signup-onboarding-flow.is-step-forward .signup-step-indicator .is-active .rental-step-bead,
.signup-onboarding-flow.is-step-backward .signup-step-indicator .is-active .rental-step-bead {
  animation: signupStepBeadSettle var(--motion-base) ease-out both;
}

.signup-onboarding-flow.is-signup-entering .signup-step-indicator,
.signup-onboarding-flow.is-signup-entering .signup-field-grid,
.signup-onboarding-flow.is-signup-entering .signup-department-field,
.signup-onboarding-flow.is-signup-entering .signup-step-actions {
  animation: signupEnterItemRise var(--motion-control) var(--motion-ease) both;
}

.signup-onboarding-flow.is-signup-entering .signup-step-indicator {
  animation-delay: 0ms;
}

.signup-onboarding-flow.is-signup-entering .signup-field-grid.is-primary {
  animation-delay: 28ms;
}

.signup-onboarding-flow.is-signup-entering .signup-field-grid.is-compact {
  animation-delay: 56ms;
}

.signup-onboarding-flow.is-signup-entering .signup-department-field {
  animation-delay: 84ms;
}

.signup-onboarding-flow.is-signup-entering .signup-step-actions {
  animation-delay: 112ms;
}

.signup-onboarding-step {
  border: 1px solid var(--hairline);
  border-radius: 8px;
  background: var(--color-bg-subtle);
  padding: 12px;
  display: grid;
  gap: 10px;
}

.signup-onboarding-step.is-submit-step {
  background: var(--surface);
}

.signup-onboarding-step-head {
  display: grid;
  gap: 10px;
  align-items: start;
}

.signup-profile-form {
  display: grid;
  gap: 14px;
}

.signup-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 12px;
}

.signup-field {
  position: relative;
  display: grid;
  gap: 6px;
  min-width: 0;
}

.signup-field-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin: 0;
  color: var(--body);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  line-height: 1.25;
}

.signup-required-dot {
  width: 5px;
  height: 5px;
  border-radius: var(--radius-pill);
  background: var(--primary);
  box-shadow: 0 0 0 2px var(--ku-crimson-soft);
  flex: 0 0 auto;
}

.signup-field .input {
  min-height: 42px;
  border-radius: 7px;
  padding: 0 12px;
  font-size: var(--font-size-md);
  font-weight: 800;
}

.signup-field .input::placeholder {
  color: var(--muted);
  font-weight: 700;
}

.signup-phone-input-wrap {
  position: relative;
  display: block;
}

.signup-phone-suffix-hint {
  position: absolute;
  left: calc(12px + 3ch);
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  font-size: var(--font-size-md);
  font-weight: 800;
  line-height: 1;
  pointer-events: none;
}

.signup-phone-input-wrap:not(.is-prefix-seeded) .signup-phone-suffix-hint {
  display: none;
}

.signup-field.is-suffix-field::after {
  content: attr(data-suffix);
  position: absolute;
  right: 12px;
  bottom: 12px;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  line-height: 1;
  pointer-events: none;
}

.signup-field.is-suffix-field .input {
  padding-right: 48px;
}

.signup-department-field {
  min-width: 0;
  border: 0;
  padding: 0;
  margin: 0;
}

.signup-department-field > legend.signup-field-label {
  padding: 0;
}

.signup-department-options {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
}

.signup-department-choice {
  position: relative;
  display: inline-flex;
  min-width: 0;
}

.signup-department-radio {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

.signup-department-choice > span {
  min-height: 34px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--surface);
  padding: 0 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--body);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  line-height: 1;
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease);
}

.signup-department-choice.is-selected > span,
.signup-department-radio:checked + span {
  border-color: var(--ku-crimson-border);
  background: var(--ku-crimson-soft);
  color: var(--primary);
}

.signup-department-choice:focus-within > span {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--field-focus-ring);
}

.signup-step-indicator {
  --signup-step-c1: 72px;
  --signup-step-c2: 72px;
  display: flex;
  align-items: center;
  min-height: 30px;
}

.signup-step-indicator[data-stepper-step="review"] {
  --signup-step-c1: 34px;
  --signup-step-c2: 86px;
}

.signup-step-indicator[data-stepper-step="google"],
.signup-step-indicator[data-stepper-step="complete"] {
  --signup-step-c1: 34px;
  --signup-step-c2: 34px;
}

.signup-step-indicator-content {
  justify-content: flex-start;
  width: 100%;
}

.signup-step-indicator .rental-step-chip.is-active em {
  max-width: 92px;
}

.signup-step-indicator .rental-step-connector[data-rental-step-connector="1"] {
  --connector-size: var(--signup-step-c1);
}

.signup-step-indicator .rental-step-connector[data-rental-step-connector="2"] {
  --connector-size: var(--signup-step-c2);
}

.signup-step-indicator .rental-step-chip.is-complete .rental-step-bead {
  border-color: var(--ku-crimson-border);
  background: var(--ku-crimson-soft);
  color: var(--primary);
}

.signup-step-indicator .rental-step-chip.is-active .rental-step-bead {
  border-color: var(--primary);
  background: var(--primary);
  color: var(--color-text-on-action);
}

.signup-google-identity-note {
  border: 1px solid var(--color-state-green-200);
  border-radius: 8px;
  background: var(--color-state-green-50);
  color: var(--available);
  padding: 9px 10px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  font-size: 13px;
  font-weight: 800;
}

.signup-onboarding-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.signup-submit-summary {
  border: 1px solid var(--color-state-green-200);
  border-radius: 8px;
  background: var(--color-state-green-50);
  color: var(--available);
  padding: 12px;
  display: grid;
  gap: 4px;
  font-size: 13px;
}

.signup-submit-summary.is-error {
  border-color: var(--color-danger-200, #fecaca);
  background: var(--color-danger-50, #fef2f2);
  color: var(--danger);
}

.signup-review-panel {
  display: grid;
  gap: 10px;
}

.signup-review-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.signup-onboarding-flow.is-step-forward .signup-review-item,
.signup-onboarding-flow.is-step-forward .signup-submit-summary {
  animation: signupReviewItemRise var(--motion-control) ease-out both;
}

.signup-onboarding-flow.is-step-forward .signup-review-item:nth-child(2) {
  animation-delay: 24ms;
}

.signup-onboarding-flow.is-step-forward .signup-review-item:nth-child(3) {
  animation-delay: 48ms;
}

.signup-onboarding-flow.is-step-forward .signup-review-item:nth-child(4) {
  animation-delay: 72ms;
}

.signup-onboarding-flow.is-step-forward .signup-review-item:nth-child(4),
.signup-onboarding-flow.is-step-forward .signup-submit-summary {
  animation-delay: 96ms;
}

@keyframes signupStepForward {
  from {
    opacity: 0;
    transform: translateX(12px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes signupStepBackward {
  from {
    opacity: 0;
    transform: translateX(-12px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes signupStepBeadSettle {
  0% {
    transform: scale(0.86);
  }

  70% {
    transform: scale(1.08);
  }

  100% {
    transform: scale(1);
  }
}

@keyframes signupReviewItemRise {
  from {
    opacity: 0;
    transform: translateY(7px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes signupEnterItemRise {
  from {
    opacity: 0;
    transform: translateY(6px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .signup-onboarding-flow.is-step-forward .signup-step-frame,
  .signup-onboarding-flow.is-step-backward .signup-step-frame,
  .signup-onboarding-flow.is-step-forward .signup-step-indicator .is-active .rental-step-bead,
  .signup-onboarding-flow.is-step-backward .signup-step-indicator .is-active .rental-step-bead,
  .signup-onboarding-flow.is-step-forward .signup-review-item,
  .signup-onboarding-flow.is-step-forward .signup-submit-summary,
  .signup-onboarding-flow.is-signup-entering .signup-step-indicator,
  .signup-onboarding-flow.is-signup-entering .signup-field-grid,
  .signup-onboarding-flow.is-signup-entering .signup-department-field,
  .signup-onboarding-flow.is-signup-entering .signup-step-actions {
    animation: none;
  }
}

@media (max-width: 720px) {
  .signup-field-grid {
    grid-template-columns: 1fr;
  }
}

.signup-review-item {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: 8px;
  background: var(--surface);
  padding: 14px 16px;
  display: grid;
  align-content: center;
  min-height: 70px;
}

.signup-review-item strong {
  margin: 0;
  color: var(--ink);
  font-size: 15px;
  font-weight: 800;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.signup-step-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.3fr);
  gap: 8px;
}

.signup-step-actions.is-first-step {
  grid-template-columns: 1fr;
}

.signup-step-actions.is-submit-only {
  grid-template-columns: 1fr;
}

.auth-textarea {
  min-height: 92px;
  resize: vertical;
}

.auth-notice,
.oauth-login-panel,
.auth-pending-panel {
  border: 1px solid var(--hairline);
  border-radius: 8px;
  background: var(--color-bg-subtle);
  padding: 12px;
  display: grid;
  gap: 5px;
}

.auth-pending-panel.is-rejected,
.auth-pending-panel.is-waiting {
  position: relative;
  padding: 16px;
  padding-top: 18px;
}

.auth-pending-panel.is-rejected .status-chip,
.auth-pending-panel.is-waiting .status-chip {
  position: absolute;
  top: 12px;
  right: 12px;
}

.auth-pending-panel.is-waiting .auth-pending-status-chip {
  border-color: var(--color-state-warning-border);
  background: var(--color-state-warning-bg);
  color: var(--color-state-warning-text);
}

.auth-pending-panel.is-rejected .auth-rejected-title {
  display: flex;
  align-items: center;
  gap: 7px;
  color: var(--ink);
}

.auth-pending-panel.is-waiting .auth-pending-title {
  display: flex;
  align-items: center;
  gap: 7px;
  color: var(--ink);
}

.auth-pending-panel.is-rejected .auth-rejected-title svg,
.auth-pending-panel.is-rejected .auth-rejected-title i,
.auth-pending-panel.is-waiting .auth-pending-title svg,
.auth-pending-panel.is-waiting .auth-pending-title i {
  width: 20px;
  height: 20px;
  flex: 0 0 auto;
}

.auth-pending-panel.is-rejected .auth-rejected-title svg,
.auth-pending-panel.is-rejected .auth-rejected-title i {
  color: var(--color-state-orange-600);
  stroke-width: 2.4;
}

.auth-pending-panel.is-waiting .auth-pending-title svg,
.auth-pending-panel.is-waiting .auth-pending-title i {
  color: var(--color-state-success-text);
  stroke-width: 2.5;
}

.auth-pending-panel.is-rejected strong,
.auth-pending-panel.is-waiting strong {
  padding-right: 82px;
  font-size: 20px;
}

.auth-pending-panel.is-rejected p,
.auth-pending-panel.is-waiting p {
  margin-top: 7px;
}

.auth-pending-panel.is-rejected .auth-rejected-copy,
.auth-pending-panel.is-waiting .auth-pending-copy {
  color: var(--muted);
  font-weight: var(--font-weight-medium);
  line-height: 1.65;
}

.auth-notice strong {
  color: var(--ink);
  font-size: 13px;
}

.auth-notice span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.oauth-login-panel p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: var(--font-weight-medium);
  line-height: 1.65;
}

.auth-actions {
  display: grid;
  gap: 8px;
}

.auth-actions.has-secondary-action {
  grid-template-columns: minmax(138px, 0.42fr) minmax(0, 1fr);
}

.auth-notice[hidden],
.auth-actions[hidden] {
  display: none !important;
}

/* bundled from styles/auth.responsive.css */
/*
 * AUTH RESPONSIVE CSS CONTRACT
 * Auth page compact breakpoints separated from admin and photo route files.
 */
@media (max-width: 1023px) {
  .auth-product-panel {
    min-height: 0;
    grid-template-rows: auto auto;
    gap: 14px;
  }

  .auth-route-map {
    display: grid;
    align-content: start;
    min-height: 220px;
  }

  .auth-guide-carousel {
    min-height: 220px;
  }

  .auth-guide-slide {
    min-height: 144px;
  }
}

@media (max-width: 520px) {
  .auth-screen {
    padding: 8px;
    place-items: start center;
  }

  .auth-layout {
    width: 100%;
    min-height: auto;
  }

  .auth-product-panel {
    padding: 14px 16px;
    grid-template-rows: auto auto;
    gap: 12px;
  }

  .auth-brand {
    align-items: center;
    gap: 8px;
  }

  .auth-brand .brand-title {
    display: block;
    max-width: none;
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
  }

  .auth-route-map,
  .auth-guide-carousel,
  .auth-guide-slide {
    min-height: 0;
  }

  .auth-guide-carousel {
    padding: 12px;
    gap: 10px;
  }

  .auth-guide-slide {
    align-content: start;
    gap: 10px;
  }

  .auth-guide-step strong {
    font-size: 20px;
    line-height: 1.25;
  }

  .auth-guide-step p {
    font-size: 13px;
    line-height: 1.65;
  }

  .auth-guide-list {
    gap: 6px;
  }

  .auth-guide-list li {
    padding: 7px 9px;
    font-size: 12px;
  }

  .auth-guide-controls {
    padding-top: 9px;
  }

  .auth-panel {
    padding: 14px 16px 16px;
    gap: 12px;
  }

  .auth-mode-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .auth-mode-button {
    min-height: 38px;
  }

  .auth-form {
    gap: 12px;
  }

  .auth-copy h1 {
    font-size: 24px;
  }

  .auth-notice,
  .oauth-login-panel,
  .auth-pending-panel {
    padding: 10px;
  }

  .signup-onboarding-step {
    padding: 10px;
  }

  .signup-onboarding-flow,
  .signup-step-frame {
    min-height: 0;
  }

  .signup-step-indicator {
    --signup-step-c1: 28px;
    --signup-step-c2: 28px;
  }

  .signup-step-indicator[data-stepper-step="review"] {
    --signup-step-c1: 22px;
    --signup-step-c2: 34px;
  }

  .signup-step-indicator .rental-step-chip.is-active em {
    max-width: 72px;
  }

  .signup-onboarding-grid,
  .signup-review-grid {
    grid-template-columns: 1fr;
  }

  .signup-google-identity-note {
    display: grid;
    gap: 3px;
  }
}

@media (max-width: 520px) {
  .auth-product-panel {
    padding: 12px 14px;
    gap: 10px;
  }

  .auth-guide-carousel {
    padding: 10px;
  }

  .auth-guide-step p {
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }

  .auth-guide-list li {
    padding: 6px 8px;
    line-height: 1.25;
  }

  .auth-guide-controls {
    padding-top: 8px;
  }

  .auth-panel {
    padding: 12px 14px 14px;
  }
}

/* Auth owner copy of former admin modal overrides. */
@media (max-width: 520px) {
  .auth-mode-tabs {
    grid-template-columns: 1fr;
  }

  .auth-mode-button {
    min-height: 40px;
  }
}

@media (max-width: 1023px) {
  .auth-screen {
    padding: 12px;
  }

  .auth-layout {
    min-height: calc(100dvh - 24px);
    grid-template-columns: 1fr;
    grid-template-areas:
      "product"
      "auth";
  }

  .auth-product-panel {
    border-right: 0;
    border-top: 0;
    border-bottom: 1px solid var(--hairline);
  }

  .auth-route-map {
    min-height: 300px;
  }

  .auth-panel {
    padding: 18px;
  }

  .auth-copy h1 {
    font-size: 24px;
  }
}

/* bundled from styles/app-shell.css */
.app-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.topbar {
  min-height: var(--topbar-height-desktop);
  padding: 0 28px;
  border-bottom: 1px solid var(--hairline);
  background: var(--color-app-topbar-bg);
  display: grid;
  grid-template-columns: minmax(240px, 1fr) auto minmax(180px, 1fr);
  grid-template-rows: none;
  gap: 12px;
  align-items: center;
  position: sticky;
  top: 0;
  z-index: 20;
  backdrop-filter: blur(16px);
}

.brand-block,
.profile-pill,
.month-controls,
.toolbar-actions,
.section-heading-row,
.drawer-heading,
.detail-panel-header,
.page-heading,
.upload-summary,
.admin-actions,
.legend-row {
  display: flex;
  align-items: center;
}

.brand-block {
  gap: 9px;
  min-width: 0;
}

.brand-mark {
  width: var(--topbar-brand-mark-desktop);
  height: var(--topbar-brand-mark-desktop);
  flex: 0 0 var(--topbar-brand-mark-desktop);
  border-radius: 8px;
  background: var(--primary);
  color: var(--color-neutral-0);
  display: grid;
  place-items: center;
  font-size: 18px;
  font-weight: 800;
}

.brand-title {
  display: block;
  max-width: none;
  overflow: visible;
  font-size: 18px;
  line-height: 1.1;
  font-weight: 800;
  color: var(--ink);
  text-overflow: clip;
  white-space: nowrap;
}

.brand-subtitle,
.privacy-note,
.muted-copy {
  font-size: 12px;
  color: var(--muted);
}

.brand-subtitle {
  display: block;
  margin-top: 1px;
  font-size: 11px;
  line-height: 1.1;
  font-weight: 700;
}

.primary-tabs {
  display: flex;
  grid-column: auto;
  justify-self: center;
  align-self: stretch;
  gap: 0;
  padding: 0;
  border: 0;
  background: transparent;
  border-radius: 0;
  min-width: 0;
  max-width: 100%;
  box-shadow: none;
  overflow: visible;
}

.tab-button {
  border: 0;
  border-radius: var(--radius-control-small);
  color: var(--body);
  background: transparent;
  font-size: 13px;
  font-weight: 700;
  min-height: 32px;
  padding: 0 12px;
  white-space: nowrap;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.tab-button:active {
  transform: translateY(1px);
}

.tab-button {
  position: relative;
  min-width: 0;
  min-height: var(--topbar-height-desktop);
  padding: 0 20px;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  font-size: var(--font-size-lg);
  font-weight: 800;
}

.tab-button.is-active {
  background: transparent;
  color: var(--primary);
  box-shadow: none;
}

.tab-button.is-active::after {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 0;
  height: 3px;
  border-radius: 999px 999px 0 0;
  background: var(--primary);
}

.profile-pill {
  justify-self: end;
  display: flex;
  min-height: 38px;
  max-width: none;
  gap: 8px;
  border: 1px solid var(--hairline);
  background: var(--surface);
  border-radius: 999px;
  padding: 0 12px;
  font-size: 14px;
  font-weight: 800;
  color: var(--ink);
  box-shadow: none;
}

.profile-pill::before,
.profile-pill::after {
  content: none;
}

.profile-icon {
  display: block;
  width: 17px;
  height: 17px;
  flex: 0 0 17px;
  color: var(--primary);
  stroke-width: 2.4;
}

.role-chip,
.count-pill {
  border-radius: 999px;
  background: var(--surface-muted);
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  padding: 3px 7px;
}

.profile-pill .role-chip {
  display: none;
}

.workspace {
  flex: 1;
  padding: 18px;
  min-width: 0;
}

.view-panel {
  display: none;
}

.view-panel.is-visible {
  display: grid;
}

:root[data-initial-panel] .view-panel.is-visible {
  display: none;
}

:root[data-initial-panel="calendar"] .view-panel[data-panel="calendar"],
:root[data-initial-panel="mine"] .view-panel[data-panel="mine"],
:root[data-initial-panel="photos"] .view-panel[data-panel="photos"],
:root[data-initial-panel="profile"] .view-panel[data-panel="profile"],
:root[data-initial-panel="admin-home"] .view-panel[data-panel="admin-home"],
:root[data-initial-panel="admin-photos"] .view-panel[data-panel="admin-photos"],
:root[data-initial-panel="admin-signup"] .view-panel[data-panel="admin-signup"],
:root[data-initial-panel="admin-approvals"] .view-panel[data-panel="admin-approvals"],
:root[data-initial-panel="admin-equipment"] .view-panel[data-panel="admin-equipment"],
:root[data-initial-panel="admin-members"] .view-panel[data-panel="admin-members"],
:root[data-initial-panel="admin-violations"] .view-panel[data-panel="admin-violations"],
:root[data-initial-panel="archive"] .view-panel[data-panel="archive"],
:root[data-initial-panel="billing"] .view-panel[data-panel="billing"] {
  display: grid;
}

html[data-initial-panel] body.is-authenticated .view-panel:not(.is-visible) {
  display: none !important;
}

html[data-initial-panel] body.is-authenticated .view-panel.is-visible {
  display: grid;
}

.detail-panel,
.compact-view,
.ledger-card,
.admin-detail,
.admin-queue,
.upload-board {
  border: 1px solid var(--hairline);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: var(--shadow);
}

@media (min-width: 1024px) {
  :where(
    [data-panel="mine"].compact-view,
    [data-panel="mine-detail"].compact-view,
    [data-panel="project-directory"].compact-view,
    [data-panel="policy-history"].compact-view,
    [data-panel="photos"].compact-view,
    [data-panel="billing"].compact-view,
    [data-panel="archive"].compact-view
  ).is-visible {
    width: min(100%, var(--content-max-width-operational));
  }

  :where([data-panel="profile"].compact-view).is-visible:not(:has(.profile-settings-layout.is-dashboard-mode)) {
    width: min(100%, var(--content-max-width-readable));
  }
}

.section-kicker {
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
  font-weight: 800;
  text-transform: uppercase;
}

.panel-heading,
.section-heading-row h2,
.detail-panel h2,
.page-heading h1,
.drawer-heading h3,
.upload-summary h2,
.admin-detail h2 {
  color: var(--ink);
  margin: 0;
  line-height: 1.25;
  letter-spacing: 0;
}

.panel-heading,
.detail-panel h2,
.page-heading h1 {
  font-size: 20px;
}

.drawer-heading h3,
.upload-summary h2,
.admin-detail h2 {
  font-size: 16px;
}

.admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.project-name-field {
  display: block;
  margin-bottom: 10px;
}

.section-heading-row {
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
}

/* bundled from styles/app-shell.responsive.css */
/*
 * APP SHELL RESPONSIVE CSS CONTRACT
 * Topbar, profile menu, workspace, and tab visibility responsive rules.
 */
@media (min-width: 1024px) {
  .tab-button.is-active::after {
    height: 3px;
  }
}

/* Header component policy: keep one source and resize with topbar tokens only. */
@media (min-width: 521px) and (max-width: 1023px) {
  .topbar,
  body:has([data-panel="mine"].is-visible) .topbar {
    min-height: var(--topbar-height-wide-tablet);
    padding: 0 28px;
    grid-template-columns: minmax(220px, 1fr) auto minmax(150px, 1fr);
  }

  .brand-mark,
  body:has([data-panel="mine"].is-visible) .brand-mark {
    width: var(--topbar-brand-mark-wide-tablet);
    height: var(--topbar-brand-mark-wide-tablet);
    flex-basis: var(--topbar-brand-mark-wide-tablet);
    font-size: 20px;
  }

  .brand-title,
  body:has([data-panel="mine"].is-visible) .brand-title {
    font-size: 18px;
    font-weight: 800;
  }

  .brand-subtitle,
  body:has([data-panel="mine"].is-visible) .brand-subtitle {
    font-size: 12px;
    font-weight: 700;
  }

  .tab-button,
  body:has([data-panel="mine"].is-visible) .tab-button {
    min-height: var(--topbar-height-wide-tablet);
    padding: 0 18px;
    font-size: 14px;
    font-weight: 800;
  }

  .tab-button.is-active::after,
  body:has([data-panel="mine"].is-visible) .tab-button.is-active::after {
    left: 18px;
    right: 18px;
    height: 3px;
  }

  .profile-pill,
  .profile-area .profile-pill,
  body:has([data-panel="mine"].is-visible) .profile-pill,
  body:has([data-panel="mine"].is-visible) .profile-area .profile-pill {
    min-height: 40px;
    padding: 0 12px;
    font-size: 14px;
    font-weight: 800;
  }
}

@media (min-width: 521px) and (max-width: 1023px) {
  .topbar,
  body:has([data-panel="mine"].is-visible) .topbar {
    min-height: var(--topbar-height-tablet);
    padding: 0 14px;
    grid-template-columns: minmax(150px, 1fr) auto minmax(74px, 1fr);
    gap: 10px;
  }

  .brand-mark,
  body:has([data-panel="mine"].is-visible) .brand-mark {
    width: var(--topbar-brand-mark-tablet);
    height: var(--topbar-brand-mark-tablet);
    flex-basis: var(--topbar-brand-mark-tablet);
    font-size: 18px;
  }

  .brand-title,
  body:has([data-panel="mine"].is-visible) .brand-title {
    max-width: 132px;
    overflow: hidden;
    font-size: 16px;
    font-weight: 800;
    text-overflow: ellipsis;
  }

  .brand-subtitle,
  body:has([data-panel="mine"].is-visible) .brand-subtitle {
    display: none;
  }

  .tab-button,
  body:has([data-panel="mine"].is-visible) .tab-button {
    min-height: var(--topbar-height-tablet);
    padding: 0 12px;
    font-size: 13px;
    font-weight: 800;
  }

  .tab-button.is-active::after,
  body:has([data-panel="mine"].is-visible) .tab-button.is-active::after {
    left: 12px;
    right: 12px;
    height: 2px;
  }

  .profile-pill,
  .profile-area .profile-pill,
  body:has([data-panel="mine"].is-visible) .profile-pill,
  body:has([data-panel="mine"].is-visible) .profile-area .profile-pill {
    min-height: 38px;
    max-width: 92px;
    padding: 0 10px;
    font-size: 13px;
    font-weight: 800;
  }
}

@media (max-width: 520px) {
  .topbar,
  body:has([data-panel="mine"].is-visible) .topbar {
    min-height: var(--topbar-height-mobile);
    padding: 0 10px;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 8px;
  }

  .brand-mark,
  body:has([data-panel="mine"].is-visible) .brand-mark {
    width: var(--topbar-brand-mark-mobile);
    height: var(--topbar-brand-mark-mobile);
    flex-basis: var(--topbar-brand-mark-mobile);
    font-size: 17px;
  }

  .brand-title,
  .brand-subtitle,
  body:has([data-panel="mine"].is-visible) .brand-title,
  body:has([data-panel="mine"].is-visible) .brand-subtitle {
    display: none;
  }

  .tab-button,
  body:has([data-panel="mine"].is-visible) .tab-button {
    min-height: var(--topbar-height-mobile);
    padding: 0 10px;
    font-size: 12px;
    font-weight: 800;
  }

  .tab-button.is-active::after,
  body:has([data-panel="mine"].is-visible) .tab-button.is-active::after {
    left: 10px;
    right: 10px;
    height: 2px;
  }

  .profile-pill,
  .profile-area .profile-pill,
  body:has([data-panel="mine"].is-visible) .profile-pill,
  body:has([data-panel="mine"].is-visible) .profile-area .profile-pill {
    width: 38px;
    min-width: 38px;
    max-width: 38px;
    height: 38px;
    min-height: 38px;
    padding: 0;
    justify-content: center;
  }

  .profile-pill .profile-name,
  .profile-area .profile-pill .profile-name,
  body:has([data-panel="mine"].is-visible) .profile-pill .profile-name,
  body:has([data-panel="mine"].is-visible) .profile-area .profile-pill .profile-name {
    display: none;
  }

  .profile-area .profile-icon,
  .profile-area .profile-pill .lucide {
    display: block;
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
  }

  body:has([data-panel="mine"].is-visible) .workspace {
    height: calc(100dvh - var(--topbar-height-mobile));
  }
}

@media (max-width: 1023px) {
  .profile-menu {
    position: fixed;
    top: calc(56px + max(8px, env(safe-area-inset-top)));
    right: max(10px, env(safe-area-inset-right));
    left: auto;
    width: min(320px, calc(100vw - 20px));
    max-height: calc(100dvh - 76px);
    overflow-y: auto;
    z-index: 120;
  }
}

.workspace {
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

@media (max-width: 1023px) {
  .workspace {
    height: calc(100dvh - 56px);
    padding: 8px;
    overflow-x: hidden;
    overflow-y: auto;
    max-width: 100vw;
  }

  .compact-view {
    min-height: auto;
    max-height: none;
    overflow: visible;
  }

  .view-panel.is-visible.compact-view {
    display: grid;
  }

  .page-heading {
    align-items: flex-start;
    flex-direction: row;
    padding-bottom: 10px;
  }
}

@media (max-width: 520px) {
  .profile-menu {
    top: calc(52px + max(8px, env(safe-area-inset-top)));
    right: max(8px, env(safe-area-inset-right));
    left: max(8px, env(safe-area-inset-left));
    width: auto;
    max-height: calc(100dvh - 72px);
  }

  .workspace {
    height: calc(100dvh - 52px);
    padding: 6px;
  }
}

.tab-button.is-hidden {
  display: none;
}


/* bundled from styles/components/buttons.css */
/*
 * COMPONENT BUTTONS CSS CONTRACT
 *
 * Reusable button primitives belong here. Do not add route-specific selectors.
 */

.icon-button,
.ui-square-icon-button,
.secondary-button,
.primary-button,
.danger-button {
  min-height: var(--control-height-search);
  border-radius: var(--button-radius);
  padding: 0 var(--space-3);
  border: 1px solid transparent;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.icon-button:enabled:active,
.ui-square-icon-button:enabled:active,
.secondary-button:enabled:active,
.primary-button:enabled:active,
.danger-button:enabled:active {
  transform: translateY(1px);
}

.icon-button {
  width: var(--control-size-icon-md);
  padding: 0;
  font-size: 20px;
  background: var(--surface);
  border-color: var(--hairline-strong);
  color: var(--ink);
}

.ui-square-icon-button {
  width: var(--control-size-icon-md);
  min-width: var(--control-size-icon-md);
  height: var(--control-size-icon-md);
  min-height: var(--control-height-search);
  padding: 0;
  display: inline-grid;
  place-items: center;
  border-color: var(--hairline-strong);
  border-radius: var(--button-radius);
  background: var(--surface);
  color: var(--ink);
  cursor: pointer;
  line-height: 1;
}

.icon-button [data-lucide],
.floating-create-button [data-lucide] {
  display: none;
}

.icon-button .lucide,
.floating-create-button .lucide {
  display: block;
}

.icon-button .lucide {
  width: 18px;
  height: 18px;
  stroke-width: 2.4;
  margin: auto;
}

.icons-ready .icon-fallback {
  display: none;
}

.secondary-button {
  background: var(--surface);
  border-color: var(--hairline-strong);
  color: var(--ink);
}

.secondary-button:hover:not(:disabled):not(.is-disabled) {
  border-color: var(--hairline-strong);
  background: var(--surface-muted);
  color: var(--ink);
  box-shadow: var(--shadow-control);
}

.ui-square-icon-button:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.ui-square-icon-button [data-lucide],
.ui-square-icon-button .lucide {
  width: 18px;
  height: 18px;
  stroke-width: 2.5;
}

.ui-filter-icon-button {
  border-color: var(--hairline-strong);
  background: var(--surface);
  color: var(--primary);
}

.ui-filter-icon-button.is-active,
.ui-filter-icon-button[aria-pressed="true"],
.ui-filter-icon-button[aria-expanded="true"] {
  border-color: var(--color-brand-tint-border);
  background: var(--color-brand-tint-bg);
  color: var(--primary);
  box-shadow: var(--shadow-control);
}

@media (hover: hover) {
  .ui-filter-icon-button:not(:disabled):not(.is-disabled):not([aria-disabled="true"]):hover {
    border-color: var(--primary);
    background: var(--ku-crimson-soft);
    color: var(--primary);
    box-shadow: var(--shadow-panel-hover);
    transform: translateY(-1px);
  }
}

.primary-button {
  background: var(--primary);
  color: var(--color-text-on-action);
}

.primary-button:hover {
  background: var(--primary-hover);
}

.danger-button {
  border-color: var(--color-state-danger-border);
  background: var(--color-state-danger-bg);
  color: var(--danger);
}

.ui-action-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  font-weight: var(--font-weight-strong);
  cursor: pointer;
}

.ui-action-button [data-lucide],
.ui-action-button .lucide {
  width: 16px;
  height: 16px;
  stroke-width: 2.3;
  flex: 0 0 auto;
}

.ui-action-button-normal {
  border-color: var(--hairline-strong);
  background: var(--surface);
  color: var(--ink);
}

.ui-action-button-emphasis {
  border-color: var(--color-brand-tint-border);
  background: var(--color-brand-tint-bg-subtle);
  color: var(--primary);
}

.ui-action-button-danger {
  border-color: var(--color-state-danger-border);
  background: var(--color-state-danger-bg);
  color: var(--danger);
}

.ui-action-button.is-active,
.ui-action-button[aria-pressed="true"] {
  border-color: var(--primary);
  background: var(--color-brand-tint-bg);
  color: var(--primary);
  box-shadow: var(--shadow-control);
}

.ui-action-button-danger.is-active,
.ui-action-button-danger[aria-pressed="true"] {
  border-color: var(--color-state-danger-border);
  background: var(--color-state-danger-bg);
  color: var(--danger);
}

.ui-action-button:disabled,
.ui-action-button.is-disabled,
.ui-action-button[aria-disabled="true"] {
  opacity: 0.52;
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}

@media (hover: hover) {
  .ui-action-button:not(:disabled):not(.is-disabled):not([aria-disabled="true"]):hover {
    border-color: var(--primary);
    box-shadow: var(--shadow-panel-hover);
    transform: translateY(-1px);
  }

  .ui-action-button-normal:not(:disabled):not(.is-disabled):not([aria-disabled="true"]):hover {
    background: var(--ku-crimson-soft);
    color: var(--primary);
  }

  .ui-action-button-emphasis:not(:disabled):not(.is-disabled):not([aria-disabled="true"]):hover {
    border-color: var(--color-brand-tint-border);
    background: var(--color-brand-tint-bg);
    color: var(--primary);
  }

  .ui-action-button-danger:not(:disabled):not(.is-disabled):not([aria-disabled="true"]):hover {
    border-color: var(--color-state-danger-border);
    background: var(--color-state-danger-bg);
    color: var(--danger);
  }
}

.ui-action-button:not(:disabled):not(.is-disabled):not([aria-disabled="true"]):focus-visible {
  border-color: var(--focus);
  box-shadow:
    0 0 0 3px var(--color-focus-ring-soft),
    var(--shadow-panel-hover);
}

.ui-action-button:not(:disabled):not(.is-disabled):not([aria-disabled="true"]):active {
  box-shadow: var(--shadow-control);
  transform: translateY(0);
}

.compact {
  min-height: var(--control-height-small);
  font-size: var(--font-size-sm);
  padding: 0 10px;
}

.full-width {
  width: 100%;
}

.calendar-toolbar-filter-button {
  width: var(--control-size-icon-md);
  height: var(--control-size-icon-md);
  min-width: var(--control-size-icon-md);
  color: var(--primary);
}

.calendar-toolbar-filter-button.is-active {
  border-color: var(--ku-crimson-border);
  background: var(--ku-crimson-soft);
}

.floating-create-button {
  position: fixed;
  z-index: 50;
  width: var(--control-size-floating);
  height: var(--control-size-floating);
  border: 1px solid var(--ku-crimson-border);
  border-radius: var(--radius-pill);
  background: var(--primary);
  color: var(--color-text-on-action);
  font-size: 30px;
  line-height: 1;
  display: inline-grid;
  place-items: center;
  box-shadow: var(--shadow-float);
  transition:
    transform var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease);
}

.floating-create-button:hover {
  background: var(--primary-hover);
  transform: translateY(-1px);
}

.floating-create-button:active {
  transform: translateY(1px);
}

/* bundled from styles/components/forms.css */
/*
 * COMPONENT FORMS CSS CONTRACT
 *
 * Reusable input, select, textarea, and form layout primitives belong here.
 * Do not add route-specific selectors.
 */

.field-label {
  display: block;
  margin-bottom: 7px;
  color: var(--body);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
}

.form-field {
  display: grid;
  gap: 7px;
  min-width: 0;
}

.form-field .field-label {
  margin-bottom: 0;
}

.field-help,
.field-error {
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.45;
}

.field-error {
  color: var(--color-state-danger-text);
  font-weight: var(--font-weight-medium);
}

.input,
.textarea {
  width: 100%;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--field-radius);
  background: var(--surface);
  color: var(--ink);
  font-size: var(--font-size-lg);
  padding: 10px 11px;
  outline: 0;
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease);
}

.input:focus,
.textarea:focus,
button:focus-visible {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--field-focus-ring);
}

.input.is-invalid,
.textarea.is-invalid,
.form-field.is-invalid .input,
.form-field.is-invalid .textarea {
  border-color: var(--color-state-danger-border);
  background: var(--color-state-danger-bg);
}

.input:disabled,
.textarea:disabled,
.form-field.is-disabled {
  opacity: 0.72;
  cursor: not-allowed;
}

.field-with-icon {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-2);
  align-items: center;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--field-radius);
  background: var(--surface);
  padding: 0 11px;
  min-height: var(--control-height-search);
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease);
}

.field-with-icon:focus-within {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--field-focus-ring);
}

.field-with-icon .field-icon,
.field-with-icon [data-lucide] {
  width: 16px;
  height: 16px;
  color: var(--muted);
  stroke-width: 2.2;
}

.field-with-icon .input {
  min-height: 0;
  border: 0;
  border-radius: 0;
  padding-inline: 0;
  background: transparent;
  box-shadow: none;
}

.field-with-icon .input:focus {
  box-shadow: none;
}

.textarea {
  resize: vertical;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* bundled from styles/components/modals.css */
/*
 * COMPONENT MODALS CSS CONTRACT
 *
 * Reusable modal shell primitives belong here.
 * Route/admin CSS may set modal-specific width, grid rows, and content layout.
 */

.ui-modal,
.calendar-modal {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: grid;
  place-items: center;
  padding: 18px;
}

.ui-modal.is-hidden,
.calendar-modal.is-hidden {
  display: none;
}

.ui-modal.is-closing,
.calendar-modal.is-closing {
  display: grid;
  pointer-events: none;
}

.ui-modal-backdrop,
.calendar-modal-backdrop {
  position: absolute;
  inset: 0;
  background: var(--color-route-overlay-modal);
}

.ui-modal-panel,
.calendar-modal-panel {
  position: relative;
  width: min(980px, calc(100vw - 36px));
  max-height: min(760px, calc(100dvh - 42px));
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-panel);
  background: var(--surface);
  box-shadow: 0 26px 74px var(--color-route-shadow-modal-strong);
  display: grid;
  overflow: hidden;
}

.ui-modal:not(.is-hidden) .ui-modal-backdrop,
.calendar-modal:not(.is-hidden) .calendar-modal-backdrop {
  animation: fadeIn var(--motion-base) var(--motion-ease);
}

.ui-modal.is-closing .ui-modal-backdrop,
.calendar-modal.is-closing .calendar-modal-backdrop {
  animation: fadeOut var(--motion-base) var(--motion-ease) forwards;
}

.ui-modal:not(.is-hidden) .ui-modal-panel,
.calendar-modal:not(.is-hidden) .calendar-modal-panel {
  animation: modalPanelIn var(--motion-slow) var(--motion-ease);
}

.ui-modal.is-closing .ui-modal-panel,
.calendar-modal.is-closing .calendar-modal-panel {
  animation: modalPanelOut var(--motion-base) var(--motion-ease) forwards;
}

.ui-modal-header {
  min-width: 0;
}

.ui-modal-close-button:hover:not(:disabled):not(.is-disabled) {
  border-color: var(--ku-crimson-border);
  background: var(--ku-crimson-soft);
  color: var(--primary);
  box-shadow: var(--shadow-panel-hover);
  transform: translateY(-1px);
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes modalPanelIn {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.985);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes modalPanelOut {
  from {
    opacity: 1;
    transform: translateY(0) scale(1);
  }

  to {
    opacity: 0;
    transform: translateY(8px) scale(0.99);
  }
}

@media (prefers-reduced-motion: reduce) {
  .ui-modal:not(.is-hidden) .ui-modal-backdrop,
  .calendar-modal:not(.is-hidden) .calendar-modal-backdrop,
  .ui-modal.is-closing .ui-modal-backdrop,
  .calendar-modal.is-closing .calendar-modal-backdrop,
  .ui-modal:not(.is-hidden) .ui-modal-panel,
  .calendar-modal:not(.is-hidden) .calendar-modal-panel,
  .ui-modal.is-closing .ui-modal-panel,
  .calendar-modal.is-closing .calendar-modal-panel {
    animation: none;
  }
}

/* bundled from styles/components/filters.css */
/*
 * COMPONENT FILTERS CSS CONTRACT
 *
 * Reusable search, filter, tab, chip, segmented-control, and compact progress primitives belong here.
 * Do not add route-specific filter rows.
 */
/* bundled from styles/components/filters.base.css */
/*
 * COMPONENT FILTERS BASE OWNER CSS CONTRACT
 * Generated from filters.css to keep component ownership reviewable.
 */
.segmented-button,
.chip-button {
  border: 0;
  border-radius: var(--chip-radius);
  color: var(--body);
  background: transparent;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  min-height: var(--control-height-filter);
  padding: var(--control-padding-block-compact) var(--control-padding-inline-compact);
  white-space: nowrap;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.segmented-button:active,
.chip-button:active {
  transform: translateY(1px);
}

.segmented-button.is-active,
.chip-button.is-active {
  background: var(--surface);
  color: var(--ink);
  box-shadow: var(--shadow-control);
}

.segmented {
  display: flex;
  gap: var(--space-1);
  padding: var(--space-1);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-control);
  background: var(--surface-muted);
}

.ui-progress-stepper {
  --connector-size: 18px;
  --stepper-chip-shift: 0px;
  --stepper-label-offset: 0px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ui-progress-stepper-step:not(.rental-step-chip) {
  list-style: none;
  width: 26px;
  height: 26px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--muted);
  display: grid;
  place-items: center;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.ui-progress-stepper-step::marker {
  content: "";
}

.ui-progress-stepper-step:not(.rental-step-chip).is-active {
  border-color: var(--primary);
  background: var(--primary);
  color: var(--color-text-on-action);
}

.ui-progress-stepper-step:not(.rental-step-chip).is-complete {
  border-color: var(--ku-crimson-border);
  background: var(--ku-crimson-soft);
  color: var(--primary);
}

.chip-row,
.legend-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

/* bundled from styles/components/filters.status.css */
/*
 * COMPONENT FILTERS STATUS OWNER CSS CONTRACT
 * Generated from filters.css to keep component ownership reviewable.
 */
.ui-status-filter-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

.ui-filter-chip-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

.ui-filter-chip {
  min-height: var(--control-height-compact);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-control);
  background: var(--surface);
  color: var(--body);
  padding: 0 var(--space-3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--filter-chip-gap);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.ui-filter-chip:hover {
  border-color: var(--color-hover-neutral-border);
  background: var(--control-hover-bg);
  box-shadow: var(--shadow-control);
  transform: translateY(-1px);
}

.ui-filter-chip.is-active {
  border-color: var(--ku-crimson-border);
  background: var(--ku-crimson-soft);
  color: var(--primary);
  box-shadow: inset 0 0 0 1px var(--color-focus-ring-soft);
}

.ui-filter-chip:active {
  transform: translateY(1px);
}

.ui-filter-chip:focus-visible {
  outline: 3px solid var(--color-focus-ring-soft);
  outline-offset: 2px;
}

.ui-filter-chip [data-lucide],
.ui-filter-chip .lucide {
  width: var(--filter-chip-icon-size);
  height: var(--filter-chip-icon-size);
  stroke-width: 2.2;
  flex: 0 0 auto;
}

.ui-filter-chip-count {
  min-width: 18px;
  border-radius: var(--count-badge-radius);
  background: var(--color-bg-surface-muted);
  color: var(--color-text-muted);
  padding: var(--count-badge-padding-block) var(--count-badge-padding-inline);
  font-size: var(--font-size-xs);
  line-height: var(--line-height-tight);
  text-align: center;
}

.ui-filter-chip.is-active .ui-filter-chip-count {
  background: var(--surface);
  color: currentColor;
}

.ui-filter-chip.tone-photo {
  border-color: var(--color-state-orange-200);
  background: var(--color-state-orange-50);
  color: var(--color-state-orange-700);
}

.ui-filter-chip.tone-warning {
  border-color: var(--color-state-warning-border);
  background: var(--color-state-warning-bg);
  color: var(--color-state-warning-text);
}

.ui-filter-chip.tone-penalty,
.ui-filter-chip.tone-approval,
.ui-filter-chip.tone-pending {
  border-color: var(--color-state-red-200);
  background: var(--color-state-red-50);
  color: var(--color-state-red-700);
}

.ui-filter-chip.tone-project {
  border-color: var(--color-state-purple-50);
  background: var(--color-state-purple-50);
  color: var(--color-state-purple-700);
}

.ui-status-filter-chip {
  min-height: var(--control-height-compact);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-control);
  background: var(--surface);
  color: var(--body);
  padding: var(--control-padding-block-compact) 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--filter-chip-gap);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.ui-status-filter-chip:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-control), inset 0 0 0 1px currentColor;
}

.ui-status-filter-chip.is-active {
  box-shadow: inset 0 0 0 1px currentColor;
}

.ui-status-filter-chip:active {
  transform: translateY(1px);
}

.ui-status-filter-chip:focus-visible {
  outline: 3px solid var(--color-focus-ring-soft);
  outline-offset: 2px;
}

.ui-status-filter-chip [data-lucide],
.ui-status-filter-chip .lucide {
  width: var(--filter-chip-icon-size);
  height: var(--filter-chip-icon-size);
  stroke-width: 2.2;
  flex: 0 0 auto;
}

.ui-status-filter-chip.tone-reserved {
  border-color: var(--color-status-reserved-border);
  background: var(--color-status-reserved-bg);
  color: var(--color-status-reserved-text);
}

.ui-status-filter-chip.tone-photo {
  border-color: var(--color-status-checkout-border);
  background: var(--color-status-checkout-bg);
  color: var(--color-status-checkout-text);
}

.ui-status-filter-chip.tone-pending,
.ui-status-filter-chip.tone-approval {
  border-color: var(--color-status-approval-border);
  background: var(--color-status-approval-bg);
  color: var(--color-status-approval-text);
}

.ui-status-filter-chip.tone-checked-out,
.ui-status-filter-chip.tone-active {
  border-color: var(--color-status-active-border);
  background: var(--color-status-active-bg);
  color: var(--color-status-active-text);
}

.ui-status-filter-chip.tone-available {
  border-color: var(--color-state-success-border);
  background: var(--color-state-success-bg);
  color: var(--color-state-success-text);
}

.ui-status-filter-chip.tone-maintenance {
  border-color: var(--color-state-warning-border);
  background: var(--color-state-warning-bg);
  color: var(--color-state-warning-text);
}

.ui-status-filter-chip.tone-unavailable {
  border-color: var(--color-status-neutral-border);
  background: var(--color-status-neutral-bg);
  color: var(--color-status-neutral-text);
}

.ui-status-filter-chip.tone-return {
  border-color: var(--color-status-return-border);
  background: var(--color-status-return-bg);
  color: var(--color-status-return-text);
}

.ui-status-filter-chip.tone-done,
.ui-status-filter-chip.tone-returned,
.ui-status-filter-chip.tone-neutral {
  border-color: var(--color-status-neutral-border);
  background: var(--color-status-neutral-bg);
  color: var(--color-status-neutral-text);
}

.ui-status-filter-chip.is-neutral {
  border-color: var(--color-neutral-300);
  background: var(--color-neutral-50);
  color: var(--color-neutral-600);
}

.ui-sort-toggle {
  min-height: var(--control-height-compact);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-control);
  background: var(--surface);
  color: var(--body);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sort-toggle-gap);
  padding: var(--control-padding-block-compact) var(--control-padding-inline-compact);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.ui-sort-toggle:active {
  transform: translateY(1px);
}

.ui-sort-toggle:focus-visible {
  outline: 3px solid var(--color-focus-ring-soft);
  outline-offset: 2px;
}

.ui-sort-toggle [data-lucide],
.ui-sort-toggle .lucide {
  width: var(--filter-chip-icon-size);
  height: var(--filter-chip-icon-size);
  stroke-width: 2.2;
  flex: 0 0 auto;
}

/* bundled from styles/components/filters.primitives.css */
/*
 * COMPONENT FILTERS PRIMITIVE OWNER CSS CONTRACT
 * Generated from filters.css to keep component ownership reviewable.
 */
.filter-bar {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: var(--space-3);
  align-items: center;
  border: 1px solid var(--hairline);
  border-radius: var(--filter-bar-radius);
  background: var(--surface);
  padding: var(--space-3);
}

.filter-bar-search {
  width: 100%;
}

.filter-bar-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: flex-end;
}

@media (max-width: 520px) {
  .filter-bar {
    grid-template-columns: 1fr;
  }

  .filter-bar-actions {
    justify-content: flex-start;
  }
}

.chip-button {
  min-height: var(--control-height-filter);
  border: 1px solid var(--hairline);
  background: var(--surface);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--filter-chip-gap);
}

.chip-button.is-active {
  border-color: var(--primary);
}

.chip-icon {
  display: block;
  flex: 0 0 auto;
  width: var(--filter-chip-icon-size);
  height: var(--filter-chip-icon-size);
  stroke-width: 2.2;
}

.status-chip {
  width: fit-content;
  max-width: 100%;
  min-height: var(--status-chip-min-height);
  border: 1px solid transparent;
  border-radius: var(--status-chip-radius);
  padding: var(--status-chip-padding-block) var(--status-chip-padding-inline);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-snug);
  font-weight: var(--font-weight-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  white-space: nowrap;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

button.status-chip {
  appearance: none;
  cursor: pointer;
}

.status-chip.status-reserved {
  border-color: var(--color-status-reserved-border);
  background: var(--color-status-reserved-bg);
  color: var(--color-status-reserved-text);
}

.status-chip.status-photo,
.status-chip.status-warning,
.status-checkout_photo_needed {
  border-color: var(--color-status-checkout-border);
  background: var(--color-status-checkout-bg);
  color: var(--color-status-checkout-text);
}

.status-chip.status-pending,
.status-chip.status-approval,
.status-extension_approval_needed {
  border-color: var(--color-status-approval-border);
  background: var(--color-status-approval-bg);
  color: var(--color-status-approval-text);
}

.status-chip.status-active,
.status-checked_out {
  border-color: var(--color-status-active-border);
  background: var(--color-status-active-bg);
  color: var(--color-status-active-text);
}

.status-chip.status-return,
.status-return_photo_needed {
  border-color: var(--color-status-return-border);
  background: var(--color-status-return-bg);
  color: var(--color-status-return-text);
}

.status-chip.status-danger {
  border-color: var(--color-brand-ku-crimson-200);
  background: var(--ku-crimson-soft);
  color: var(--primary);
}

.status-chip.status-done,
.status-returned,
.status-cancelled,
.status-chip.status-neutral {
  border-color: var(--color-status-neutral-border);
  background: var(--color-status-neutral-bg);
  color: var(--color-status-neutral-text);
}

.ui-search-field {
  min-width: 0;
  min-height: var(--control-height-search);
  border: 1px solid var(--hairline);
  border-radius: var(--control-search-radius);
  background: var(--surface);
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  align-items: center;
  gap: var(--space-2);
  padding: var(--control-padding-block-compact) var(--control-padding-inline-compact);
  color: var(--muted);
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
}

.ui-search-field:hover {
  border-color: var(--hairline-strong);
  box-shadow: var(--shadow-control);
}

.ui-search-field:focus-within {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--color-focus-ring-soft);
}

.ui-search-field [data-lucide],
.ui-search-field .lucide {
  width: 17px;
  height: 17px;
  color: var(--muted);
}

.ui-search-field input {
  appearance: none;
  width: 100%;
  height: 100%;
  min-width: 0;
  border: 0;
  margin: 0;
  padding: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-snug);
  outline: 0;
  box-shadow: none;
}

.ui-search-field input::placeholder {
  color: var(--muted);
}

.ui-search-field input::-webkit-search-decoration,
.ui-search-field input::-webkit-search-cancel-button {
  appearance: none;
}

.event-pill {
  width: 100%;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  background: var(--surface-muted);
  padding: 5px 7px;
  display: grid;
  gap: 1px;
  text-align: left;
  color: var(--ink);
  font-size: var(--font-size-xs);
  line-height: var(--line-height-snug);
  cursor: pointer;
  transition:
    transform var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
}

.event-pill:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-panel-hover);
}

.event-pill:active {
  transform: translateY(0);
}

.event-pill strong {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
}

.event-pill span {
  color: var(--body);
  font-size: 10.5px;
}

.calendar-grid .event-pill {
  min-height: 22px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  display: block;
  padding: 3px 6px;
  box-shadow: none;
}

.calendar-grid .event-pill strong {
  display: block;
  font-size: var(--font-size-xs);
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.event-pill-time {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
}

.calendar-grid .event-pill-time {
  font-size: inherit;
}

.event-approved,
.event-reserved {
  background: var(--color-status-reserved-bg);
  color: var(--color-status-reserved-text);
}

.event-checkout_photo_needed {
  background: var(--color-status-checkout-bg);
  color: var(--color-status-checkout-text);
}

.event-pending,
.event-extension_approval_needed {
  background: var(--color-status-approval-bg);
  color: var(--color-status-approval-text);
}

.event-checked_out {
  background: var(--color-status-active-bg);
  color: var(--color-status-active-text);
}

.event-return_pending,
.event-return_photo_needed {
  background: var(--color-status-return-bg);
  color: var(--color-status-return-text);
}

.event-returned,
.event-cancelled {
  background: var(--color-status-neutral-bg);
  color: var(--color-status-neutral-text);
}

.event-pill.is-status-off {
  background: var(--surface-muted);
  color: var(--muted);
  opacity: 0.45;
}

/* Calendar filter/status controls promoted from route-local copies. */

/* bundled from styles/components/filters.calendar.css */
/*
 * COMPONENT FILTERS CALENDAR OWNER CSS CONTRACT
 * Generated from filters.css to keep component ownership reviewable.
 */
.calendar-filter-bar {
  grid-area: filters;
}

.calendar-filter-bar[hidden] {
  display: none;
}

.calendar-filter-bar::-webkit-scrollbar {
  display: none;
}

.ui-filter-scope-toggle {
  flex: 0 0 auto;
  min-height: var(--control-height-filter);
  border: 1px solid var(--primary);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--primary);
  padding: 0 13px;
  display: inline-flex;
  align-items: center;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
}

.ui-filter-scope-toggle.is-all {
  border-color: var(--primary);
  background: var(--surface);
  color: var(--primary);
}

.ui-filter-scope-toggle.is-mine {
  border-color: var(--primary);
  background: var(--ku-crimson-soft);
  color: var(--primary);
}

.ui-filter-scope-toggle:hover {
  border-color: var(--primary);
  background: var(--surface);
  box-shadow: var(--shadow-control);
}

.ui-filter-scope-toggle.is-mine:hover {
  background: var(--ku-crimson-soft);
}

.calendar-scope-toggle {
  flex: 0 0 auto;
}

.calendar-filter-chip {
  flex: 0 0 auto;
  min-height: var(--control-height-compact);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-control);
  background: var(--surface);
  color: var(--body);
  padding: var(--control-padding-block-compact) 10px;
  display: inline-flex;
  align-items: center;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.calendar-status-filter-group {
  flex-wrap: nowrap;
}

.calendar-filter-chip.tone-reserved {
  border-color: var(--color-status-reserved-border);
  background: var(--color-status-reserved-bg);
  color: var(--color-status-reserved-text);
}

.calendar-filter-chip.tone-photo {
  border-color: var(--color-status-checkout-border);
  background: var(--color-status-checkout-bg);
  color: var(--color-status-checkout-text);
}

.calendar-filter-chip.tone-return {
  border-color: var(--color-status-return-border);
  background: var(--color-status-return-bg);
  color: var(--color-status-return-text);
}

.calendar-filter-chip.tone-checked-out {
  border-color: var(--color-status-active-border);
  background: var(--color-status-active-bg);
  color: var(--color-status-active-text);
}

.calendar-filter-chip.tone-returned {
  border-color: var(--color-status-neutral-border);
  background: var(--color-status-neutral-bg);
  color: var(--color-status-neutral-text);
}

.calendar-filter-chip.tone-approval {
  border-color: var(--color-status-approval-border);
  background: var(--color-status-approval-bg);
  color: var(--color-status-approval-text);
}

.calendar-filter-chip.is-neutral {
  border-color: var(--color-neutral-300);
  background: var(--color-neutral-50);
  color: var(--color-neutral-600);
}

.calendar-filter-chip.is-neutral:hover {
  border-color: var(--hairline-strong);
  background: var(--surface-muted);
  color: var(--body);
}

.calendar-filter-chip:hover,
.calendar-filter-chip.is-active {
  box-shadow: var(--shadow-control), inset 0 0 0 1px currentColor;
}

.calendar-filter-chip:hover {
  transform: translateY(-1px);
}

/* Horizontal month strip primitive used by calendar-style route toolbars. */

/* bundled from styles/components/filters.month-strip.css */
/*
 * COMPONENT FILTERS MONTH STRIP OWNER CSS CONTRACT
 * Generated from filters.css to keep component ownership reviewable.
 */
.month-strip-wrap {
  grid-area: months;
  position: relative;
  min-width: 0;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.month-strip-wrap.is-hidden-for-space {
  display: none;
}

.month-strip {
  width: 100%;
  min-height: 46px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  overflow-x: auto;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  scroll-padding-inline: 50%;
  touch-action: pan-x;
  overscroll-behavior-inline: contain;
  scrollbar-width: none;
  padding: 5px max(4px, calc(50% - 44px));
  mask-image: linear-gradient(90deg, transparent 0, black 28px, black calc(100% - 28px), transparent 100%);
  cursor: grab;
  user-select: none;
  opacity: 1;
  transition: opacity var(--motion-fast) var(--motion-ease);
}

.month-strip[data-month-ready="false"] {
  opacity: 0;
}

.month-strip.is-pointer-active,
.month-strip.is-dragging {
  cursor: grabbing;
}

.month-strip.is-dragging {
  scroll-behavior: auto;
  scroll-snap-type: none;
}

.month-strip::before,
.month-strip::after {
  content: "";
  flex: 0 0 6px;
}

.month-strip::-webkit-scrollbar {
  display: none;
}

.month-strip-button,
.month-year-separator {
  flex: 0 0 auto;
  min-height: var(--control-height-small);
  border-radius: var(--radius-control);
  padding: 0 14px;
  white-space: nowrap;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  scroll-snap-align: center;
}

.month-strip-button {
  position: relative;
  border: 1px solid var(--hairline-strong);
  background: transparent;
  color: var(--color-neutral-600);
  opacity: 1;
  transition:
    background-color var(--motion-base) var(--motion-ease),
    border-color var(--motion-base) var(--motion-ease),
    color var(--motion-base) var(--motion-ease),
    box-shadow var(--motion-base) var(--motion-ease),
    transform var(--motion-base) var(--motion-ease);
}

.month-strip-button:hover {
  z-index: 2;
  background: var(--surface);
  box-shadow: var(--shadow-panel-hover);
  transform: translateY(-1px);
}

.month-strip-button:active {
  transform: translateY(0);
}

.month-strip-button.is-active {
  z-index: 1;
  border-color: var(--primary);
  background: var(--primary);
  color: var(--color-text-on-action);
  opacity: 1;
  font-weight: var(--font-weight-strong);
  transform: translateY(-1px);
  box-shadow: var(--shadow-control);
}

.month-strip-button.is-active:hover {
  z-index: 2;
  box-shadow: var(--shadow-panel-hover);
}

.month-year-separator {
  display: inline-grid;
  place-items: center;
  color: var(--muted);
  background: var(--surface-muted);
}

/* bundled from styles/components/filters.segmented.css */
/*
 * COMPONENT FILTERS SEGMENTED OWNER CSS CONTRACT
 * Generated from filters.css to keep component ownership reviewable.
 */
.ui-segmented-switch {
  display: inline-grid;
  grid-template-columns: repeat(2, minmax(54px, 1fr));
  position: relative;
  overflow: hidden;
  isolation: isolate;
  --segmented-active-index: 0;
}

.ui-segmented-switch[data-active-index="1"] {
  --segmented-active-index: 1;
}

.ui-segmented-switch::before {
  content: "";
  position: absolute;
  z-index: 0;
  inset: 3px auto 3px 3px;
  width: calc((100% - 6px) / 2);
  border-radius: var(--chip-radius);
  background: var(--surface);
  box-shadow: var(--shadow-control);
  transform: translateX(calc(var(--segmented-active-index) * 100%));
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.ui-segmented-switch .segmented-button {
  position: relative;
  z-index: 1;
  isolation: isolate;
}

.ui-segmented-switch .segmented-button.secondary-button::after {
  content: "";
  position: absolute;
  z-index: -1;
  inset: 2px 3px;
  border-radius: calc(var(--chip-radius) - 2px);
  background: transparent;
  pointer-events: none;
  transition: background-color var(--motion-fast) var(--motion-ease);
}

.ui-segmented-switch .segmented-button.is-active {
  background: transparent;
  box-shadow: none;
}

.ui-segmented-switch.is-switching-forward::before {
  animation: segmentedSwitchForward var(--motion-base) var(--motion-ease);
}

.ui-segmented-switch.is-switching-back::before {
  animation: segmentedSwitchBack var(--motion-base) var(--motion-ease);
}

.ui-segmented-switch .segmented-button.secondary-button:hover:not(:disabled):not(.is-disabled) {
  border-color: transparent;
  background: transparent;
  color: var(--ink);
  box-shadow: none;
}

.ui-segmented-switch .segmented-button.secondary-button:hover:not(:disabled):not(.is-disabled)::after {
  background: color-mix(in srgb, var(--surface-muted) 90%, var(--body));
}

.ui-segmented-switch .segmented-button.secondary-button.is-active:hover:not(:disabled):not(.is-disabled) {
  border-color: transparent;
  background: transparent;
  color: var(--ink);
  box-shadow: none;
}

.ui-segmented-switch .segmented-button.secondary-button.is-active:hover:not(:disabled):not(.is-disabled)::after {
  background: transparent;
}

.side-mode-switch {
  gap: var(--space-1);
  align-items: center;
}

.side-mode-switch .segmented-button {
  min-height: 28px;
  border-radius: var(--radius-control-small);
  padding: 0 var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.side-mode-switch::before {
  border-radius: var(--radius-control-small);
}

@keyframes segmentedSwitchForward {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(100%);
  }
}

@keyframes segmentedSwitchBack {
  from {
    transform: translateX(100%);
  }
  to {
    transform: translateX(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .ui-segmented-switch.is-switching-forward::before,
  .ui-segmented-switch.is-switching-back::before {
    animation: none;
  }
}

/* bundled from styles/components/states.css */
/*
 * COMPONENT STATES CSS CONTRACT
 *
 * Reusable empty, loading, error, and success state blocks belong here.
 * Do not add route-specific state copy or route selectors.
 */

.state-block {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--state-block-radius);
  background: var(--color-bg-subtle);
  color: var(--body);
  padding: var(--space-panel-padding-md);
  display: grid;
  gap: 6px;
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.state-block strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
  line-height: 1.35;
  font-weight: var(--font-weight-strong);
}

.state-block span {
  color: var(--muted);
  font-size: var(--font-size-md);
  line-height: 1.5;
}

.state-block .secondary-button,
.state-block .primary-button,
.state-block .danger-button {
  width: max-content;
  margin-top: 4px;
}

.state-block-empty {
  background: var(--color-bg-subtle);
}

.state-block-loading,
.state-block-info {
  border-color: var(--color-state-info-border);
  background: var(--color-state-info-bg);
}

.state-block-error {
  border-color: var(--color-state-danger-border);
  background: var(--color-state-danger-bg);
}

.state-block-success,
.state-block-ready {
  border-color: var(--color-state-success-border);
  background: var(--color-state-success-bg);
}

/* bundled from styles/components/previews.css */
/*
 * COMPONENT PREVIEWS CSS CONTRACT
 *
 * Reusable dashboard/list preview primitives belong here. Route CSS may size
 * the panel or tune row density, but not redefine the base action/list shape.
 */

.ui-preview-panel {
  display: grid;
  gap: var(--preview-panel-gap);
}

.ui-preview-panel-heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--preview-panel-gap);
}

.ui-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: max-content;
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--count-badge-radius);
  background: var(--surface);
  color: var(--muted);
  padding: var(--count-badge-padding-block) var(--count-badge-padding-inline);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  line-height: var(--line-height-snug);
  white-space: nowrap;
}

.ui-mini-metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-2);
}

.ui-mini-metric-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-control);
  background: var(--surface);
  min-height: 58px;
  padding: 9px var(--space-2);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.ui-mini-metric-copy {
  min-width: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-snug);
}

.ui-mini-metric-copy strong {
  display: block;
  margin-top: 2px;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: var(--line-height-tight);
  font-weight: var(--font-weight-strong);
  letter-spacing: 0;
}

.ui-mini-metric-icon {
  width: 25px;
  height: 25px;
  border-radius: var(--radius-control);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}

.ui-panel-more-action {
  justify-self: end;
  width: auto;
  min-height: var(--control-height-compact);
  appearance: none;
  border: 0;
  border-radius: var(--radius-control-small);
  background: transparent;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  padding: 0 var(--space-1) 0 var(--space-2);
  font: inherit;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  line-height: 1;
  cursor: pointer;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.ui-panel-more-action [data-lucide],
.ui-panel-more-action .lucide {
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
  stroke-width: 2.2;
}

.ui-panel-more-action:hover {
  background: var(--ku-crimson-soft);
  color: var(--primary);
}

.ui-panel-more-action:active {
  transform: translateY(1px);
}

.ui-panel-more-action:focus-visible {
  outline: 2px solid var(--color-focus-ring-soft);
  outline-offset: 2px;
}

.ui-borderless-icon-button {
  width: auto;
  min-width: var(--control-size-icon-sm);
  height: var(--control-size-icon-sm);
  min-height: var(--control-height-compact);
  appearance: none;
  border: 0;
  border-radius: var(--radius-control-small);
  background: transparent;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  padding: 0 7px;
  font: inherit;
  line-height: 1;
  cursor: pointer;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.ui-borderless-icon-button [data-lucide],
.ui-borderless-icon-button .lucide {
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
  stroke-width: 2.2;
}

.ui-borderless-icon-button span {
  display: none;
}

.ui-borderless-icon-button:hover {
  background: var(--ku-crimson-soft);
  color: var(--primary);
}

.ui-borderless-icon-button:active {
  transform: translateY(1px);
}

.ui-borderless-icon-button:focus-visible {
  outline: 2px solid var(--color-focus-ring-soft);
  outline-offset: 2px;
}

.ui-borderless-icon-button.is-danger {
  color: var(--muted);
}

.ui-borderless-icon-button.is-danger:hover {
  background: var(--color-state-red-100);
  color: var(--danger);
}

.ui-borderless-icon-button:disabled,
.ui-borderless-icon-button.is-disabled,
.ui-borderless-icon-button[aria-disabled="true"] {
  opacity: 0.5;
  cursor: not-allowed;
}

.ui-borderless-icon-button:disabled:hover,
.ui-borderless-icon-button.is-disabled:hover,
.ui-borderless-icon-button[aria-disabled="true"]:hover {
  background: transparent;
  color: var(--muted);
}

.ui-preview-list {
  display: grid;
  gap: 0;
  align-content: start;
}

.ui-preview-summary-row {
  position: relative;
  isolation: isolate;
  min-width: 0;
  appearance: none;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: inherit;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto 18px;
  gap: var(--preview-row-gap);
  align-items: center;
  min-height: var(--preview-row-min-height);
  padding: var(--preview-row-padding-block) var(--preview-row-padding-inline);
  text-align: left;
  transition: color var(--motion-fast) var(--motion-ease);
}

.ui-preview-summary-row.has-leading-icon {
  grid-template-columns: 22px minmax(0, 1fr) auto 18px;
  gap: 9px;
}

.ui-preview-summary-row::before {
  content: "";
  position: absolute;
  inset: 0 -2px;
  border-radius: var(--radius-control);
  background: transparent;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    opacity var(--motion-fast) var(--motion-ease);
  z-index: 0;
  pointer-events: none;
}

.ui-preview-summary-row::after {
  content: "";
  position: absolute;
  inset-inline: 4px;
  bottom: 0;
  height: 1px;
  background: var(--hairline);
  z-index: 1;
  pointer-events: none;
}

.ui-preview-summary-row > * {
  position: relative;
  z-index: 1;
}

.ui-preview-summary-row:hover::before,
.ui-preview-summary-row:focus-visible::before {
  background: var(--preview-row-hover-bg);
}

.ui-preview-summary-row.is-active,
.ui-preview-summary-row.is-active strong {
  color: var(--primary);
}

.ui-preview-summary-row.is-active::before {
  background: var(--ku-crimson-soft);
}

.ui-preview-summary-row:focus-visible {
  outline: 2px solid var(--color-focus-ring-soft);
  outline-offset: -2px;
}

.ui-preview-summary-row:last-child::after {
  display: none;
}

.ui-preview-summary-row > span {
  min-width: 0;
  overflow: hidden;
}

.ui-preview-summary-row strong,
.ui-preview-summary-row small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ui-preview-summary-row small {
  color: var(--muted);
  color: color-mix(in srgb, var(--muted) 64%, var(--surface));
}

.ui-preview-summary-row > [data-lucide],
.ui-preview-summary-row > .lucide {
  width: var(--icon-size-md);
  height: var(--icon-size-md);
  color: var(--muted);
}

.ui-preview-summary-row > .ui-preview-summary-leading-icon {
  justify-self: start;
}

.ui-preview-summary-status {
  justify-self: end;
  font-style: normal;
}

/* bundled from styles/components/resource-card.css */
.equipment-category-icon,
.availability-icon {
  display: block;
  flex: 0 0 auto;
  width: 15px;
  height: 15px;
  stroke-width: 2.2;
}

.resource-list {
  overflow: auto;
  display: grid;
  gap: var(--space-panel-gap-sm);
  padding-right: 2px;
}

.resource-card {
  width: 100%;
  display: grid;
  grid-template-columns: 58px 1fr;
  gap: var(--space-panel-gap-sm);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface);
  padding: 9px;
  text-align: left;
  transition:
    border-color var(--motion-base) var(--motion-ease),
    background-color var(--motion-base) var(--motion-ease),
    box-shadow var(--motion-base) var(--motion-ease),
    transform var(--motion-base) var(--motion-ease);
}

.resource-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-resource-card-hover);
}

.resource-card:active {
  transform: translateY(0);
}

.resource-card.is-selected {
  border-color: var(--focus);
  background: var(--ku-crimson-soft);
}

.resource-card.is-conflict {
  background: var(--color-status-checkout-bg);
}

.resource-card:disabled,
.resource-card.is-disabled {
  cursor: not-allowed;
  border-style: dashed;
  background: var(--color-resource-disabled-bg);
  color: var(--muted);
  opacity: 0.56;
}

.resource-card:disabled:hover,
.resource-card.is-disabled:hover {
  transform: none;
  box-shadow: none;
}

.resource-card:disabled .resource-name,
.resource-card.is-disabled .resource-name {
  color: var(--muted);
}

.resource-name,
.agenda-title,
.record-title {
  color: var(--ink);
  font-size: var(--font-size-lg);
  line-height: 1.35;
  font-weight: var(--font-weight-strong);
}

.resource-meta,
.agenda-meta,
.record-meta,
.photo-card,
.event-log span {
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.35;
}

.availability-line {
  margin-top: 6px;
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.availability-dot {
  width: 7px;
  height: 7px;
  border-radius: var(--radius-pill);
  background: var(--available);
}

.resource-card.is-conflict .availability-dot {
  background: var(--photo-needed);
}

.resource-card.is-maintenance .availability-dot {
  background: var(--danger);
}

.availability-icon {
  color: var(--muted);
}

.resource-card:not(.is-disabled) .availability-icon {
  color: var(--available);
}

.resource-card.is-conflict .availability-icon {
  color: var(--photo-needed);
}

.resource-card.is-maintenance .availability-icon {
  color: var(--danger);
}

.equipment-thumb {
  width: 58px;
  min-width: 58px;
  height: 58px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-equipment-thumb-bg);
  position: relative;
  overflow: hidden;
  aspect-ratio: 1;
}

.equipment-thumb.large {
  width: 96px;
  height: 96px;
}

.equipment-thumb img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.equipment-thumb.no-photo {
  display: grid;
  place-items: center;
  gap: 2px;
  background: var(--equipment-thumb-empty-bg);
}

.no-photo-icon {
  width: var(--icon-size-lg);
  height: var(--icon-size-lg);
  color: var(--muted);
  stroke-width: 2;
}

.no-photo-label {
  color: var(--muted);
  font-size: 10px;
  font-weight: var(--font-weight-strong);
  line-height: 1;
}

.equipment-thumb.large .no-photo-icon {
  width: var(--control-height-filter);
  height: var(--control-height-filter);
}

.equipment-thumb.large .no-photo-label {
  font-size: var(--font-size-xs);
}

/* bundled from styles/components/admin-list-board.css */
.admin-list-board {
  min-width: 0;
  min-height: 0;
  height: 100%;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  overflow: hidden;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface);
}

.admin-list-header-stack {
  min-width: 0;
  display: grid;
  grid-auto-rows: auto;
}

.admin-list-toolbar {
  min-width: 0;
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--hairline);
}

.admin-list-toolbar-primary {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-panel-gap-sm);
  align-items: center;
}

.admin-list-filter-panel {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.admin-list-filter-panel[hidden] {
  display: none;
}

.admin-list-title {
  min-width: 0;
}

.admin-list-title h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-title-sm);
  line-height: 1.25;
}

.admin-list-body,
.admin-list-scroll-root {
  min-width: 0;
  min-height: 0;
  overflow: hidden;
}

.admin-list-scroll-root {
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
}

.admin-list-head,
.admin-list-rows > * {
  display: grid;
  grid-template-columns: var(--admin-list-columns, minmax(0, 1fr));
  align-items: center;
}

.admin-list-head {
  position: sticky;
  top: 0;
  z-index: 1;
}

.admin-list-rows {
  min-width: 0;
  min-height: 0;
}

.admin-list-footer {
  min-width: 0;
  min-height: var(--row-height-regular);
  border-top: 1px solid var(--hairline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.admin-list-footer-right {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
}

.admin-list-api-status {
  min-height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  padding: 0 10px;
  color: var(--primary);
  background: var(--color-route-surface-white);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-emphasis);
  white-space: nowrap;
}

.admin-list-api-status.is-connected {
  border-color: var(--color-state-success-border);
  color: var(--color-state-success-text);
  background: var(--color-state-success-bg);
}

/* bundled from styles/components/admin-workstation.css */
.admin-workstation {
  min-width: 0;
  min-height: 0;
  display: grid;
  gap: var(--admin-workstation-gap, var(--space-panel-gap-md));
}

.admin-workstation__board,
.admin-workstation__inspector {
  min-width: 0;
  min-height: 0;
}

.admin-workstation__board {
  height: 100%;
}

@media (min-width: 1024px) {
  .admin-workstation--split,
  .admin-workstation[data-admin-workstation="split"] {
    height: var(--admin-workstation-height, 100%);
    min-height: var(--admin-workstation-min-height, 0);
    grid-template-columns: var(--admin-workstation-columns, minmax(0, 1fr) minmax(320px, 420px));
    align-items: stretch;
    overflow: hidden;
  }

  .admin-workstation--split > .admin-workstation__board,
  .admin-workstation[data-admin-workstation="split"] > .admin-workstation__board,
  .admin-workstation--split > .admin-workstation__inspector,
  .admin-workstation[data-admin-workstation="split"] > .admin-workstation__inspector {
    min-height: 0;
  }
}

@media (max-width: 1023px) {
  .admin-workstation--split,
  .admin-workstation[data-admin-workstation="split"] {
    grid-template-columns: minmax(0, 1fr);
  }
}


/* bundled from styles/routes/calendar.css */
/*
 * CALENDAR ROUTE CSS CONTRACT
 * Import hub only for calendar-adjacent route surfaces.
 */
/* bundled from styles/routes/calendar.core.css */
.view-calendar {
  position: relative;
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
  align-items: stretch;
  min-width: 0;
}

.resource-rail,
.calendar-stage {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface);
  box-shadow: var(--shadow);
}

.resource-rail {
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - 100px);
  overflow: hidden;
}

.rail-section {
  padding: var(--space-4);
  border-bottom: 1px solid var(--hairline);
}

.rail-section-fill {
  min-height: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.calendar-stage {
  min-height: calc(100vh - 100px);
  min-width: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.calendar-toolbar {
  padding: 16px 18px 12px;
  border-bottom: 1px solid var(--hairline);
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  min-width: 0;
}

.month-controls {
  gap: var(--space-2);
  min-width: 0;
}

#calendarTitle {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-title-lg);
  line-height: 1.25;
}

#rangeCaption {
  margin: 2px 0 0;
  color: var(--muted);
  font-size: var(--font-size-md);
}

.toolbar-actions {
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.calendar-meta {
  min-height: 44px;
  padding: 10px 18px;
  border-bottom: 1px solid var(--hairline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.legend-row span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--body);
}

.legend-dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-pill);
  display: inline-block;
}

.tone-checkout-photo {
  background: var(--photo-needed);
}

.tone-extension-approval {
  background: var(--color-state-orange-700);
}

.tone-checked {
  background: var(--available);
}

.tone-return-photo,
.tone-return {
  background: var(--return-photo-needed);
}

.calendar-surface {
  flex: 1;
  min-height: 0;
  overflow: auto;
  touch-action: pan-y;
  overscroll-behavior: contain;
}

.calendar-weekdays,
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(106px, 1fr));
}

.calendar-weekdays {
  position: sticky;
  top: 0;
  z-index: 4;
  background: var(--surface);
  border-bottom: 1px solid var(--hairline);
}

.calendar-swipe-viewport {
  width: 100%;
  height: calc(100% - 35px);
  min-width: 0;
  overflow: hidden;
}

.calendar-swipe-track {
  width: 300%;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  transform: translateX(calc(-33.333333% + var(--calendar-swipe-offset, 0px)));
}

.calendar-swipe-pane {
  position: relative;
  min-width: 0;
  pointer-events: none;
}

.calendar-swipe-track,
.calendar-swipe-pane,
.calendar-swipe-pane .calendar-grid {
  height: 100%;
}

.calendar-swipe-pane.is-current {
  pointer-events: auto;
}

.calendar-swipe-pane[data-calendar-swipe-pane="prev"]::after,
.calendar-swipe-pane[data-calendar-swipe-pane="next"]::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 2;
  width: 2px;
  background: var(--hairline-strong);
  box-shadow: 0 0 0 1px var(--color-route-brand-tint-08);
  pointer-events: none;
}

.calendar-swipe-pane[data-calendar-swipe-pane="prev"]::after {
  right: 0;
}

.calendar-swipe-pane[data-calendar-swipe-pane="next"]::before {
  left: 0;
}

.weekday {
  padding: 9px 10px;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  text-align: center;
}

.weekday.is-sunday {
  color: var(--weekend-sunday);
}

.weekday.is-saturday {
  color: var(--weekend-saturday);
}

.day-cell {
  position: relative;
  isolation: isolate;
  min-height: 132px;
  border: 0;
  border-right: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  padding: 9px;
  background: var(--color-neutral-0);
  text-align: left;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 6px;
  appearance: none;
  transition:
    background-color var(--motion-base) var(--motion-ease),
    outline-color var(--motion-base) var(--motion-ease),
    box-shadow var(--motion-base) var(--motion-ease);
}

.ui-calendar-day-cell::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border: 1.5px solid var(--calendar-selected-border);
  border-radius: var(--radius-control-small);
  pointer-events: none;
  opacity: 0;
  transform: scale(0.985);
  transform-origin: center;
  transition:
    opacity var(--motion-calendar-fade) var(--motion-ease),
    transform var(--motion-base) var(--motion-ease),
    border-color var(--motion-base) var(--motion-ease),
    box-shadow var(--motion-base) var(--motion-ease);
}

.ui-calendar-day-cell > * {
  position: relative;
  z-index: 1;
}

.day-cell:nth-child(7n) {
  border-right: 0;
}

.day-cell.is-muted {
  background: var(--color-calendar-disabled-day-bg);
  color: var(--muted);
}

.day-cell.is-selected {
  outline: 0;
  background: var(--color-neutral-0);
  z-index: 1;
}

.day-cell.is-selected::after {
  opacity: 1;
  transform: scale(1);
  box-shadow: none;
}

.ui-calendar-day-cell.is-selection-entering::after {
  opacity: 0;
  transform: scale(0.985);
}

.day-cell.is-today .day-number {
  background: var(--primary);
  color: var(--color-neutral-0);
}

.day-number {
  width: 24px;
  min-width: 24px;
  height: 24px;
  border-radius: var(--radius-pill);
  padding: 0;
  align-self: center;
  display: inline-grid;
  place-items: center;
  box-sizing: border-box;
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--ink);
}

.day-cell.is-sunday .day-number {
  color: var(--weekend-sunday);
}

.day-cell.is-saturday .day-number {
  color: var(--weekend-saturday);
}

.day-cell.is-today .day-number {
  color: var(--color-neutral-0);
}

.day-events {
  position: relative;
  z-index: 1;
  display: grid;
  gap: var(--space-1);
  min-width: 0;
}

.calendar-grid .day-events {
  gap: 3px;
}

.day-conflict-warning {
  width: 20px;
  height: 20px;
  border-radius: var(--radius-pill);
  background: var(--color-state-orange-100);
  color: var(--color-route-text-orange-750);
  display: inline-grid;
  place-items: center;
  box-shadow: inset 0 0 0 1px var(--color-calendar-conflict-warning-ring);
}

.day-conflict-warning svg,
.day-conflict-warning-icon {
  width: 13px;
  height: 13px;
  stroke-width: 2.4;
}

.calendar-feed-warning {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 10px;
  padding: 9px 11px;
  border: 1px solid var(--color-state-warning-border);
  border-radius: var(--radius-md);
  background: var(--color-state-warning-bg);
  color: var(--color-state-warning-text);
  font-size: 0.82rem;
  font-weight: 700;
}

.calendar-feed-warning svg {
  width: 15px;
  height: 15px;
  flex: 0 0 auto;
}

.week-layout,
.agenda-layout {
  padding: 14px;
  display: grid;
  gap: 10px;
}

.week-layout {
  grid-template-columns: repeat(7, minmax(130px, 1fr));
}

.week-day-card,
.agenda-row {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  padding: var(--space-3);
  background: var(--surface);
}

.week-day-card.is-selected {
  border-color: var(--focus);
  background: var(--ku-crimson-soft);
}

.week-day-card h3,
.agenda-row h3 {
  margin: 0 0 10px;
  color: var(--ink);
  font-size: var(--font-size-lg);
}

.agenda-row {
  display: grid;
  grid-template-columns: 120px 1fr auto;
  gap: 14px;
  align-items: center;
}

.detail-panel {
  min-height: calc(100vh - 100px);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.detail-panel-header {
  justify-content: space-between;
  gap: 10px;
}

.selected-agenda {
  display: grid;
  gap: 10px;
}

.agenda-card,
.record-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  padding: var(--space-3);
  background: var(--surface);
}

.agenda-card {
  display: grid;
  gap: var(--space-2);
}

.agenda-card.is-empty {
  background: var(--surface-muted);
}

.agenda-card-header,
.record-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}

.rental-record .record-card-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  column-gap: var(--space-3);
}

.rental-record .record-card-header > div {
  min-width: 0;
}

.rental-record .status-chip {
  justify-self: end;
  align-self: start;
  margin-top: 2px;
}

.rental-period-meta {
  max-width: 100%;
  margin-top: 3px;
  color: var(--ink);
  font-size: var(--font-size-md);
  line-height: 1.35;
  font-weight: var(--font-weight-strong);
}

.rental-period-block {
  margin-top: 7px;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 7px;
}

.period-node {
  min-width: 132px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-bg-subtle);
  padding: 7px 9px;
  display: grid;
  gap: 2px;
}

.period-node em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: var(--font-weight-strong);
  line-height: 1.2;
}

.period-node strong {
  color: var(--ink);
  font-size: var(--font-size-md);
  line-height: 1.25;
}

.period-node b {
  color: var(--ku-crimson-dark);
  font-size: var(--font-size-lg);
  line-height: 1.15;
}

.period-arrow {
  align-self: center;
  color: var(--muted);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
}

.rental-drawer {
  margin-top: auto;
  display: grid;
  gap: 14px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  padding: 14px;
  background: var(--surface);
}

.drawer-heading {
  justify-content: space-between;
  gap: 10px;
}

.date-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.selection-summary {
  border: 1px dashed var(--hairline-strong);
  border-radius: var(--radius-panel);
  padding: 10px;
  background: var(--color-bg-subtle);
  transition:
    border-color var(--motion-base) var(--motion-ease),
    background-color var(--motion-base) var(--motion-ease),
    box-shadow var(--motion-base) var(--motion-ease);
}

.selection-summary ul {
  margin: 8px 0 0;
  padding-left: 18px;
}

.selection-summary li {
  margin: 4px 0;
  font-size: var(--font-size-md);
}

.selected-date-inline {
  margin-bottom: 10px;
  border: 1px solid var(--rental-neutral-border);
  border-radius: var(--radius-panel);
  background: var(--rental-neutral-surface);
  padding: 9px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.selected-date-input-field {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  align-items: center;
}

.selected-date-input-field .input {
  min-height: var(--control-height-search);
}

.selected-date-inline span {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.selected-date-inline strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
}

.rental-chapter .input,
.rental-chapter .textarea {
  border-color: var(--rental-neutral-border-strong);
  background-color: var(--rental-neutral-surface);
}

.duration-status,
.approval-summary {
  margin-top: 9px;
  border: 1px solid var(--color-state-green-200);
  border-radius: var(--radius-panel);
  background: var(--color-state-green-50);
  color: var(--color-route-text-green-700);
  padding: 8px 10px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  line-height: 1.35;
  transition:
    border-color var(--motion-base) var(--motion-ease),
    background-color var(--motion-base) var(--motion-ease),
    color var(--motion-base) var(--motion-ease);
}

.duration-status.needs-approval,
.approval-summary.needs-approval {
  border-color: var(--color-state-orange-200);
  background: var(--color-state-orange-50);
  color: var(--color-route-text-orange-800);
}

.duration-status.is-invalid {
  border-color: var(--color-state-red-200);
  background: var(--color-state-red-100);
  color: var(--color-route-text-red-650);
}

.approval-warning-modal {
  z-index: 120;
}

.approval-warning-panel {
  width: min(440px, calc(100vw - 36px));
  grid-template-rows: auto 1fr;
}

.approval-warning-body {
  padding: var(--space-4);
  display: grid;
  gap: 14px;
}

.approval-warning-body p {
  margin: 0;
  color: var(--body);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-strong);
  line-height: 1.5;
}

.approval-warning-actions {
  display: flex;
  gap: var(--space-2);
  justify-content: flex-end;
}

.checkbox-line {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: var(--space-2);
  align-items: start;
  color: var(--body);
  font-size: var(--font-size-md);
  line-height: 1.45;
}

.compact-view {
  margin: 0 auto;
  padding: 18px;
  gap: var(--space-4);
}

.page-heading {
  justify-content: space-between;
  gap: 14px;
  border-bottom: 1px solid var(--hairline);
  padding-bottom: 14px;
}

.page-heading-title-with-back {
  min-width: 0;
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  column-gap: 10px;
  align-items: center;
}

.page-heading-title-with-back .route-back-button {
  grid-row: 1;
  align-self: center;
}

.calendar-month-nav-button:hover:not(:disabled) {
  border-color: var(--ku-crimson-border);
  background: var(--ku-crimson-soft);
  color: var(--primary);
  box-shadow: var(--shadow-panel-hover);
}

.calendar-toolbar-filter-button:hover:not(:disabled) {
  border-color: var(--ku-crimson-border);
  background: var(--ku-crimson-soft);
  color: var(--primary);
  box-shadow: var(--shadow-panel-hover);
}

.route-back-button:hover:not(:disabled) {
  border-color: var(--ku-crimson-border);
  background: var(--ku-crimson-soft);
  color: var(--primary);
  box-shadow: var(--shadow-panel-hover);
}

.page-heading-title-with-back h1 {
  align-self: center;
}

.route-back-button {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
}

/* bundled from styles/routes/calendar.tablet.css */
/*
 * CALENDAR TABLET CSS CONTRACT
 * Tablet calendar split width and event density adjustments.
 */
@media (min-width: 521px) and (max-width: 1023px) {
  :root {
    --calendar-main-min-width: 392px;
    --calendar-side-panel-max-width: 640px;
  }

  .split-toolbar {
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 10px;
  }

  .calendar-content-split {
    grid-template-columns: minmax(var(--calendar-main-min-width), 1fr) 8px minmax(var(--calendar-side-panel-min-width), var(--calendar-side-panel-width));
  }

  .calendar-content-split .calendar-weekdays,
  .calendar-content-split .calendar-grid {
    grid-template-columns: repeat(7, minmax(56px, 1fr));
  }

  .event-pill strong {
    font-size: 11px;
  }

  .event-pill span {
    font-size: 10px;
  }
}

/* bundled from styles/routes/calendar.mobile-label.css */
/*
 * CALENDAR MOBILE LABEL CSS CONTRACT
 * Mobile month label and calendar-surface touch overrides.
 */
.mobile-month-label {
  display: none;
  min-height: 42px;
  align-items: center;
  padding: 0 12px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-3);
  background: var(--surface);
  color: var(--ink);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

@media (max-width: 1023px) {
  .calendar-surface {
    touch-action: pan-y;
  }
}

@media (max-width: 520px) {
  .calendar-toolbar {
    min-height: 72px;
  }

  .day-number {
    width: 22px;
    min-width: 22px;
    height: 22px;
    font-size: 11px;
  }

  .day-events {
    display: grid;
    width: 100%;
    gap: 2px;
  }

  .calendar-grid .event-pill-time {
    display: none;
  }

  .mobile-month-label {
    display: flex;
    min-width: 0;
    min-height: var(--control-height-search);
    padding: 0 10px;
    font-size: 14px;
  }
}

/* bundled from styles/routes/calendar.toolbar.css */
/*
 * CALENDAR TOOLBAR CSS CONTRACT
 * Calendar toolbar, month heading, filter bar, and compact toolbar breakpoints.
 */
/* Calendar toolbar source block: status-first header and filter controls. */
.split-toolbar {
  grid-template-columns: max-content minmax(0, 1fr) auto;
  grid-template-areas:
    "controls months actions"
    "filters filters filters";
  align-items: center;
  row-gap: 10px;
}

.split-toolbar .month-controls {
  grid-area: controls;
  width: fit-content;
  display: grid;
  grid-template-columns: 42px max-content 42px;
  align-items: center;
  gap: 7px;
}

.calendar-month-heading {
  min-width: 0;
  display: grid;
  gap: 1px;
  justify-items: center;
  text-align: center;
}

.calendar-month-heading #calendarTitle {
  margin: 0;
  color: var(--ink);
  font-size: 23px;
  line-height: 1.15;
  font-weight: var(--font-weight-strong);
  letter-spacing: 0;
  white-space: nowrap;
}

.calendar-month-heading #rangeCaption {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.calendar-month-heading #rangeCaption:empty {
  display: none;
}

.month-controls .mobile-month-label {
  display: none;
}

.calendar-toolbar-actions {
  grid-area: actions;
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.calendar-filter-bar {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  overflow-x: auto;
  padding: 0 1px 2px;
  scrollbar-width: none;
}

.calendar-toolbar-today-button {
  min-height: var(--control-height-search);
  padding: 0 16px;
  white-space: nowrap;
}

.day-cell-header {
  width: 100%;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}

.day-cell.is-muted,
.day-cell.is-muted .day-number {
  color: var(--color-calendar-toolbar-disabled-text) !important;
}

.day-cell.is-muted .event-pill {
  opacity: 0.42;
}

@media (max-width: 1023px) {
  .split-toolbar {
    grid-template-columns: max-content minmax(0, 1fr) auto;
    grid-template-areas:
      "controls months actions"
      "filters filters filters";
  }

  .split-toolbar .month-controls {
    width: fit-content;
    grid-template-columns: 42px max-content 42px;
    gap: 7px;
  }

  .calendar-month-heading #calendarTitle {
    font-size: var(--font-size-title-lg);
  }

  .calendar-month-heading #rangeCaption {
    display: none;
  }

}

@media (max-width: 1023px) {
  .split-toolbar {
    column-gap: 8px;
    grid-template-columns: max-content minmax(0, 1fr) auto;
    grid-template-areas:
      "controls months actions"
      "filters filters filters";
  }

  .split-toolbar .month-controls {
    grid-template-columns: 36px max-content 36px;
    gap: 5px;
  }

  .split-toolbar .icon-button,
  .calendar-toolbar-filter-button {
    width: 36px;
    height: 36px;
    min-width: 36px;
    min-height: 36px;
  }

  .calendar-month-heading #calendarTitle {
    font-size: var(--font-size-title-sm);
  }

  .calendar-toolbar-actions {
    gap: 6px;
  }

  .calendar-toolbar-today-button {
    min-height: 36px;
    padding: 0 10px;
    font-size: 13px;
  }

  .month-strip {
    gap: 6px;
    min-height: 42px;
  }

  .month-strip::before,
  .month-strip::after {
    flex-basis: 0;
  }

  .month-strip-button,
  .month-year-separator {
    min-height: var(--control-height-filter);
    padding: 0 10px;
    font-size: 12px;
  }
}

@media (max-width: 520px) {
  .split-toolbar {
    column-gap: 6px;
    grid-template-columns: max-content minmax(0, 1fr) auto;
    grid-template-areas:
      "controls months actions"
      "filters filters filters";
  }

  .split-toolbar .month-controls {
    width: fit-content;
    grid-template-columns: 34px max-content 34px;
    gap: 4px;
  }

  .split-toolbar .icon-button,
  .calendar-toolbar-filter-button {
    width: var(--control-height-small);
    height: var(--control-height-small);
    min-width: var(--control-height-small);
    min-height: var(--control-height-small);
  }

  .calendar-toolbar-actions {
    display: inline-flex;
    justify-self: end;
    gap: 5px;
  }

  .calendar-toolbar-today-button {
    width: auto;
    min-height: var(--control-height-small);
    padding: 0 8px;
    font-size: 12px;
  }

  .calendar-month-heading #calendarTitle {
    max-width: 86px;
    overflow: hidden;
    font-size: 18px;
    text-overflow: ellipsis;
  }

  .month-strip {
    gap: 5px;
    min-height: 40px;
  }

  .month-strip-button,
  .month-year-separator {
    min-height: var(--control-height-compact);
    padding: 0 8px;
    font-size: 11px;
  }

  .calendar-scope-toggle,
  .calendar-filter-chip {
    min-height: var(--control-height-filter);
    padding: var(--control-padding-block-compact) 10px;
    font-size: 11px;
  }
}

/* bundled from styles/routes/calendar.mobile-split.css */
/*
 * CALENDAR MOBILE SPLIT CSS CONTRACT
 * Mobile calendar split-pane and create-side behavior.
 */
@media (min-width: 1024px) {
  .view-calendar.is-creating-side .floating-create-button {
    display: none;
  }
}

@media (max-width: 1023px) {
  body:has([data-panel="calendar"].is-visible) .calendar-content-split {
    display: block;
    height: 100%;
  }

  body:has([data-panel="calendar"].is-visible) .calendar-main-column {
    height: 100%;
    border-right: 0;
  }

  body:has([data-panel="calendar"].is-visible) .calendar-side-panel,
  body:has([data-panel="calendar"].is-visible) .calendar-side-resizer {
    display: none;
  }

  body:has([data-panel="calendar"].is-visible) .view-calendar.is-creating-side .floating-create-button {
    display: grid;
  }

  body:has([data-panel="calendar"].is-visible) .calendar-grid .event-pill {
    min-height: 24px;
    padding: 3px 4px;
  }

  body:has([data-panel="calendar"].is-visible) .calendar-grid .event-pill span {
    display: none;
  }

  body:has([data-panel="calendar"].is-visible) .calendar-grid .event-pill strong {
    font-size: 10px;
  }
}

@media (max-width: 520px) {
  .split-toolbar {
    grid-template-columns: auto minmax(0, 1fr);
    grid-template-areas:
      "controls months"
      "months months";
    align-items: center;
  }

  .calendar-toolbar {
    min-height: 96px;
  }
}

/* bundled from styles/routes/calendar.account-dashboard.css */
.member-page-heading {
  align-items: center;
}

.member-page-titlebar {
  min-width: 0;
  display: flex;
  align-items: baseline;
  gap: 18px;
  flex-wrap: wrap;
}

.member-inline-tabs {
  min-width: 0;
  display: flex;
  align-items: baseline;
  gap: 14px;
  flex-wrap: wrap;
}

.member-inline-tab {
  border: 0;
  background: transparent;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: var(--control-height-filter);
  padding: 0;
  font: inherit;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-strong);
  cursor: pointer;
}

.member-inline-tab strong {
  border-radius: var(--radius-pill);
  background: var(--surface-muted);
  color: inherit;
  padding: 2px 7px;
  font-size: 11px;
  line-height: 1.2;
}

.member-inline-tab.is-active {
  color: var(--ink);
}

.record-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(220px, 1fr));
  gap: 12px;
}

.account-dashboard {
  grid-column: 1 / -1;
  display: grid;
  gap: 12px;
}

.account-dashboard-compact {
  display: grid;
  gap: 12px;
}

.account-dashboard-desktop {
  display: none;
}

.account-desktop-profile-card {
  width: 100%;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  color: inherit;
  font: inherit;
  padding: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  text-align: left;
  cursor: pointer;
}

.account-desktop-profile-card:hover {
  border-color: var(--hairline-strong);
  box-shadow: var(--shadow-panel-raised);
}

.account-desktop-profile-card:focus-visible {
  outline: 3px solid var(--color-account-dashboard-focus-outline);
  outline-offset: 2px;
}

.account-desktop-profile-main {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 14px;
}

.account-desktop-avatar {
  width: 54px;
  height: 54px;
  border-radius: var(--radius-pill);
  background: var(--primary);
  color: var(--color-text-on-action);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-title-lg);
  font-weight: var(--font-weight-strong);
  flex: 0 0 auto;
}

.account-desktop-profile-main h2 {
  margin: 0 0 5px;
  color: var(--ink);
  font-size: 23px;
  line-height: 1.2;
}

.account-desktop-profile-main p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
}

.account-desktop-metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.account-desktop-metric {
  min-width: 0;
  min-height: 86px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  color: inherit;
  padding: 13px 14px;
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) 18px;
  gap: 12px;
  align-items: center;
  text-align: left;
}

.account-desktop-metric > svg {
  width: 18px;
  height: 18px;
  color: var(--muted);
}

.account-desktop-metric-icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.account-desktop-metric-icon svg {
  width: 23px;
  height: 23px;
}

.account-desktop-metric em,
.account-desktop-metric strong,
.account-desktop-metric small {
  display: block;
  min-width: 0;
  font-style: normal;
}

.account-desktop-metric em {
  color: var(--ink);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
  line-height: 1.2;
}

.account-desktop-metric strong {
  margin-top: 2px;
  color: var(--ink);
  font-size: 23px;
  line-height: 1.1;
}

.account-desktop-metric small {
  margin-top: 4px;
  color: var(--muted);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
  line-height: 1.25;
}

.account-desktop-metric.tone-blue .account-desktop-metric-icon {
  background: var(--color-dashboard-metric-blue-bg);
  color: var(--color-dashboard-metric-blue-text);
}

.account-desktop-metric.tone-orange .account-desktop-metric-icon {
  background: var(--color-dashboard-metric-orange-bg);
  color: var(--color-dashboard-metric-orange-text);
}

.account-desktop-metric.tone-approval .account-desktop-metric-icon,
.account-desktop-metric.tone-purple .account-desktop-metric-icon {
  background: var(--color-dashboard-metric-approval-bg);
  color: var(--color-dashboard-metric-approval-text);
}

.account-desktop-metric.tone-danger .account-desktop-metric-icon,
.account-desktop-metric.tone-red .account-desktop-metric-icon {
  background: var(--color-dashboard-metric-danger-bg);
  color: var(--color-dashboard-metric-danger-text);
}

.account-desktop-workspace {
  display: grid;
  grid-template-columns: minmax(340px, 1.18fr) minmax(260px, 0.84fr) minmax(260px, 0.72fr);
  gap: 12px;
  align-items: stretch;
}

.account-desktop-workspace > .account-panel {
  height: 100%;
}

.account-desktop-project-panel {
  grid-template-rows: auto minmax(0, 1fr);
  align-content: stretch;
}

.account-desktop-workspace .account-notification-panel {
  grid-template-rows: auto minmax(0, 1fr);
  align-content: stretch;
}

.account-desktop-policy-panel {
  grid-template-rows: auto minmax(0, 1fr);
  align-content: stretch;
}

.account-desktop-policy-panel {
  padding: 11px 12px;
  gap: 8px;
}

.account-desktop-menu-list {
  display: grid;
  gap: 8px;
}

.account-desktop-project-panel .ui-preview-list {
  grid-auto-rows: minmax(68px, auto);
}

.account-desktop-workspace .account-notification-list {
  align-content: start;
  grid-auto-rows: minmax(63px, auto);
}

.account-desktop-policy-panel .account-desktop-menu-list {
  gap: 0;
  grid-auto-rows: minmax(68px, auto);
  align-content: start;
}

.account-desktop-schedule-row {
  width: 100%;
  appearance: none;
  border-top: 1px solid var(--hairline);
  border-right: 0;
  border-bottom: 0;
  border-left: 0;
  background: transparent;
  color: inherit;
  padding: 10px 0;
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr) auto 18px;
  gap: 12px;
  align-items: center;
  text-align: left;
  font: inherit;
  cursor: pointer;
  min-height: 0;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease);
}

.account-desktop-schedule-row:hover {
  background: var(--color-brand-tint-bg-subtle);
}

.account-desktop-schedule-row:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 3px;
  border-radius: var(--radius-3);
}

.account-desktop-schedule-row:first-child {
  border-top: 0;
  padding-top: 0;
}

.account-desktop-schedule-chevron {
  width: 18px;
  height: 18px;
  color: var(--muted);
  stroke-width: 2.5;
  justify-self: end;
}

.account-desktop-date-block {
  min-height: 44px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-2);
  background: var(--surface-muted);
  padding: 6px 8px;
  display: grid;
  align-content: center;
  text-align: center;
}

.account-desktop-date-block strong,
.account-desktop-date-block span {
  display: block;
  color: var(--body);
  font-size: 12px;
  line-height: 1.2;
}

.account-desktop-date-block span {
  margin-top: 3px;
  color: var(--muted);
  font-weight: var(--font-weight-strong);
}

.account-desktop-schedule-main {
  min-width: 0;
}

.account-desktop-schedule-main strong,
.account-desktop-schedule-main small {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-desktop-schedule-main strong {
  color: var(--ink);
  font-size: 14px;
  line-height: 1.25;
}

.account-desktop-schedule-main small {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.account-desktop-menu-row {
  width: 100%;
  min-height: 50px;
  border: 0;
  border-top: 1px solid var(--hairline);
  background: transparent;
  color: inherit;
  font: inherit;
  padding: 7px 0;
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr) auto 18px;
  gap: 9px;
  align-items: center;
  text-align: left;
  cursor: pointer;
  min-height: 0;
}

.account-desktop-menu-row:first-child {
  border-top: 0;
  padding-top: 0;
}

.account-desktop-policy-panel .account-desktop-menu-row {
  border: 0;
  border-radius: 0;
  padding: 9px;
}

.account-desktop-policy-panel .account-desktop-menu-row:first-child {
  border-top: 0;
  padding-top: 9px;
}

.account-desktop-policy-panel .account-desktop-menu-row > [data-lucide]:last-child {
  grid-column: -1;
  justify-self: end;
}

.account-desktop-menu-list svg {
  width: 18px;
  height: 18px;
  color: var(--muted);
}

.account-desktop-menu-list strong,
.account-desktop-menu-list small {
  display: block;
  min-width: 0;
}

.account-desktop-menu-list strong {
  color: var(--ink);
  font-size: 13px;
  line-height: 1.2;
}

.account-desktop-menu-list small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
  line-height: 1.25;
}

.account-dashboard-heading {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 12px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.account-dashboard-heading h2 {
  margin: 2px 0 4px;
  color: var(--ink);
  font-size: var(--font-size-title-lg);
  line-height: 1.2;
}

.account-dashboard-heading p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
}

.account-metric-button {
  width: 100%;
  appearance: none;
  color: inherit;
  font: inherit;
  cursor: pointer;
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.account-metric-button:hover {
  border-color: var(--ku-crimson-border);
  background: var(--color-bg-surface);
  box-shadow: var(--shadow-panel-hover);
  transform: translateY(-1px);
}

.account-metric-button:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.account-metric-attention-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-left: 6px;
  border-radius: var(--radius-pill);
  background: var(--color-attention-dot-bg);
  box-shadow: 0 0 0 3px var(--color-attention-dot-ring);
  vertical-align: 1px;
}

.account-compact-action-list {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  overflow: hidden;
  gap: 0;
}

.account-compact-action-row {
  min-height: 54px;
}

.account-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(250px, 0.85fr);
  gap: 12px;
}

.account-panel {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 12px;
  display: grid;
  gap: 10px;
  align-content: start;
}

.account-panel-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.account-desktop-workspace > .account-panel > .account-panel-heading {
  padding-left: 6px;
}

/* bundled from styles/routes/calendar.notifications.css */
.account-panel-heading-actions,
.modal-header-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.account-panel-heading h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.2;
}

.account-panel-heading strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.account-notification-list,
.account-policy-list,
.account-schedule-list {
  display: grid;
  gap: 8px;
}

.account-notification-row,
.account-schedule-row {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-neutral-0);
  padding: 9px;
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr);
  gap: 9px;
  align-items: flex-start;
}

.account-notification-row {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  width: 100%;
  color: inherit;
  font: inherit;
  text-align: left;
  position: relative;
  padding-right: 9px;
  cursor: pointer;
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease);
}

button.account-notification-row {
  appearance: none;
}

.account-notification-row:hover {
  border-color: var(--hairline-strong);
  background: var(--color-bg-subtle);
}

.account-notification-row:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.account-notification-row.is-preview {
  grid-template-columns: minmax(0, 1fr) auto;
  padding-right: 9px;
}

.notification-history-list .account-notification-row:not(.is-empty) {
  grid-template-columns: 34px minmax(0, 1fr) auto;
  align-items: start;
  gap: 10px;
  padding-left: 9px;
}

.account-notification-row > div {
  min-width: 0;
}

.account-notification-type-icon {
  width: var(--control-height-small);
  height: var(--control-height-small);
  display: grid;
  place-items: center;
  border-radius: var(--radius-3);
  background: var(--color-notification-type-default-bg);
  color: var(--ku-crimson);
}

.account-notification-type-icon.is-approval {
  background: var(--color-notification-type-approval-bg);
  color: var(--color-state-blue-600);
}

.account-notification-type-icon.is-project {
  background: var(--color-notification-type-project-bg);
  color: var(--color-notification-type-project-text);
}

.account-notification-type-icon svg {
  width: 18px;
  height: 18px;
  stroke-width: 2.4;
}

.account-notification-row.is-preview small {
  min-width: 0;
}

.account-notification-row.is-preview small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-notification-row.is-empty {
  grid-template-columns: 10px minmax(0, 1fr);
  padding-right: 9px;
  cursor: default;
}

.account-notification-empty-state {
  min-height: 68px;
}

.account-notification-row.is-empty:hover {
  border-color: var(--hairline);
  background: var(--color-neutral-0);
}

.account-notification-row.is-confirmed {
  background: var(--surface-muted);
  color: var(--muted);
}

.account-notification-row.is-confirmed .status-dot {
  opacity: 0.45;
}

.account-notification-row.is-confirmed .account-notification-type-icon {
  opacity: 0.62;
}

.notification-row-meta {
  justify-self: end;
  align-self: start;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
  line-height: 1;
  white-space: nowrap;
}

.notification-row-meta time {
  display: block;
}

.notification-unread-dot {
  width: 8px;
  height: 8px;
  flex: 0 0 auto;
  border-radius: var(--radius-pill);
  background: var(--color-route-danger-bg);
}

.account-schedule-row {
  width: 100%;
  appearance: none;
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease);
}

.account-schedule-row:hover {
  border-color: var(--hairline-strong);
  background: var(--surface-muted);
}

.account-schedule-row:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.account-notification-row strong,
.account-policy-row strong,
.account-schedule-row strong,
.account-schedule-empty strong {
  display: block;
  color: var(--ink);
  font-size: var(--font-size-md);
  line-height: 1.25;
}

.account-notification-row small,
.account-policy-row span,
.account-schedule-row small,
.account-schedule-empty span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  line-height: 1.35;
}

.account-schedule-empty {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 10px;
}

.notification-modal-panel {
  max-width: min(640px, calc(100vw - 24px));
}

.notification-modal-panel.is-detail-mode {
  grid-template-rows: minmax(0, 1fr);
}

.notification-modal-panel.is-detail-mode > .modal-header {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.notification-modal-panel.is-detail-mode .event-summary-body {
  padding: 0;
  overflow: visible;
}

.policy-detail-modal-panel {
  max-width: min(640px, calc(100vw - 24px));
  grid-template-rows: auto minmax(0, 1fr);
}

.notification-modal-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.notification-control-groups {
  min-width: 0;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 7px;
}

.notification-filter-tag-group {
  max-width: 100%;
  padding: 2px 0;
  overflow-x: auto;
  scrollbar-width: none;
}

.notification-filter-tag-group::-webkit-scrollbar {
  display: none;
}

.notification-sort-row {
  display: flex;
  justify-content: flex-end;
}

.notification-sort-toggle:hover {
  border-color: var(--primary);
  background: var(--surface);
  color: var(--primary);
  box-shadow: var(--shadow-control);
}

.notification-preview-actions {
  padding-top: 2px;
}

.notification-preview-action-button {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  color: var(--body);
  padding: 9px 11px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 10px;
  align-items: center;
  text-align: left;
  font: inherit;
  cursor: pointer;
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease);
}

.notification-preview-action-button:hover {
  border-color: var(--ku-crimson-border);
  background: var(--color-neutral-0);
  box-shadow: 0 8px 18px var(--color-route-shadow-admin-micro);
}

.notification-preview-action-button:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.notification-preview-action-button span {
  min-width: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.notification-preview-action-button strong {
  color: var(--ink);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.notification-preview-action-button svg {
  width: 16px;
  height: 16px;
  color: var(--primary);
  stroke-width: 2.5;
}

.policy-preview-actions {
  display: flex;
  justify-content: flex-end;
  padding-top: 2px;
}

.notification-history-list {
  gap: 10px;
}

.notification-detail-card {
  position: relative;
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 18px;
  display: grid;
  gap: 14px;
}

.notification-detail-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: var(--control-size-icon-md);
  height: var(--control-size-icon-md);
  background: var(--color-bg-subtle);
  border-color: var(--hairline-strong);
  color: var(--ink);
  z-index: 1;
}

.notification-detail-close:hover {
  border-color: var(--ku-crimson-border);
  background: var(--ku-crimson-soft);
}

.notification-detail-heading {
  position: relative;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 12px;
  align-items: flex-start;
  padding-right: 48px;
}

.notification-detail-icon {
  width: var(--control-height-small);
  height: var(--control-height-small);
  display: grid;
  place-items: center;
  border-radius: var(--radius-3);
  background: var(--ku-crimson-soft);
  color: var(--ku-crimson);
}

.notification-detail-icon.is-photo {
  background: var(--color-notification-type-default-bg);
  color: var(--ku-crimson);
}

.notification-detail-icon.is-approval {
  background: var(--color-notification-type-approval-bg);
  color: var(--color-state-blue-600);
}

.notification-detail-icon.is-project {
  background: var(--color-notification-type-project-bg);
  color: var(--color-notification-type-project-text);
}

.notification-detail-icon svg {
  width: 18px;
  height: 18px;
  stroke-width: 2.4;
}

.notification-detail-heading h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.25;
}

.notification-detail-heading p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  line-height: 1.45;
}

.notification-detail-body {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 12px;
  color: var(--body);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  line-height: 1.5;
}

.notification-detail-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.notification-shortcut-context {
  min-width: 0;
  flex: 1 1 220px;
  display: flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}

.notification-shortcut-context small {
  flex: 0 0 auto;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.notification-shortcut-separator {
  flex: 0 0 auto;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.notification-shortcut-context strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--ink);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-emphasis);
}

.notification-detail-action-buttons {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 8px;
}

.notification-shortcut-button {
  min-width: 0;
  padding-inline: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
  white-space: nowrap;
  text-decoration: none;
}

@media (max-width: 520px) {
  .notification-detail-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .notification-shortcut-context {
    flex-basis: auto;
  }

  .notification-detail-action-buttons {
    width: 100%;
  }

  .notification-detail-actions .compact {
    width: 100%;
  }
}

.status-dot {
  width: 9px;
  height: 9px;
  border-radius: var(--radius-pill);
  background: var(--muted);
  margin-top: 4px;
}

/* bundled from styles/routes/calendar.modal-status.css */
/* bundled from styles/routes/calendar.modal-status.policy.css */
/*
 * CALENDAR MODAL STATUS OWNER CSS CONTRACT: calendar.modal-status.policy.css
 * Ordered chunk split from calendar.modal-status.css. Preserve import order.
 */
.status-dot.status-checkout_photo_needed,
.status-dot.status-extension_approval_needed {
  background: var(--weekend-sunday);
}

.status-dot.status-checked_out {
  background: var(--available);
}

.status-dot.status-return_photo_needed {
  background: var(--return-photo-needed);
}

.status-dot.status-returned {
  background: var(--archive);
}

.account-policy-row {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 9px;
  display: grid;
  gap: 8px;
}

.account-policy-row.is-clear {
  border-color: var(--color-state-green-200);
  background: var(--color-state-green-50);
}

.account-policy-row.is-warning {
  border-color: var(--color-state-orange-200);
  background: var(--color-state-orange-50);
}

.account-policy-row.is-penalty {
  border-color: var(--color-state-red-200);
  background: var(--color-route-surface-red-25);
}

.account-policy-row-main {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.policy-action-chip {
  width: fit-content;
  border-radius: var(--radius-pill);
  padding: 3px 8px;
  font-size: 11px;
  font-weight: var(--font-weight-strong);
}

.account-policy-row span.policy-action-chip {
  margin-top: 0;
  line-height: 1.1;
}

.policy-action-chip.is-warning {
  background: var(--color-state-orange-100);
  color: var(--color-route-text-orange-800);
}

.policy-action-chip.is-penalty {
  background: var(--color-route-surface-red-100);
  color: var(--color-route-text-red-800);
}

.policy-row-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.policy-row-meta span {
  border: 1px solid var(--color-route-brand-tint-14);
  border-radius: var(--radius-pill);
  background: var(--color-route-surface-glass);
  padding: 3px 7px;
}

.policy-history-board,
.policy-history-page {
  display: grid;
  gap: 12px;
}

.policy-history-view .page-heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
}

.policy-history-view .page-heading > div {
  min-width: 0;
}

.policy-history-view .page-heading .secondary-button {
  width: auto;
  max-width: 100%;
  justify-self: end;
}

.policy-history-status-panel {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 14px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.policy-history-status-panel span,
.policy-history-list-heading span {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.policy-history-status-panel strong {
  display: block;
  margin-top: 4px;
  color: var(--ink);
  font-size: 22px;
  line-height: 1.2;
}

.policy-history-status-panel p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
  line-height: 1.45;
}

.policy-history-status-counts {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}

.policy-history-status-counts span {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--surface-muted);
  color: var(--body);
  padding: 5px 8px;
}

.policy-history-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.policy-history-summary-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 12px;
  display: grid;
  gap: 5px;
  min-width: 0;
}

.policy-history-summary-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.policy-history-summary-card strong {
  color: var(--ink);
  font-size: var(--font-size-title-sm);
  line-height: 1.2;
}

.policy-history-toolbar {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.policy-history-toolbar > span {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.policy-history-list {
  display: grid;
  gap: 10px;
}

.policy-history-list-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.policy-history-list-heading h2 {
  margin: 0;
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
}

/* bundled from styles/routes/calendar.modal-status.summary.css */
/*
 * CALENDAR MODAL STATUS OWNER CSS CONTRACT: calendar.modal-status.summary.css
 * Ordered chunk split from calendar.modal-status.css. Preserve import order.
 */
.policy-history-row {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 10px 12px;
  display: grid;
  grid-template-columns: 4px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  min-height: 66px;
}

.policy-history-row:hover {
  border-color: var(--color-route-brand-tint-22);
  background: var(--surface-muted);
}

.policy-history-row-marker {
  width: 4px;
  height: 38px;
  border-radius: var(--radius-pill);
  background: var(--color-route-warning-bg);
}

.policy-history-row.is-penalty .policy-history-row-marker {
  background: var(--color-route-danger-bg);
}

.policy-history-row-main {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.policy-history-row-title {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.policy-history-row-title h2 {
  min-width: 0;
  margin: 0;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.policy-history-row-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  min-width: 0;
}

.policy-history-row-meta span {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.policy-history-row-meta span + span::before {
  content: "·";
  margin-right: 6px;
  color: var(--muted);
}

.policy-history-row-side {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.policy-history-detected-at {
  flex: 0 0 auto;
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.policy-history-page {
  --policy-warning: var(--color-state-orange-600);
  --policy-warning-soft: var(--color-state-orange-50);
  --policy-penalty: var(--color-route-danger-bg);
  --policy-penalty-soft: var(--color-state-red-50);
  --policy-blue-soft: var(--color-state-blue-50);
  --policy-green: var(--color-state-green-700);
  --policy-green-soft: var(--color-state-green-50);
}

.policy-history-page .policy-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(330px, 0.48fr);
  gap: 12px;
  align-items: start;
}

.policy-history-page .policy-main-column {
  min-width: 0;
  display: grid;
  gap: 10px;
}

.policy-history-page .standing-strip {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-route-surface-white);
  padding: 14px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}

.policy-history-page .standing-main {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.policy-history-page .standing-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-3);
  background: var(--policy-green-soft);
  color: var(--policy-green);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}

.policy-history-page .standing-main span,
.policy-history-page .inspector-label {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-medium);
}

.policy-history-page .standing-main strong {
  display: block;
  margin-top: 2px;
  color: var(--ink);
  font-size: var(--font-size-title-sm);
  line-height: 1.2;
}

.policy-history-page .standing-main p {
  margin: 6px 0 0;
  color: var(--body);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
  line-height: 1.45;
}

.policy-history-page .standing-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.policy-history-page .quiet-button,
.policy-history-page .primary-button {
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-3);
  background: var(--color-route-surface-white);
  color: var(--body);
  min-height: var(--control-height-search);
  padding: 0 14px;
  font-size: 13px;
  font-weight: var(--font-weight-emphasis);
  cursor: pointer;
}

.policy-history-page .primary-button {
  border-color: var(--ku-crimson);
  background: var(--ku-crimson);
  color: var(--color-route-surface-white);
}

.policy-history-page .standing-actions .quiet-button,
.policy-history-page .standing-actions .primary-button {
  min-height: var(--control-height-filter);
  border-radius: var(--radius-control-small);
  padding: 0 11px;
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.policy-history-page .metric-row {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.policy-history-page .metric {
  border-color: var(--hairline);
}

.policy-history-page .metric .ui-mini-metric-copy {
  color: var(--muted);
  font-weight: var(--font-weight-medium);
}

.policy-history-page .metric .ui-mini-metric-copy strong {
  color: var(--ink);
  font-weight: var(--font-weight-strong);
}

.policy-history-page .metric.tone-total .ui-mini-metric-icon {
  color: var(--color-route-text-blue-900);
  background: var(--policy-blue-soft);
}

.policy-history-page .metric.tone-warning .ui-mini-metric-icon {
  color: var(--policy-warning);
  background: var(--policy-warning-soft);
}

/* bundled from styles/routes/calendar.modal-status.forms.css */
/*
 * CALENDAR MODAL STATUS OWNER CSS CONTRACT: calendar.modal-status.forms.css
 * Ordered chunk split from calendar.modal-status.css. Preserve import order.
 */
.policy-history-page .metric.tone-penalty .ui-mini-metric-icon {
  color: var(--policy-penalty);
  background: var(--policy-penalty-soft);
}

.policy-history-page .metric.tone-recent .ui-mini-metric-icon {
  color: var(--policy-green);
  background: var(--policy-green-soft);
}

.policy-history-page .content-grid {
  min-width: 0;
  display: grid;
}

.policy-history-page .list-panel,
.policy-history-page .inspector {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-route-surface-white);
}

.policy-history-page .list-panel {
  overflow: hidden;
}

.policy-history-page .list-heading {
  border-bottom: 1px solid var(--hairline);
  min-height: 50px;
  padding: 8px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.policy-history-page .list-heading h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.2;
}

.policy-history-page .list-heading span {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-emphasis);
}

.policy-history-page .list-heading-actions {
  display: inline-flex;
  align-items: center;
  gap: 14px;
}

.policy-history-page .filter-toggle-button {
  width: var(--control-height-compact);
  height: var(--control-height-compact);
  min-width: var(--control-height-compact);
  border: 1px solid var(--hairline);
  padding: 0;
  border-radius: var(--radius-control-small);
  color: var(--ku-crimson);
  background: var(--color-bg-subtle);
  display: grid;
  place-items: center;
}

.policy-history-page .filter-toggle-button.is-active,
.policy-history-page .filter-toggle-button[aria-expanded="true"] {
  border-color: var(--color-route-brand-tint-45);
  background: var(--color-route-surface-pink-75);
}

.policy-history-page .filter-toggle-button svg {
  width: 15px;
  height: 15px;
}

.policy-history-page .list-filter-panel {
  border-bottom: 1px solid var(--hairline);
  background: var(--color-bg-subtle);
  padding: 9px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.policy-history-page .list-filter-panel.is-collapsed {
  display: none;
}

.policy-history-page .policy-filter-options {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.policy-history-page .sort-button,
.policy-history-page .load-more-button {
  min-height: var(--control-height-compact);
  border: 1px solid var(--color-route-neutral-tint-16);
  border-radius: var(--radius-control-small);
  background: var(--color-bg-subtle);
  color: var(--body);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.policy-history-page .sort-button svg,
.policy-history-page .load-more-button svg {
  width: 15px;
  height: 15px;
  stroke-width: 2.3;
}

.policy-history-page .record-list {
  display: grid;
  align-content: start;
  grid-auto-rows: max-content;
  max-height: min(320px, calc(100vh - 555px));
  min-height: 212px;
  overflow: auto;
  overscroll-behavior: contain;
  background: var(--color-route-surface-white);
}

.policy-history-page .record-list.is-terminal {
  border-radius: 0 0 8px 8px;
}

.policy-history-page .record-row {
  width: 100%;
  min-width: 0;
  border: 0;
  border-bottom: 1px solid var(--hairline);
  border-radius: 0;
  background: var(--color-route-surface-white);
  padding: 11px 14px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  text-align: left;
}

.policy-history-page .record-row:last-child {
  border-bottom: 0;
}

.policy-history-page .record-row:hover,
.policy-history-page .record-row.is-selected {
  background: var(--surface-muted);
}

.policy-history-page .record-tone-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-3);
  display: grid;
  place-items: center;
}

.policy-history-page .record-row.is-warning .record-tone-icon {
  background: var(--policy-warning-soft);
  color: var(--policy-warning);
}

.policy-history-page .record-row.is-penalty .record-tone-icon {
  background: var(--policy-penalty-soft);
  color: var(--policy-penalty);
}

.policy-history-page .record-main {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.policy-history-page .record-title {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  flex: 0 1 auto;
}

.policy-history-page .record-title strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--ink);
  font-size: var(--font-size-lg);
  line-height: 1.25;
  font-weight: var(--font-weight-strong);
}

.policy-history-page .chip {
  width: max-content;
  border-radius: var(--radius-pill);
  padding: 4px 8px;
  font-size: var(--font-size-sm);
  line-height: 1;
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.policy-history-page .chip.warning {
  background: var(--policy-warning-soft);
  color: var(--color-route-text-orange-750);
}

/* bundled from styles/routes/calendar.modal-status.responsive.css */
/*
 * CALENDAR MODAL STATUS OWNER CSS CONTRACT: calendar.modal-status.responsive.css
 * Ordered chunk split from calendar.modal-status.css. Preserve import order.
 */
.policy-history-page .chip.penalty {
  background: var(--policy-penalty-soft);
  color: var(--color-route-border-danger);
}

.policy-history-page .record-meta {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
}

.policy-history-page .record-meta::before {
  content: "";
  width: 3px;
  height: 3px;
  border-radius: var(--radius-pill);
  background: var(--color-route-text-muted-500);
}

.policy-history-page .record-meta span + span::before {
  content: "·";
  margin-right: 6px;
}

.policy-history-page .record-side {
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: var(--font-weight-medium);
  white-space: nowrap;
}

.policy-history-page .list-load-footer {
  border-top: 1px solid var(--hairline);
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  background: var(--color-bg-subtle);
}

.policy-history-page .list-load-footer span {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.policy-history-page .inspector {
  position: sticky;
  top: 88px;
  max-height: calc(100vh - 108px);
  overflow: auto;
  overscroll-behavior: contain;
  padding: 14px;
  display: grid;
  gap: 12px;
}

.policy-history-page .inspector-hero {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 12px;
  display: grid;
  gap: 8px;
}

.policy-history-page .inspector-hero.is-warning {
  border-color: var(--color-state-orange-200);
  background: var(--policy-warning-soft);
}

.policy-history-page .inspector-hero.is-penalty {
  border-color: var(--color-route-border-pink-150);
  background: var(--policy-penalty-soft);
}

.policy-history-page .inspector-hero h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-title-sm);
  line-height: 1.25;
}

.policy-history-page .inspector-section {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-route-surface-white);
  padding: 11px;
  display: grid;
  gap: 8px;
}

.policy-history-page .inspector-section h4 {
  margin: 0;
  color: var(--ink);
  font-size: 13px;
  line-height: 1.2;
}

.policy-history-page .inspector-section p,
.policy-history-page .inspector-section li {
  margin: 0;
  color: var(--body);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
  line-height: 1.5;
}

.policy-history-page .evidence-summary,
.policy-history-page .evidence-points {
  display: grid;
  gap: 8px;
}

.policy-history-page .evidence-lede {
  border: 1px solid var(--color-route-brand-tint-12);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 9px 10px;
  color: var(--ink);
  font-size: 13px;
  font-weight: var(--font-weight-emphasis);
  line-height: 1.45;
}

.policy-history-page .evidence-point {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 7px;
  align-items: start;
  color: var(--body);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
  line-height: 1.45;
}

.policy-history-page .evidence-point :is(i, svg) {
  width: 18px;
  height: 18px;
  color: var(--ku-crimson);
}

.policy-history-page .inspector-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.policy-history-page .inspector-actions button {
  width: 100%;
}

.policy-history-page .empty-state {
  padding: 28px 16px;
  color: var(--muted);
  display: grid;
  place-items: center;
  gap: 8px;
  text-align: center;
  font-weight: var(--font-weight-strong);
}

.policy-evidence-disclosure {
  border: 1px solid var(--color-route-brand-tint-12);
  border-radius: var(--radius-3);
  background: var(--color-route-surface-glass-soft);
  padding: 8px 9px;
}

.policy-evidence-disclosure summary {
  color: var(--ink);
  cursor: pointer;
  font-size: 13px;
  font-weight: var(--font-weight-strong);
}

.policy-evidence-disclosure ul {
  margin: 8px 0 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
  line-height: 1.5;
}

.policy-detail-hero {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 12px;
  display: grid;
  gap: 7px;
}

.policy-detail-hero.is-warning {
  border-color: var(--color-state-orange-200);
  background: var(--color-state-orange-50);
}

.policy-detail-hero.is-penalty {
  border-color: var(--color-state-red-200);
  background: var(--color-route-surface-red-25);
}

.policy-detail-hero strong {
  color: var(--ink);
  font-size: 18px;
  line-height: 1.35;
}

.policy-detail-hero > span:not(.policy-action-chip) {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.policy-detail-evidence-list {
  margin: 0;
  padding-left: 18px;
  color: var(--body);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
  line-height: 1.55;
}

/* bundled from styles/routes/projects.css */
.project-rentals-header {
  grid-column: 1 / -1;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 12px;
}

.project-setup-card {
  grid-column: 1 / -1;
  display: grid;
  gap: var(--space-project-section-gap);
  margin-top: 18px;
  padding: 18px 0 10px;
  border-top: 1px solid var(--hairline);
}

.project-management-header {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-project-section-gap);
}

.project-management-actions {
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-end;
  gap: 8px;
}

.project-management-actions .compact {
  min-width: 52px;
  padding-inline: 10px;
}

.project-setup-card h2,
.project-rentals-header h2 {
  min-width: 0;
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.25;
  white-space: nowrap;
}

.project-management-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--space-project-section-gap);
}

.project-management-panel {
  display: grid;
  gap: var(--space-project-panel-gap);
  min-width: 0;
}

.project-management-panel h3 {
  margin: 0;
  color: var(--muted);
  font-size: var(--font-size-md);
  line-height: 1.2;
}

.project-modal-panel {
  background: var(--surface);
}

#projectModal[data-project-modal-mode="join"] .project-modal-panel {
  overflow: visible;
}

.project-modal-panel .ui-modal-header {
  border-radius: var(--radius-panel) var(--radius-panel) 0 0;
  border-bottom: 1px solid var(--hairline);
  background: linear-gradient(180deg, var(--color-bg-subtle), var(--surface));
  padding: 18px 20px 16px;
}

#projectModal[data-project-modal-mode="join"] .project-modal-panel .ui-modal-header {
  background: linear-gradient(180deg, var(--color-route-surface-pink-50), var(--surface));
}

.project-modal-panel .ui-modal-header > div {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.project-modal-panel .ui-modal-header h2 {
  margin: 0;
  font-size: var(--font-size-3xl);
  line-height: 1.2;
}

#projectModalBody {
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
}

#projectModal[data-project-modal-mode="join"] #projectModalBody {
  overflow: visible;
}

.project-modal-content {
  min-width: 0;
  display: grid;
  gap: var(--space-project-modal-gap);
  padding: var(--space-project-modal-padding);
}

.project-modal-intro {
  min-width: 0;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: var(--space-project-section-gap);
  align-items: center;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: var(--space-project-section-gap);
}

.project-modal-intro-icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-3);
  background: var(--surface);
  color: var(--primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.project-modal-intro-icon :is(svg, i) {
  width: 20px;
  height: 20px;
}

.project-modal-intro-copy strong,
.project-modal-intro-copy span {
  display: block;
}

.project-modal-intro-copy strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
  line-height: 1.25;
}

.project-modal-intro-copy span {
  margin-top: 3px;
  color: var(--body);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  line-height: 1.45;
}

.project-modal-intro-success .project-modal-intro-icon {
  color: var(--color-state-green-700);
  background: var(--color-state-green-50);
}

.project-modal-intro-danger {
  border-color: var(--color-route-surface-red-100);
  background: var(--color-route-surface-red-25);
}

.project-modal-intro-danger .project-modal-intro-icon {
  color: var(--weekend-sunday);
  background: var(--surface);
}

.project-modal-search-area {
  display: grid;
  gap: 10px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 12px;
}

.project-join-combobox {
  position: relative;
  min-width: 0;
}

.project-join-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
}

.project-search-field {
  min-width: 0;
  display: grid;
  gap: 7px;
}

.project-search-submit {
  min-height: 40px;
}

.project-search-summary {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 9px 11px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.project-search-summary span {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.project-search-summary strong {
  color: var(--primary);
  font-size: var(--font-size-lg);
  line-height: 1.2;
}

.project-suggestion-heading {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.project-suggestion-heading span {
  color: var(--ink);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  line-height: 1.25;
}

.project-suggestion-heading strong {
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.2;
}

.project-join-suggestion-panel {
  position: absolute;
  z-index: 6;
  inset-inline: 0;
  top: calc(100% + 8px);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  box-shadow: var(--shadow);
  padding: 10px;
  display: grid;
  gap: 8px;
  max-height: min(280px, calc(100dvh - 220px));
  overflow-y: auto;
}

.project-join-suggestion-list {
  display: grid;
  gap: 8px;
}

.project-join-suggestion-row {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-neutral-0);
  padding: 9px 10px;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.project-join-suggestion-row .project-join-request-button {
  white-space: nowrap;
}

.project-join-help,
.project-create-help,
.project-create-duplicate-note {
  margin: 0;
}

.project-management-list {
  display: grid;
  gap: 8px;
}

.project-modal-panel .project-management-list {
  max-height: min(50vh, 420px);
  overflow: auto;
  padding-right: 2px;
}

.project-archive-sections {
  display: grid;
  gap: 12px;
}

.project-archive-section {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  overflow: hidden;
}

.project-archive-section-heading {
  min-height: 46px;
  border-bottom: 1px solid var(--hairline);
  padding: 10px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.project-archive-section-heading h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-lg);
  line-height: 1.25;
}

.project-archive-section-heading span {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.project-archive-section .project-management-list {
  max-height: min(34vh, 280px);
  padding: 10px;
}

.project-empty-note-framed {
  min-height: 58px;
  border: 1px dashed var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 12px;
  display: flex;
  align-items: center;
  gap: 9px;
}

.project-empty-note-framed :is(svg, i) {
  width: 18px;
  height: 18px;
  color: var(--primary);
  flex: 0 0 auto;
}

.project-management-row {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-neutral-0);
  padding: 10px;
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
}

.project-management-row-danger {
  border-color: var(--color-route-surface-red-100);
}

.project-management-row-archive,
.project-management-row.is-archived {
  border-color: var(--hairline);
}

.project-row-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-3);
  background: var(--color-route-surface-pink-75);
  color: var(--primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.project-management-row-danger .project-row-icon {
  background: var(--color-route-surface-red-25);
  color: var(--weekend-sunday);
}

.project-management-row.is-archived .project-row-icon {
  background: var(--color-state-orange-50);
  color: var(--color-state-orange-700);
}

.project-row-icon :is(svg, i) {
  width: 18px;
  height: 18px;
}

.project-row-copy {
  min-width: 0;
}

.project-row-copy strong,
.project-row-copy span {
  display: block;
}

.project-row-copy strong {
  color: var(--ink);
  font-size: var(--font-size-md);
  line-height: 1.25;
}

.project-row-copy span {
  margin-top: 3px;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  line-height: 1.35;
}

.project-code-token {
  color: var(--ink);
  font-weight: var(--font-weight-strong);
}

.danger-button {
  color: var(--weekend-sunday);
}

.project-create-form {
  display: grid;
  gap: 12px;
}

.project-create-duplicate-note:not([hidden]) {
  color: var(--primary);
}

.project-create-review {
  display: grid;
  gap: var(--space-project-modal-gap);
}

.project-created-summary {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-neutral-0);
  padding: 18px 20px;
  display: grid;
  gap: 8px;
}

.project-created-name {
  color: var(--ink);
  font-size: var(--font-size-title-lg);
  font-weight: var(--font-weight-strong);
  line-height: 1.25;
}

.project-created-code {
  color: var(--primary);
  font-size: 44px;
  font-weight: var(--font-weight-strong);
  letter-spacing: 0;
  line-height: 1.1;
}

.project-copy-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.project-modal-content .modal-actions {
  margin-top: 2px;
  padding-top: 14px;
  border-top: 1px solid var(--hairline);
}

@media (max-width: 520px) {
  .project-modal-panel .ui-modal-header,
  .project-modal-content {
    padding-inline: 14px;
  }

  .project-modal-intro {
    grid-template-columns: 36px minmax(0, 1fr);
  }

  .project-modal-intro-icon,
  .project-row-icon {
    width: 36px;
    height: 36px;
  }

  .project-join-form,
  .project-management-row {
    grid-template-columns: 1fr;
  }

  .project-row-icon {
    display: none;
  }

  .project-management-row .ui-action-button {
    justify-self: start;
  }
}

.project-members-card {
  grid-column: 1 / -1;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 12px;
  display: grid;
  gap: 12px;
}

.project-members-heading {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.project-members-heading h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.25;
}

.project-member-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.project-member-chip {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--body);
  padding: 5px 9px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.project-member-chip.is-owner {
  border-color: var(--color-route-border-pink-200);
  color: var(--primary);
  background: var(--color-route-surface-pink-50);
}

.project-invite-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
}

.project-pending-list {
  display: grid;
  gap: 8px;
}

.project-pending-row {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 9px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.project-pending-row span {
  display: grid;
  gap: 2px;
}

.project-pending-row small,
.project-empty-note {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.project-management-page {
  grid-column: 1 / -1;
  display: grid;
  gap: 14px;
  width: 100%;
}

[data-panel="project-directory"].compact-view {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
  gap: 10px;
}

[data-panel="project-directory"] > .page-heading {
  border-bottom: 0;
  padding-bottom: 4px;
}

.project-management-hero {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 16px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: end;
}

.project-management-hero h2 {
  margin: 4px 0 0;
  color: var(--ink);
  font-size: clamp(22px, 3vw, 30px);
  line-height: 1.12;
}

.project-management-hero p {
  margin: 7px 0 0;
  color: var(--body);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-medium);
  line-height: 1.45;
}

.project-management-detail-hero {
  grid-template-columns: minmax(0, 1fr) minmax(220px, 300px);
  align-items: start;
}

.project-management-detail-stat-strip {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.project-management-detail-stat-strip > span {
  background: var(--surface);
  padding: 10px;
}

.project-management-detail-stat-strip strong {
  font-size: var(--font-size-title-sm);
}

.project-management-hero-actions {
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.project-management-stat-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.project-management-stat-strip > span {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 12px;
  display: grid;
  gap: 4px;
}

.project-management-stat-strip strong {
  color: var(--ink);
  font-size: var(--font-size-title-lg);
  font-weight: var(--font-weight-strong);
  line-height: 1;
}

.project-management-stat-strip small {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.project-management-detail-stat-strip {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.project-management-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
  gap: 14px;
  align-items: start;
}

.project-management-workspace.is-detail {
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
}

.project-directory-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
  gap: 14px;
  align-items: start;
}

.project-management-side {
  display: grid;
  gap: 14px;
}

.project-management-panel {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 14px;
  display: grid;
  gap: 12px;
  min-width: 0;
}

.project-management-panel-heading {
  min-width: 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.project-management-panel-heading h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.25;
}

.project-management-panel-heading p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  line-height: 1.4;
}

.project-management-panel-heading > span {
  flex: 0 0 auto;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-control-small);
  background: var(--color-bg-subtle);
  color: var(--body);
  padding: 5px 8px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.project-management-project-list,
.project-management-rental-list,
.project-management-queue-list {
  display: grid;
  gap: 9px;
}

.project-management-project-card {
  width: 100%;
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-neutral-0);
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) minmax(170px, auto) 18px;
  gap: 12px;
  align-items: center;
  padding: 12px;
}

.project-management-project-card:hover {
  border-color: var(--color-route-brand-tint-32);
  box-shadow: 0 8px 20px var(--color-route-shadow-admin-subtle);
}

.project-directory-list-panel,
.project-directory-section,
.project-directory-list {
  min-width: 0;
  display: grid;
}

.project-directory-list-panel {
  gap: 18px;
}

.project-directory-section {
  gap: 10px;
}

.project-directory-list {
  gap: 8px;
  max-height: 284px;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 3px;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
  scrollbar-gutter: stable;
}

.project-directory-list::-webkit-scrollbar {
  width: var(--scrollbar-size);
}

.project-directory-list::-webkit-scrollbar-track {
  background: var(--scrollbar-track);
}

.project-directory-list::-webkit-scrollbar-thumb {
  border-radius: var(--radius-pill);
  background: var(--scrollbar-thumb);
}

.project-directory-row {
  width: 100%;
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-neutral-0);
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) minmax(170px, auto) auto 18px;
  gap: 12px;
  align-items: center;
  padding: 12px;
}

.project-directory-row:hover {
  border-color: var(--color-route-brand-tint-32);
  box-shadow: 0 8px 20px var(--color-route-shadow-admin-subtle);
}

.project-directory-main {
  min-width: 0;
  display: grid;
  gap: 5px;
}

.project-directory-main > span:last-child {
  min-width: 0;
  color: var(--body);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.project-directory-state {
  width: fit-content;
  font-style: normal;
  white-space: nowrap;
}

.project-directory-workspace {
  grid-template-columns: minmax(0, 1fr) minmax(320px, 390px);
  gap: 16px;
  align-items: start;
}

.project-directory-main-column {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  box-shadow: 0 8px 24px var(--color-route-shadow-admin-hairline);
  display: grid;
  gap: 0;
  overflow: hidden;
}

.project-directory-list-panel {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
  gap: 0;
  overflow: hidden;
}

.project-directory-toolbar {
  display: grid;
  gap: 8px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--hairline);
  background: var(--color-bg-subtle);
}

.project-directory-toolbar-primary {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) var(--control-height-search);
  gap: 10px;
  align-items: center;
}

.project-directory-search {
  min-width: 0;
  min-height: var(--control-height-search);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-control-small);
  background: var(--surface);
  color: var(--body);
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  padding: 0 12px;
}

.project-directory-search svg {
  width: 18px;
  height: 18px;
  color: var(--muted);
}

.project-directory-search input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
}

/* bundled from styles/routes/calendar.desktop.css */
/*
 * DESKTOP ROUTE CSS CONTRACT: calendar
 *
 * Desktop-only calendar CSS belongs here. Keep mobile/tablet rules out.
 * BROWSER SMOKE TARGET: the :has + 100dvh + overflow hidden lock below must
 * be covered by desktop calendar smoke checks before changing it.
 */
@media (min-width: 1024px) {
  body:has([data-panel="calendar"].is-visible) {
    overflow: hidden;
  }

  body:has([data-panel="calendar"].is-visible) .app-shell {
    height: 100dvh;
    min-height: 100dvh;
    max-height: 100dvh;
    overflow: hidden;
  }

  body:has([data-panel="calendar"].is-visible) .workspace {
    --calendar-workspace-height: calc(100dvh - var(--topbar-height-desktop) - 1px);

    flex: 0 0 var(--calendar-workspace-height);
    height: var(--calendar-workspace-height);
    max-height: var(--calendar-workspace-height);
    overflow: hidden;
  }

  body:has([data-panel="calendar"].is-visible) .view-calendar.is-visible,
  body:has([data-panel="calendar"].is-visible) .calendar-stage,
  body:has([data-panel="calendar"].is-visible) .calendar-content-split,
  body:has([data-panel="calendar"].is-visible) .calendar-main-column,
  body:has([data-panel="calendar"].is-visible) .calendar-surface,
  body:has([data-panel="calendar"].is-visible) .calendar-swipe-viewport,
  body:has([data-panel="calendar"].is-visible) .calendar-swipe-track,
  body:has([data-panel="calendar"].is-visible) .calendar-swipe-pane {
    min-height: 0;
  }

  body:has([data-panel="calendar"].is-visible) .view-calendar.is-visible,
  body:has([data-panel="calendar"].is-visible) .calendar-stage {
    height: 100%;
  }

  body:has([data-panel="calendar"].is-visible) .calendar-surface {
    overflow: hidden;
  }

  body:has([data-panel="calendar"].is-visible) .calendar-swipe-pane .calendar-grid {
    min-height: 0;
    grid-template-rows: repeat(6, minmax(0, 1fr));
  }

  body:has([data-panel="calendar"].is-visible) .calendar-swipe-pane .day-cell {
    min-height: 0;
  }
}

/* bundled from styles/routes/calendar.mobile.css */
/*
 * MOBILE ROUTE CSS CONTRACT: calendar
 *
 * Mobile-only calendar CSS belongs here. Keep desktop workstation rules out.
 */

/* bundled from styles/routes/account-my-rentals.css */
/*
 * ACCOUNT MY RENTALS ROUTE CSS CONTRACT
 * Import hub only for account rentals, profile, and adjacent project slices.
 */
/* bundled from styles/routes/account-profile.css */
/*
 * ACCOUNT PROFILE ROUTE CSS CONTRACT
 * Profile, account settings, issue report, and account settings responsive styles.
 */
.side-consent {
  align-items: flex-start;
}

.profile-settings-view {
  overflow: auto;
  scrollbar-gutter: stable;
}

.profile-settings-view:has(.profile-settings-layout.is-dashboard-mode),
.profile-settings-view:has(.profile-settings-layout.is-settings-mode) {
  border: 0;
  background: transparent;
  box-shadow: none;
  gap: 0;
  padding: 0;
}

.profile-settings-view:has(.profile-settings-layout.is-dashboard-mode) > .page-heading,
.profile-settings-view:has(.profile-settings-layout.is-settings-mode) > .page-heading {
  display: none;
}

body:has([data-panel="profile"].is-visible) .workspace {
  scrollbar-gutter: stable;
}

.profile-settings-layout {
  padding: var(--space-account-layout-padding);
  display: grid;
  grid-template-columns: minmax(0, 680px);
  justify-content: start;
  gap: var(--space-account-layout-gap);
}

.profile-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: var(--space-account-card-padding);
  display: grid;
  gap: var(--space-account-card-gap);
}

.profile-card h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-title-sm);
}

.profile-card p {
  margin: 0;
  color: var(--muted);
  font-size: var(--font-size-md);
}

.account-card {
  grid-template-columns: 64px 1fr;
  align-items: center;
}

.profile-avatar {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-5);
  background: var(--primary);
  color: var(--color-neutral-0);
  display: grid;
  place-items: center;
  font-size: var(--font-size-title-lg);
  font-weight: var(--font-weight-strong);
}

.profile-status-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.profile-log-card {
  grid-column: auto;
}

.profile-security-card {
  background: var(--color-bg-subtle);
}

.profile-settings-layout:has(> .account-settings-shell) {
  grid-template-columns: minmax(0, 1180px);
  width: min(100%, var(--content-max-width-readable));
  margin-inline: auto;
  padding: 16px 18px 22px;
}

.profile-settings-layout.is-policy-document-mode {
  grid-template-columns: minmax(0, 1180px);
  width: min(100%, var(--content-max-width-readable));
  margin-inline: auto;
  padding: 16px 18px 22px;
}

.account-settings-shell {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(300px, 360px) minmax(520px, 1fr);
  align-items: start;
  gap: 16px;
}

.account-settings-board,
.account-settings-summary,
.account-settings-menu-panel {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  overflow: hidden;
}

.account-settings-board {
  display: grid;
  width: 100%;
}

.account-settings-detail-panel {
  min-width: 0;
}

.account-settings-detail-back {
  display: none;
}

.account-settings-summary,
.account-settings-menu-panel {
  position: sticky;
  top: 14px;
  display: grid;
}

.account-settings-board-header,
.account-settings-section,
.account-settings-summary-card,
.account-settings-summary-section,
.account-settings-menu-summary {
  padding: 14px 16px;
}

.account-settings-board-header {
  border-bottom: 1px solid var(--hairline);
  background: var(--color-bg-subtle);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.account-settings-board-header h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-3xl);
  line-height: var(--line-height-snug);
}

.account-settings-summary h2,
.account-settings-menu-panel h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: var(--line-height-snug);
}

.account-settings-board-header p,
.account-settings-summary p,
.account-settings-menu-panel p,
.account-settings-row small,
.account-settings-log small,
.account-settings-menu-item small {
  margin: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.4;
  font-weight: var(--font-weight-medium);
}

.account-settings-sections {
  display: grid;
}

.account-settings-detail-body {
  min-width: 0;
  display: grid;
}

.account-settings-section {
  border-bottom: 1px solid var(--hairline);
  display: grid;
  gap: 12px;
}

.account-settings-section:last-child {
  border-bottom: 0;
}

.account-settings-section.settings-disclosure-card {
  border-color: var(--hairline);
  border-radius: 0;
  background: var(--surface);
  padding: 14px 16px;
  gap: 0;
}

.account-settings-section-head {
  min-width: 0;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  align-items: center;
  gap: 11px;
}

.account-settings-section-head.is-button {
  width: 100%;
  min-height: var(--control-height-search);
  border: 0;
  background: transparent;
  padding: 0;
  text-align: left;
  font: inherit;
  cursor: pointer;
}

.account-settings-section-head h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-xl);
  line-height: var(--line-height-snug);
  font-weight: var(--font-weight-medium);
}

.account-settings-summary-section h3,
.account-settings-menu-summary h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-lg);
  line-height: 1.25;
  font-weight: var(--font-weight-strong);
}

.account-settings-account-summary {
  border-bottom: 1px solid var(--hairline);
  background: var(--color-bg-subtle);
  padding: 16px 18px 14px;
  display: grid;
  gap: 10px;
}

.account-settings-account-summary .account-settings-identity {
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 12px;
}

.account-settings-account-summary .profile-avatar {
  width: 52px;
  height: 52px;
  font-size: var(--font-size-3xl);
}

.account-settings-account-summary h2 {
  font-size: var(--font-size-xl);
}

.account-settings-account-summary p {
  margin-top: 2px;
  font-weight: var(--font-weight-medium);
}

.account-settings-account-summary .profile-status-row {
  padding-left: 64px;
  gap: 6px;
}

.account-settings-menu-list {
  border-top: 1px solid var(--hairline);
  display: grid;
  gap: 6px;
  padding: 8px;
}

.account-settings-menu-item {
  width: 100%;
  min-height: 54px;
  border: 1px solid transparent;
  border-radius: var(--radius-3);
  background: transparent;
  color: var(--ink);
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 8px;
  text-align: left;
  font: inherit;
  cursor: pointer;
}

.account-settings-menu-item:hover {
  border-color: var(--hairline);
  background: var(--surface-muted);
}

.account-settings-menu-item.is-active {
  border-color: var(--ku-crimson-border);
  background: var(--ku-crimson-soft);
}

.account-settings-menu-item strong {
  display: block;
  font-size: var(--font-size-lg);
  line-height: 1.25;
  font-weight: var(--font-weight-medium);
}

.settings-disclosure-card .account-settings-section-head h3 {
  font-size: var(--font-size-xl);
  line-height: var(--line-height-snug);
  font-weight: var(--font-weight-medium);
}

.account-settings-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
}

.account-settings-meta span {
  min-height: 22px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--surface-muted);
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  padding: 0 7px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
}

.account-settings-icon {
  width: var(--control-height-compact);
  height: var(--control-height-compact);
  border: 1px solid var(--ku-crimson-border);
  border-radius: var(--radius-3);
  background: var(--primary-soft);
  color: var(--primary);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}

.account-settings-icon svg {
  width: 15px;
  height: 15px;
  stroke-width: 2.3;
}

.account-settings-value-grid,
.account-settings-policy-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.account-settings-value,
.account-settings-row {
  min-width: 0;
  min-height: 48px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 9px 10px;
  display: grid;
  gap: 4px;
}

.account-settings-value span {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
}

.account-settings-value strong,
.account-settings-row strong,
.account-settings-log strong {
  min-width: 0;
  color: var(--ink);
  font-size: var(--font-size-md);
  line-height: 1.3;
  font-weight: var(--font-weight-strong);
  overflow-wrap: anywhere;
}

.account-settings-row {
  grid-template-columns: 30px minmax(0, 1fr) auto;
  align-items: center;
  column-gap: 10px;
  color: inherit;
  text-decoration: none;
}

.account-settings-row > span:nth-child(2) {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.account-settings-toggle-row {
  grid-template-columns: 30px minmax(0, 1fr) auto auto;
}

.account-settings-push-device {
  min-width: 0;
  min-height: 54px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 9px 10px;
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 10px;
}

.account-settings-push-device strong {
  display: block;
  color: var(--ink);
  font-size: var(--font-size-md);
  line-height: 1.3;
  font-weight: var(--font-weight-strong);
}

.account-settings-push-device small {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.4;
  font-weight: var(--font-weight-medium);
}

.account-settings-push-error {
  color: var(--danger) !important;
}

.account-settings-toggle-state {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
  text-align: right;
  min-width: var(--control-height-small);
}

.account-settings-actions {
  display: flex;
  justify-content: flex-end;
}

.account-settings-identity {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
}

.account-settings-summary-card {
  display: grid;
  gap: 14px;
}

.account-settings-summary-section {
  border-top: 1px solid var(--hairline);
  display: grid;
  gap: 10px;
}

.account-settings-log-list {
  display: grid;
  gap: 7px;
}

.account-settings-log {
  min-width: 0;
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  align-items: center;
  gap: 9px;
}

.account-settings-log {
  min-height: 44px;
  align-items: start;
}

.account-settings-log span {
  min-width: 0;
}

@media (min-width: 1024px) {
  .account-settings-summary-section {
    gap: 8px;
  }

  .account-settings-log > span:last-child {
    min-width: 0;
    display: grid;
    gap: 2px;
  }

  .account-settings-log-list {
    gap: 0;
  }

  .account-settings-log {
    min-height: auto;
    border-top: 1px solid var(--hairline);
    grid-template-columns: minmax(0, 1fr);
    padding: 9px 0;
  }

  .account-settings-log:first-child {
    border-top: 0;
    padding-top: 0;
  }

  .account-settings-log:last-child {
    padding-bottom: 0;
  }

  .account-settings-log .account-settings-icon {
    display: none;
  }
}

.issue-report-contact-list {
  display: grid;
  gap: 8px;
}

.issue-report-card {
  min-width: 0;
}

.issue-report-main,
.issue-report-side {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: 12px;
}

.issue-report-contact-list span {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  color: var(--body);
  padding: 10px;
  display: grid;
  gap: 3px;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-strong);
}

.issue-report-contact-list strong {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.issue-report-contact-list a {
  color: var(--ku-crimson-dark);
  text-decoration: none;
}

.issue-report-template {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 12px;
  display: grid;
  gap: 8px;
}

.issue-report-template strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
}

.issue-report-template ul {
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: var(--font-size-md);
  line-height: 1.5;
}

.issue-report-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.issue-report-actions a {
  align-items: center;
  display: inline-flex;
  text-decoration: none;
}


@media (max-width: 1023px) {
  .profile-settings-layout {
    grid-template-columns: 1fr;
    padding: 10px;
  }

  .profile-log-card {
    grid-column: auto;
  }
}

@media (max-width: 1023px) {
  .profile-settings-layout:has(> .account-settings-shell) {
    grid-template-columns: 1fr;
    padding: 10px;
  }

  .account-settings-shell {
    grid-template-columns: 1fr;
  }

  .account-settings-shell:not(.is-detail-open) .account-settings-detail-panel {
    display: none;
  }

  .account-settings-shell.is-detail-open .account-settings-menu-panel {
    display: none;
  }

  .account-settings-shell.is-detail-open .account-settings-detail-panel {
    display: grid;
    order: 1;
  }

  .account-settings-shell.is-detail-open .account-settings-detail-back {
    display: inline-flex;
  }

  .account-settings-detail-panel .account-settings-board-header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .account-settings-board {
    order: 2;
  }

  .account-settings-summary,
  .account-settings-menu-panel {
    position: static;
    order: 1;
  }

  .account-settings-menu-item {
    min-height: 58px;
  }
}

@media (max-width: 520px) {
  .account-settings-board-header,
  .account-settings-section-head {
    grid-template-columns: 1fr;
  }

  .account-settings-section-head.is-button {
    grid-template-columns: 30px minmax(0, 1fr) auto;
  }

  .account-settings-board-header {
    display: grid;
  }

  .account-settings-detail-panel .account-settings-section {
    padding: 12px;
  }

  .account-settings-detail-panel .settings-list {
    gap: 10px;
  }

  .account-settings-value-grid,
  .account-settings-policy-grid,
  .settings-field-grid {
    grid-template-columns: 1fr;
  }

  .account-settings-detail-panel .settings-field-cell,
  .account-settings-detail-panel .settings-choice-row {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .account-settings-detail-panel .settings-field-cell.is-compact .input {
    width: 100%;
  }

  .account-settings-detail-panel .settings-choice-list {
    gap: 8px;
  }

  .account-settings-detail-panel .settings-choice {
    min-height: var(--control-height-search);
  }

  .account-settings-row,
  .account-settings-toggle-row,
  .account-settings-push-device {
    grid-template-columns: 30px minmax(0, 1fr) auto;
  }

  .account-settings-detail-panel .account-settings-row,
  .account-settings-detail-panel .account-settings-toggle-row,
  .account-settings-detail-panel .account-settings-push-device {
    align-items: start;
  }

  .account-settings-detail-panel .switch-input {
    justify-self: end;
  }

  .account-settings-toggle-state,
  .account-settings-push-device .secondary-button {
    grid-column: 2;
    justify-self: start;
    text-align: left;
  }

  .account-settings-detail-panel .account-settings-actions .primary-button {
    width: 100%;
    justify-content: center;
  }

  .settings-document-toolbar {
    align-items: flex-start;
  }

  .settings-document-header,
  .settings-document-section-grid {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 1024px) {
  .profile-settings-layout:has(> .account-dashboard),
  .profile-settings-layout.is-dashboard-mode {
    grid-template-columns: minmax(0, 1fr);
    width: min(100%, var(--content-max-width-operational));
    margin-inline: auto;
    padding: 0;
  }

  .profile-settings-layout:has(> .issue-report-card) {
    grid-template-columns: minmax(0, 760px);
    padding: 16px 18px 22px;
  }

  .issue-report-card {
    gap: 14px;
    padding: 18px;
  }

  .issue-report-template {
    min-height: 132px;
    align-content: start;
  }
}

/* bundled from styles/routes/account-projects.directory.css */
.desktop-rental-search input::placeholder,
.project-directory-search input::placeholder,
.side-equipment-search-input::placeholder {
  color: var(--muted);
  font: inherit;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  opacity: 1;
}

.project-directory-filter-panel {
  display: contents;
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 0;
}

.project-directory-filter-panel[hidden] {
  display: none;
}

.project-directory-filter-chips {
  display: flex;
  align-items: center;
  gap: var(--filter-chip-gap);
  flex-wrap: wrap;
}

.project-directory-filter-chip svg {
  width: 15px;
  height: 15px;
}

.project-directory-filter-chip.tone-role {
  border-color: var(--color-status-reserved-border);
  background: var(--color-status-reserved-bg);
  color: var(--color-state-blue-700);
}

.project-directory-filter-chip.tone-host {
  border-color: var(--color-status-active-border);
  background: var(--color-status-active-bg);
  color: var(--color-status-active-text);
}

.project-directory-filter-chip.tone-check {
  border-color: var(--color-status-checkout-border);
  background: var(--color-status-checkout-bg);
  color: var(--color-status-checkout-text);
}

.project-directory-filter-chip.tone-approval {
  border-color: var(--color-status-approval-border);
  background: var(--color-status-approval-bg);
  color: var(--color-status-approval-text);
}

.project-directory-filter-chip.tone-done {
  border-color: var(--color-status-neutral-border);
  background: var(--color-status-neutral-bg);
  color: var(--color-status-neutral-text);
}

.project-directory-filter-chip.is-neutral,
.project-directory-filter-chip.tone-role.is-neutral,
.project-directory-filter-chip.tone-host.is-neutral,
.project-directory-filter-chip.tone-check.is-neutral,
.project-directory-filter-chip.tone-approval.is-neutral,
.project-directory-filter-chip.tone-done.is-neutral {
  border-color: var(--hairline);
  background: var(--color-bg-app);
  color: var(--muted);
}

.project-directory-table-head,
.project-directory-row {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(54px, 72px) minmax(80px, 94px) 42px;
  gap: 10px;
  align-items: center;
}

.project-directory-table-head {
  border-bottom: 1px solid var(--hairline);
  color: var(--muted);
  padding: 10px 18px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-emphasis);
}

.project-directory-table-head span:nth-child(4) {
  visibility: hidden;
}

.project-directory-list {
  gap: 0;
  max-height: min(396px, calc(100vh - 424px));
  min-height: 0;
  padding-right: 12px;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-gutter: stable;
}

.project-directory-group-label {
  position: static;
  z-index: 1;
  border-bottom: 0;
  background: var(--surface);
  color: var(--body);
  padding: 14px 18px 8px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-emphasis);
}

.project-directory-row {
  position: relative;
  width: auto;
  box-sizing: border-box;
  margin: var(--space-project-directory-row-margin);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  box-shadow: none;
  min-height: 74px;
  padding: var(--space-project-directory-row-padding);
}

.project-directory-row:hover,
.project-directory-row:focus-within {
  border-color: var(--color-route-brand-tint-32);
  background: var(--color-route-surface-pink-50);
  box-shadow: 0 8px 18px var(--color-route-shadow-admin-micro);
  outline: 0;
}

.project-directory-row.is-request {
  background: var(--color-bg-subtle);
}

.project-directory-row.is-rejected {
  border-color: var(--color-state-red-200);
  background: var(--color-state-red-50);
}

.project-directory-row.is-selected {
  border-color: var(--color-route-brand-tint-36);
  background: var(--color-bg-subtle);
  box-shadow: 0 8px 16px var(--color-route-shadow-admin-hairline);
  outline: 0;
}

.project-directory-row:hover {
  border-color: var(--color-route-brand-tint-32);
}

.project-directory-project-cell {
  min-width: 0;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.project-directory-count {
  color: var(--ink);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-strong);
  line-height: 1;
}

.project-directory-state {
  max-width: 100%;
  justify-self: start;
  font-style: normal;
}

.project-directory-row-actions {
  position: relative;
  width: 42px;
  min-width: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  justify-self: end;
  max-width: 100%;
}

.project-directory-row-action {
  width: 36px;
  min-width: 36px;
  min-height: 36px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-control-small);
  background: var(--surface);
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}

.project-directory-more.is-active {
  border-color: var(--color-route-brand-tint-42);
  background: var(--color-route-brand-tint-06);
  color: var(--primary);
}

.project-directory-more-wrap {
  position: relative;
  display: inline-flex;
}

.project-directory-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  width: 190px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  box-shadow: 0 16px 32px var(--color-route-shadow-calendar);
  padding: 6px;
  z-index: 20;
}

.project-directory-menu[hidden] {
  display: none;
}

.project-directory-menu button {
  width: 100%;
  min-height: 36px;
  border: 0;
  border-radius: var(--radius-control-small);
  background: transparent;
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  padding: 0 9px;
  font: inherit;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  text-align: left;
}

.project-directory-menu button:hover {
  background: var(--color-bg-subtle);
  color: var(--primary);
}

.project-directory-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: nowrap;
  border-top: 1px solid var(--hairline);
  border-radius: 0 0 8px 8px;
  background: var(--color-bg-subtle);
  padding: 10px 14px;
}

.project-directory-footer > span {
  color: var(--body);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-emphasis);
}

.project-directory-footer-actions {
  min-width: 0;
  flex: 0 1 auto;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: nowrap;
}

.project-management-page .project-directory-footer-action {
  width: auto;
  min-width: 72px;
  flex: 0 0 auto;
  padding-inline: 12px;
}

.project-directory-detail-panel {
  gap: 14px;
}

.project-directory-detail-heading {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}

.project-directory-detail-heading h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.25;
}

.project-directory-detail-heading p {
  margin: 4px 0 0;
  color: var(--body);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  line-height: 1.4;
}

.project-directory-detail-section {
  min-width: 0;
  border-top: 1px solid var(--hairline);
  padding-top: 12px;
  display: grid;
  gap: 9px;
}

.project-directory-detail-section h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-emphasis);
}

.project-directory-summary-grid {
  margin: 0;
  display: grid;
  grid-template-columns: 80px minmax(0, 1fr);
  gap: 7px 10px;
}

.project-directory-summary-grid dt,
.project-directory-summary-grid dd {
  margin: 0;
  min-width: 0;
  font-size: var(--font-size-md);
  line-height: 1.35;
}

.project-directory-summary-grid dt {
  color: var(--muted);
  font-weight: var(--font-weight-strong);
}

.project-directory-summary-grid dd {
  color: var(--ink);
  font-weight: var(--font-weight-strong);
}

.project-directory-chip-row {
  display: flex;
  gap: 7px;
  flex-wrap: nowrap;
  min-width: 0;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.project-directory-chip-row::-webkit-scrollbar {
  display: none;
}

.project-directory-person-chip {
  flex: 0 0 auto;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--body);
  padding: 6px 9px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.project-directory-person-chip.is-me {
  border-color: var(--color-route-border-pink-100);
  background: var(--color-route-surface-pink-75);
  color: var(--primary);
}

.project-directory-task-list {
  max-height: 184px;
  overflow-y: auto;
  display: grid;
  gap: 8px;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
  scrollbar-gutter: stable;
}

.project-directory-task-link {
  min-width: 0;
  min-height: 56px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  color: inherit;
  text-decoration: none;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) 18px;
  gap: 10px;
  align-items: center;
  padding: 10px;
}

.project-directory-task-link:hover {
  border-color: var(--color-route-brand-tint-34);
  background: var(--color-bg-subtle);
}

.project-directory-task-link.has-actions {
  grid-template-columns: 34px minmax(0, 1fr) auto;
}

.project-directory-task-actions {
  display: flex;
  justify-content: flex-end;
  gap: 6px;
  flex-wrap: wrap;
}

.project-directory-task-actions button {
  min-height: var(--control-height-small);
}

.project-directory-task-icon {
  width: var(--control-height-small);
  height: var(--control-height-small);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  display: grid;
  place-items: center;
}

.project-directory-task-icon svg,
.project-directory-task-link > svg {
  width: 17px;
  height: 17px;
}

.project-directory-task-link.tone-photo .project-directory-task-icon {
  border-color: var(--color-state-orange-200);
  background: var(--color-state-orange-50);
  color: var(--color-state-orange-700);
}

.project-directory-task-link.tone-wait .project-directory-task-icon {
  border-color: var(--color-state-blue-200);
  background: var(--color-state-blue-50);
  color: var(--color-state-blue-700);
}

.project-directory-task-link.tone-approval .project-directory-task-icon {
  border-color: var(--color-route-border-pink-150);
  background: var(--color-route-surface-pink-75);
  color: var(--primary);
}

.project-directory-task-link.tone-done .project-directory-task-icon {
  border-color: var(--color-route-border-neutral-100);
  background: var(--color-route-surface-neutral-75);
  color: var(--body);
}

.project-directory-task-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.project-directory-task-copy strong,
.project-directory-task-copy small {
  min-width: 0;
  overflow-wrap: anywhere;
  line-height: 1.3;
}

.project-directory-task-copy strong {
  color: var(--ink);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-emphasis);
}

.project-directory-task-copy small {
  color: var(--muted);
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.project-directory-detail-actions {
  display: grid;
  gap: 8px;
}

.project-directory-detail-actions .desktop-new-rental-button {
  width: 100%;
}

.project-directory-member-action {
  width: 100%;
  min-height: var(--control-height-search);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-control-small);
  background: var(--surface);
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font: inherit;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-emphasis);
}

.project-directory-member-action:hover {
  border-color: var(--color-route-brand-tint-34);
  background: var(--color-bg-subtle);
  color: var(--primary);
}

.project-directory-member-action svg {
  width: 16px;
  height: 16px;
}

.project-directory-secondary-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.project-directory-secondary-actions.is-single {
  grid-template-columns: 1fr;
}

.project-directory-secondary-actions button {
  min-height: var(--control-height-search);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-control-small);
  background: var(--surface);
  color: var(--ink);
  font: inherit;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-emphasis);
}

.project-directory-request-notice {
  border: 1px dashed var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  color: var(--body);
  padding: var(--space-project-section-gap);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  line-height: 1.5;
}

.project-directory-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  background: var(--color-overlay-backdrop);
  padding: 24px;
}

.project-directory-modal {
  width: min(720px, calc(100vw - 48px));
  max-height: min(760px, calc(100vh - 48px));
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  box-shadow: 0 24px 60px var(--color-route-shadow-calendar);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  overflow: hidden;
}

.project-directory-modal-header {
  min-width: 0;
  border-bottom: 1px solid var(--hairline);
  display: grid;
  grid-template-columns: minmax(0, 1fr) 42px;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
}

.project-directory-modal-header h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-title-sm);
  line-height: 1.25;
}

.project-directory-modal-header p {
  margin: 5px 0 0;
  color: var(--body);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  line-height: 1.35;
}

.project-directory-modal-close {
  width: var(--control-size-icon-md);
  height: var(--control-size-icon-md);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-control-small);
  background: var(--surface);
  color: var(--ink);
  display: grid;
  place-items: center;
}

.project-directory-modal-close:hover {
  border-color: var(--color-route-brand-tint-34);
  background: var(--color-bg-subtle);
  color: var(--primary);
}

.project-directory-modal-close svg {
  width: 18px;
  height: 18px;
}

.project-directory-modal-body {
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
  display: grid;
  gap: 18px;
  padding: 18px 20px 20px;
}

.project-directory-modal-section {
  min-width: 0;
  display: grid;
  gap: 10px;
}

.project-directory-modal-section h3,
.project-directory-member-summary h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-emphasis);
  line-height: 1.35;
}

.project-directory-member-summary {
  min-width: 0;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.project-directory-member-summary span {
  color: var(--body);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.project-directory-member-grid {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-content: flex-start;
  max-height: 150px;
  overflow-y: auto;
  padding: 10px;
}

.project-directory-member-chip,
.project-directory-member-empty {
  width: max-content;
  max-width: 100%;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--body);
  padding: 7px 12px;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.project-directory-member-chip.is-me {
  border-color: var(--color-route-border-pink-100);
  background: var(--color-route-surface-pink-75);
  color: var(--primary);
}

.project-directory-member-empty {
  border-style: dashed;
  color: var(--muted);
}

.project-directory-modal-request-list {
  min-width: 0;
  display: grid;
  gap: 10px;
}

.project-directory-modal-request-row {
  min-width: 0;
  min-height: 58px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
}

.project-directory-modal-request-row > span {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.project-directory-modal-request-row strong,
.project-directory-modal-request-row small {
  min-width: 0;
  overflow-wrap: anywhere;
  line-height: 1.3;
}

.project-directory-modal-request-row strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-emphasis);
}

.project-directory-modal-request-row small {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.project-directory-modal-row-actions {
  display: inline-flex;
  justify-content: flex-end;
  gap: 6px;
  flex-wrap: wrap;
}

.project-directory-modal-row-actions button {
  min-height: var(--control-height-small);
}

@media (max-width: 520px) {
  .project-directory-modal-backdrop {
    align-items: end;
    padding: 12px;
  }

  .project-directory-modal {
    width: 100%;
    max-height: calc(100vh - 24px);
  }

  .project-directory-modal-header {
    padding: 16px;
  }

  .project-directory-modal-body {
    padding: 16px;
  }

  .project-directory-member-summary {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }

  .project-directory-member-summary span {
    white-space: normal;
  }

  .project-directory-modal-request-row {
    grid-template-columns: 1fr;
  }

  .project-directory-modal-row-actions {
    justify-content: flex-start;
  }
}

/* bundled from styles/routes/account-projects.cards.css */
@media (max-width: 1023px) {
  .project-directory-table-head {
    display: none;
  }

  .project-directory-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .project-directory-row > .project-directory-count,
  .project-directory-row > .project-directory-state {
    display: none;
  }

  .project-directory-list {
    max-height: none;
  }

  .project-directory-detail-heading {
    grid-template-columns: 1fr;
  }
}

.project-card-icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-3);
  background: var(--ku-crimson-soft);
  color: var(--primary);
  display: grid;
  place-items: center;
}

.project-card-icon svg,
.project-management-project-card > svg,
.project-directory-row-action svg {
  width: 17px;
  height: 17px;
}

.project-card-main,
.project-card-title-row {
  min-width: 0;
}

.project-card-main {
  display: grid;
  gap: 5px;
}

.project-card-title-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.project-card-title-row strong {
  min-width: 0;
  color: var(--ink);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-strong);
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.project-card-title-row em {
  flex: 0 0 auto;
  border: 1px solid var(--color-status-checkout-border);
  border-radius: var(--radius-2);
  background: var(--color-status-checkout-bg);
  color: var(--color-status-checkout-text);
  padding: 3px 6px;
  font-size: var(--font-size-xs);
  font-style: normal;
  font-weight: var(--font-weight-strong);
}

.project-card-main > span:last-child {
  color: var(--body);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-medium);
  line-height: 1.35;
}

.project-card-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(44px, 1fr));
  gap: 6px;
}

.project-card-stat-grid span {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-control-small);
  background: var(--color-bg-subtle);
  padding: 7px;
  display: grid;
  gap: 2px;
  text-align: center;
}

.project-card-stat-grid strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-strong);
  line-height: 1;
}

.project-card-stat-grid small {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
}

.project-management-queue-row,
.project-rental-row {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-surface);
  padding: 11px;
  display: grid;
  align-items: center;
  gap: var(--space-project-section-gap);
}

.project-management-queue-row {
  grid-template-columns: minmax(0, 1fr) auto;
}

.project-management-queue-row span,
.project-rental-main,
.project-rental-period {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.project-management-queue-row strong,
.project-rental-main strong {
  min-width: 0;
  color: var(--ink);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-strong);
  line-height: 1.25;
}

.project-management-queue-row small,
.project-management-queue-row em,
.project-rental-main span,
.project-rental-period,
.project-rental-period time {
  color: var(--body);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  font-style: normal;
  line-height: 1.35;
}

.project-rental-row {
  grid-template-columns: minmax(180px, 1.4fr) 104px minmax(150px, 0.8fr) max-content;
}

.project-rental-actions {
  display: flex;
  justify-content: flex-end;
  gap: 6px;
  align-items: center;
  justify-self: end;
}

.project-management-page .desktop-back-button,
.project-management-page .desktop-project-action-button,
.project-management-page .desktop-rental-action,
.project-management-page .desktop-rental-more,
.project-management-page .desktop-new-rental-button {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-control-small);
  background: var(--surface);
  color: var(--ink);
  min-height: var(--control-height-search);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 0 12px;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.project-management-page .desktop-new-rental-button,
.project-management-page .desktop-rental-action.primary {
  border-color: var(--primary);
  background: var(--primary);
  color: var(--color-text-on-action);
}

.project-management-page .desktop-project-action-button.danger {
  border-color: var(--color-state-red-200);
  background: var(--color-state-red-75);
  color: var(--primary);
}

.project-management-page .desktop-rental-more {
  width: var(--control-height-small);
  padding: 0;
}

.project-management-page .desktop-rental-action svg,
.project-management-page .desktop-rental-more svg,
.project-management-page .desktop-back-button svg,
.project-management-page .desktop-project-action-button svg,
.project-management-page .desktop-new-rental-button svg {
  width: 16px;
  height: 16px;
  stroke-width: 2.3;
}

.project-management-page .desktop-rental-action svg {
  width: 20px;
  height: 20px;
}

.project-management-page .project-rental-actions .desktop-rental-action {
  min-width: 42px;
  width: 42px;
  padding: 0;
}

.project-management-page .project-rental-actions .desktop-rental-action svg {
  flex: 0 0 20px;
}

.project-management-page .desktop-rental-status {
  justify-self: start;
}

.project-management-empty {
  border: 1px dashed var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  color: var(--muted);
  padding: 14px;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  line-height: 1.45;
}

.project-management-side .project-members-card {
  grid-column: auto;
  background: var(--surface);
}

.project-management-side .project-members-heading h2 {
  font-size: var(--font-size-2xl);
}

.project-management-side .project-invite-form {
  grid-template-columns: 1fr;
}

.project-member-chip {
  font-weight: var(--font-weight-strong);
}

/* bundled from styles/routes/account-my-rentals.overview.css */
#myRentals {
  --my-rentals-heading-offset: 14px;
  --my-rentals-project-offset: 20px;
  --my-rentals-task-offset: 6px;
}

.my-rentals-desktop-workspace {
  display: none;
}

.my-rentals-mobile-flow {
  display: contents;
}

#myRentals .project-management-header {
  padding-left: var(--my-rentals-heading-offset);
}

#myRentals > .project-card,
#myRentals .my-rentals-mobile-flow > .project-card {
  position: relative;
  width: calc(100% - var(--my-rentals-project-offset));
  margin-left: var(--my-rentals-project-offset);
}

#myRentals > .project-card::before,
#myRentals .my-rentals-mobile-flow > .project-card::before {
  content: "";
  position: absolute;
  left: -12px;
  top: 50%;
  height: 26px;
  width: 2px;
  border-radius: var(--radius-pill);
  background: var(--hairline);
  transform: translateY(-50%);
}

.project-card .record-card-header > div {
  min-width: 0;
}

.project-card-badges {
  display: flex;
  flex: 0 0 auto;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}

.project-card:hover {
  border-color: var(--primary);
  box-shadow: 0 8px 20px var(--color-route-shadow-admin-subtle);
}

.project-card.is-empty {
  cursor: default;
}

.project-rentals-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

@media (max-width: 1023px) {
  .account-dashboard-grid,
  .project-management-grid,
  .project-setup-card {
    grid-template-columns: 1fr;
  }

  .project-management-hero,
  .project-management-workspace,
  .project-management-workspace.is-detail,
  .project-directory-workspace {
    grid-template-columns: 1fr;
  }

  .project-management-hero-actions {
    min-width: 0;
    justify-content: stretch;
  }

  .project-management-hero-actions > button {
    min-width: 0;
    flex: 1 1 120px;
  }

  .project-management-stat-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .project-management-project-card,
  .project-directory-row,
  .project-rental-row {
    grid-template-columns: 1fr;
  }

  .project-card-icon,
  .project-management-project-card > svg {
    display: none;
  }

  .project-directory-project-cell {
    grid-template-columns: minmax(0, 1fr);
  }

  .project-card-stat-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .project-rental-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr)) 38px;
  }

  [data-panel="project-management"] > .page-heading h1 {
    font-size: 22px;
    line-height: 1.2;
    white-space: nowrap;
  }

  [data-panel="project-management"] > .page-heading .secondary-button {
    min-height: var(--control-height-search);
    padding-inline: 18px;
  }

  .policy-history-summary-grid {
    grid-template-columns: 1fr;
  }

  .policy-history-status-panel,
  .policy-history-row,
  .policy-history-row-title,
  .policy-history-row-side {
    align-items: flex-start;
  }

  .policy-history-status-panel {
    flex-direction: column;
  }

  .policy-history-row {
    grid-template-columns: 1fr;
  }

  .policy-history-row-marker {
    width: 42px;
    height: 4px;
  }

  .policy-history-status-counts,
  .policy-history-row-side {
    justify-content: flex-start;
  }
}

@media (max-width: 520px) {
  .project-management-hero-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .project-management-hero-actions .danger-button {
    grid-column: 1 / -1;
  }

  .project-card-stat-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .account-dashboard-compact {
    display: none;
  }

  .account-dashboard-desktop {
    display: grid;
    gap: 12px;
  }
}

@media (max-width: 520px) {
  .settings-input-row,
  .settings-choice-row {
    grid-template-columns: 1fr;
  }

  .settings-choice-list {
    gap: 6px;
  }

  .settings-input-row > span,
  .settings-choice-row > span {
    justify-self: start;
    text-align: left;
  }

  #myRentals {
    --my-rentals-project-offset: 12px;
    --my-rentals-task-offset: 0px;
  }

  .project-create-form,
  .project-management-row,
  .project-rentals-header,
  .project-members-heading,
  .project-invite-form,
  .project-pending-row {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  #myRentals .project-management-header {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    padding-left: 0;
  }

  #myRentals .project-management-actions {
    gap: 6px;
  }

  #myRentals .project-management-actions .compact {
    min-width: 46px;
    min-height: var(--control-height-filter);
    padding-inline: 8px;
  }

  #myRentals .project-setup-card h2 {
    font-size: var(--font-size-2xl);
  }

  #myRentals > .project-card::before,
  #myRentals .my-rentals-mobile-flow > .project-card::before {
    left: -8px;
  }
}

.record-card {
  display: grid;
  gap: 12px;
}

.record-card-body {
  display: flex;
  gap: 10px;
}

/* bundled from styles/routes/account-my-rentals.detail.css */
.rental-record-body {
  display: block;
}

.rental-equipment-list {
  margin-top: 7px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px 7px;
  max-width: 100%;
}

.rental-equipment-chip {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--color-bg-subtle);
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 25px;
  padding: 4px 8px;
  font-size: 12px;
  font-weight: var(--font-weight-strong);
  line-height: 1.2;
}

.rental-equipment-chip.is-empty {
  color: var(--muted);
}

.rental-equipment-chip.is-more {
  background: var(--color-route-surface-neutral-50);
  color: var(--muted);
}

.rental-equipment-chip em {
  color: var(--muted);
  font-style: normal;
  font-weight: var(--font-weight-strong);
}

.rental-equipment-list-preview {
  margin-top: 0;
  max-height: 64px;
  overflow: hidden;
}

.rental-state-note {
  margin-top: 7px;
}

.record-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.rental-detail-view {
  max-width: 980px;
}

.rental-detail-view .page-heading > div {
  min-width: 0;
}

.rental-detail-view .page-heading h1 {
  white-space: nowrap;
}

.rental-detail-view .page-heading .secondary-button {
  width: auto;
  max-width: none;
  min-width: max-content;
  flex: 0 0 auto;
}

.rental-detail-board {
  display: grid;
  gap: 12px;
  min-width: 0;
}

.rental-detail-hero,
.detail-section {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
}

.rental-detail-hero {
  padding: 14px;
  display: grid;
  gap: 12px;
}

.rental-detail-masthead {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}

.rental-detail-masthead .status-chip {
  justify-self: end;
}

.rental-detail-masthead h2 {
  margin: 2px 0 4px;
  color: var(--ink);
  font-size: 22px;
  line-height: 1.2;
}

.rental-detail-masthead p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}

.rental-detail-masthead .detail-primary-time {
  color: var(--ink);
  font-size: 18px;
  font-weight: var(--font-weight-strong);
  line-height: 1.35;
}

.rental-detail-masthead .detail-renter {
  margin-top: 6px;
  font-size: 13px;
  font-weight: var(--font-weight-strong);
}

.detail-resource-count {
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
}

.detail-action-row,
.detail-hero-actions,
.detail-management-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.detail-hero-actions,
.detail-management-actions {
  justify-content: flex-end;
}

.detail-management-actions {
  border-top: 1px solid var(--hairline);
  padding-top: 10px;
}

.detail-proof-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.detail-photo-workbench {
  display: grid;
  gap: 10px;
}

.detail-photo-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.5fr);
  gap: 10px;
  align-items: stretch;
}

.detail-photo-status-stack {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.detail-photo-action-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 12px;
}

.detail-photo-action-card.action {
  border-color: var(--color-state-orange-200);
  background: var(--color-state-orange-50);
}

.detail-photo-action-card.complete {
  border-color: var(--color-state-green-200);
  background: var(--color-state-green-50);
}

.detail-photo-action-card div,
.detail-photo-feedback,
.detail-history-card,
.detail-photo-record-card {
  min-width: 0;
}

.detail-photo-action-card div {
  display: grid;
  gap: 4px;
}

.detail-photo-action-card span,
.detail-photo-feedback span,
.detail-photo-record-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.detail-photo-action-card strong,
.detail-photo-feedback strong,
.detail-photo-record-card strong {
  color: var(--ink);
  line-height: 1.3;
}

.detail-photo-action-card small,
.detail-photo-record-card small {
  color: var(--muted);
  line-height: 1.4;
}

.detail-photo-action-card .primary-button {
  width: auto;
  min-width: 132px;
}

.detail-photo-feedback {
  border: 1px solid var(--color-state-orange-200);
  border-radius: var(--radius-3);
  background: var(--color-state-orange-50);
  display: grid;
  gap: 4px;
  padding: 11px 12px;
}

.detail-history-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  display: grid;
  gap: 10px;
  padding: 12px;
}

.detail-history-heading,
.detail-history-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: baseline;
}

.detail-history-heading span,
.detail-history-row span {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.detail-history-heading strong,
.detail-history-row time {
  color: var(--ink);
  font-weight: var(--font-weight-strong);
}

.detail-history-list {
  display: grid;
  gap: 0;
}

.detail-history-row {
  border-top: 1px solid var(--hairline);
  display: grid;
  grid-template-columns: minmax(128px, 1fr) max-content;
  padding: 8px 0;
}

.detail-history-row time {
  text-align: right;
  white-space: nowrap;
}

.detail-history-row:first-child {
  border-top: 0;
  padding-top: 0;
}

.detail-history-row:last-child {
  padding-bottom: 0;
}

.detail-photo-record-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.detail-photo-record-card {
  appearance: none;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  color: inherit;
  cursor: pointer;
  display: grid;
  gap: 8px;
  font: inherit;
  padding: 12px;
  text-align: left;
  width: 100%;
}

.detail-photo-record-card:hover,
.detail-photo-record-card:focus-visible {
  border-color: color-mix(in srgb, var(--primary) 58%, var(--hairline));
  outline: none;
}

.detail-photo-record-card > div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: baseline;
}

.detail-photo-record-card.complete {
  border-color: var(--color-state-green-200);
  background: var(--color-state-green-50);
}

.detail-photo-record-card.is-selected {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary) 18%, transparent);
}

.detail-photo-record-card.is-empty {
  background: var(--surface);
  border-style: dashed;
}

.detail-photo-shared-panel {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  display: grid;
  gap: 10px;
  padding: 12px;
}

.detail-photo-shared-panel[hidden] {
  display: none;
}

.detail-photo-detail-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.detail-photo-detail-head div {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.detail-photo-detail-head strong {
  color: var(--ink);
  font-size: 16px;
  line-height: 1.25;
}

.detail-photo-detail-head span {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.detail-photo-detail-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.detail-photo-detail-item {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-2);
  background: var(--surface);
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 10px;
}

.detail-photo-category {
  color: var(--ink);
  font-size: 14px;
  font-weight: var(--font-weight-strong);
}

.detail-photo-detail-item time,
.detail-photo-count-note {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
  line-height: 1.35;
}

.detail-photo-count-note {
  margin: 0;
}

.detail-proof-card {
  padding: 12px;
  display: grid;
  gap: 5px;
}

.detail-proof-card span,
.detail-section-heading span {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.detail-proof-card strong,
.detail-section-heading strong {
  color: var(--ink);
  line-height: 1.3;
}

.detail-resource-summary-list {
  display: grid;
  gap: 4px;
  min-width: 0;
  margin: 0;
  padding: 0;
  list-style: none;
  color: var(--ink);
  font-weight: var(--font-weight-strong);
  justify-items: end;
  line-height: 1.3;
  text-align: right;
}

.detail-resource-summary-line {
  display: block;
}

.detail-section {
  padding: 14px;
  display: grid;
  gap: 12px;
}

.detail-section-heading {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: baseline;
  border-bottom: 1px solid var(--hairline);
  padding-bottom: 10px;
}

.detail-equipment-workbench {
  display: grid;
  gap: 10px;
}

.detail-equipment-stress {
  display: grid;
  gap: 14px;
}

.detail-equipment-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.detail-equipment-summary span,
.detail-equipment-category summary,
.detail-equipment-item {
  border: 1px solid var(--hairline);
  border-radius: 8px;
  background: var(--surface);
}

.detail-equipment-summary span {
  display: grid;
  gap: 3px;
  min-width: 0;
  padding: 10px;
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.detail-equipment-summary strong {
  color: var(--ink);
  font-size: 18px;
}

.detail-equipment-groups {
  display: grid;
  gap: 8px;
}

.detail-equipment-category {
  border: 1px solid var(--hairline);
  border-radius: 8px;
  overflow: hidden;
  background: var(--color-bg-subtle);
}

.detail-equipment-category summary {
  cursor: pointer;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 10px;
  align-items: center;
  list-style: none;
  padding: 11px 12px;
}

.detail-equipment-category summary::-webkit-details-marker {
  display: none;
}

.detail-equipment-category summary > strong {
  min-width: 0;
}

.detail-equipment-category summary > strong small {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 12px;
}

.detail-equipment-count {
  color: var(--ink);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.detail-equipment-category summary::after {
  content: "펼침";
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  padding: 4px 8px;
  color: var(--muted);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.detail-equipment-category[open] summary::after {
  content: "접기";
  color: var(--primary);
}

.detail-equipment-list {
  border-top: 1px solid var(--hairline);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 10px;
}

.detail-equipment-item {
  min-width: 0;
  padding: 9px 10px;
}

.detail-equipment-item-compact {
  padding: 12px;
}

.detail-equipment-item strong,
.detail-equipment-item span {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.detail-equipment-item small,
.detail-equipment-category small,
.detail-proof-card small,
.detail-log-item small {
  color: var(--muted);
}

.detail-equipment-item small {
  overflow-wrap: anywhere;
}

.detail-equipment-item strong,
.detail-equipment-category strong,
.detail-log-item strong {
  color: var(--ink);
}

.detail-proof-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
}

.detail-proof-card.complete {
  border-color: var(--color-state-green-200);
  background: var(--color-state-green-50);
}

.detail-proof-card.waiting {
  border-color: var(--color-state-orange-200);
  background: var(--color-state-orange-50);
}

.detail-log-list {
  display: grid;
  gap: 8px;
}

.detail-log-disclosure {
  padding: 0;
}

.detail-log-disclosure summary {
  cursor: pointer;
  list-style: none;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 14px;
}

.detail-log-disclosure summary::-webkit-details-marker {
  display: none;
}

.detail-log-disclosure summary span {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.detail-log-disclosure summary strong {
  color: var(--ink);
}

.detail-log-disclosure summary em {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--color-bg-subtle);
  color: var(--body);
  font-style: normal;
  font-size: 11px;
  font-weight: var(--font-weight-strong);
  padding: 4px 8px;
}

.detail-log-disclosure[open] summary {
  border-bottom: 1px solid var(--hairline);
}

.detail-log-list.is-compact {
  padding: 10px 14px 14px;
  gap: 0;
}

.detail-log-item {
  display: grid;
  grid-template-columns: 118px minmax(0, 1fr);
  gap: 12px;
  border-bottom: 1px solid var(--hairline);
  padding: 8px 0;
  background: transparent;
}

.detail-log-item:last-child {
  border-bottom: 0;
}

.detail-empty-log {
  margin: 0;
  padding: 14px 0;
  color: var(--muted);
  font-size: 14px;
  font-weight: var(--font-weight-medium);
}

.detail-log-item time {
  color: var(--primary);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.detail-log-item div {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.rental-policy-tags {
  margin-top: 7px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.rental-policy-tags span,
.policy-grid span {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--color-bg-subtle);
  color: var(--body);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
  line-height: 1.25;
  padding: 5px 8px;
}

.is-disabled {
  opacity: 0.58;
}

button.is-disabled {
  cursor: not-allowed;
}

.upload-board {
  padding: 16px;
  display: grid;
  gap: 16px;
}

.upload-summary {
  justify-content: space-between;
  gap: 14px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  padding: 14px;
  background: var(--color-bg-subtle);
}

.upload-summary p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.upload-gate-note {
  max-width: 620px;
}

@media (max-width: 720px) {
  .detail-photo-action-card,
  .detail-photo-record-grid,
  .detail-photo-overview-grid,
  .detail-photo-detail-list,
  .detail-equipment-list {
    grid-template-columns: 1fr;
  }

  .detail-equipment-category summary {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .detail-equipment-category summary::after {
    display: none;
  }

  .detail-photo-action-card .primary-button {
    width: 100%;
  }

  .detail-hero-actions,
  .detail-management-actions {
    justify-content: flex-start;
  }
}

/* bundled from styles/routes/account-my-rentals.photos.css */
.photo-grid {
  display: grid;
  grid-template-columns: minmax(420px, 1.2fr) minmax(320px, 0.8fr);
  gap: 14px;
}

.upload-policy-board,
.photo-requirement-board,
.photo-staging-board,
.photo-version-board {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 14px;
  display: grid;
  gap: 12px;
}

.upload-policy-board {
  grid-column: 1 / -1;
  grid-template-columns: minmax(240px, 0.65fr) minmax(320px, 1fr);
  align-items: center;
  background: var(--color-bg-subtle);
}

.upload-policy-board h2 {
  margin: 0;
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
}

.upload-policy-board p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.policy-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  justify-content: flex-end;
}

.photo-board-heading,
.category-zone-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.photo-board-heading h2 {
  margin: 0;
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
}

.category-zone-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(180px, 1fr));
  gap: 10px;
}

.category-zone {
  min-height: 118px;
  border: 1px dashed var(--hairline-strong);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 10px;
  display: grid;
  gap: 10px;
  align-content: start;
}

.category-zone.has-photo {
  border-style: solid;
  background: var(--color-photo-success-soft-bg);
}

.category-zone.is-drop-target {
  border-color: var(--primary);
  background: var(--ku-crimson-soft);
}

.category-zone-header strong {
  color: var(--ink);
  font-size: 14px;
}

.category-zone-header span {
  color: var(--muted);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
}

.assigned-photos {
  display: grid;
  gap: 7px;
}

.assigned-photos p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
}

.assigned-photo {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 8px;
  text-align: left;
  display: grid;
  gap: 3px;
}

.assigned-photo span,
.staged-photo-card strong {
  color: var(--ink);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
}

.assigned-photo small,
.staged-photo-card span,
.staged-photo-card small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.staged-photo-grid {
  display: grid;
  gap: 10px;
}

.staged-photo-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-route-surface-soft-pink);
  padding: 9px;
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 10px;
  cursor: grab;
}

.staged-photo-card:active {
  cursor: grabbing;
}

.staged-photo-card.state-uploaded {
  background: var(--color-state-green-50);
  border-color: var(--color-state-green-200);
}

.staged-photo-card.state-uploading {
  background: var(--color-state-blue-50);
  border-color: var(--color-state-blue-200);
}

.staged-photo-card.state-failed {
  background: var(--color-state-red-100);
  border-color: var(--color-state-red-200);
}

.mock-photo-preview {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  color: var(--ku-crimson-dark);
  display: grid;
  place-items: center;
  font-weight: var(--font-weight-strong);
}

.mock-photo-preview {
  height: 52px;
}

.photo-card {
  min-height: 92px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 10px;
  display: flex;
  flex-direction: column;
  justify-content: end;
  gap: 6px;
}

.photo-card.complete {
  background: var(--color-state-green-50);
  border-color: var(--color-state-green-200);
}

.photo-card.waiting {
  background: var(--color-route-surface-soft-pink);
}

.photo-version-board {
  grid-column: 1 / -1;
}

.photo-version-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  gap: 10px;
}

.photo-version-list article {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-route-surface-soft-pink);
  padding: 10px;
  display: grid;
  gap: 4px;
}

.photo-version-list strong {
  color: var(--ink);
  font-size: 13px;
}

.photo-version-list span,
.photo-version-list small,
.admin-lock-note {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

/* bundled from styles/routes/account-rentals.dashboard.css */
/*
 * ACCOUNT RENTALS DASHBOARD CSS CONTRACT
 * Rental dashboard task rows and compact task actions.
 */
.rental-dashboard {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius-3);
  background: var(--surface);
}

.rental-dashboard-heading,
.rental-task-row,
.rental-task-actions {
  display: flex;
  align-items: center;
}

.rental-dashboard-heading {
  justify-content: space-between;
  gap: 12px;
}

.rental-dashboard-heading h2 {
  margin: 2px 0 0;
  font-size: var(--font-size-title-sm);
}

.rental-dashboard-list {
  display: grid;
  gap: 8px;
}

#myRentals .rental-dashboard-list {
  margin-left: var(--my-rentals-task-offset);
}

.rental-task-row {
  justify-content: space-between;
  gap: 12px;
  min-height: 58px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
}

.rental-task-row.is-actionable {
  border-color: var(--ku-crimson);
  background: var(--ku-crimson-soft);
}

.rental-task-main {
  flex: 1 1 auto;
  display: grid;
  min-width: 0;
  gap: 2px;
}

.rental-task-main strong,
.rental-task-main span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rental-task-main strong {
  color: var(--ink);
  font-size: 14px;
  line-height: 1.3;
  font-weight: var(--font-weight-strong);
}

.rental-task-main span,
.rental-task-empty span {
  color: var(--muted);
  font-size: 13px;
  font-weight: var(--font-weight-medium);
  line-height: 1.35;
}

.rental-task-actions {
  flex: 0 0 auto;
  gap: 8px;
}

.rental-task-action-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.rental-task-action-icon {
  display: none;
  width: 16px;
  height: 16px;
  stroke-width: 2.5;
}

.rental-task-empty {
  display: grid;
  gap: 4px;
  padding: 12px;
  border: 1px dashed var(--line);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
}

@media (max-width: 1023px) {
  .rental-dashboard {
    padding: 14px;
  }

  .rental-dashboard-heading h2 {
    font-size: 18px;
  }
}

@media (max-width: 520px) {
  .rental-task-actions {
    display: flex;
  }

  .rental-task-action-button.compact {
    width: var(--control-size-icon-md);
    min-width: var(--control-size-icon-md);
    padding: 0;
  }

  .rental-task-button-text {
    display: none;
  }

  .rental-task-action-icon {
    display: block;
  }

  .my-rental-filter-bar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* bundled from styles/routes/account-my-rentals.shell-responsive.css */
/*
 * ACCOUNT MY RENTALS SHELL RESPONSIVE CSS CONTRACT
 * Account route shell height corrections outside the desktop workstation source.
 */
@media (min-width: 521px) and (max-width: 1023px) {
  body:has([data-panel="mine"].is-visible) .workspace {
    height: calc(100dvh - var(--topbar-height-wide-tablet));
  }
}

/* bundled from styles/routes/account-my-rentals.mobile-records.css */
/*
 * ACCOUNT MY RENTALS MOBILE RECORD CSS CONTRACT
 * Mobile rental record and filter-bar overrides.
 */
@media (max-width: 520px) {
  .rental-record .record-card-header {
    grid-template-columns: minmax(0, 1fr) auto;
    column-gap: 10px;
  }

  .rental-record .status-chip {
    justify-self: end;
    align-self: start;
  }

  .rental-period-block {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: stretch;
  }

  .period-node {
    min-width: 0;
  }

  .my-rental-filter-bar {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 6px;
  }

  .my-rental-filter-bar .chip-button {
    min-height: var(--control-height-search);
    padding: 0 6px;
    font-size: 13px;
  }
}

/* bundled from styles/admin/home.css */
.admin-workspace {
  display: grid;
  gap: 14px;
}

.member-admin-workspace {
  gap: 0;
}

.admin-members-view .member-admin-grid {
  grid-template-columns: minmax(0, 1fr);
}

.admin-subnav {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 4px;
  padding: 4px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
}

.admin-subnav-button {
  min-height: var(--control-height-search);
  border: 0;
  border-radius: var(--radius-control-small);
  background: transparent;
  color: var(--body);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
}

.admin-subnav-button.is-active {
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 1px 2px var(--color-route-shadow-page);
}

.admin-home-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  justify-content: stretch;
  gap: 12px;
}

.admin-home-hero-count {
  color: var(--primary);
  font-size: 64px;
  line-height: 1;
  letter-spacing: 0;
}

.admin-home-hero-count span {
  color: var(--primary);
  font-size: 28px;
  margin-left: 4px;
}

.admin-home-panel-heading .admin-home-hero-count {
  flex: 0 0 auto;
  color: var(--primary);
  font-size: 34px;
  font-weight: var(--font-weight-emphasis);
  line-height: 1;
  text-align: right;
}

.admin-home-panel-heading .admin-home-hero-count span {
  font-size: var(--font-size-lg);
}

.admin-home-panel-heading h2,
.admin-home-quick .admin-section-heading h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-emphasis);
  line-height: 1.2;
}

.admin-home-task-list {
  display: grid;
  gap: 8px;
}

.admin-home-task-row {
  --task-accent: var(--admin-card-accent);
  --task-soft: var(--admin-card-badge-bg);
  width: 100%;
  min-width: 0;
  min-height: 70px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  color: var(--ink);
  padding: 11px 12px;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  text-align: left;
}

.admin-home-task-row:hover,
.admin-quick-card:hover,
.admin-recent-row:hover {
  border-color: var(--primary);
  background: var(--surface);
  box-shadow: 0 0 0 3px var(--color-focus-ring-soft);
}

.admin-home-task-row:focus-visible,
.admin-quick-card:focus-visible,
.admin-recent-row:focus-visible,
.admin-r2-refresh-button:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.admin-home-task-row.admin-tone-photos {
  --task-accent: var(--primary);
  --task-soft: var(--ku-crimson-soft);
  --admin-card-badge-bg: var(--ku-crimson-soft);
  --admin-card-badge-text: var(--primary);
}

.admin-home-task-row.admin-tone-approvals {
  --task-accent: var(--color-state-orange-700);
  --task-soft: var(--color-state-orange-100);
}

.admin-home-task-row.admin-tone-members {
  --task-accent: var(--color-state-purple-700);
  --task-soft: var(--color-route-surface-indigo-50);
}

.admin-home-task-row.admin-tone-equipment {
  --task-accent: var(--color-route-text-slate-700);
  --task-soft: var(--color-route-surface-slate-100);
}

.admin-home-task-icon {
  width: var(--control-height-compact);
  height: var(--control-height-compact);
  border-radius: var(--radius-pill);
  background: var(--task-soft);
  color: var(--task-accent);
  display: grid;
  place-items: center;
}

.admin-home-task-icon svg {
  width: 16px;
  height: 16px;
  stroke-width: 2.35;
}

.admin-home-task-main {
  min-width: 0;
  display: flex;
  align-items: center;
}

.admin-home-task-main strong {
  color: var(--ink);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-emphasis);
  line-height: 1.2;
  white-space: normal;
}

.admin-home-task-due {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
  text-align: right;
  white-space: nowrap;
}

.admin-home-quick,
.admin-recent-panel,
.admin-home-quick,
.admin-r2-usage-panel,
.admin-recent-panel {
  padding: 26px 30px;
}

.admin-home-quick .admin-section-heading {
  margin-bottom: 12px;
}

.admin-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.admin-quick-card {
  --admin-card-border: var(--hairline);
  --admin-card-badge-bg: var(--surface-muted);
  --admin-card-badge-text: var(--body);
  min-height: 84px;
  border: 1px solid var(--admin-card-border);
  border-radius: var(--radius-3);
  background: var(--surface);
  color: var(--ink);
  padding: 12px 10px;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 7px;
  text-align: center;
}

.admin-quick-icon {
  width: var(--control-height-compact);
  height: var(--control-height-compact);
  border-radius: var(--radius-3);
  background: transparent;
  color: var(--admin-card-accent);
  display: grid;
  place-items: center;
}

.admin-quick-icon svg {
  width: 20px;
  height: 20px;
  stroke-width: 2.4;
}

.admin-quick-card strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
  line-height: 1.25;
  white-space: nowrap;
}

.admin-quick-card .admin-alert-badge,
.admin-quick-card .admin-clear-badge {
  grid-column: auto;
  grid-row: auto;
  justify-self: start;
  align-self: end;
}

.admin-recent-list {
  display: grid;
  gap: 7px;
}

.admin-recent-row {
  min-height: 48px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  color: var(--body);
  padding: 8px 10px;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  text-align: left;
  cursor: pointer;
}

.admin-recent-icon {
  width: var(--control-height-compact);
  height: var(--control-height-compact);
  border-radius: var(--radius-pill);
  background: var(--ku-crimson-soft);
  color: var(--primary);
  display: grid;
  place-items: center;
}

.admin-recent-icon svg {
  width: 16px;
  height: 16px;
  stroke-width: 2.4;
}

.admin-recent-tone-approvals .admin-recent-icon {
  background: var(--color-state-orange-100);
  color: var(--color-state-orange-700);
}

.admin-recent-tone-members .admin-recent-icon {
  background: var(--color-route-surface-indigo-50);
  color: var(--color-state-purple-700);
}

.admin-recent-tone-equipment .admin-recent-icon {
  background: var(--color-route-surface-slate-100);
  color: var(--color-route-text-slate-700);
}

.admin-recent-main {
  min-width: 0;
  display: flex;
  align-items: baseline;
  gap: 10px;
}

.admin-recent-main strong {
  color: var(--ink);
  font-size: var(--font-size-md);
  line-height: 1.3;
  white-space: nowrap;
}

.admin-recent-main span {
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-recent-row time {
  color: var(--muted);
  font-size: var(--font-size-sm);
  white-space: nowrap;
}

.admin-home-priority-compact .admin-recent-row {
  grid-template-columns: 34px minmax(0, 1fr) minmax(110px, 0.32fr);
}

.admin-priority-meta {
  min-width: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-home-empty-note {
  margin: 0;
  border: 1px dashed var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  color: var(--muted);
  padding: 12px;
  font-size: var(--font-size-md);
  line-height: 1.45;
}

.admin-recent-more {
  border: 0;
  background: transparent;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-strong);
}

.admin-recent-more svg {
  width: 16px;
  height: 16px;
  stroke-width: 2.5;
}

.admin-home-archive-link {
  width: 100%;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  color: var(--ink);
  padding: 16px 18px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto 18px;
  align-items: center;
  gap: 12px;
  text-align: left;
}

.admin-home-archive-link strong,
.admin-home-archive-link small {
  display: block;
}

.admin-home-archive-link strong {
  color: var(--ink);
  font-size: var(--font-size-title-sm);
  line-height: 1.25;
}

.admin-home-archive-link small {
  margin-top: 4px;
  color: var(--muted);
  font-size: var(--font-size-lg);
  line-height: 1.35;
}

.admin-home-archive-link .admin-alert-badge,
.admin-home-archive-link .admin-clear-badge {
  grid-column: auto;
  grid-row: auto;
  justify-self: end;
}

.admin-home-archive-link svg {
  width: 18px;
  height: 18px;
  color: var(--muted);
  stroke-width: 2.4;
}

.admin-system-card {
  min-height: 132px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  padding: 14px;
  text-align: center;
}

.admin-system-check {
  width: var(--control-height-small);
  height: var(--control-height-small);
  border-radius: var(--radius-pill);
  background: var(--color-state-green-600);
  color: var(--color-route-surface-white);
  display: grid;
  place-items: center;
}

.admin-system-check svg {
  width: 18px;
  height: 18px;
  stroke-width: 3;
}

.admin-system-card strong {
  color: var(--color-state-green-700);
  font-size: var(--font-size-xl);
  line-height: 1.25;
}

.admin-system-card p {
  margin: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.35;
}

.admin-r2-status-summary.risk-clear .admin-system-check {
  background: var(--color-state-green-600);
}

.admin-r2-status-summary.risk-clear strong {
  color: var(--color-state-green-700);
}

.admin-r2-status-summary.risk-warning .admin-system-check {
  background: var(--color-state-orange-700);
}

.admin-r2-status-summary.risk-warning strong {
  color: var(--color-route-text-orange-900);
}

.admin-r2-status-summary.risk-danger .admin-system-check {
  background: var(--color-route-text-red-700);
}

.admin-r2-status-summary.risk-danger strong {
  color: var(--color-route-text-red-700);
}

.admin-r2-heading-actions {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.admin-r2-heading-actions small {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-emphasis);
  white-space: nowrap;
}

.admin-r2-refresh-button {
  width: var(--control-height-small);
  height: var(--control-height-small);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  color: var(--primary);
  display: inline-grid;
  place-items: center;
  padding: 0;
}

.admin-r2-refresh-button svg {
  width: 16px;
  height: 16px;
  stroke-width: 2.4;
}

.admin-r2-system-panel {
  display: grid;
  gap: 8px;
}

.admin-r2-signal-row,
.admin-r2-sync-status-row {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 10px;
}

.admin-r2-signal-row {
  display: grid;
  gap: 9px;
}

.admin-r2-signal-row-head,
.admin-r2-sync-status-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.admin-r2-signal-row-head strong,
.admin-r2-sync-status-row strong {
  color: var(--ink);
  font-size: var(--font-size-md);
  line-height: 1.3;
}

.admin-r2-signal-row-head span {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.admin-r2-signal-meter {
  height: 7px;
  border-radius: var(--radius-pill);
  background: var(--color-route-surface-rose-100);
  overflow: hidden;
}

.admin-r2-signal-meter span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--color-state-green-700);
}

.admin-r2-signal-meter span.risk-warning {
  background: var(--color-state-orange-700);
}

.admin-r2-signal-meter span.risk-danger {
  background: var(--color-route-text-red-700);
}

.admin-r2-usage-panel {
  display: grid;
  gap: 12px;
  min-width: 0;
}

#billingUsagePanel > .admin-r2-usage-panel {
  display: contents;
  padding: 0;
}

.billing-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(280px, 0.9fr);
  gap: 12px;
  align-items: start;
  min-width: 0;
}

.billing-r2-panel,
.billing-status-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 14px;
  display: grid;
  gap: 12px;
  min-width: 0;
}

.billing-panel-heading h2 {
  color: var(--ink);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-emphasis);
  line-height: 1.3;
}

.r2-usage-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 12px;
}

.r2-usage-metric-group {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.r2-usage-metric-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-width: 0;
}

.r2-usage-metric-label,
.r2-usage-metric-limit,
.r2-usage-value-caption,
.r2-usage-meter-labels {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  line-height: 1.35;
}

.r2-usage-metric-limit {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.r2-usage-metric-limit strong {
  color: inherit;
  font-weight: inherit;
}

.r2-usage-metric {
  min-height: 116px;
  border: 1px solid var(--color-route-border-neutral-200);
  border-radius: var(--radius-3);
  background: var(--color-route-surface-slate-50);
  padding: 14px;
  display: grid;
  gap: 10px;
  min-width: 0;
}

.r2-usage-value-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  min-width: 0;
}

.r2-usage-value-row > strong {
  color: var(--ink);
  font-size: var(--font-size-title-lg);
  font-weight: var(--font-weight-emphasis);
  line-height: 1;
}

.r2-usage-meter {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.r2-usage-meter-labels {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 4px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
}

.r2-usage-meter-labels span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.r2-usage-meter-labels span:nth-child(2),
.r2-usage-meter-labels span:nth-child(3),
.r2-usage-meter-labels span:nth-child(4) {
  text-align: center;
}

.r2-usage-meter-labels span:last-child {
  text-align: right;
}

.r2-usage-meter-track {
  position: relative;
  height: 12px;
  border: 1px solid var(--color-route-border-neutral-200);
  border-radius: var(--radius-pill);
  background:
    linear-gradient(to right, transparent calc(25% - 1px), var(--color-route-brand-tint-16) calc(25% - 1px), var(--color-route-brand-tint-16) calc(25% + 1px), transparent calc(25% + 1px)),
    linear-gradient(to right, transparent calc(50% - 1px), var(--color-route-brand-tint-16) calc(50% - 1px), var(--color-route-brand-tint-16) calc(50% + 1px), transparent calc(50% + 1px)),
    linear-gradient(to right, transparent calc(75% - 1px), var(--color-route-brand-tint-16) calc(75% - 1px), var(--color-route-brand-tint-16) calc(75% + 1px), transparent calc(75% + 1px)),
    var(--color-neutral-75);
  overflow: hidden;
}

.r2-usage-meter-bar {
  display: block;
  width: var(--usage-progress);
  height: 100%;
  max-width: 100%;
  border-radius: inherit;
  background: var(--color-state-green-700);
}

.r2-usage-meter-current {
  position: absolute;
  top: 50%;
  left: var(--usage-progress);
  width: 7px;
  height: 18px;
  border: 2px solid var(--surface);
  border-radius: var(--radius-pill);
  background: var(--color-state-green-700);
  box-shadow: 0 0 0 1px var(--color-state-green-200);
  transform: translate(-50%, -50%);
}

.r2-usage-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.35;
}

.billing-status-panel {
  min-width: 0;
}

.billing-status-list {
  display: grid;
  gap: 8px;
}

.billing-status-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-route-surface-slate-50);
  padding: 11px 12px;
}

.billing-status-row strong {
  display: block;
  color: var(--ink);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  line-height: 1.35;
}

.billing-status-row span {
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.35;
}

.billing-status-row > strong {
  text-align: right;
  white-space: nowrap;
}

.r2-risk-pill {
  border-radius: var(--radius-pill);
  padding: 6px 10px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.r2-risk-pill.risk-clear {
  background: var(--color-route-surface-green-100);
  color: var(--color-route-text-green-700);
}

.r2-risk-pill.risk-warning {
  background: var(--color-state-orange-100);
  color: var(--color-route-text-orange-900);
}

.r2-risk-pill.risk-danger {
  background: var(--color-state-red-150);
  color: var(--color-route-text-red-700);
}

.admin-tone-photos {
  --admin-card-bg: var(--color-route-surface-blue-25);
  --admin-card-border: var(--color-route-border-blue-200);
  --admin-card-accent: var(--color-state-blue-600);
  --admin-card-badge-bg: var(--color-state-blue-100);
  --admin-card-badge-text: var(--color-state-blue-700);
}

.admin-tone-approvals {
  --admin-card-bg: var(--color-state-orange-50);
  --admin-card-border: var(--color-route-border-orange-200);
  --admin-card-accent: var(--color-state-orange-700);
  --admin-card-badge-bg: var(--color-state-orange-100);
  --admin-card-badge-text: var(--color-route-text-orange-800);
}

.admin-tone-signup {
  --admin-card-bg: var(--color-route-surface-blue-25);
  --admin-card-border: var(--color-route-border-blue-200);
  --admin-card-accent: var(--color-state-blue-700);
  --admin-card-badge-bg: var(--color-state-blue-100);
  --admin-card-badge-text: var(--color-state-blue-700);
}

.admin-tone-equipment {
  --admin-card-bg: var(--color-state-green-50);
  --admin-card-border: var(--color-route-border-green-200);
  --admin-card-accent: var(--color-state-green-700);
  --admin-card-badge-bg: var(--color-route-surface-green-100);
  --admin-card-badge-text: var(--color-route-text-green-700);
}

.admin-tone-members {
  --admin-card-bg: var(--color-route-surface-indigo-25);
  --admin-card-border: var(--color-route-border-indigo-200);
  --admin-card-accent: var(--color-state-purple-700);
  --admin-card-badge-bg: var(--color-route-surface-indigo-50);
  --admin-card-badge-text: var(--color-route-text-indigo-700);
}

.admin-tone-violations {
  --admin-card-bg: var(--color-state-red-50);
  --admin-card-border: var(--color-state-red-200);
  --admin-card-accent: var(--color-state-red-700);
  --admin-card-badge-bg: var(--color-state-red-150);
  --admin-card-badge-text: var(--color-route-text-red-700);
}

.admin-tone-billing {
  --admin-card-bg: var(--color-route-surface-slate-50);
  --admin-card-border: var(--color-route-border-neutral-200);
  --admin-card-accent: var(--color-route-text-slate-700);
  --admin-card-badge-bg: var(--color-route-surface-slate-100);
  --admin-card-badge-text: var(--color-route-text-slate-700);
}

.admin-home-top,
.admin-heading-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.admin-alert-badge,
.admin-clear-badge {
  grid-column: 2;
  grid-row: 1 / span 3;
  justify-self: end;
  align-self: start;
  border-radius: var(--radius-pill);
  padding: 5px 8px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
}

.admin-alert-badge {
  background: var(--admin-card-badge-bg);
  color: var(--admin-card-badge-text);
}

.admin-clear-badge {
  background: var(--color-route-surface-slate-100);
  color: var(--muted);
}

/* bundled from styles/admin/home.desktop.css */
.admin-home-desktop-view {
  display: grid;
  gap: 12px;
}

/* bundled from styles/admin/home.mobile.css */
@media (max-width: 1023px) {
  .workspace.is-admin-shell .view-panel[data-panel="admin-home"].is-visible {
    width: min(680px, 100%);
    max-width: 680px;
    min-width: 0;
    margin-inline: auto;
  }

  .workspace.is-admin-shell .view-panel[data-panel="admin-home"] .admin-workspace,
  .workspace.is-admin-shell .view-panel[data-panel="admin-home"] .admin-home-panel,
  .workspace.is-admin-shell .view-panel[data-panel="admin-home"] .admin-home-grid {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .workspace.is-admin-shell .view-panel[data-panel="admin-home"] .admin-home-desktop-view {
    display: grid;
    max-width: 100%;
    min-width: 0;
  }

  .workspace.is-admin-shell .admin-section.admin-home-panel {
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
  }
}

/* bundled from styles/routes/account-my-rentals.desktop.css */
/*
 * ACCOUNT MY RENTALS DESKTOP CSS CONTRACT
 * Import hub only for desktop /my-rentals workstation slices.
 */
/* bundled from styles/routes/account-my-rentals.desktop-workspace.css */
/*
 * ACCOUNT MY RENTALS DESKTOP WORKSPACE CSS CONTRACT
 * Desktop shell, toolbar, and board framing for /my-rentals.
 */
@media (min-width: 1024px) {
  body:has([data-panel="mine"].is-visible) .workspace {
    scrollbar-gutter: stable;
  }

  [data-panel="mine"].compact-view {
    max-width: none;
    border: 0;
    background: transparent;
    box-shadow: none;
    padding: 0 30px 0;
  }

  body:has([data-panel="mine"].is-visible) [data-panel="mine"] > .page-heading,
  [data-panel="mine"] > .page-heading {
    display: none !important;
  }

  #myRentals.record-grid {
    display: block;
    width: min(var(--content-max-width-operational), 100%);
    margin: 0 auto;
  }

  #myRentals .my-rentals-mobile-flow {
    display: none;
  }

  .my-rentals-desktop-workspace {
    display: grid;
    grid-template-columns: minmax(720px, 1fr) 368px;
    gap: 30px;
    align-items: start;
  }

  .my-rentals-desktop-main,
  .my-rentals-desktop-side {
    min-width: 0;
  }

  .my-rentals-desktop-title {
    min-height: 72px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
  }

  .my-rentals-desktop-title h2 {
    margin: 0;
    color: var(--ink);
    font-size: 31px;
    line-height: 1.15;
    letter-spacing: 0;
  }

  .my-rentals-desktop-title h2 span {
    display: inline-flex;
    margin-left: 10px;
    transform: translateY(-4px);
    border: 1px solid var(--hairline);
    border-radius: var(--radius-2);
    padding: 5px 9px;
    color: var(--muted);
    background: var(--surface);
    font-size: 13px;
    font-weight: var(--font-weight-strong);
    vertical-align: middle;
  }

  .my-rentals-desktop-title p {
    margin: 9px 0 0;
    color: var(--body);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-medium);
  }

  .my-rentals-desktop-board,
  .desktop-side-card {
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--surface);
    box-shadow: 0 8px 24px var(--color-route-shadow-admin-hairline);
  }

  .my-rentals-desktop-board {
    min-height: 0;
    max-height: calc(100vh - 126px);
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    overflow: hidden;
  }

  .my-rentals-desktop-title.is-project-detail + .my-rentals-desktop-board {
    max-height: calc(100vh - 210px);
  }

  .my-rentals-desktop-toolbar {
    margin-inline: -1px;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
    align-items: center;
    padding: 14px 16px;
    border-bottom: 1px solid var(--hairline);
  }

  .desktop-filter-primary-row {
    min-width: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) var(--control-height-search);
    gap: 10px;
    align-items: center;
  }

  .desktop-filter-panel {
    min-width: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
  }

  .desktop-filter-panel[hidden] {
    display: none;
  }

  .desktop-status-tabs {
    min-width: 0;
  }

  .desktop-sort-toggle {
    justify-self: end;
  }

  .desktop-sort-toggle:hover {
    border-color: var(--primary);
    background: var(--surface);
    color: var(--primary);
    box-shadow: var(--shadow-control);
  }

  .desktop-project-manage,
  .desktop-back-button,
  .desktop-rental-action,
  .desktop-rental-more,
  .desktop-all-projects-button,
  .desktop-project-action-button,
  .my-rentals-load-more {
    border: 1px solid var(--hairline);
    border-radius: var(--radius-control-small);
    background: var(--surface);
    color: var(--ink);
    min-height: var(--control-height-search);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 0 12px;
    font-size: 13px;
    font-weight: var(--font-weight-strong);
    white-space: nowrap;
  }

  .desktop-project-manage svg,
  .desktop-back-button svg,
  .desktop-rental-action svg,
  .desktop-rental-more svg,
  .desktop-all-projects-button svg,
  .desktop-project-action-button svg,
  .my-rentals-load-more svg {
    width: 16px;
    height: 16px;
    stroke-width: 2.3;
  }

}

/* bundled from styles/routes/account-my-rentals.desktop-list.css */
/*
 * ACCOUNT MY RENTALS DESKTOP LIST CSS CONTRACT
 * Desktop rental project list rows, statuses, and row actions.
 */
@media (min-width: 1024px) {
  .my-rentals-project-section {
    border-bottom: 1px solid var(--hairline);
    padding: 14px 22px;
  }

  .my-rentals-project-section:last-child {
    border-bottom: 0;
  }

  .my-rentals-project-heading {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-4);
    margin-bottom: 14px;
  }

  .my-rentals-project-heading > div {
    padding-left: 10px;
  }

  .my-rentals-project-heading h2 {
    display: inline;
    margin: 0;
    color: var(--ink);
    font-size: var(--font-size-title-sm);
    line-height: 1.25;
  }

  .desktop-project-count {
    margin-left: 8px;
    transform: translateY(-1px);
  }

  .desktop-project-summary-row b {
    color: var(--hairline);
    font-weight: var(--font-weight-medium);
  }

  .my-rentals-desktop-rows {
    display: grid;
    gap: 10px;
  }

  .my-rentals-project-list {
    min-height: 0;
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
  }

  .my-rentals-desktop-row {
    min-height: 92px;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-panel);
    background: var(--surface);
    display: grid;
    grid-template-columns: minmax(180px, 1fr) 96px minmax(136px, 0.72fr) minmax(286px, auto) 18px;
    gap: 10px;
    align-items: center;
    padding: 14px 12px 14px 18px;
    cursor: pointer;
  }

  .my-rentals-desktop-row:hover,
  .my-rentals-desktop-row:focus-visible {
    border-color: var(--color-rental-row-selected-border);
    box-shadow: 0 8px 18px var(--color-route-shadow-admin-micro);
    outline: 0;
  }

  .desktop-rental-equipment,
  .desktop-rental-period,
  .desktop-rental-owner {
    min-width: 0;
    display: grid;
    gap: 5px;
  }

  .desktop-rental-equipment strong,
  .desktop-rental-owner strong {
    color: var(--ink);
    font-size: var(--font-size-xl);
    line-height: 1.25;
    font-weight: var(--font-weight-strong);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .desktop-rental-equipment span,
  .desktop-rental-period span,
  .desktop-rental-period time,
  .desktop-rental-owner small {
    color: var(--body);
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-medium);
    line-height: 1.35;
  }

  .desktop-rental-equipment span {
    display: block;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .desktop-rental-status {
    justify-self: start;
  }

  .my-rentals-desktop-members {
    display: flex;
    align-items: center;
    min-width: 0;
  }

  .member-avatar-mini,
  .member-avatar-extra {
    width: 24px;
    height: 24px;
    border: 2px solid var(--surface);
    border-radius: var(--radius-pill);
    background: var(--color-rental-row-active-bg);
    color: var(--primary);
    display: grid;
    place-items: center;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-strong);
  }

  .member-avatar-mini + .member-avatar-mini,
  .member-avatar-extra {
    margin-left: -7px;
  }

  .member-avatar-extra {
    background: var(--color-rental-row-hover-bg);
    color: var(--body);
  }

  .desktop-rental-actions {
    position: relative;
    min-width: 0;
    display: flex;
    gap: 6px;
    align-items: center;
    justify-content: end;
    justify-self: end;
    max-width: 100%;
  }

  .desktop-rental-action {
    flex: 0 0 auto;
    min-width: 112px;
  }

  .desktop-rental-action.primary {
    min-width: 132px;
  }

  .desktop-rental-action.primary {
    border-color: var(--primary);
    color: var(--primary);
    background: var(--color-route-surface-white);
  }

  .desktop-rental-action.is-disabled,
  .desktop-rental-action:disabled {
    border-color: var(--color-rental-row-border-subtle);
    color: var(--muted);
    background: var(--color-route-surface-neutral-25);
    cursor: not-allowed;
    opacity: 0.62;
  }

  .desktop-rental-more {
    width: var(--control-size-icon-md);
    min-width: var(--control-size-icon-md);
    height: var(--control-size-icon-md);
    min-height: var(--control-height-search);
    padding: 0;
  }

  .desktop-rental-more.is-active {
    border-color: var(--color-route-brand-tint-34);
    color: var(--primary);
    background: var(--color-route-brand-tint-06);
  }

  .desktop-rental-row-chevron {
    width: 18px;
    height: 18px;
    color: var(--body);
    stroke-width: 2.4;
    justify-self: end;
  }

  .desktop-rental-more-wrap {
    position: relative;
    display: inline-flex;
    justify-self: end;
  }

  .desktop-rental-menu {
    position: absolute;
    z-index: 60;
    top: calc(100% + 8px);
    right: 0;
    width: 168px;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-panel);
    background: var(--surface);
    box-shadow: var(--shadow-rental-detail-card);
    padding: 6px;
    display: grid;
    gap: 3px;
  }

  .desktop-rental-menu.is-above {
    top: auto;
    bottom: calc(100% + 8px);
  }

  .desktop-rental-menu[hidden] {
    display: none;
  }

  .desktop-rental-menu button {
    min-height: var(--control-height-small);
    border: 0;
    border-radius: var(--radius-sm);
    background: transparent;
    color: var(--ink);
    display: grid;
    grid-template-columns: 16px minmax(0, 1fr);
    align-items: center;
    gap: var(--space-2);
    padding: 0 8px;
    text-align: left;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-strong);
  }

  .desktop-rental-menu button:hover {
    background: var(--color-route-brand-tint-06);
    color: var(--primary);
  }

  .desktop-rental-menu button.danger-menu-item {
    color: var(--danger);
  }

  .desktop-rental-menu button.danger-menu-item:hover {
    background: var(--color-state-red-100);
    color: var(--danger);
  }

  .desktop-rental-menu button.is-disabled {
    color: var(--muted);
    cursor: not-allowed;
    opacity: 0.62;
  }

  .desktop-rental-menu button.is-disabled:hover {
    background: transparent;
    color: var(--muted);
  }

  .desktop-rental-menu svg {
    width: 15px;
    height: 15px;
    stroke-width: 2.3;
  }

  .my-rentals-desktop-footer {
    margin-inline: -1px;
    min-height: 48px;
    border-top: 1px solid var(--hairline);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 10px 20px;
    color: var(--body);
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-strong);
  }

  .my-rentals-visible-count {
    min-width: 0;
  }

  .my-rentals-load-more {
    color: var(--primary);
    cursor: pointer;
  }

  .my-rentals-load-more:hover,
  .my-rentals-load-more:focus-visible {
    border-color: var(--color-route-brand-tint-34);
    background: var(--color-route-brand-tint-06);
    outline: none;
  }

  .my-rentals-load-sentinel {
    display: block;
    width: 1px;
    height: 1px;
    margin: 0 auto;
  }
}

/* bundled from styles/routes/account-my-rentals.desktop-sidebar.css */
/*
 * ACCOUNT MY RENTALS DESKTOP SIDEBAR CSS CONTRACT
 * Desktop task, upcoming-rental, and project summary side panels.
 */
@media (min-width: 1024px) {
  .my-rentals-desktop-side {
    display: grid;
    gap: var(--space-4);
  }

  .desktop-side-card {
    padding: var(--space-4);
    display: grid;
    gap: 14px;
  }

  .desktop-side-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
  }

  .desktop-side-heading h2 {
    margin: 0;
    color: var(--ink);
    font-size: var(--font-size-2xl);
  }

  .desktop-side-heading .ui-count-badge {
    padding: 4px 8px;
    color: var(--body);
  }

  .desktop-todo-list,
  .desktop-project-summary-list {
    display: grid;
  }

  .desktop-todo-list.ui-preview-list {
    gap: 0;
  }

  .desktop-upcoming-rental-list {
    max-height: 198px;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
  }

  .desktop-todo-row strong,
  .desktop-project-summary-row strong {
    display: block;
    color: var(--ink);
    font-size: var(--font-size-lg);
    line-height: 1.3;
    font-weight: var(--font-weight-strong);
  }

  .desktop-todo-row small,
  .desktop-project-summary-row small {
    display: block;
    margin-top: 3px;
    color: var(--body);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    line-height: 1.35;
  }

  .desktop-new-rental-button {
    min-height: 42px;
    border: 0;
    border-radius: var(--radius-control-small);
    background: var(--primary);
    color: var(--color-route-surface-white);
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-strong);
  }

  .desktop-project-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-2);
    padding-top: 2px;
  }

  .my-rentals-desktop-title.is-project-detail {
    min-height: 64px;
    align-items: center;
  }

  .desktop-project-detail-heading {
    min-width: 0;
    display: grid;
    gap: 6px;
  }

  .desktop-project-detail-heading p {
    margin: 0;
  }

  .desktop-project-detail-heading b {
    color: var(--hairline);
  }

  .desktop-back-button {
    width: fit-content;
    min-height: var(--control-height-filter);
    padding: 0 10px;
    color: var(--body);
  }

  .desktop-project-action-button {
    width: 100%;
    min-width: 0;
  }

  .desktop-project-action-button.danger {
    border-color: var(--color-project-action-danger-border);
    background: color-mix(in srgb, var(--color-route-surface-white) 98%, transparent);
    color: var(--primary);
  }

  .desktop-all-projects-button {
    width: 100%;
    justify-content: space-between;
  }

  .desktop-all-projects-button.is-active {
    border-color: var(--color-route-brand-tint-42);
    color: var(--primary);
    background: var(--color-route-brand-tint-06);
  }

  .desktop-empty-state {
    border: 1px dashed var(--hairline);
    border-radius: var(--radius-panel);
    padding: var(--space-4);
    color: var(--muted);
    background: var(--color-bg-subtle);
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-strong);
  }
}

/* bundled from styles/routes/account-my-rentals.desktop-responsive.css */
/*
 * ACCOUNT MY RENTALS DESKTOP RESPONSIVE CSS CONTRACT
 * Narrow desktop adjustments for the /my-rentals desktop workspace.
 */
@media (min-width: 1024px) {
  .my-rentals-desktop-workspace {
    grid-template-columns: minmax(0, 1fr) minmax(300px, 320px);
    gap: clamp(16px, 1.5vw, 18px);
  }

  .desktop-status-tabs {
    gap: 5px;
  }

  .my-rentals-desktop-row {
    grid-template-columns: minmax(0, 1.2fr) minmax(88px, 104px) minmax(110px, 0.82fr) minmax(82px, 116px) 18px;
    gap: clamp(8px, 0.85vw, 10px);
  }

  .desktop-rental-action span {
    display: none;
  }

  .my-rentals-desktop-side {
    grid-template-columns: 1fr;
  }

  .my-rentals-desktop-title {
    min-height: 58px;
  }

  .my-rentals-project-section {
    padding-inline: 14px;
  }

  .my-rentals-project-heading {
    gap: 10px;
  }

  .my-rentals-desktop-row {
    padding: 12px;
  }

  .desktop-rental-equipment strong,
  .desktop-rental-owner strong {
    font-size: 14px;
  }

  .desktop-rental-equipment span,
  .desktop-rental-period span,
  .desktop-rental-period time,
  .desktop-rental-owner small {
    font-size: 12px;
  }

  .desktop-rental-status {
    padding: 6px 8px;
    font-size: 11px;
  }

  .desktop-rental-actions {
    gap: 6px;
  }

  .desktop-rental-action,
  .desktop-rental-more {
    min-width: clamp(34px, 3.4vw, 42px);
    width: clamp(34px, 3.4vw, 42px);
    height: clamp(34px, 3.4vw, 42px);
    min-height: clamp(34px, 3.4vw, 42px);
    padding: 0;
  }

  .desktop-rental-action.primary {
    min-width: clamp(34px, 3.4vw, 42px);
    width: clamp(34px, 3.4vw, 42px);
  }

  .desktop-side-card {
    padding: 14px;
  }

  .desktop-todo-row {
    grid-template-columns: minmax(0, 1fr) auto 18px;
    gap: 8px;
  }

  .desktop-project-actions {
    gap: 6px;
  }
}

/* bundled from styles/routes/account-my-rentals.mobile.css */
/*
 * MOBILE ROUTE CSS CONTRACT: account my rentals
 *
 * Mobile-only account and my-rentals CSS belongs here.
 */

/* Mobile-only `/my-rentals` mockup layout. Desktop keeps its separate workstation markup. */
@media (max-width: 1023px) {
  body:has([data-panel="mine"].is-visible) .workspace {
    height: calc(100dvh - 56px);
    padding: 0 14px 18px;
    overflow-x: hidden;
  }

  body:has([data-panel="mine"].is-visible) [data-panel="mine"].compact-view {
    width: min(100%, 680px);
    max-width: 680px;
    margin: 0 auto;
    border: 0;
    background: transparent;
    box-shadow: none;
    padding: 20px 0 0;
  }

  body:has([data-panel="mine"].is-visible) [data-panel="mine"] > .page-heading {
    margin: 0 2px 12px;
    padding: 0;
    border: 0;
  }

  body:has([data-panel="mine"].is-visible) [data-panel="mine"] > .page-heading h1 {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--ink);
    font-size: var(--font-size-title-lg);
    line-height: 1.1;
    font-weight: var(--font-weight-strong);
  }

  #myRentals.record-grid {
    display: block;
    width: 100%;
    max-width: 680px;
    margin: 0 auto;
  }

  #myRentals .my-rentals-mobile-flow {
    min-width: 0;
    display: grid;
    gap: 10px;
    overflow-x: hidden;
  }

  .my-rentals-mobile-project-list {
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--surface);
    box-shadow: var(--shadow);
  }

  .my-rentals-mobile-project-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
  }

  .my-rentals-mobile-action-panel {
    padding: 10px 12px 12px;
  }

  .my-rentals-mobile-action-panel .ui-preview-panel-heading {
    gap: 8px;
  }

  .my-rentals-mobile-action-panel .ui-preview-panel-heading h2 {
    font-size: var(--font-size-2xl);
    line-height: 1.2;
  }

  .my-rentals-mobile-action-list {
    min-width: 0;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    border: 0;
    border-radius: 0;
    overflow: visible;
    gap: 8px;
  }

  .my-rentals-mobile-action-row {
    min-width: 0;
    min-height: 44px;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--surface);
    grid-template-columns: minmax(0, 1fr) auto 16px;
    gap: 6px;
    padding: 8px 10px;
  }

  .my-rentals-mobile-action-row strong {
    font-size: var(--font-size-md);
    line-height: 1.2;
  }

  .my-rentals-mobile-action-row small {
    display: none;
  }

  .my-rentals-mobile-action-row .status-chip {
    padding: 3px 8px;
    font-size: var(--font-size-sm);
  }

  .my-rentals-mobile-action-row > .lucide,
  .my-rentals-mobile-action-row > [data-lucide] {
    color: var(--primary);
  }

  .my-rentals-mobile-create-row {
    color: var(--primary);
  }

  .my-rentals-mobile-filter-region[hidden] {
    display: none;
  }

  .my-rentals-mobile-filter-region {
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
  }

  .my-rentals-mobile-status-tabs {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
    padding: 0;
  }

  .my-rentals-mobile-status-tabs .ui-status-filter-chip {
    min-height: var(--control-height-small);
    padding-inline: 10px;
  }

  .my-rentals-mobile-search-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) var(--control-height-search);
    gap: 10px;
  }

  .my-rentals-mobile-filter-button {
    justify-self: end;
  }

  .my-rentals-mobile-filter-button.is-active {
    border-color: var(--ku-crimson-border);
    color: var(--primary);
    background: var(--color-brand-tint-bg-subtle);
  }

  .my-rentals-mobile-project-list {
    padding: 0;
    overflow: hidden;
  }

  .my-rentals-mobile-project {
    border-bottom: 1px solid var(--hairline);
    padding: 14px 8px 10px;
  }

  .my-rentals-mobile-project:last-child {
    border-bottom: 0;
  }

  .my-rentals-mobile-project-heading {
    padding: 0 6px 12px;
    color: var(--ink);
  }

  .my-rentals-mobile-project-heading > span {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 8px;
  }

  .my-rentals-mobile-project-heading svg {
    width: 21px;
    height: 21px;
    stroke-width: 2.35;
  }

  .my-rentals-mobile-project-heading strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-strong);
  }

  .my-rentals-mobile-project-heading em {
    margin-left: auto;
    color: var(--muted);
    font-style: normal;
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-strong);
    white-space: nowrap;
  }

  .my-rentals-mobile-rental-list {
    display: grid;
    gap: 8px;
  }

  .my-rentals-mobile-rental {
    min-height: 0;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--surface);
    display: grid;
    grid-template-columns: 76px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    padding: 10px;
  }

  .my-rentals-mobile-thumb .equipment-thumb {
    width: 72px;
    min-width: 72px;
    height: 72px;
    min-height: 72px;
    border-radius: var(--radius-3);
  }

  .my-rentals-mobile-thumb .no-photo-icon {
    width: 24px;
    height: 24px;
  }

  .my-rentals-mobile-thumb .no-photo-label {
    font-size: 10px;
  }

  .my-rentals-mobile-rental-main {
    min-width: 0;
    display: grid;
    gap: 6px;
  }

  .my-rentals-mobile-rental-title {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
  }

  .my-rentals-mobile-rental-title strong {
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
    color: var(--ink);
    font-size: var(--font-size-xl);
    line-height: 1.2;
    font-weight: var(--font-weight-strong);
  }

  .my-rentals-mobile-rental-title span {
    border-radius: var(--radius-control-small);
    background: var(--surface-muted);
    color: var(--muted);
    padding: 4px 7px;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-strong);
    white-space: nowrap;
  }

  .my-rentals-mobile-rental-main p {
    margin: 0;
    color: var(--muted);
    font-size: var(--font-size-md);
    line-height: 1.35;
    font-weight: var(--font-weight-strong);
  }

  .my-rentals-mobile-rental-main small {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 7px;
    font-size: var(--font-size-md);
    line-height: 1.35;
    font-weight: var(--font-weight-strong);
  }

  .my-rentals-mobile-rental-main small b {
    color: var(--muted);
  }

  .my-rentals-mobile-rental-main small.tone-active,
  .my-rentals-mobile-rental-main small.tone-done {
    color: var(--color-state-green-700);
  }

  .my-rentals-mobile-rental-main small.tone-warning {
    color: var(--color-state-orange-650);
  }

  .my-rentals-mobile-rental-main small.tone-info {
    color: var(--color-state-blue-600);
  }

  .my-rentals-mobile-rental-actions {
    grid-column: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-top: 2px;
  }

  .my-rentals-mobile-photo-button {
    min-height: var(--control-height-small);
    border: 1px solid var(--primary);
    border-radius: var(--radius-3);
    background: var(--surface);
    color: var(--primary);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 0 10px;
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-strong);
    white-space: nowrap;
  }

  .my-rentals-mobile-photo-button.is-disabled {
    opacity: 0.58;
  }

  .my-rentals-mobile-photo-button svg {
    width: 16px;
    height: 16px;
  }

  .my-rentals-mobile-detail-button {
    min-height: var(--control-height-small);
    border: 0;
    background: transparent;
    color: var(--body);
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 4px;
    padding: 0;
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-strong);
    white-space: nowrap;
  }

  .my-rentals-mobile-detail-button svg {
    width: 17px;
    height: 17px;
  }

  .my-rentals-mobile-footnote {
    margin: 2px 10px 0;
    color: var(--muted);
    font-size: var(--font-size-md);
    line-height: 1.4;
    font-weight: var(--font-weight-strong);
  }

  .my-rentals-mobile-empty {
    padding: 18px;
    color: var(--muted);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-emphasis);
  }
}

@media (min-width: 521px) and (max-width: 1023px) {
  body:has([data-panel="mine"].is-visible) [data-panel="mine"].compact-view {
    width: min(100%, 680px);
    max-width: 680px;
    margin: 0 auto;
  }
}

/* bundled from styles/routes/policy-history.css */
/*
 * POLICY HISTORY ROUTE CSS CONTRACT
 * Import hub for policy history route styles.
 */
/* bundled from styles/routes/policy-history.responsive.css */
/*
 * POLICY HISTORY RESPONSIVE CSS CONTRACT
 * Policy history mobile layout adjustments.
 */
@media (max-width: 1023px) {
  .policy-history-page .policy-layout,
  .policy-history-page .standing-strip,
  .policy-history-page .standing-main {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .policy-history-page .metric-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .policy-history-page .record-list {
    max-height: none;
    overflow: visible;
  }

  .policy-history-page .inspector {
    display: none;
  }

  .policy-history-page .record-row {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .policy-history-page .record-side {
    grid-column: 2;
    justify-content: space-between;
  }
}

@media (max-width: 520px) {
  .policy-history-page .metric-row {
    grid-template-columns: 1fr;
  }
}

/* bundled from styles/admin/photos.css */
/*
 * ADMIN PHOTOS CSS CONTRACT
 * Import hub only. Keep active photo upload and photo review styles here.
 */
/* bundled from styles/admin/photos.review-archive.css */
.admin-tone-archive {
  --admin-card-bg: var(--color-admin-tone-archive-bg);
  --admin-card-border: var(--color-admin-tone-archive-border);
  --admin-card-accent: var(--archive);
  --admin-card-badge-bg: var(--color-admin-tone-archive-badge-bg);
  --admin-card-badge-text: var(--color-admin-tone-archive-badge-text);
}

.admin-tone-settings {
  --admin-card-bg: var(--color-admin-tone-settings-bg);
  --admin-card-border: var(--color-admin-tone-settings-border);
  --admin-card-accent: var(--color-admin-tone-settings-accent);
  --admin-card-badge-bg: var(--color-admin-tone-settings-badge-bg);
  --admin-card-badge-text: var(--color-admin-tone-settings-badge-text);
}

.admin-filter-bar,
.upload-progress-strip,
.admin-photo-meta-grid,
.equipment-change-log,
.archive-receipt-list,
.equipment-archive-mobile-list {
  display: grid;
  gap: 8px;
}

.admin-filter-bar {
  grid-template-columns: minmax(220px, 1fr) auto;
  align-items: center;
  margin-bottom: 12px;
}

.my-rental-filter-bar {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
}

.my-rental-filter-bar .chip-button {
  min-width: 0;
  width: 100%;
}

.admin-review-split {
  display: grid;
  grid-template-columns: minmax(280px, 420px) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.admin-review-list,
.admin-photo-detail,
.archive-receipt-list,
.equipment-archive-ledger-card {
  min-width: 0;
}

.photo-review-card.is-active,
.admin-photo-detail {
  border-color: var(--primary);
}

.admin-photo-detail {
  display: grid;
  gap: 14px;
  position: sticky;
  top: 12px;
  padding: 14px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-3);
  background: var(--surface);
}

.admin-photo-detail.is-empty {
  color: var(--muted);
}

.admin-photo-meta-grid,
.upload-progress-strip {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-photo-meta-grid span,
.upload-progress-strip span,
.equipment-change-log span,
.archive-receipt-list span {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  padding: 8px 10px;
  background: var(--surface-muted);
  color: var(--body);
  font-size: var(--font-size-sm);
}

.equipment-archive-ledger-card table strong {
  font-size: var(--font-size-sm);
}

.equipment-archive-mobile-list {
  display: none;
}

.equipment-archive-mobile-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 10px;
  display: grid;
  gap: 5px;
}

.equipment-archive-mobile-card span,
.equipment-archive-mobile-card small {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.equipment-archive-mobile-card strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
}

.admin-photo-thumb-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 8px;
}

.admin-photo-thumb {
  display: grid;
  gap: 4px;
  min-height: 72px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  padding: 10px;
  background: var(--surface-muted);
  text-align: left;
}

.admin-photo-thumb span {
  color: var(--muted);
  font-size: var(--font-size-sm);
}

.photo-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 8px;
}

.mini-chip,
.link-button {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--body);
  font: inherit;
  font-size: var(--font-size-xs);
  cursor: pointer;
}

.mini-chip {
  min-height: 26px;
  padding: 0 8px;
}

.mini-chip.is-active {
  border-color: var(--primary);
  background: var(--primary);
  color: var(--color-route-surface-white);
}

.mini-chip.is-warning {
  border-color: var(--photo-needed);
  color: var(--photo-needed);
}

.link-button {
  padding: 0;
  border: 0;
  color: var(--primary);
  text-decoration: underline;
}

.settings-list {
  display: grid;
  gap: 8px;
}

.settings-card-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.settings-card-heading .section-kicker {
  color: var(--ink);
  font-size: var(--font-size-xl);
  line-height: 1.2;
}

.settings-disclosure-card {
  gap: 0;
  border-color: var(--color-settings-disclosure-border);
  background: var(--color-settings-disclosure-bg);
  padding: 10px;
}

.profile-security-card.settings-disclosure-card {
  background: var(--color-settings-disclosure-bg);
}

.settings-disclosure-toggle {
  width: 100%;
  min-height: 26px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--muted);
  padding: 0 2px 8px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  text-align: left;
  font: inherit;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  cursor: pointer;
  transition: color var(--motion-fast) var(--motion-ease);
}

.settings-disclosure-toggle:hover {
  color: var(--body);
}

.settings-disclosure-toggle[aria-expanded="true"] {
  color: var(--body);
}

.settings-disclosure-toggle:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.settings-disclosure-toggle svg {
  width: 14px;
  height: 14px;
  color: var(--primary);
  stroke-width: 2.4;
}

.settings-disclosure-body {
  display: grid;
  gap: 10px;
  padding-top: 0;
}

.account-settings-section.settings-disclosure-card .settings-disclosure-body {
  min-height: 0;
  display: grid;
  gap: 0;
  max-height: 0;
  padding-top: 0;
  opacity: 0;
  overflow: hidden;
  visibility: hidden;
  pointer-events: none;
  transition:
    max-height var(--motion-base) var(--motion-ease),
    padding-top var(--motion-base) var(--motion-ease),
    opacity var(--motion-fast) var(--motion-ease),
    visibility 0s linear var(--motion-base);
}

.account-settings-section.settings-disclosure-card .settings-disclosure-body.is-open {
  max-height: 720px;
  padding-top: 12px;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition-delay: 0s;
}

.settings-disclosure-body-inner {
  min-height: 0;
  display: grid;
  gap: 10px;
  overflow: hidden;
}

.settings-row {
  min-height: 46px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-neutral-0);
  color: var(--body);
  padding: 9px 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  text-decoration: none;
}

.settings-row > span:first-child,
.settings-input-row > span,
.settings-choice-row > span,
.settings-field-cell > span {
  color: var(--ink);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
}

.settings-input-row,
.settings-choice-row,
.settings-value-row {
  grid-template-columns: clamp(72px, 16%, 112px) minmax(0, 1fr);
}

.settings-input-row > span,
.settings-choice-row > span,
.settings-value-row > span:first-child {
  justify-self: center;
  text-align: center;
}

.settings-value-row strong {
  min-width: 0;
  color: var(--ink);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-strong);
  overflow-wrap: anywhere;
  text-align: right;
}

.settings-choice-row {
  align-items: center;
}

.settings-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.settings-field-cell {
  min-width: 0;
  min-height: 46px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-neutral-0);
  color: var(--body);
  padding: 9px 10px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.settings-field-cell > span {
  white-space: nowrap;
}

.settings-field-cell .input {
  width: 100%;
  min-width: 0;
  min-height: var(--control-height-search);
  padding: 8px 10px;
}

.settings-field-cell.is-compact .input {
  width: 104px;
  justify-self: start;
}

.settings-input-row .input {
  min-height: var(--control-height-search);
  padding: 8px 10px;
}

.settings-choice-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.settings-choice {
  min-height: var(--control-height-filter);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--body);
  padding: 0 10px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
}

.settings-choice input {
  margin: 0;
  accent-color: var(--primary);
}

.settings-toggle-row {
  cursor: pointer;
}

.switch-input {
  appearance: none;
  width: 42px;
  height: 24px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-pill);
  background: var(--surface-muted);
  position: relative;
  cursor: pointer;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    border-color var(--motion-fast) var(--motion-ease);
}

.switch-input::before {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  border-radius: var(--radius-pill);
  background: var(--color-neutral-0);
  box-shadow: var(--shadow-photo-thumb);
  transition: transform var(--motion-fast) var(--motion-ease);
}

.switch-input:checked {
  border-color: var(--primary);
  background: var(--primary);
}

.switch-input:checked::before {
  transform: translateX(18px);
}

.switch-input:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
}

.settings-link-row {
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease);
}

.settings-link-row:hover {
  border-color: var(--ku-crimson-border);
  background: var(--color-bg-subtle);
}

.settings-link-row svg {
  width: 16px;
  height: 16px;
  color: var(--primary);
  stroke-width: 2.4;
}

@media (max-width: 520px) {
  .settings-input-row,
  .settings-choice-row,
  .settings-value-row,
  .settings-field-grid {
    grid-template-columns: 1fr;
  }

  .settings-input-row > span,
  .settings-choice-row > span,
  .settings-value-row > span:first-child {
    justify-self: start;
    text-align: left;
  }

  .settings-value-row strong {
    justify-self: start;
    text-align: left;
  }
}

.settings-document-card {
  width: 100%;
  max-width: none;
  gap: 16px;
  overflow: hidden;
}

.settings-document-toolbar {
  min-width: 0;
  border-bottom: 1px solid var(--hairline);
  background: var(--color-bg-subtle);
  margin: -20px -20px 0;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
}

.settings-document-header {
  min-width: 0;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  align-items: start;
  gap: 12px;
}

.settings-document-header h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-3xl);
  line-height: 1.2;
}

.settings-document-header p {
  max-width: 760px;
  margin: 7px 0 0;
  color: var(--body);
  font-size: var(--font-size-lg);
  line-height: 1.5;
  font-weight: var(--font-weight-medium);
}

.settings-document-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.settings-document-meta span {
  min-height: 24px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--surface-muted);
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
}

.settings-document-body {
  display: grid;
  gap: 12px;
}

.settings-document-section-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.settings-document-section {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 13px 14px;
  display: grid;
  grid-template-columns: minmax(132px, 188px) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.settings-document-section h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-lg);
  line-height: 1.25;
}

.settings-document-section ul {
  margin: 0;
  padding-left: 18px;
  color: var(--body);
  display: grid;
  gap: 6px;
  font-size: var(--font-size-md);
  line-height: 1.5;
  font-weight: var(--font-weight-medium);
}

@media (max-width: 520px) {
  .settings-document-toolbar {
    align-items: flex-start;
  }

  .settings-document-header,
  .settings-document-section-grid,
  .settings-document-section {
    grid-template-columns: 1fr;
  }
}

.confirm-action-panel {
  width: min(520px, calc(100vw - 36px));
  grid-template-rows: auto minmax(0, 1fr) auto;
}

/* bundled from styles/admin/photos.upload-desktop.css */
/* Rental photo upload. Mobile and desktop source layouts are intentionally separate. */
.photo-upload-mobile-shell {
  display: none;
}

.photo-upload-desktop-shell {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: grid;
  place-items: center;
  padding: 18px;
  background: var(--color-route-overlay-deep);
  animation: fadeIn var(--motion-base) var(--motion-ease);
}

[data-panel="photos"].is-photo-modal-open {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

[data-panel="photos"].is-photo-modal-closing {
  pointer-events: none;
}

[data-panel="photos"].is-photo-modal-closing .photo-upload-desktop-shell {
  animation: fadeOut var(--motion-slow) var(--motion-ease) forwards;
}

[data-panel="photos"].is-photo-modal-closing .photo-desktop-modal {
  animation: modalPanelOut var(--motion-slow) var(--motion-ease) forwards;
}

[data-panel="photos"].is-photo-modal-open > .page-heading,
[data-panel="photos"].is-photo-modal-open .upload-summary {
  display: none;
}

[data-panel="photos"].is-photo-modal-open .upload-board {
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.photo-desktop-modal {
  width: min(940px, calc(100vw - 36px));
  height: min(820px, calc(100dvh - 36px));
  max-height: calc(100dvh - 36px);
  border: 1px solid var(--hairline-strong);
  border-radius: 14px;
  background: var(--surface);
  box-shadow: 0 22px 60px var(--color-route-shadow-neutral);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  overflow: hidden;
  animation: modalPanelIn var(--motion-slow) var(--motion-ease);
}

.photo-desktop-modal-head {
  border-bottom: 1px solid var(--hairline);
  padding: 13px 24px 12px;
  display: grid;
  gap: 12px;
}

.photo-desktop-title-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}

.photo-desktop-title-row h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-3xl);
  line-height: 1.05;
}

.photo-desktop-close-button {
  width: 36px;
  height: 36px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--ink);
  display: grid;
  place-items: center;
  font: inherit;
  font-size: 28px;
  line-height: 1;
}

.photo-desktop-modal-body {
  min-height: 0;
  overflow: hidden;
  padding: 12px 24px;
  display: grid;
  grid-template-columns: minmax(0, 520px) minmax(250px, 280px);
  justify-content: center;
  align-items: start;
  gap: 18px;
  background: linear-gradient(90deg, var(--color-route-surface-white) 0, var(--color-route-surface-white) 66%, var(--color-bg-subtle) 66%, var(--color-bg-subtle) 100%);
}

.photo-desktop-flow-surface {
  min-width: 0;
  min-height: 0;
  display: grid;
  align-content: start;
}

.photo-desktop-summary-rail {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: 12px;
}

.photo-desktop-rail-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-5);
  background: var(--surface);
  padding: 13px 14px;
}

.photo-desktop-rail-card {
  display: grid;
  gap: 10px;
}

.photo-desktop-event-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-5);
  background: var(--color-bg-subtle);
  padding: 12px 14px;
  display: grid;
  gap: 6px;
}

.photo-desktop-event-card span {
  margin: 0;
  color: var(--primary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-emphasis);
}

.photo-desktop-event-card strong {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-xl);
  line-height: 1.2;
}

.photo-desktop-event-card p {
  margin: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.4;
}

.photo-desktop-rail-card h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-lg);
}

.photo-desktop-rail-card strong {
  color: var(--ink);
  font-size: var(--font-size-title-sm);
}

.photo-desktop-rail-card p {
  margin: 0;
  color: var(--body);
  font-size: var(--font-size-md);
  line-height: 1.5;
}

.photo-desktop-rail-metric {
  border-bottom: 1px solid var(--hairline);
  padding-bottom: 10px;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  color: var(--muted);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
}

.photo-desktop-rail-metric:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.photo-desktop-rail-metric b {
  color: var(--ink);
  font-size: var(--font-size-xl);
  white-space: nowrap;
}

.photo-desktop-modal-foot {
  border-top: 1px solid var(--hairline);
  background: var(--surface);
  padding: 10px 24px;
}

.photo-desktop-modal-foot .photo-mobile-step-actions {
  width: min(100%, 390px);
  margin-left: auto;
}

.photo-upload-desktop-shell .photo-mobile-stepper {
  --photo-step-c1: 142px;
  --photo-step-c2: 142px;
  --photo-step-c3: 142px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 28px;
  overflow: hidden;
  white-space: nowrap;
}

.photo-upload-desktop-shell .photo-mobile-stepper[data-step="2"] {
  --photo-step-c1: 118px;
  --photo-step-c2: 142px;
  --photo-step-c3: 142px;
}

.photo-upload-desktop-shell .photo-mobile-stepper[data-step="3"] {
  --photo-step-c1: 118px;
  --photo-step-c2: 118px;
  --photo-step-c3: 142px;
}

.photo-upload-desktop-shell .photo-mobile-stepper[data-step="4"] {
  --photo-step-c1: 118px;
  --photo-step-c2: 118px;
  --photo-step-c3: 118px;
}

.photo-upload-desktop-shell .photo-mobile-stepper .photo-mobile-step-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-emphasis);
}

.photo-upload-desktop-shell .photo-mobile-stepper .rental-step-bead {
  width: var(--control-height-compact);
  height: var(--control-height-compact);
  border: 2px solid var(--hairline-strong);
  border-radius: var(--radius-pill);
  background: var(--surface);
  display: grid;
  place-items: center;
  box-shadow: 0 0 0 5px var(--surface);
  transition: border-color var(--motion-control) ease, background-color var(--motion-control) ease, transform var(--motion-control) ease;
}

.photo-upload-desktop-shell .photo-mobile-stepper em {
  max-width: 0;
  overflow: hidden;
  opacity: 0;
  font-style: normal;
  transition: max-width var(--motion-control) ease, opacity var(--motion-micro) ease;
}

.photo-upload-desktop-shell .photo-mobile-stepper .rental-step-connector {
  flex: 0 0 var(--photo-step-connector);
  inline-size: var(--photo-step-connector);
  height: 1px;
  border-radius: var(--radius-pill);
  background: var(--hairline-strong);
  transition: flex-basis var(--motion-base) var(--motion-spring-ease), inline-size var(--motion-base) var(--motion-spring-ease), background-color var(--motion-control) ease;
}

.photo-upload-desktop-shell .photo-mobile-stepper .rental-step-connector[data-rental-step-connector="1"] {
  --photo-step-connector: var(--photo-step-c1);
}

.photo-upload-desktop-shell .photo-mobile-stepper .rental-step-connector[data-rental-step-connector="2"] {
  --photo-step-connector: var(--photo-step-c2);
}

.photo-upload-desktop-shell .photo-mobile-stepper .rental-step-connector[data-rental-step-connector="3"] {
  --photo-step-connector: var(--photo-step-c3);
}

.photo-upload-desktop-shell .photo-mobile-stepper .is-active,
.photo-upload-desktop-shell .photo-mobile-stepper .is-complete {
  color: var(--primary);
}

.photo-upload-desktop-shell .photo-mobile-stepper .is-active .rental-step-bead {
  border-color: var(--primary);
  transform: translateY(-1px);
}

.photo-upload-desktop-shell .photo-mobile-stepper .is-complete .rental-step-bead {
  border-color: var(--ku-crimson-border);
  background: var(--primary-soft);
}

.photo-upload-desktop-shell .photo-mobile-stepper .rental-step-connector.is-complete {
  background: var(--color-route-brand-tint-24);
}

.photo-upload-desktop-shell .photo-mobile-stepper .is-active em,
.photo-upload-desktop-shell .photo-mobile-stepper .is-complete em {
  max-width: 110px;
  opacity: 1;
}

.photo-upload-desktop-shell .photo-mobile-flow-card {
  height: clamp(500px, 63dvh, 580px);
  min-height: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-5);
  background: var(--surface);
  padding: 12px 14px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 10px;
  overflow: hidden;
}

.photo-upload-desktop-shell .photo-mobile-flow-card[hidden] {
  display: none;
}

.photo-upload-desktop-shell .photo-mobile-flow-card h3 {
  margin: 0;
  color: var(--ink);
  font-size: 19px;
  line-height: 1.1;
}

.photo-upload-desktop-shell .photo-mobile-pick-list,
.photo-upload-desktop-shell .photo-mobile-review-list {
  min-height: 0;
  display: grid;
  gap: 8px;
  align-content: start;
  overflow: auto;
}

.photo-upload-desktop-shell .photo-mobile-pick-empty {
  min-height: 0;
  display: grid;
  grid-template-rows: minmax(150px, 1fr) auto;
  gap: 12px;
}

.photo-upload-desktop-shell .photo-mobile-pick-actions {
  border-top: 1px solid var(--hairline);
  padding-top: 10px;
  display: grid;
  gap: 6px;
}

.photo-upload-desktop-shell .photo-mobile-camera-button.primary-button {
  min-height: 52px;
  border-radius: var(--radius-3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
}

.photo-upload-desktop-shell .photo-mobile-pick-stage {
  min-height: 0;
  border: 1px dashed var(--hairline-strong);
  border-radius: var(--radius-5);
  background: var(--color-bg-subtle);
  color: var(--body);
  display: grid;
  place-items: center;
  align-content: center;
  gap: 12px;
  padding: 22px 16px;
  text-align: center;
  font: inherit;
}

.photo-upload-desktop-shell .photo-mobile-pick-stage > span {
  width: 56px;
  height: 56px;
  border-radius: 18px;
  background: var(--color-route-brand-tint-08);
  color: var(--primary);
  display: grid;
  place-items: center;
  font-size: 30px;
  font-weight: var(--font-weight-emphasis);
}

.photo-upload-desktop-shell .photo-mobile-pick-stage strong {
  color: var(--ink);
  font-size: var(--font-size-2xl);
}

.photo-upload-desktop-shell .photo-mobile-pick-stage small {
  color: var(--muted);
  font-weight: var(--font-weight-strong);
}

.photo-upload-desktop-shell .photo-mobile-pick-guidance {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-4);
  background: var(--color-bg-subtle);
  padding: 13px 14px;
  display: grid;
  gap: 7px;
}

.photo-upload-desktop-shell .photo-mobile-pick-guidance p {
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.45;
}

.photo-upload-desktop-shell .photo-mobile-pick-row,
.photo-upload-desktop-shell .photo-mobile-review-row {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-4);
  background: var(--surface);
  padding: 10px;
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}

.photo-upload-desktop-shell .photo-mobile-pick-thumb {
  height: 52px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-4);
  background: var(--color-route-surface-neutral-100);
  overflow: hidden;
  display: grid;
  place-items: center;
}

.photo-upload-desktop-shell .photo-mobile-pick-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.photo-upload-desktop-shell .photo-mobile-pick-row strong,
.photo-upload-desktop-shell .photo-mobile-review-row strong,
.photo-upload-desktop-shell .photo-mobile-assignment-head strong {
  display: block;
  color: var(--ink);
  font-size: var(--font-size-lg);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.photo-upload-desktop-shell .photo-mobile-pick-row span,
.photo-upload-desktop-shell .photo-mobile-review-row span,
.photo-upload-desktop-shell .photo-mobile-assignment-head span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: var(--font-size-sm);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.photo-upload-desktop-shell .photo-mobile-pick-row small,
.photo-upload-desktop-shell .photo-mobile-review-row small {
  border-radius: var(--radius-3);
  padding: 5px 8px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-emphasis);
}

.photo-upload-desktop-shell .photo-mobile-pick-row .is-pass,
.photo-upload-desktop-shell .photo-mobile-review-row .is-pass {
  background: var(--color-route-surface-green-100);
  color: var(--color-state-green-700);
}

.photo-upload-desktop-shell .photo-mobile-pick-row .is-pending,
.photo-upload-desktop-shell .photo-mobile-review-row .is-pending {
  background: var(--color-state-orange-100);
  color: var(--color-route-text-orange-900);
}

.photo-upload-desktop-shell .photo-mobile-pick-row .is-fail,
.photo-upload-desktop-shell .photo-mobile-review-row .is-fail {
  background: var(--color-state-red-150);
  color: var(--color-route-text-red-650);
}

.photo-upload-desktop-shell .photo-mobile-assignment-carousel {
  overflow: hidden;
}

.photo-upload-desktop-shell .photo-mobile-assignment-carousel.is-moving {
  pointer-events: none;
}

.photo-upload-desktop-shell .photo-mobile-assignment-track {
  display: flex;
  transform: translateX(calc(var(--active-photo, 0) * -100%));
  transition: transform var(--motion-photo-step-track) var(--motion-spring-ease);
}

.photo-upload-desktop-shell .photo-mobile-assignment-slide {
  flex: 0 0 100%;
  inline-size: 100%;
}

.photo-upload-desktop-shell .photo-mobile-assignment-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-5);
  padding: 12px;
  display: grid;
  gap: 12px;
  transition: transform var(--motion-photo-step-enter) var(--motion-spring-ease), opacity var(--motion-photo-step-fade) ease;
}

.photo-upload-desktop-shell .photo-mobile-assignment-carousel.is-moving .photo-mobile-assignment-card {
  opacity: 0.92;
}

.photo-upload-desktop-shell .photo-mobile-assignment-head {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.photo-upload-desktop-shell .photo-mobile-proof-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 9px;
}

.photo-upload-desktop-shell .photo-mobile-proof-grid button {
  min-height: 76px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-4);
  background: var(--color-route-surface-white);
  color: var(--body);
  text-align: left;
  padding: 10px;
  font: inherit;
  transition: transform var(--motion-control) ease, background-color var(--motion-control) ease, border-color var(--motion-control) ease;
}

.photo-upload-desktop-shell .photo-mobile-proof-grid button.is-active {
  border-color: var(--color-state-green-600);
  background: var(--color-route-surface-green-50);
  transform: scale(0.98);
}

.photo-upload-desktop-shell .photo-mobile-proof-grid strong {
  display: block;
  color: var(--ink);
  font-size: var(--font-size-lg);
}

.photo-upload-desktop-shell .photo-mobile-proof-grid span {
  color: var(--muted);
  font-size: var(--font-size-xs);
}

.photo-upload-desktop-shell .photo-mobile-photo-pager,
.photo-upload-desktop-shell .photo-mobile-step-actions {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 10px;
  align-items: center;
}

.photo-upload-desktop-shell .photo-mobile-photo-pager {
  grid-template-columns: auto minmax(0, 1fr) auto;
}

.photo-upload-desktop-shell .photo-mobile-photo-pager span {
  color: var(--muted);
  text-align: center;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-emphasis);
}

.photo-upload-desktop-shell .photo-mobile-upload-row {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-4);
  padding: 12px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.photo-upload-desktop-shell .photo-mobile-upload-row .bar {
  grid-column: 1 / -1;
  height: 5px;
  border-radius: var(--radius-pill);
  background: var(--color-route-surface-rose-100);
  overflow: hidden;
}

.photo-upload-desktop-shell .photo-mobile-upload-row .bar i {
  display: block;
  width: var(--progress);
  height: 100%;
  border-radius: inherit;
  background: var(--primary);
}

.photo-upload-desktop-shell .photo-mobile-complete-card {
  place-items: center;
  align-content: center;
  text-align: center;
}

.photo-upload-desktop-shell .photo-mobile-complete-card strong {
  color: var(--ink);
  font-size: var(--font-size-title-lg);
}

.photo-upload-desktop-shell .photo-mobile-complete-card span,
.photo-upload-desktop-shell .photo-mobile-complete-card small {
  color: var(--muted);
  font-weight: var(--font-weight-strong);
}

.photo-upload-desktop-shell .photo-mobile-upload-failure {
  min-height: 100%;
  display: grid;
  align-content: center;
  gap: 10px;
  text-align: center;
}

@media (prefers-reduced-motion: reduce) {
  .photo-upload-desktop-shell,
  .photo-desktop-modal,
  [data-panel="photos"].is-photo-modal-closing .photo-upload-desktop-shell,
  [data-panel="photos"].is-photo-modal-closing .photo-desktop-modal,
  .photo-upload-desktop-shell .photo-mobile-stepper .rental-step-bead,
  .photo-upload-desktop-shell .photo-mobile-stepper em,
  .photo-upload-desktop-shell .photo-mobile-stepper .rental-step-connector,
  .photo-upload-desktop-shell .photo-mobile-assignment-track,
  .photo-upload-desktop-shell .photo-mobile-assignment-card {
    animation: none;
    transition: none;
  }
}

.photo-desktop-category-list {
  display: grid;
  gap: 10px;
}

.photo-desktop-category-row {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-4);
  background: var(--surface);
  padding: 12px;
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
}

.photo-desktop-category-row > div:first-child {
  display: grid;
  gap: 4px;
}

.photo-desktop-category-row strong {
  color: var(--ink);
}

.photo-desktop-category-row span,
.photo-desktop-category-row small {
  color: var(--muted);
  font-size: var(--font-size-sm);
}

.photo-fact-dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-pill);
  display: inline-block;
}

.photo-fact-dot.is-success {
  background: var(--color-state-green-600);
}

.photo-fact-dot.is-warning {
  background: var(--color-state-orange-650);
}

.photo-fact-dot.is-info {
  background: var(--color-state-blue-600);
}

.photo-state-label {
  justify-self: start;
  border-radius: var(--radius-2);
  padding: 2px 6px;
  font-weight: var(--font-weight-strong);
}

.photo-state-label.tone-success {
  background: var(--color-route-surface-green-100);
  color: var(--color-state-green-700);
}

.photo-state-label.tone-info {
  background: var(--color-state-blue-100);
  color: var(--color-state-blue-700);
}

.photo-state-label.tone-warning {
  background: var(--color-state-orange-100);
  color: var(--color-state-orange-700);
}

.photo-state-label.tone-danger {
  background: var(--color-state-red-150);
  color: var(--color-route-text-red-650);
}

.photo-remove-button {
  position: absolute;
  top: -8px;
  right: -8px;
  width: 24px;
  height: 24px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--muted);
  font-size: var(--font-size-xl);
  line-height: 1;
  display: grid;
  place-items: center;
}

/* bundled from styles/admin/photos.upload-mobile.css */
/*
 * ADMIN PHOTOS MOBILE UPLOAD CSS CONTRACT
 * Import hub only for mobile photo-upload subflows.
 */
/* bundled from styles/admin/photos.upload-mobile.shell.css */
/*
 * ADMIN PHOTOS MOBILE SHELL CSS CONTRACT
 * Mobile photo route shell, title, and card frame styles.
 */
@media (max-width: 1023px) {
  body:has([data-panel="photos"].is-photo-modal-open) {
    overflow: hidden;
  }

  body:has([data-panel="photos"].is-visible) .workspace {
    background: var(--color-route-surface-soft-pink);
  }

  body:has([data-panel="photos"].is-visible) [data-panel="photos"].compact-view {
    width: 100%;
    max-width: 430px;
    margin: 0 auto;
    padding: 12px 14px 28px;
    border: 0;
    background: transparent;
    box-shadow: none;
  }

  body:has([data-panel="photos"].is-photo-modal-open) [data-panel="photos"].compact-view {
    position: fixed;
    inset: 0;
    z-index: 95;
    max-width: none;
    min-height: 100dvh;
    max-height: 100dvh;
    overflow-y: auto;
    overscroll-behavior: contain;
    background: var(--color-route-surface-soft-pink);
  }

  body:has([data-panel="photos"].is-visible) [data-panel="photos"] .upload-board {
    border: 1px solid var(--hairline);
    border-radius: var(--radius-4);
    background: var(--surface);
    box-shadow: var(--shadow);
    padding: 14px;
  }

  body:has([data-panel="photos"].is-photo-modal-open) [data-panel="photos"] .upload-board {
    max-width: 430px;
    margin: 0 auto;
  }

  body:has([data-panel="photos"].is-visible) [data-panel="photos"] > .page-heading,
  body:has([data-panel="photos"].is-visible) .upload-summary {
    display: none;
  }

  body:has([data-panel="photos"].is-visible) [data-jump-mine] {
    display: none;
  }

  .photo-grid {
    display: block;
  }

  .photo-upload-desktop-shell {
    display: none;
  }

  .photo-upload-mobile-shell {
    display: grid;
    gap: 10px;
  }

  .photo-upload-mobile-shell h2,
  .photo-upload-mobile-shell h3,
  .photo-upload-mobile-shell p {
    margin: 0;
  }

  .photo-mobile-title-card,
  .photo-mobile-pick-guidance {
    border: 1px solid var(--hairline);
    border-radius: var(--radius-4);
    background: var(--surface);
  }

  .photo-mobile-title-card {
    border: 0;
    background: transparent;
    display: block;
    padding: 7px 2px 9px;
  }

  .photo-mobile-title-card h2 {
    color: var(--ink);
    font-size: 27px;
    line-height: 1.08;
    letter-spacing: -0.045em;
  }

  .photo-mobile-title-card p {
    margin-top: 8px;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.35;
  }

}

/* bundled from styles/admin/photos.upload-mobile.stepper.css */
/*
 * ADMIN PHOTOS MOBILE STEPPER CSS CONTRACT
 * Mobile photo step summary and stepper animation styles.
 */
@media (max-width: 1023px) {
  .photo-mobile-step-summary {
    border: 1px solid var(--hairline);
    border-radius: var(--radius-4);
    background: var(--surface);
    padding: var(--space-photo-step-summary-padding);
    display: grid;
    gap: var(--space-photo-step-summary-gap);
  }

  .photo-mobile-step-summary-main {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
  }

  .photo-mobile-step-summary-main strong {
    min-width: 0;
    color: var(--ink);
    font-size: var(--font-size-2xl);
    letter-spacing: -0.025em;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .photo-mobile-step-summary-main span {
    color: var(--muted);
    font-size: 12px;
    font-weight: var(--font-weight-strong);
    white-space: nowrap;
  }

  .photo-mobile-step-summary-line,
  .photo-mobile-stepper {
    display: flex;
    align-items: center;
    gap: 7px;
    white-space: nowrap;
  }

  .photo-mobile-step-summary-line {
    color: var(--muted);
    font-size: 11px;
    font-weight: var(--font-weight-strong);
    overflow: hidden;
  }

  .photo-mobile-step-summary-line b {
    color: var(--primary);
  }

  .photo-mobile-step-summary-line i {
    width: 3px;
    height: 3px;
    border-radius: var(--radius-pill);
    background: var(--hairline-strong);
    flex: 0 0 auto;
  }

  .photo-mobile-stepper {
    --photo-step-c1: 56px;
    --photo-step-c2: 14px;
    --photo-step-c3: 14px;
    justify-content: center;
    min-height: 28px;
    overflow: hidden;
  }

  .photo-mobile-stepper[data-step="2"] {
    --photo-step-c1: 24px;
    --photo-step-c2: 56px;
    --photo-step-c3: 14px;
  }

  .photo-mobile-stepper[data-step="3"] {
    --photo-step-c1: 14px;
    --photo-step-c2: 24px;
    --photo-step-c3: 56px;
  }

  .photo-mobile-stepper[data-step="4"] {
    --photo-step-c1: 14px;
    --photo-step-c2: 14px;
    --photo-step-c3: 24px;
  }

  .photo-mobile-stepper .photo-mobile-step-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    color: var(--muted);
    font-size: 11px;
    font-weight: var(--font-weight-strong);
  }

  .photo-mobile-stepper .rental-step-bead {
    width: 23px;
    height: 23px;
    border: 2px solid var(--hairline-strong);
    border-radius: var(--radius-pill);
    background: var(--surface);
    display: grid;
    place-items: center;
    box-shadow: 0 0 0 4px var(--surface);
    transition: border-color var(--motion-control) ease, background-color var(--motion-control) ease, transform var(--motion-control) ease;
  }

  .photo-mobile-stepper em {
    max-width: 0;
    overflow: hidden;
    opacity: 0;
    font-style: normal;
    transition: max-width var(--motion-control) ease, opacity var(--motion-micro) ease;
  }

  .photo-mobile-stepper .rental-step-connector {
    flex: 0 0 var(--photo-step-connector);
    inline-size: var(--photo-step-connector);
    height: 1px;
    border-radius: var(--radius-pill);
    background: var(--hairline-strong);
    transition: flex-basis var(--motion-base) var(--motion-spring-ease), inline-size var(--motion-base) var(--motion-spring-ease), background-color var(--motion-control) ease;
  }

  .photo-mobile-stepper .rental-step-connector[data-rental-step-connector="1"] {
    --photo-step-connector: var(--photo-step-c1);
  }

  .photo-mobile-stepper .rental-step-connector[data-rental-step-connector="2"] {
    --photo-step-connector: var(--photo-step-c2);
  }

  .photo-mobile-stepper .rental-step-connector[data-rental-step-connector="3"] {
    --photo-step-connector: var(--photo-step-c3);
  }

  .photo-mobile-stepper .is-active,
  .photo-mobile-stepper .is-complete {
    color: var(--primary);
  }

  .photo-mobile-stepper .is-active .rental-step-bead {
    border-color: var(--primary);
    transform: translateY(-1px);
  }

  .photo-mobile-stepper .is-complete .rental-step-bead {
    border-color: var(--ku-crimson-border);
    background: var(--primary-soft);
  }

  .photo-mobile-stepper .rental-step-connector.is-complete {
    background: var(--color-route-brand-tint-24);
  }

  .photo-mobile-stepper .is-active em {
    max-width: 74px;
    opacity: 1;
  }

  @media (prefers-reduced-motion: reduce) {
    .photo-mobile-stepper .rental-step-bead,
    .photo-mobile-stepper em,
    .photo-mobile-stepper .rental-step-connector {
      transition: none;
    }
  }
}

/* bundled from styles/admin/photos.upload-mobile.flow.css */
/*
 * ADMIN PHOTOS MOBILE FLOW CSS CONTRACT
 * Mobile photo pick, review, assignment, upload, and completion flow styles.
 */
@media (max-width: 1023px) {
  .ui-mobile-workflow-shell,
  .photo-mobile-flow-card {
    min-height: min(58vh, 560px);
    border: 1px solid var(--hairline);
    border-radius: var(--radius-4);
    background: var(--surface);
    padding: var(--space-photo-flow-card-padding);
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    gap: var(--space-photo-flow-card-gap);
    overflow: hidden;
  }

  .photo-mobile-flow-card[hidden] {
    display: none;
  }

  .ui-mobile-workflow-context,
  .ui-mobile-workflow-stepper,
  .ui-mobile-workflow-body,
  .ui-mobile-workflow-actions {
    min-width: 0;
    min-height: 0;
  }

  .ui-mobile-workflow-body {
    overflow: auto;
  }

  .photo-mobile-flow-card h3 {
    color: var(--ink);
    font-size: var(--font-size-title-sm);
    line-height: 1.1;
    letter-spacing: -0.035em;
  }

  .photo-mobile-pick-list,
  .photo-mobile-review-list {
    min-height: 0;
    display: grid;
    gap: 8px;
    align-content: start;
    overflow: auto;
  }

  .photo-mobile-pick-empty {
    min-height: 100%;
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    gap: 10px;
  }

  .photo-mobile-pick-stage {
    min-height: 100%;
    border: 1px dashed var(--hairline-strong);
    border-radius: var(--radius-4);
    background: var(--color-bg-subtle);
    color: var(--body);
    display: grid;
    place-items: center;
    align-content: center;
    gap: 12px;
    padding: 24px 14px;
    text-align: center;
    font: inherit;
  }

  .photo-mobile-pick-stage > span {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    background: var(--color-route-brand-tint-08);
    color: var(--primary);
    display: grid;
    place-items: center;
    font-size: 28px;
    font-weight: var(--font-weight-emphasis);
  }

  .photo-mobile-pick-stage strong {
    color: var(--ink);
    font-size: var(--font-size-2xl);
  }

  .photo-mobile-pick-stage small {
    color: var(--muted);
    font-weight: var(--font-weight-strong);
  }

  .photo-mobile-pick-actions {
    grid-column: 1 / -1;
    display: grid;
    gap: 6px;
  }

  .photo-mobile-camera-button {
    grid-column: 1 / -1;
    min-height: 52px;
    border-radius: var(--radius-3);
    font-size: 16px;
  }

  .photo-mobile-pick-guidance {
    background: var(--color-bg-subtle);
    padding: 11px 12px;
    display: grid;
    gap: 4px;
  }

  .photo-mobile-pick-guidance p {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.45;
  }

  .photo-mobile-pick-row,
  .photo-mobile-review-row {
    border: 1px solid var(--hairline);
    border-radius: var(--radius-4);
    background: var(--surface);
    padding: var(--space-photo-row-padding);
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr) auto;
    gap: var(--space-photo-row-gap);
    align-items: center;
  }

  .photo-mobile-pick-thumb {
    height: 42px;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--color-route-surface-neutral-100);
    overflow: hidden;
    display: grid;
    place-items: center;
  }

  .photo-mobile-pick-thumb img,
  .mock-photo-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .photo-mobile-pick-row strong,
  .photo-mobile-review-row strong,
  .photo-mobile-assignment-head strong {
    display: block;
    color: var(--ink);
    font-size: 13px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .photo-mobile-pick-row span,
  .photo-mobile-review-row span,
  .photo-mobile-assignment-head span {
    display: block;
    margin-top: 3px;
    color: var(--muted);
    font-size: 11px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .photo-mobile-pick-row small,
  .photo-mobile-review-row small {
    border-radius: var(--radius-control-small);
    padding: 4px 6px;
    font-size: 10px;
    font-weight: var(--font-weight-emphasis);
  }

  .photo-mobile-pick-row .is-pass,
  .photo-mobile-review-row .is-pass {
    background: var(--color-route-surface-green-100);
    color: var(--color-state-green-700);
  }

  .photo-mobile-pick-row .is-pending,
  .photo-mobile-review-row .is-pending {
    background: var(--color-state-orange-100);
    color: var(--color-route-text-orange-900);
  }

  .photo-mobile-pick-row .is-fail,
  .photo-mobile-review-row .is-fail {
    background: var(--color-state-red-150);
    color: var(--color-route-text-red-650);
  }

  .photo-mobile-assignment-carousel {
    overflow: hidden;
  }

  .photo-mobile-assignment-carousel.is-moving {
    pointer-events: none;
  }

  .photo-mobile-assignment-track {
    display: flex;
    transform: translateX(calc(var(--active-photo, 0) * -100%));
    transition: transform var(--motion-photo-step-track) var(--motion-spring-ease);
  }

  .photo-mobile-assignment-slide {
    flex: 0 0 100%;
    inline-size: 100%;
  }

  .photo-mobile-assignment-card {
    border: 1px solid var(--hairline);
    border-radius: var(--radius-4);
    padding: 9px;
    display: grid;
    gap: 9px;
    transition: transform var(--motion-photo-step-enter) var(--motion-spring-ease), opacity var(--motion-photo-step-fade) ease;
  }

  .photo-mobile-assignment-carousel.is-moving .photo-mobile-assignment-card {
    opacity: 0.92;
  }

  .photo-mobile-assignment-head {
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr);
    gap: 8px;
    align-items: center;
  }

  .photo-mobile-proof-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 7px;
  }

  .photo-mobile-proof-grid button {
    min-height: 64px;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-4);
    background: var(--color-route-surface-white);
    color: var(--body);
    text-align: left;
    padding: var(--space-photo-proof-padding);
    font: inherit;
    transition: transform var(--motion-control) ease, background-color var(--motion-control) ease, border-color var(--motion-control) ease;
  }

  .photo-mobile-proof-grid button.is-active {
    border-color: var(--color-state-green-600);
    background: var(--color-route-surface-green-50);
    transform: scale(0.98);
  }

  .photo-mobile-proof-grid strong {
    display: block;
    color: var(--ink);
    font-size: 13px;
  }

  .photo-mobile-proof-grid span {
    color: var(--muted);
    font-size: 10px;
  }

  .photo-mobile-photo-pager,
  .photo-mobile-step-actions {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: var(--space-photo-action-gap);
    align-items: center;
  }

  .photo-mobile-photo-pager {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .photo-mobile-photo-pager span {
    color: var(--muted);
    text-align: center;
    font-size: 12px;
    font-weight: var(--font-weight-emphasis);
  }

  .photo-mobile-upload-row {
    border: 1px solid var(--hairline);
    border-radius: var(--radius-4);
    padding: var(--space-photo-upload-row-padding);
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--space-photo-row-gap);
    align-items: center;
  }

  .photo-mobile-upload-row .bar {
    grid-column: 1 / -1;
    height: 5px;
    border-radius: var(--radius-pill);
    background: var(--color-route-surface-rose-100);
    overflow: hidden;
  }

  .photo-mobile-upload-row .bar i {
    display: block;
    width: var(--progress);
    height: 100%;
    border-radius: inherit;
    background: var(--primary);
  }

  .photo-mobile-complete-card {
    place-items: center;
    align-content: center;
    text-align: center;
  }

  .photo-mobile-complete-card strong {
    color: var(--ink);
    font-size: 22px;
  }

  .photo-mobile-complete-card span,
  .photo-mobile-complete-card small {
    color: var(--muted);
    font-weight: var(--font-weight-strong);
  }

  .photo-mobile-upload-failure {
    min-height: 100%;
    display: grid;
    align-content: center;
    gap: 10px;
    text-align: center;
  }

  .photo-mobile-upload-failure strong {
    color: var(--ink);
    font-size: 18px;
  }

  .photo-mobile-upload-failure span {
    color: var(--muted);
    font-size: 13px;
    line-height: 1.45;
    font-weight: var(--font-weight-strong);
  }

}


/* bundled from styles/admin/shared.css */
/*
 * ADMIN SHARED CSS CONTRACT
 * Import hub only for shared admin shell primitives only.
 * Keep route, legacy, modal, auth, and calendar ownership split into
 * the owner hubs below instead of importing implementation files here.
 */
/* bundled from styles/admin/shared.route.css */
/*
 * ADMIN ROUTE OWNER CSS CONTRACT
 * Admin route and shell implementation imports live here.
 */
/* bundled from styles/admin/shared.admin-members-equipment.css */
/*
 * ADMIN SHARED CSS CONTRACT
 *
 * This file is for shared admin shell primitives only: sidebar, workspace grid,
 * shared inspectors, shared buttons, shared inputs, shared filters, and shared
 * modal primitives.
 *
 * Do not add route-specific page layouts or one-off equipment/photo/member/
 * archive selectors here. Prefer a route-owned stylesheet under
 * ./styles/admin/ when that route CSS boundary exists. If a route-owned file
 * does not exist yet, keep the exception narrow and mark it for extraction.
 */
.admin-section {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface);
  padding: var(--space-panel-padding-md);
  display: grid;
  gap: var(--space-panel-gap-md);
}

.admin-section.is-hidden {
  display: none;
}

.admin-section-heading,
.admin-card-header,
.equipment-admin-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.admin-section-heading h2,
.admin-card h3 {
  margin: 0;
  color: var(--ink);
  line-height: 1.25;
}

.admin-section-heading h2 {
  font-size: var(--font-size-2xl);
}

.admin-card h3 {
  font-size: var(--font-size-xl);
}

.admin-card p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.45;
}

.admin-photo-grid,
.admin-approval-grid,
.equipment-admin-grid,
.member-admin-grid,
.violation-case-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(260px, 1fr));
  gap: var(--space-3);
}

#adminPhotoReview {
  grid-template-columns: minmax(0, 1fr);
}

.admin-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-bg-subtle);
  padding: var(--space-3);
  display: grid;
  gap: var(--space-3);
}

.photo-review-card,
.member-admin-card {
  background: var(--surface);
}

.member-admin-card {
  gap: var(--space-panel-gap-sm);
}

.member-admin-card.is-empty {
  grid-column: 1 / -1;
}

.member-filter-bar {
  grid-column: 1 / -1;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-bg-subtle);
  padding: var(--space-3);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.member-filter-bar h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-xl);
  line-height: 1.2;
}

.member-status-filter-list {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.member-compact-row {
  display: grid;
  grid-template-columns: minmax(128px, 1fr) auto auto minmax(160px, auto);
  align-items: center;
  gap: var(--space-panel-gap-sm);
}

.member-identity-block {
  min-width: 0;
}

.member-identity-block p {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.member-compact-row .status-chip {
  justify-self: end;
}

.member-compact-actions {
  justify-content: flex-end;
}

.schedule-edit-card {
  background: var(--color-state-orange-50);
}

.admin-approval-grid,
.approval-request-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(260px, 1fr));
  gap: var(--space-panel-gap-sm);
}

.approval-request-card {
  border: 1px solid var(--color-state-orange-200);
  border-radius: var(--radius-panel);
  background: color-mix(in srgb, var(--color-route-surface-white) 95%, transparent);
  padding: var(--space-3);
  display: grid;
  gap: var(--space-panel-gap-sm);
}

.approval-request-card.is-empty {
  grid-column: 1 / -1;
  background: var(--surface-muted);
  border-color: var(--hairline);
}

.approval-request-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-panel-gap-sm);
}

.approval-request-card strong,
.approval-request-card span,
.approval-request-card small,
.violation-case-card strong,
.violation-case-card span,
.violation-case-card small {
  display: block;
}

.approval-request-card strong,
.violation-case-card strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
}

.approval-request-card span,
.approval-request-card small,
.violation-case-card span,
.violation-case-card small {
  margin-top: 4px;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.4;
}

.policy-detection-board {
  grid-column: 1 / -1;
  border: 1px solid var(--color-state-red-200);
  border-radius: var(--radius-panel);
  background: color-mix(in srgb, var(--color-route-surface-white) 97%, transparent);
  padding: var(--space-3);
  display: grid;
  gap: var(--space-3);
}

.violation-case-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-neutral-0);
  padding: var(--space-panel-padding-sm);
  display: grid;
  gap: var(--space-panel-gap-sm);
}

.violation-case-card.is-empty {
  grid-column: 1 / -1;
  background: var(--color-bg-subtle);
  border-color: var(--hairline);
}

.violation-case-card.is-active {
  border-color: var(--ku-crimson);
  box-shadow: 0 0 0 2px var(--color-route-brand-tint-12);
}

.violation-case-top,
.member-score-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-panel-gap-sm);
}

.violation-case-card p {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-md);
  line-height: 1.45;
}

.risk-pill {
  flex: 0 0 auto;
  border-radius: var(--radius-pill);
  padding: 6px 9px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.risk-high {
  color: var(--color-route-text-red-700);
  background: var(--color-state-red-150);
}

.risk-medium {
  color: var(--color-route-text-orange-900);
  background: var(--color-state-orange-100);
}

.risk-low {
  color: var(--color-admin-info-text);
  background: var(--color-route-surface-blue-50);
}

.violation-evidence-panel {
  border: 1px dashed var(--color-admin-danger-border-dashed);
  border-radius: var(--radius-panel);
  background: color-mix(in srgb, var(--color-route-surface-white) 98%, transparent);
  padding: var(--space-3);
  display: grid;
  gap: var(--space-panel-gap-sm);
}

.violation-evidence-panel h3,
.violation-evidence-panel p {
  margin: 0;
}

.violation-evidence-heading {
  display: grid;
  gap: 6px;
}

.violation-evidence-heading h3 {
  margin: 0;
}

.violation-evidence-heading strong {
  color: var(--muted);
}

.violation-evidence-panel ul {
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: var(--font-size-md);
  line-height: 1.55;
}

.member-score-row {
  justify-content: flex-start;
}

.member-score-row span {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  padding: 6px 9px;
  color: var(--ink);
  background: var(--color-neutral-0);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.member-status-manager {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-bg-subtle);
  padding: var(--space-panel-padding-sm);
  display: grid;
  gap: var(--space-panel-gap-sm);
}

.member-status-manager strong,
.member-status-manager span {
  display: block;
}

.member-status-manager strong {
  color: var(--ink);
  font-size: var(--font-size-md);
}

.member-status-danger-panel p {
  margin: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.5;
}

.member-status-danger-panel {
  border: 1px solid var(--color-state-danger-border);
  border-radius: var(--radius-panel);
  background: var(--color-state-danger-bg);
  padding: var(--space-panel-padding-sm);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-panel-gap-sm);
  align-items: center;
}

.member-status-danger-panel.is-disabled {
  border-color: var(--hairline);
  background: var(--surface);
}

.member-status-danger-panel .member-withdraw-action {
  align-self: center;
}

.member-inspector-identity {
  display: grid;
  gap: 6px;
}

.member-inspector-title-row {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: var(--space-panel-gap-sm);
}

.member-inspector-title-row h3 {
  margin: 0;
  color: var(--ink);
  font-size: 21px;
  line-height: 1.25;
}

.member-inspector-email {
  margin: 0;
  color: var(--muted);
  font-size: var(--font-size-lg);
  line-height: 1.4;
}

.member-inspector-facts,
.member-policy-summary {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-2);
}

.member-inspector-facts div,
.member-policy-summary div {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface-muted);
  color: var(--body);
  padding: 9px 10px;
  display: grid;
  gap: 3px;
  min-width: 0;
}

.member-inspector-facts dt,
.member-policy-summary dt {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
  line-height: 1.2;
}

.member-inspector-facts dd,
.member-policy-summary dd {
  margin: 0;
  min-width: 0;
  color: var(--ink);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  line-height: 1.3;
  overflow-wrap: anywhere;
}

.member-policy-summary div {
  background: var(--surface);
}

@media (max-width: 1023px) {
  .member-filter-bar {
    align-items: stretch;
    flex-direction: column;
  }

  .member-status-filter-list {
    justify-content: flex-start;
  }

  .member-compact-row {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .member-score-row {
    grid-column: 1 / -1;
  }

  .member-compact-actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
}

@media (max-width: 520px) {
  .member-status-choice-grid {
    grid-template-columns: 1fr;
  }
}

.equipment-admin-card {
  background: var(--surface);
  padding: var(--space-panel-padding-sm);
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  align-items: center;
  gap: var(--space-3);
}

.equipment-admin-card .equipment-thumb {
  width: 72px;
  height: 72px;
  min-height: 72px;
  aspect-ratio: 1;
}

.equipment-admin-grid {
  grid-template-columns: 1fr;
  align-items: start;
  gap: var(--space-3);
}

.equipment-admin-toolbar,
.equipment-category-settings {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-bg-subtle);
  padding: var(--space-3);
  display: grid;
  gap: var(--space-panel-gap-sm);
}

.equipment-admin-toolbar-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.equipment-admin-toolbar-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-2);
}

.admin-search-pill {
  min-width: 220px;
  min-height: var(--control-height-small);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-sm);
  background: var(--surface);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0 10px;
}

.admin-search-pill svg {
  width: 15px;
  height: 15px;
  color: var(--muted);
}

.admin-search-pill input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  font: inherit;
  font-size: var(--font-size-sm);
  background: transparent;
}

.equipment-admin-toolbar h3 {
  margin: 2px 0 3px;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.2;
}

.equipment-admin-toolbar p {
  margin: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.equipment-category-tabs,
.equipment-status-tabs,
.equipment-category-setting-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.equipment-admin-filterbar {
  border-top: 1px solid var(--hairline);
  padding-top: 10px;
  display: grid;
  gap: var(--space-2);
}

.equipment-category-tab {
  min-height: var(--control-height-small);
}

.equipment-status-tab {
  min-height: var(--control-height-small);
}

.equipment-category-tab strong {
  min-width: 20px;
  border-radius: var(--radius-pill);
  background: var(--surface-muted);
  color: var(--muted);
  padding: 2px 6px;
  font-size: var(--font-size-xs);
  text-align: center;
}

.equipment-status-tab strong {
  min-width: 20px;
  border-radius: var(--radius-pill);
  background: var(--surface-muted);
  color: var(--muted);
  padding: 2px 6px;
  font-size: var(--font-size-xs);
  text-align: center;
}

.equipment-status-tab.is-active strong {
  background: var(--surface);
  color: var(--ku-crimson-dark);
}

@media (max-width: 1023px) {
  .equipment-admin-toolbar-main {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .equipment-admin-toolbar-actions {
    width: 100%;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 38px auto;
    align-items: center;
  }

  .equipment-admin-toolbar-actions .admin-search-pill {
    width: 100%;
    min-width: 0;
  }
}

.equipment-category-settings-header,
.equipment-category-setting-row,
.equipment-compact-row,
.equipment-compact-kickers,
.equipment-compact-actions {
  display: flex;
  align-items: center;
}

.equipment-category-settings-header {
  justify-content: space-between;
  gap: var(--space-panel-gap-sm);
}

.equipment-category-settings-header strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
}

.equipment-category-setting-row {
  gap: var(--space-2);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface);
  padding: 7px;
}

.equipment-category-setting-row span {
  color: var(--ink);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
}

.equipment-category-setting-row strong {
  border-radius: var(--radius-pill);
  background: var(--surface-muted);
  color: var(--muted);
  padding: 3px 7px;
  font-size: var(--font-size-xs);
}

.equipment-admin-list {
  display: grid;
  gap: var(--space-2);
}

.admin-queue-empty {
  min-height: 120px;
  border: 1px dashed var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface);
  color: var(--muted);
  padding: var(--space-4);
  display: grid;
  place-items: center;
  align-content: center;
  gap: 6px;
  text-align: center;
}

.admin-queue-empty strong {
  color: var(--ink);
}

.equipment-admin-card.is-editing {
  border-color: var(--primary);
  background: var(--color-bg-subtle);
  gap: var(--space-3);
}

.equipment-compact-row {
  min-width: 0;
  justify-content: stretch;
  gap: var(--space-panel-gap-sm);
}

.equipment-compact-main {
  min-width: 0;
  flex: 1;
  display: grid;
  gap: 3px;
}

.equipment-compact-main h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-xl);
  line-height: 1.2;
}

.equipment-compact-main p {
  margin: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  line-height: 1.35;
}

.equipment-compact-kickers {
  gap: 6px;
  flex-wrap: wrap;
}

.equipment-compact-kickers > span:first-child {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
}

.equipment-compact-actions {
  justify-content: flex-end;
  gap: var(--space-2);
  flex-shrink: 0;
}

.equipment-edit-panel {
  border-top: 1px solid var(--hairline);
  padding-top: 12px;
  display: grid;
  gap: var(--space-3);
}

.equipment-edit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-panel-gap-sm);
}

.equipment-edit-wide {
  grid-column: 1 / -1;
}

@media (max-width: 1023px) {
  .equipment-category-settings-header,
  .equipment-compact-row {
    align-items: stretch;
    flex-direction: column;
  }

  .equipment-compact-actions {
    justify-content: flex-start;
    width: 100%;
  }

  .equipment-edit-grid {
    grid-template-columns: 1fr;
  }

  .equipment-summary-content,
  .equipment-summary-meta,
  .equipment-inspector-actions,
  .equipment-summary-actions {
    grid-template-columns: 1fr;
  }

  .equipment-summary-content .equipment-thumb {
    width: 100%;
    min-width: 0;
  }
}

/* bundled from styles/admin/shared.equipment-cards.css */
.equipment-admin-mobile-list {
  display: none;
}

.photo-compare-grid,
.schedule-edit-grid {
  display: grid;
  gap: var(--space-panel-gap-sm);
}

.photo-compare-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.photo-proof-card {
  min-height: 76px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface-muted);
  padding: var(--space-panel-padding-sm);
  display: grid;
  align-content: end;
  gap: var(--space-1);
}

.photo-proof-card.complete {
  border-color: var(--color-state-green-200);
  background: var(--color-state-green-50);
}

.photo-proof-card.waiting {
  background: var(--color-route-surface-soft-pink);
}

.photo-proof-card strong {
  color: var(--ink);
  font-size: var(--font-size-md);
}

.photo-proof-card span {
  color: var(--muted);
  font-size: var(--font-size-sm);
}

.schedule-edit-grid,
.edit-time-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.equipment-admin-top {
  justify-content: flex-start;
}

.route-chip {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  margin-left: 8px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-sm);
  background: var(--surface);
  color: var(--muted);
  padding: 0 8px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  vertical-align: middle;
}

.equipment-page-heading p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
}

.equipment-section-heading {
  min-height: auto;
}

.equipment-description {
  min-height: 72px;
}

.equipment-admin-board {
  min-width: 0;
  display: grid;
  gap: 0;
}

.equipment-admin-table {
  min-width: 0;
  display: grid;
}

.equipment-admin-table-head,
.equipment-admin-row-main {
  display: grid;
  grid-template-columns: minmax(230px, 1.45fr) 72px 76px 68px 92px minmax(130px, 1fr);
  gap: var(--space-panel-gap-sm);
  align-items: center;
}

.equipment-admin-table-head {
  color: var(--ink);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.equipment-admin-table-head span:last-child {
  text-align: right;
}

.equipment-admin-row {
  display: grid;
  grid-template-columns: minmax(230px, 1.45fr) 72px 76px 68px 92px minmax(130px, 1fr);
  gap: var(--space-panel-gap-sm);
  align-items: center;
}

.equipment-admin-row-main {
  display: contents;
  min-width: 0;
  border: 0;
  background: transparent;
  color: inherit;
  padding: 0;
  text-align: left;
}

.equipment-admin-item {
  min-width: 0;
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: var(--space-panel-gap-sm);
  align-items: center;
}

.equipment-admin-number,
.equipment-admin-days,
.equipment-schedule-summary strong,
.equipment-schedule-summary small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.equipment-admin-number,
.equipment-admin-days {
  color: var(--ink);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
}

.equipment-category-badge {
  width: fit-content;
  border: 1px solid var(--color-state-blue-200);
  border-radius: var(--radius-sm);
  background: var(--color-state-blue-50);
  color: var(--color-state-blue-700);
  padding: 4px 9px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.equipment-schedule-summary {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.equipment-warning-strip,
.equipment-inspector-alerts {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.equipment-warning-chip {
  width: fit-content;
  border-radius: var(--radius-pill);
  padding: 3px 7px;
  font-size: 10px;
  font-style: normal;
  font-weight: var(--font-weight-emphasis);
  line-height: 1.2;
}

.equipment-warning-photo {
  background: var(--color-state-orange-50);
  color: var(--color-route-text-orange-800);
}

.equipment-warning-info {
  background: var(--color-equipment-card-muted-bg);
  color: var(--color-equipment-card-muted-text);
}

.equipment-warning-reserved {
  background: var(--color-state-blue-50);
  color: var(--color-state-blue-700);
}

.equipment-schedule-summary strong {
  color: var(--ink);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-emphasis);
}

.equipment-schedule-summary small {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
}

.equipment-edit-row-button {
  min-height: var(--control-height-small);
  border: 1px solid var(--color-brand-ku-crimson-200);
  border-radius: var(--radius-control-small);
  background: var(--surface);
  color: var(--primary);
  padding: 0 11px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.equipment-admin-footer,
.equipment-admin-pager,
.equipment-inspector-heading,
.equipment-record-row {
  display: flex;
  align-items: center;
}

.equipment-admin-footer {
  justify-content: space-between;
  gap: var(--space-3);
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.equipment-admin-pager {
  gap: var(--space-2);
}

.equipment-admin-page-current {
  width: var(--control-size-icon-compact);
  height: var(--control-size-icon-compact);
  border: 1px solid var(--primary);
  border-radius: var(--radius-control-small);
  background: var(--primary);
  color: var(--color-route-surface-white);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.equipment-inspector-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface);
  padding: var(--space-panel-padding-md);
  display: grid;
  gap: var(--space-3);
}

.equipment-inspector-heading {
  justify-content: space-between;
  gap: var(--space-panel-gap-sm);
}

.equipment-inspector-heading h3,
.equipment-record-card h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-xl);
  line-height: 1.25;
}

.equipment-summary-content {
  display: grid;
  grid-template-columns: 160px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.equipment-summary-content .equipment-thumb {
  width: 160px;
  height: 150px;
  min-width: 160px;
  min-height: 150px;
}

.equipment-summary-meta {
  margin: 0;
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 8px 14px;
}

.equipment-summary-meta dt,
.equipment-summary-meta dd {
  margin: 0;
  font-size: var(--font-size-sm);
  line-height: 1.35;
}

.equipment-summary-meta dt {
  color: var(--ink);
  font-weight: var(--font-weight-strong);
}

.equipment-summary-meta dd {
  color: var(--body);
  font-weight: var(--font-weight-strong);
}

.equipment-save-button {
  width: 100%;
  min-height: 40px;
}

.equipment-inspector-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-panel-gap-sm);
}

.equipment-summary-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
}

.equipment-filtered-note {
  border: 1px solid var(--color-state-blue-200);
  border-radius: var(--radius-panel);
  background: var(--color-state-blue-50);
  color: var(--color-state-blue-700);
  padding: 10px 12px;
  display: grid;
  gap: var(--space-1);
}

.equipment-filtered-note strong,
.equipment-filtered-note span {
  display: block;
  font-size: var(--font-size-sm);
  line-height: 1.35;
}

.equipment-edit-placeholder {
  margin: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.equipment-record-tabs {
  display: flex;
  gap: var(--space-6);
  border-bottom: 1px solid var(--hairline);
}

.equipment-record-tabs button {
  border: 0;
  border-bottom: 2px solid transparent;
  background: transparent;
  color: var(--ink);
  padding: 8px 0;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.equipment-record-tabs button.is-active {
  color: var(--primary);
  border-bottom-color: var(--primary);
}

.equipment-record-row {
  justify-content: space-between;
  gap: var(--space-panel-gap-sm);
  border-bottom: 1px solid var(--hairline);
  padding: 10px 0;
}

.equipment-record-row:last-child {
  border-bottom: 0;
}

.equipment-record-row span {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.equipment-record-row strong,
.equipment-record-row small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.equipment-record-row em {
  border-radius: var(--radius-sm);
  background: var(--surface-muted);
  color: var(--muted);
  padding: 4px 8px;
  font-size: var(--font-size-xs);
  font-style: normal;
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

@media (min-width: 1024px) {
  .workspace.is-admin-shell .equipment-admin-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .workspace.is-admin-shell .equipment-inspector {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .workspace.is-admin-shell .equipment-record-card {
    grid-column: 1 / -1;
  }
}

@media (max-width: 1023px) {
  .equipment-admin-table-head,
  .equipment-admin-list {
    display: none;
  }

  .equipment-admin-mobile-list {
    padding: var(--space-panel-padding-sm);
    display: grid;
    gap: var(--space-2);
  }

  .equipment-admin-mobile-card {
    width: 100%;
    min-width: 0;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-panel);
    background: var(--surface);
    color: var(--ink);
    padding: var(--space-panel-padding-sm);
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--space-2);
    text-align: left;
    font: inherit;
  }

  .equipment-admin-mobile-card.is-active {
    border-color: var(--primary);
    box-shadow: 0 0 0 1px var(--color-route-brand-tint-16);
  }

  .equipment-admin-mobile-card .equipment-admin-item,
  .equipment-admin-mobile-card .equipment-schedule-summary {
    grid-column: 1 / -1;
  }

  .equipment-admin-mobile-card .equipment-category-badge,
  .equipment-admin-mobile-card .equipment-admin-number,
  .equipment-admin-mobile-card .equipment-admin-days {
    display: none;
  }

  .equipment-admin-footer {
    align-items: stretch;
    flex-direction: column;
  }

  .equipment-admin-pager {
    justify-content: space-between;
  }
}

/* bundled from styles/admin/shell-desktop.css */
/*
 * ADMIN DESKTOP SHELL CSS CONTRACT
 * Admin desktop sidebar and admin workspace chrome.
 */
/* bundled from styles/admin/shell-desktop.layout.css */
/*
 * ADMIN SHELL DESKTOP OWNER CSS CONTRACT: shell-desktop.layout.css
 * Ordered chunk split from shell-desktop.css. Preserve import order.
 */
.admin-desktop-sidebar {
  display: none;
}

.admin-desktop-sidebar.is-hidden {
  display: none !important;
}

@media (min-width: 1024px) {
  :root[data-initial-admin-shell="true"] .workspace {
      --admin-sidebar-rail-width: 64px;
      --admin-sidebar-flyout-width: 165px;
      --admin-sidebar-motion-duration: var(--motion-control);
      --admin-sidebar-motion-ease: var(--motion-sidebar-ease);
      --admin-sidebar-label-delay: var(--motion-sidebar-label-delay);
      width: min(1480px, 100%);
      margin: 0 auto;
      padding: 16px 20px;
      display: grid;
      grid-template-columns: var(--admin-sidebar-rail-width) minmax(0, 1fr);
      gap: 16px;
      align-items: start;
    }

  :root[data-initial-admin-shell="true"] .admin-desktop-sidebar {
      position: sticky;
      top: 0;
      z-index: 20;
      width: var(--admin-sidebar-rail-width);
      min-height: calc(100dvh - 104px);
      border: 1px solid var(--hairline);
      border-radius: var(--radius-3);
      background: var(--surface);
      box-shadow: var(--shadow);
      padding: 10px;
      display: grid;
      grid-template-rows: minmax(0, 1fr) auto;
      gap: 16px;
      overflow: hidden;
    }

  :root[data-initial-admin-shell="true"] .view-panel:is([data-panel^="admin-"], [data-panel="archive"], [data-panel="billing"]) {
      grid-column: 2;
      width: 100%;
      max-width: none;
      margin: 0;
    }

  :root[data-initial-admin-shell="true"] .view-panel:is([data-panel^="admin-"], [data-panel="archive"], [data-panel="billing"]).compact-view {
      padding: 16px;
    }

  :root[data-initial-admin-shell="true"] .view-panel:is([data-panel^="admin-"], [data-panel="archive"], [data-panel="billing"]) [data-admin-back] {
      display: none;
    }

  :root[data-initial-admin-shell="true"] .admin-section,
    :root[data-initial-admin-shell="true"] .admin-home-panel {
      padding: 0;
      border: 0;
      background: transparent;
      box-shadow: none;
    }

  .workspace.is-admin-shell {
      --admin-sidebar-rail-width: 64px;
      --admin-sidebar-flyout-width: 165px;
      --admin-sidebar-motion-duration: var(--motion-control);
      --admin-sidebar-motion-ease: var(--motion-sidebar-ease);
      --admin-sidebar-label-delay: var(--motion-sidebar-label-delay);
      width: min(1480px, 100%);
      margin: 0 auto;
      padding: 16px 20px;
      display: grid;
      grid-template-columns: var(--admin-sidebar-rail-width) minmax(0, 1fr);
      gap: 16px;
      align-items: start;
    }

  .workspace.is-admin-shell .admin-desktop-sidebar {
      position: sticky;
      top: 0;
      z-index: 20;
      width: var(--admin-sidebar-rail-width);
      min-height: calc(100dvh - 104px);
      border: 1px solid var(--hairline);
      border-radius: var(--radius-3);
      background: var(--surface);
      box-shadow: var(--shadow);
      padding: 10px;
      display: grid;
      grid-template-rows: minmax(0, 1fr) auto;
      gap: 16px;
      overflow: hidden;
      transition:
        width var(--admin-sidebar-motion-duration) var(--admin-sidebar-motion-ease),
        padding var(--admin-sidebar-motion-duration) var(--admin-sidebar-motion-ease),
        box-shadow var(--admin-sidebar-motion-duration) var(--admin-sidebar-motion-ease);
    }

  .workspace.is-admin-shell .admin-desktop-sidebar:hover,
    .workspace.is-admin-shell .admin-desktop-sidebar:focus-within {
      z-index: 60;
      width: var(--admin-sidebar-flyout-width);
      padding: 10px;
      box-shadow: var(--shadow-panel-raised);
    }

  .workspace.is-admin-shell .view-panel:is([data-panel^="admin-"], [data-panel="archive"], [data-panel="billing"]).is-visible {
      grid-column: 2;
      width: 100%;
      max-width: none;
      margin: 0;
    }

  .workspace.is-admin-shell .view-panel:is([data-panel^="admin-"], [data-panel="archive"], [data-panel="billing"]).compact-view {
      padding: 16px;
    }

  body:has([data-panel="billing"].is-visible) .workspace.is-admin-shell [data-panel="billing"].compact-view.is-visible {
      display: contents;
      border: 0;
      border-radius: 0;
      background: transparent;
      box-shadow: none;
      padding: 0;
    }

  body:has([data-panel="billing"].is-visible) .workspace.is-admin-shell [data-panel="billing"] > #billingUsagePanel {
      grid-column: 2;
      min-width: 0;
    }

  .workspace.is-admin-shell .view-panel:is([data-panel^="admin-"], [data-panel="archive"], [data-panel="billing"]).is-visible .page-heading {
      margin-bottom: 12px;
      padding-bottom: 12px;
    }

  .workspace.is-admin-shell .view-panel:is([data-panel^="admin-"], [data-panel="archive"], [data-panel="billing"]).is-visible .page-heading h1 {
      font-size: var(--font-size-title-sm);
    }

  .workspace.is-admin-shell .view-panel:is([data-panel^="admin-"], [data-panel="archive"], [data-panel="billing"]).is-visible [data-admin-back] {
      display: none;
    }

  .admin-desktop-nav {
      display: grid;
      gap: 6px;
      align-content: start;
    }

  .admin-desktop-nav-item,
    .admin-desktop-run-button {
      position: relative;
      width: 100%;
      min-height: 36px;
      border: 0;
      border-radius: var(--radius-control-small);
      background: transparent;
      color: var(--body);
      display: grid;
      grid-template-columns: 24px minmax(0, 1fr) auto;
      align-items: center;
      gap: 8px;
      padding: 8px;
      text-align: left;
      font: inherit;
      font-size: 12px;
      font-weight: var(--font-weight-emphasis);
      cursor: pointer;
      transition:
        background-color var(--motion-micro) ease,
        color var(--motion-micro) ease,
        grid-template-columns var(--admin-sidebar-motion-duration) var(--admin-sidebar-motion-ease),
        padding var(--admin-sidebar-motion-duration) var(--admin-sidebar-motion-ease);
    }

  .workspace.is-admin-shell .admin-desktop-sidebar:not(:hover):not(:focus-within) .admin-desktop-nav-item,
    .workspace.is-admin-shell .admin-desktop-sidebar:not(:hover):not(:focus-within) .admin-desktop-run-button {
      grid-template-columns: 24px 0 0;
      justify-items: center;
      gap: 0;
      padding: 8px;
    }

  .admin-desktop-nav-item svg,
    .admin-desktop-run-button svg {
      width: 16px;
      height: 16px;
      stroke-width: 2.25;
    }

  .admin-desktop-nav-item span,
    .admin-desktop-run-button span {
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
      transform: translateX(-4px);
      transition:
        max-width var(--admin-sidebar-motion-duration) var(--admin-sidebar-motion-ease),
        opacity var(--motion-fast) ease,
        transform 150ms ease;
    }

  .workspace.is-admin-shell .admin-desktop-sidebar:not(:hover):not(:focus-within) .admin-desktop-nav-item span,
    .workspace.is-admin-shell .admin-desktop-sidebar:not(:hover):not(:focus-within) .admin-desktop-run-button span {
      max-width: 0;
      opacity: 0;
    }

  .workspace.is-admin-shell .admin-desktop-sidebar:hover .admin-desktop-nav-item span,
    .workspace.is-admin-shell .admin-desktop-sidebar:hover .admin-desktop-run-button span,
    .workspace.is-admin-shell .admin-desktop-sidebar:focus-within .admin-desktop-nav-item span,
    .workspace.is-admin-shell .admin-desktop-sidebar:focus-within .admin-desktop-run-button span {
      max-width: 132px;
      opacity: 1;
      transform: translateX(0);
      transition-delay: 0ms, var(--admin-sidebar-label-delay), var(--admin-sidebar-label-delay);
    }

  .admin-desktop-nav-item strong {
      min-width: 17px;
      height: 17px;
      border-radius: var(--radius-pill);
      background: var(--primary);
      color: var(--color-route-surface-white);
      display: grid;
      place-items: center;
      font-size: 10px;
      line-height: 1;
      transition:
        transform var(--admin-sidebar-motion-duration) var(--admin-sidebar-motion-ease),
        top var(--admin-sidebar-motion-duration) var(--admin-sidebar-motion-ease),
        right var(--admin-sidebar-motion-duration) var(--admin-sidebar-motion-ease);
    }

  .workspace.is-admin-shell .admin-desktop-sidebar:not(:hover):not(:focus-within) .admin-desktop-nav-item strong {
      position: absolute;
      top: 4px;
      right: 4px;
      min-width: 15px;
      height: 15px;
      font-size: 9px;
    }

  .admin-desktop-nav-item strong.is-empty {
      display: none;
    }

  .admin-desktop-nav-item.is-active {
      background: color-mix(in srgb, var(--primary) 8%, var(--color-route-surface-white));
      color: var(--primary);
    }

  .admin-desktop-nav-item.is-active::before {
      content: "";
      position: absolute;
      left: -12px;
      top: 4px;
      bottom: 4px;
      width: 4px;
      border-radius: var(--radius-pill);
      background: var(--primary);
    }

  .admin-desktop-run-button {
      grid-template-columns: 24px minmax(0, 1fr);
      border: 1px solid var(--hairline);
      background: var(--color-bg-subtle);
    }

  @media (prefers-reduced-motion: reduce) {
    .workspace.is-admin-shell .admin-desktop-sidebar,
      .workspace.is-admin-shell .admin-desktop-nav-item,
      .workspace.is-admin-shell .admin-desktop-run-button,
      .workspace.is-admin-shell .admin-desktop-nav-item span,
      .workspace.is-admin-shell .admin-desktop-run-button span,
      .workspace.is-admin-shell .admin-desktop-nav-item strong {
        transition-duration: 1ms !important;
        transition-delay: 0ms !important;
      }
  }

  .workspace.is-admin-shell .admin-section,
    .workspace.is-admin-shell .admin-home-panel {
      padding: 0;
      border: 0;
      background: transparent;
      box-shadow: none;
    }

  .workspace.is-admin-shell .admin-workspace {
      gap: 12px;
    }

  .admin-home-desktop-layout {
      display: grid;
      grid-template-columns: minmax(0, 1fr) 260px;
      gap: 12px;
    }

  .admin-home-today-panel,
    .admin-home-status-panel,
    .admin-home-quick,
    .admin-home-priority-compact,
    .workspace.is-admin-shell .admin-filter-bar,
    .workspace.is-admin-shell .admin-review-split,
    .workspace.is-admin-shell .equipment-admin-toolbar,
    .workspace.is-admin-shell .member-lane-panel,
    .workspace.is-admin-shell .admin-inspector,
    .workspace.is-admin-shell .admin-queue-list {
      border: 1px solid var(--hairline);
      border-radius: var(--radius-3);
      background: var(--surface);
    }

  .admin-home-today-panel,
    .admin-home-status-panel,
    .admin-home-quick,
    .admin-home-priority-compact {
      padding: 14px;
    }

  .admin-home-panel-heading {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      margin-bottom: 12px;
    }

  .admin-home-panel-heading h2 {
      margin: 0;
      color: var(--ink);
      font-size: 18px;
      font-weight: var(--font-weight-emphasis);
      line-height: 1.2;
    }

  .admin-home-panel-heading p {
      margin: 3px 0 0;
      color: var(--muted);
      font-size: 11px;
      line-height: 1.35;
    }

  .admin-home-task-list {
      gap: 8px;
    }

  .admin-home-task-row {
      min-height: 70px;
      padding: 11px 12px;
      grid-template-columns: 34px minmax(0, 1fr) auto;
      gap: 10px;
    }

  .admin-home-task-icon {
      width: var(--control-height-compact);
      height: var(--control-height-compact);
      border-radius: var(--radius-pill);
    }

  .admin-home-task-icon svg {
      width: 16px;
      height: 16px;
    }

  .admin-home-task-main {
      display: flex;
      align-items: center;
    }

  .admin-home-task-main strong {
      font-size: 16px;
      font-weight: var(--font-weight-emphasis);
      line-height: 1.2;
      white-space: normal;
    }

  .admin-home-task-due {
      color: var(--muted);
      font-size: 11px;
      font-weight: var(--font-weight-strong);
      text-align: right;
      white-space: nowrap;
    }

  .admin-system-card {
      min-height: 164px;
      border: 1px solid var(--hairline);
      border-radius: var(--radius-3);
      background: var(--color-bg-subtle);
      display: grid;
      place-items: center;
      align-content: center;
      gap: 8px;
      padding: 14px;
      text-align: center;
    }

  .admin-system-check {
      width: var(--control-height-small);
      height: var(--control-height-small);
      border-radius: var(--radius-pill);
      background: var(--color-state-green-600);
      color: var(--color-route-surface-white);
      display: grid;
      place-items: center;
    }
}

/* bundled from styles/admin/shell-desktop.workbench.css */
/*
 * ADMIN SHELL DESKTOP OWNER CSS CONTRACT: shell-desktop.workbench.css
 * Ordered chunk split from shell-desktop.css. Preserve import order.
 */
@media (min-width: 1024px) {
  .admin-system-check svg {
      width: 18px;
      height: 18px;
      stroke-width: 3;
    }

  .admin-system-card strong {
      color: var(--color-state-green-700);
      font-size: 16px;
    }

  .admin-system-card p {
      margin: 0;
      color: var(--muted);
      font-size: 12px;
    }

  .admin-home-recent-mini {
      margin-top: 10px;
      display: grid;
      gap: 6px;
    }

  .admin-quick-grid {
      grid-template-columns: repeat(8, minmax(0, 1fr));
    }

  .admin-quick-card {
      position: relative;
      min-height: 84px;
      padding: 12px 10px;
      gap: 7px;
    }

  .admin-quick-icon {
      width: var(--control-height-compact);
      height: var(--control-height-compact);
    }

  .admin-quick-icon svg {
      width: 20px;
      height: 20px;
    }

  .admin-quick-card strong {
      font-size: 13px;
    }

  .admin-quick-badge {
      position: absolute;
      top: 8px;
      right: 8px;
      min-width: 18px;
      height: 18px;
      border-radius: var(--radius-pill);
      background: var(--primary);
      color: var(--color-route-surface-white);
      display: grid;
      place-items: center;
      font-size: 10px;
      font-weight: var(--font-weight-strong);
    }

  .workspace.is-admin-shell .admin-review-split,
    .workspace.is-admin-shell .equipment-workstation,
    .workspace.is-admin-shell .member-workstation {
      display: grid;
      grid-template-columns: minmax(280px, 0.36fr) minmax(0, 1fr);
      gap: 0;
      overflow: hidden;
    }

  .workspace.is-admin-shell .equipment-workstation {
      height: clamp(430px, calc(100dvh - 270px), 680px);
      min-height: 0;
    }

  .workspace.is-admin-shell .admin-filter-bar-desktop {
      min-height: 46px;
      padding: 10px 12px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      border-bottom-left-radius: 0;
      border-bottom-right-radius: 0;
    }

  .workspace.is-admin-shell .admin-filter-bar-desktop + .admin-review-split {
      border-top: 0;
      border-top-left-radius: 0;
      border-top-right-radius: 0;
    }

  .workspace.is-admin-shell .admin-review-list,
    .workspace.is-admin-shell .equipment-admin-list,
    .workspace.is-admin-shell .member-approval-list,
    .workspace.is-admin-shell .member-admin-list,
    .workspace.is-admin-shell .violation-case-grid {
      border: 0;
      border-right: 1px solid var(--hairline);
      border-radius: 0;
      background: var(--color-bg-subtle);
      padding: 8px;
      gap: 7px;
      align-content: start;
    }

  .workspace.is-admin-shell .equipment-admin-list {
      max-height: 100%;
      overflow-y: auto;
      overscroll-behavior: contain;
      scrollbar-gutter: stable;
    }

  .workspace.is-admin-shell .admin-queue-row {
      min-width: 0;
      border: 1px solid var(--hairline);
      border-radius: var(--radius-control-small);
      background: var(--surface);
      color: var(--ink);
      text-align: left;
    }

  .workspace.is-admin-shell .admin-queue-row.is-active {
      border-color: var(--primary);
      box-shadow: 0 0 0 1px var(--color-route-brand-tint-16);
    }

  .photo-review-card {
      min-height: 64px;
      padding: 9px 8px 9px 12px;
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      align-items: start;
      column-gap: 8px;
      row-gap: 4px;
    }

  .admin-photo-visual {
      width: 54px;
      height: 54px;
      border-radius: var(--radius-control-small);
      background: linear-gradient(145deg, var(--color-route-slate-800), var(--color-route-slate-900));
      color: var(--color-route-text-slate-200);
      display: grid;
      place-items: center;
      overflow: hidden;
    }

  .admin-photo-visual-icon {
      width: 24px;
      height: 24px;
      stroke-width: 1.9;
    }

  .admin-photo-visual > span {
      display: none;
    }

  .admin-photo-visual-2,
    .admin-photo-visual-5 {
      background: linear-gradient(145deg, var(--color-route-slate-600), var(--color-route-slate-800));
    }

  .admin-photo-visual-3,
    .admin-photo-visual-6 {
      background: linear-gradient(145deg, var(--color-route-slate-700), var(--color-route-slate-950));
    }

  .admin-review-row-main {
      min-width: 0;
      display: grid;
      gap: 2px;
      align-self: center;
    }

  .admin-review-row-status {
      min-width: max-content;
      justify-self: end;
      align-self: start;
    }

  .admin-review-row-main strong,
    .admin-review-row-main small,
    .admin-review-row-main span {
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

  .admin-review-row-main strong {
      color: var(--ink);
      font-size: 13px;
    }

  .admin-review-row-main small,
    .admin-review-row-main span {
      color: var(--muted);
      font-size: 11px;
      font-weight: var(--font-weight-strong);
    }

  .admin-photo-detail,
    .workspace.is-admin-shell .admin-inspector {
      border: 0;
      border-radius: 0;
      box-shadow: none;
      padding: 12px;
      display: grid;
      align-content: start;
      gap: 12px;
    }

  .admin-detail-meta-strip {
      display: flex;
      align-items: start;
      justify-content: space-between;
      gap: 10px;
    }

  .admin-detail-meta-strip,
    .admin-detail-meta-table {
      border: 1px solid var(--hairline);
      border-radius: var(--radius-control-small);
      background: var(--color-bg-subtle);
      padding: 10px;
    }

  .admin-detail-meta-strip span,
    .admin-detail-meta-table span {
      color: var(--body);
      font-size: 11px;
      line-height: 1.35;
    }

  .admin-detail-meta-strip strong,
    .admin-detail-meta-table strong {
      display: block;
      color: var(--muted);
      font-size: 10px;
      margin-bottom: 4px;
    }

  .admin-photo-info-status .status-chip {
      display: inline-flex;
    }

  .admin-photo-tabs {
      display: flex;
      gap: 14px;
      border-bottom: 1px solid var(--hairline);
    }

  .admin-photo-tabs button {
      border: 0;
      border-bottom: 2px solid transparent;
      background: transparent;
      color: var(--muted);
      padding: 8px 0;
      font-size: 12px;
      font-weight: var(--font-weight-strong);
    }

  .admin-photo-tabs button.is-active {
      color: var(--primary);
      border-bottom-color: var(--primary);
    }

  .admin-photo-gallery {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 8px;
    }

  .admin-photo-tile {
      min-height: 96px;
      border: 1px solid var(--hairline);
      border-radius: var(--radius-control-small);
      background: var(--surface-muted);
      padding: 0;
      display: grid;
      overflow: hidden;
      color: var(--ink);
      font: inherit;
      font-size: 10px;
      font-weight: var(--font-weight-strong);
    }

  .admin-photo-tile .admin-photo-visual {
      width: 100%;
      height: 70px;
      border-radius: 0;
    }

  .admin-photo-tile > span:last-child {
      padding: 6px;
      text-align: left;
    }

  .admin-photo-tile.is-add {
      border-style: dashed;
      align-content: center;
      justify-items: center;
      gap: 6px;
    }

  .admin-photo-tile.is-add svg {
      width: 20px;
      height: 20px;
    }

  .admin-photo-memo {
      display: grid;
      gap: 4px;
    }
}

@media (min-width: 1024px) and (max-width: 1180px) {
  .admin-quick-card[data-admin-quick-id="billing"] {
      display: none;
    }

  .admin-quick-grid {
      grid-template-columns: repeat(7, minmax(0, 1fr));
    }
}

@media (min-width: 1024px) and (max-width: 1080px) {
  .admin-quick-card[data-admin-quick-id="archive"] {
      display: none;
    }

  .admin-quick-grid {
      grid-template-columns: repeat(6, minmax(0, 1fr));
    }
}

/* bundled from styles/admin/shell-desktop.responsive.css */
/*
 * ADMIN SHELL DESKTOP OWNER CSS CONTRACT: shell-desktop.responsive.css
 * Ordered chunk split from shell-desktop.css. Preserve import order.
 */
@media (min-width: 1024px) {
  .admin-photo-memo strong,
    .admin-photo-memo p {
      margin: 0;
      font-size: 11px;
    }

  .admin-photo-memo p {
      color: var(--muted);
    }

  .admin-search-pill {
      min-width: 220px;
      min-height: var(--control-height-small);
      border: 1px solid var(--hairline);
      border-radius: var(--radius-2);
      background: var(--surface);
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 0 10px;
    }

  .admin-search-pill svg {
      width: 15px;
      height: 15px;
      color: var(--muted);
    }

  .admin-search-pill input {
      width: 100%;
      min-width: 0;
      border: 0;
      outline: 0;
      font: inherit;
      font-size: 12px;
      background: transparent;
    }

  .admin-filter-icon-button {
      width: var(--control-height-small);
      min-width: var(--control-height-small);
      height: var(--control-height-small);
    }

  .workspace.is-admin-shell .equipment-admin-toolbar {
      padding: 10px 12px;
    }

  .workspace.is-admin-shell .equipment-admin-grid {
      display: grid;
      grid-template-columns: minmax(700px, 1fr) minmax(360px, 400px);
      gap: 14px;
      align-items: start;
    }

  .workspace.is-admin-shell .equipment-admin-board,
    .workspace.is-admin-shell .equipment-inspector {
      border: 1px solid var(--hairline);
      border-radius: var(--radius-3);
      background: var(--surface);
      overflow: hidden;
    }

  .workspace.is-admin-shell .equipment-inspector {
      border: 0;
      background: transparent;
      padding: 0;
      gap: 10px;
    }

  .workspace.is-admin-shell .equipment-admin-toolbar {
      border: 0;
      border-bottom: 1px solid var(--hairline);
      border-radius: 0;
      background: var(--surface);
    }

  .workspace.is-admin-shell .equipment-admin-toolbar-main {
      display: grid;
      grid-template-columns: minmax(260px, 1fr) auto;
    }

  .workspace.is-admin-shell .equipment-admin-filterbar {
      grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
      border-top: 0;
      border-bottom: 1px solid var(--hairline);
      background: var(--color-bg-subtle);
      padding: 0;
    }

  .workspace.is-admin-shell .equipment-admin-filterbar,
    .workspace.is-admin-shell .equipment-admin-table {
      display: grid;
    }

  .workspace.is-admin-shell .equipment-category-tabs,
    .workspace.is-admin-shell .equipment-status-tabs {
      padding: 11px 16px;
    }

  .workspace.is-admin-shell .equipment-status-tabs {
      border-left: 1px solid var(--hairline);
    }

  .workspace.is-admin-shell .equipment-admin-table-head {
      padding: 15px 16px 12px;
    }

  .workspace.is-admin-shell .equipment-admin-list {
      max-height: clamp(450px, calc(100dvh - 310px), 680px);
      border: 0;
      border-right: 0;
      border-radius: 0;
      background: var(--surface);
      padding: 0 14px 14px;
      overflow-y: auto;
    }

  .workspace.is-admin-shell .equipment-admin-row {
      min-height: 86px;
      padding: 10px 12px;
    }

  .workspace.is-admin-shell .equipment-admin-footer {
      border-top: 1px solid var(--hairline);
      padding: 13px 18px;
    }

  .workspace.is-admin-shell .equipment-category-tabs {
      display: flex;
      flex-wrap: nowrap;
      overflow-x: auto;
      padding-bottom: 2px;
      scrollbar-width: none;
    }

  .workspace.is-admin-shell .equipment-category-tabs::-webkit-scrollbar {
      display: none;
    }

  .workspace.is-admin-shell .equipment-status-tabs {
      flex-wrap: nowrap;
      overflow-x: auto;
      scrollbar-width: none;
    }

  .workspace.is-admin-shell .equipment-status-tabs::-webkit-scrollbar {
      display: none;
    }

  .workspace.is-admin-shell .equipment-admin-card {
      grid-template-columns: 62px minmax(0, 1fr) auto;
      padding: 8px;
    }

  .workspace.is-admin-shell .equipment-admin-card .equipment-thumb {
      width: 62px;
      height: 62px;
      min-width: 62px;
      min-height: 62px;
      aspect-ratio: 1 / 1;
    }

  .workspace.is-admin-shell .equipment-admin-row .equipment-thumb {
      width: 54px;
      height: 54px;
      min-width: 54px;
      min-height: 54px;
      aspect-ratio: 1 / 1;
    }

  .workspace.is-admin-shell .equipment-summary-content .equipment-thumb {
      width: 160px;
      height: 150px;
      min-width: 160px;
      min-height: 150px;
    }

  .workspace.is-admin-shell .equipment-inspector .admin-section-heading h3 {
      font-size: 16px;
    }

  .admin-detail-meta-table {
      display: grid;
      grid-template-columns: 120px minmax(0, 1fr);
      gap: 8px 12px;
    }

  .equipment-change-log {
      border: 1px solid var(--hairline);
      border-radius: var(--radius-control-small);
      padding: 10px;
      display: grid;
      gap: 6px;
    }

  .equipment-change-log span {
      color: var(--muted);
      font-size: 11px;
      font-weight: var(--font-weight-strong);
    }

  .equipment-change-log strong,
    .equipment-change-log small {
      font-size: 11px;
      line-height: 1.35;
    }

  .equipment-change-log small {
      color: var(--muted);
    }

  .member-page-titlebar {
      width: 100%;
    }

  .workspace.is-admin-shell .member-inline-tabs {
      width: 100%;
      border: 1px solid var(--hairline);
      border-radius: var(--radius-control-small);
      padding: 2px;
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 2px;
    }

  .workspace.is-admin-shell .member-inline-tab {
      min-height: var(--control-height-small);
      border-radius: 5px;
      justify-content: center;
      font-size: 12px;
    }

  .workspace.is-admin-shell .member-inline-tab strong {
      display: none;
    }

  .member-admin-utility-actions {
      display: flex;
      gap: 6px;
    }

  .member-approval-card {
      grid-template-columns: 44px minmax(0, 1fr) auto;
      align-items: center;
      gap: 10px;
      padding: 10px;
    }

  .member-avatar-soft,
    .member-avatar-large {
      border-radius: var(--radius-pill);
      background: var(--color-route-text-slate-200);
      color: var(--color-route-text-slate-400);
      display: grid;
      place-items: center;
      font-weight: var(--font-weight-strong);
    }

  .member-avatar-soft {
      width: 44px;
      height: 44px;
    }

  .member-avatar-large {
      width: 84px;
      height: 84px;
      font-size: 30px;
    }

  .member-identity-block span {
      display: block;
      margin-top: 3px;
      color: var(--muted);
      font-size: 11px;
      font-weight: var(--font-weight-strong);
    }

  .member-approval-hero {
      display: grid;
      grid-template-columns: 96px minmax(0, 1fr) minmax(240px, 0.7fr);
      gap: 16px;
      align-items: center;
    }

  .member-approval-hero h3 {
      margin: 0 0 4px;
      color: var(--ink);
      font-size: 16px;
    }

  .member-approval-hero h3 small {
      color: var(--muted);
      font-size: 12px;
    }

  .member-approval-hero p {
      margin: 2px 0;
      color: var(--body);
      font-size: 12px;
    }

  .member-docs-panel {
      border: 1px solid var(--hairline);
      border-radius: var(--radius-control-small);
      background: var(--color-bg-subtle);
      padding: 10px;
      display: grid;
      gap: 6px;
    }

  .member-docs-panel strong,
    .member-docs-panel span,
    .member-docs-panel small {
      font-size: 11px;
    }

  .member-docs-panel span {
      color: var(--color-state-green-700);
      font-weight: var(--font-weight-strong);
    }

  .member-docs-panel small {
      color: var(--muted);
    }

  .member-approval-actions {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

/* bundled from styles/admin/equipment-workstation.css */
/* TODO(route-css-extraction): move admin equipment route-only CSS to ./styles/admin/equipment.css. Plan: docs/plans/2026-05-14-frontend-root-file-contract-plan.md */
@media (min-width: 1024px) {
  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell {
    height: calc(100dvh - var(--topbar-height-desktop));
    min-height: 0;
    align-items: stretch;
    overflow: hidden;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell .admin-desktop-sidebar {
    height: 100%;
    min-height: 0;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"].compact-view {
    display: contents;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"].compact-view.is-visible > .admin-workspace {
    grid-column: 2;
    width: 100%;
    max-width: none;
    min-width: 0;
    height: 100%;
    min-height: 0;
    overflow: hidden;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .admin-workspace,
  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .admin-section,
  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-grid {
    height: 100%;
    min-height: 0;
    overflow: hidden;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .admin-section {
    grid-template-rows: minmax(0, 1fr);
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-grid {
    align-items: stretch;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-board,
  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-inspector {
    height: 100%;
    min-height: 0;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-inspector {
    max-height: 100%;
    overflow-y: auto;
    overscroll-behavior: contain;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-table {
    height: 100%;
    min-height: 0;
    grid-template-rows: auto minmax(0, 1fr) auto;
    overflow: hidden;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-table .admin-list-body {
    min-height: 0;
    display: grid;
    grid-template-rows: minmax(0, 1fr);
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-table .admin-list-scroll-root {
    height: 100%;
    max-height: 100%;
    min-height: 0;
    overflow-y: auto;
    overscroll-behavior: contain;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-list {
    min-height: 0;
    overflow: visible;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-filterbar[hidden] {
    display: none;
  }
}

/* Admin equipment workstation production shell */
.workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-top {
  display: none;
}

.workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-page-heading,
.workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-section-heading {
  display: none;
}

.workspace.is-admin-shell .equipment-admin-grid {
  min-height: 0;
  height: calc(100dvh - var(--header-height, 72px) - 34px);
  display: grid;
  grid-template-columns: minmax(640px, 1fr) minmax(300px, 360px);
  gap: 14px;
  align-items: stretch;
}

.workspace.is-admin-shell .equipment-admin-board,
.workspace.is-admin-shell .equipment-inspector {
  min-height: 0;
}

.workspace.is-admin-shell .equipment-admin-board {
  display: grid;
  grid-template-rows: minmax(0, 1fr);
}

.workspace.is-admin-shell .equipment-admin-toolbar {
  padding: 10px;
}

.workspace.is-admin-shell .equipment-admin-toolbar-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 42px;
  gap: 10px;
}

.workspace.is-admin-shell .admin-search-pill {
  width: 100%;
  min-height: var(--control-height-search);
  border-radius: var(--radius-control-small);
  padding: 0 12px;
}

.workspace.is-admin-shell .equipment-filter-toggle {
  width: 42px;
  min-width: 42px;
  min-height: var(--control-height-search);
  padding: 0;
  justify-content: center;
}

.workspace.is-admin-shell .equipment-filter-toggle svg {
  width: 17px;
  height: 17px;
}

.workspace.is-admin-shell .equipment-admin-filterbar {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  overflow: hidden;
  background: var(--color-bg-subtle);
}

.workspace.is-admin-shell .equipment-category-tabs,
.workspace.is-admin-shell .equipment-status-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding: 10px;
  border: 0;
}

.workspace.is-admin-shell .equipment-status-tabs {
  border-top: 1px solid var(--hairline);
}

.workspace.is-admin-shell .equipment-category-tab,
.workspace.is-admin-shell .equipment-status-tab {
  min-height: var(--control-height-small);
}

.workspace.is-admin-shell .equipment-admin-table {
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
}

.workspace.is-admin-shell .equipment-admin-table-head,
.workspace.is-admin-shell .equipment-admin-row {
  grid-template-columns: var(--admin-list-columns, minmax(300px, 1fr) 96px 60px 112px);
  gap: var(--space-4);
}

.workspace.is-admin-shell .equipment-admin-table-head {
  padding: 11px 16px;
}

.workspace.is-admin-shell .equipment-admin-list {
  max-height: none;
  min-height: 0;
  overflow: visible;
  padding: 0;
}

.workspace.is-admin-shell .equipment-admin-row {
  min-height: 68px;
  padding: 8px 10px 8px 12px;
  border-radius: var(--radius-panel);
}

.workspace.is-admin-shell .equipment-admin-row .equipment-thumb {
  width: 46px;
  height: 46px;
  min-width: 46px;
  min-height: 46px;
  aspect-ratio: 1 / 1;
}

.workspace.is-admin-shell .equipment-admin-item {
  grid-template-columns: 46px minmax(0, 1fr);
  gap: var(--space-3);
}

.workspace.is-admin-shell .equipment-compact-main {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.workspace.is-admin-shell .equipment-compact-main strong,
.workspace.is-admin-shell .equipment-compact-main small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.workspace.is-admin-shell .equipment-admin-footer {
  padding: 10px 16px;
}

.workspace.is-admin-shell .equipment-inspector {
  display: grid;
  grid-template-rows: auto auto 1fr;
  gap: 10px;
  overflow: auto;
}

.workspace.is-admin-shell .equipment-summary-card .equipment-summary-content {
  grid-template-columns: 1fr;
  gap: var(--space-3);
}

.workspace.is-admin-shell .equipment-summary-content .equipment-thumb {
  width: 100%;
  height: auto;
  min-width: 0;
  min-height: 0;
  aspect-ratio: 4 / 3;
}

.workspace.is-admin-shell .equipment-summary-meta {
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 7px 12px;
}

.workspace.is-admin-shell .equipment-summary-actions,
.workspace.is-admin-shell .management-actions,
.equipment-modal-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
}

.equipment-management-card h3,
.equipment-management-card p {
  margin: 0;
}

.equipment-management-card p {
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.equipment-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: grid;
  place-items: center;
  background: var(--color-overlay-scrim-strong);
  padding: var(--space-5);
}

.equipment-modal {
  width: min(680px, calc(100vw - 32px));
  max-height: min(760px, calc(100dvh - 44px));
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface);
  box-shadow: var(--shadow-equipment-workstation-modal);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  overflow: hidden;
}

.equipment-modal-heading {
  min-height: 62px;
  border-bottom: 1px solid var(--hairline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: 14px 18px;
}

.equipment-modal-heading h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.2;
}

.equipment-modal-heading h2 small {
  margin-left: 8px;
  color: var(--muted);
  font-size: var(--font-size-sm);
}

.equipment-modal .icon-only {
  width: var(--control-size-icon-md);
  min-width: var(--control-size-icon-md);
  padding: 0;
  justify-content: center;
}

.equipment-edit-form,
.category-modal-body,
.delete-equipment-body {
  min-height: 0;
  overflow: auto;
  display: grid;
  gap: 14px;
  padding: 16px 18px;
}

.equipment-edit-stepper {
  display: flex;
  justify-content: center;
  gap: var(--space-5);
  padding: 2px 0 8px;
}

.equipment-edit-step-chip {
  border: 0;
  background: transparent;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-emphasis);
}

.equipment-edit-step-chip span {
  width: var(--control-size-icon-sm);
  height: var(--control-size-icon-sm);
  border: 2px solid var(--color-route-neutral-line);
  border-radius: var(--radius-pill);
  display: grid;
  place-items: center;
  background: var(--surface);
  color: var(--muted);
}

.equipment-edit-step-chip.is-active {
  color: var(--primary);
}

.equipment-edit-step-chip.is-active span,
.equipment-edit-step-chip.is-done span {
  border-color: var(--primary);
  background: var(--primary);
  color: var(--color-route-surface-white);
}

.equipment-edit-step-panel {
  display: grid;
  gap: var(--space-3);
}

.equipment-edit-step-panel[hidden] {
  display: none !important;
}

.photo-control {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-bg-subtle);
  padding: 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-3);
  align-items: end;
}

.photo-preview {
  width: 100%;
  aspect-ratio: 4 / 3;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-control-small);
  background: var(--surface-muted);
  display: grid;
  place-items: center;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  overflow: hidden;
}

.photo-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.photo-actions {
  display: flex;
  gap: var(--space-2);
}

.number-conflict-panel {
  border: 1px solid var(--color-state-blue-200);
  border-radius: var(--radius-panel);
  background: var(--color-state-blue-50);
  color: var(--color-equipment-info-text);
  padding: var(--space-3);
  display: grid;
  gap: var(--space-2);
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity var(--motion-micro) ease, transform var(--motion-micro) ease;
}

.number-conflict-panel.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.number-conflict-panel[hidden] {
  display: none;
}

.number-conflict-panel strong,
.number-conflict-panel p {
  margin: 0;
  font-size: var(--font-size-sm);
  line-height: 1.45;
}

.radio-row {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.category-modal {
  width: min(680px, calc(100vw - 32px));
}

.category-modal-note {
  margin: 0;
  border-radius: var(--radius-control-small);
  background: var(--color-bg-subtle);
  color: var(--muted);
  padding: 10px 12px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  line-height: 1.45;
}

.category-tools {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
}

.category-create {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-bg-subtle);
  padding: 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: var(--space-2);
  align-items: end;
}

.category-create-toggle {
  min-height: var(--control-height-search);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.category-table {
  min-height: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  overflow: hidden;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}

.category-table-head,
.category-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 92px 132px;
  gap: 10px;
  align-items: center;
}

.category-table-head {
  background: var(--color-bg-subtle);
  color: var(--muted);
  padding: 9px 12px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-emphasis);
}

.category-list {
  max-height: 310px;
  overflow: auto;
}

.category-row {
  border-top: 1px solid var(--hairline);
  padding: 10px 12px;
}

.category-row strong {
  font-size: var(--font-size-sm);
}

.category-name-display {
  min-height: var(--control-height-search);
  min-width: 0;
  display: inline-flex;
  align-items: center;
  border: 1px solid transparent;
  border-radius: var(--radius-panel);
  color: var(--ink);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-emphasis);
}

.category-row-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
}

.delete-equipment-body {
  gap: var(--space-2);
}

.delete-equipment-body strong,
.delete-equipment-body p {
  margin: 0;
}

.delete-equipment-body p {
  color: var(--muted);
  font-size: var(--font-size-md);
  line-height: 1.5;
}

.danger-note {
  color: var(--primary) !important;
  font-weight: var(--font-weight-strong);
}

@media (min-width: 1024px) {
  .workspace.is-admin-shell .equipment-admin-grid {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  }

  .workspace.is-admin-shell .equipment-admin-table-head,
  .workspace.is-admin-shell .equipment-admin-row {
    grid-template-columns: var(--admin-list-columns, minmax(220px, 1fr) 80px 48px 86px);
    gap: 10px;
  }
}

@media (max-width: 1023px) {
  .workspace.is-admin-shell .equipment-admin-grid {
    height: auto;
    grid-template-columns: 1fr;
  }

  .workspace.is-admin-shell .equipment-admin-table-head,
  .workspace.is-admin-shell .equipment-admin-list {
    display: none;
  }

  .equipment-admin-mobile-list {
    display: grid;
  }

  .equipment-modal-backdrop {
    align-items: end;
    padding: 0;
  }

  .equipment-modal {
    width: 100%;
    max-height: calc(100dvh - 24px);
    border-radius: 12px 12px 0 0;
  }

  .photo-control,
  .category-tools,
  .category-create,
  .category-table-head,
  .category-row {
    grid-template-columns: 1fr;
  }

  .photo-actions,
  .category-row-actions {
    justify-content: stretch;
  }

  .photo-actions > *,
  .category-row-actions > * {
    flex: 1;
  }
}

/* bundled from styles/admin/equipment-inspector-history.css */
/*
 * ADMIN EQUIPMENT INSPECTOR HISTORY CSS CONTRACT
 * Equipment inspector history and change log styles.
 */
.equipment-inspector-hero {
  display: grid;
  gap: 10px;
}

.equipment-change-log {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 10px;
  display: grid;
  gap: 4px;
}

.equipment-change-log span {
  color: var(--muted);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
}

.equipment-change-log strong {
  color: var(--ink);
  font-size: 14px;
  line-height: 1.35;
}

.equipment-change-log small {
  color: var(--muted);
  line-height: 1.4;
}

.equipment-inspector.is-editing-drawer {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px var(--color-route-brand-tint-08);
}

/* bundled from styles/admin/queues.css */
/*
 * ADMIN QUEUES CSS CONTRACT
 * Admin priority rows, queues, archive mobile cards, and queue responsive behavior.
 */
.admin-priority-board {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 14px;
  display: grid;
  gap: 12px;
}

.compact-heading p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.admin-priority-list,
.admin-queue-list,
.member-approval-list {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.admin-priority-row,
.admin-queue-row,
.archive-mobile-card {
  width: 100%;
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  color: var(--ink);
  padding: 10px 12px;
  display: grid;
  gap: 5px;
  text-align: left;
  font: inherit;
  cursor: pointer;
}

.admin-priority-row {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  border-left-width: 4px;
}

.admin-priority-row strong,
.admin-priority-row small {
  min-width: 0;
  overflow-wrap: anywhere;
}

.admin-priority-row small {
  grid-column: 2;
}

.admin-priority-row strong,
.admin-queue-row strong,
.archive-mobile-card strong {
  color: var(--ink);
  line-height: 1.25;
}

.admin-priority-row span,
.admin-priority-row small,
.admin-queue-row small,
.archive-mobile-card span {
  color: var(--muted);
  line-height: 1.35;
}

.priority-danger {
  border-left-color: var(--color-route-text-red-650);
  background: color-mix(in srgb, var(--color-route-surface-white) 97%, transparent);
}

.priority-warning {
  border-left-color: var(--photo-needed);
  background: color-mix(in srgb, var(--color-route-surface-white) 95%, transparent);
}

.priority-primary {
  border-left-color: var(--primary);
}

.priority-muted {
  border-left-color: var(--archive);
}

.admin-queue-row.is-active,
.admin-priority-row:hover,
.admin-queue-row:hover,
.archive-mobile-card.is-active {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px var(--color-focus-ring-faint);
}

.admin-workstation-split {
  display: grid;
  grid-template-columns: minmax(280px, 420px) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.admin-inspector {
  min-width: 0;
  position: sticky;
  top: 12px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 14px;
  display: grid;
  gap: 14px;
}

.admin-inspector.is-empty {
  color: var(--muted);
}

.violation-case-grid.admin-queue-list {
  grid-template-columns: 1fr;
}

.violation-case-card.admin-queue-row {
  display: grid;
}

.violation-evidence-panel.admin-inspector {
  border-style: solid;
}

.archive-mobile-list,
.audit-mobile-list,
.equipment-archive-mobile-list {
  display: none;
}

.archive-mobile-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.audit-mobile-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 10px;
  display: grid;
  gap: 4px;
}

.audit-mobile-card strong {
  color: var(--ink);
}

.audit-mobile-card span,
.audit-mobile-card small {
  color: var(--muted);
  line-height: 1.35;
}

@media (max-width: 1023px) {
  .ledger-card table {
    display: none;
  }

  .archive-mobile-list,
  .audit-mobile-list,
  .equipment-archive-mobile-list {
    display: grid;
    gap: 8px;
    padding: 10px;
  }

  .ledger-heading {
    min-width: 0;
    align-items: stretch;
    flex-direction: column;
  }
}

@media (max-width: 520px) {
  .admin-priority-row {
    grid-template-columns: 1fr;
  }

  .admin-priority-row small {
    grid-column: auto;
  }
}

/* bundled from styles/admin/members.css */
/*
 * ADMIN MEMBERS CSS CONTRACT
 * Member lane tabs, approval cards, detail grids, and member responsive layout.
 */
.member-lane-tabs {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-admin-members-soft-bg);
  padding: 6px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.member-lane-button {
  min-width: 0;
  min-height: 42px;
  border: 0;
  border-radius: var(--radius-panel);
  background: transparent;
  color: var(--muted);
  font: inherit;
  font-weight: var(--font-weight-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  cursor: pointer;
}

.member-lane-button strong {
  border-radius: var(--radius-pill);
  background: var(--color-neutral-0);
  padding: 2px 7px;
  font-size: var(--font-size-xs);
}

.member-lane-button.is-active {
  background: var(--surface);
  color: var(--ink);
  box-shadow: var(--shadow-admin-member-card);
}

.member-lane-panel {
  display: grid;
  gap: var(--space-3);
}

.member-approval-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface);
  padding: var(--space-3);
  display: grid;
  gap: var(--space-panel-gap-sm);
}

.member-approval-card.is-empty {
  background: var(--surface-muted);
  color: var(--muted);
}

.member-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-2);
}

.member-detail-grid span {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface-muted);
  color: var(--body);
  padding: 8px 10px;
  font-size: var(--font-size-sm);
  line-height: 1.35;
}

.member-role-chip {
  border-color: var(--color-role-renter-border);
  background: var(--color-role-renter-bg);
  color: var(--color-role-renter-text);
}

.member-role-chip.status-admin {
  border-color: var(--color-role-admin-border);
  background: var(--color-role-admin-bg);
  color: var(--color-role-admin-text);
}

.member-role-chip.status-owner {
  border-color: var(--color-role-owner-border);
  background: var(--color-role-owner-bg);
  color: var(--color-role-owner-text);
}

.member-admin-list .member-admin-card,
.member-admin-list .member-admin-row {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
}

.member-admin-list .member-score-row {
  grid-column: 1 / -1;
}

@media (min-width: 1024px) {
  body:has([data-panel="admin-members"].is-visible) .workspace.is-admin-shell [data-panel="admin-members"].compact-view {
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    padding: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-grid {
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-lane-panel {
    grid-column: 1 / -1;
    min-height: clamp(520px, calc(100dvh - 160px), 760px);
    overflow: hidden;
    align-content: start;
    grid-template-rows: auto minmax(0, 1fr);
    gap: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-workspace {
    min-height: 0;
    height: clamp(520px, calc(100dvh - 160px), 760px);
    max-width: 1192px;
    display: grid;
    grid-template-columns: minmax(0, 836px) minmax(300px, 340px);
    grid-template-rows: minmax(0, 1fr);
    gap: var(--space-4);
    align-items: stretch;
    border: 0;
    border-radius: 0;
    background: transparent;
    overflow: visible;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-list-board {
    --member-board-x: 18px;
    --member-table-gap: var(--space-3);
    min-width: 0;
    min-height: 0;
    height: clamp(520px, calc(100dvh - 160px), 760px);
    max-height: 100%;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    overflow: hidden;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-panel);
    background: var(--surface);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-filter-bar {
    border: 0;
    border-bottom: 1px solid var(--hairline);
    border-radius: 0;
    background: var(--surface);
    padding: 16px var(--member-board-x) 14px;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-panel-gap-sm);
    align-items: center;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-filter-primary-row {
    min-width: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 42px;
    gap: var(--space-panel-gap-sm);
    align-items: center;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .admin-member-search {
    width: 100%;
    min-height: 42px;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-filter-toggle {
    width: 42px;
    min-width: 42px;
    height: 42px;
    border-color: var(--color-route-neutral-line);
    background: var(--color-bg-subtle);
    color: var(--primary);
    box-shadow: none;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-filter-toggle:hover,
  .workspace.is-admin-shell [data-panel="admin-members"] .member-filter-toggle[aria-pressed="true"] {
    border-color: var(--color-admin-filter-selected-border);
    background: var(--color-route-surface-white);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-filter-panel {
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: var(--space-2);
    padding: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-filter-panel[hidden] {
    display: none;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-filter-list {
    justify-content: flex-start;
    gap: var(--space-2);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-filter.tone-active.is-active {
    border-color: var(--color-status-active-border);
    background: var(--color-status-active-bg);
    color: var(--color-status-active-text);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-filter.tone-danger.is-active,
  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-list .member-admin-row .status-chip.status-cancelled,
  .workspace.is-admin-shell [data-panel="admin-members"] .member-inspector .status-chip.status-cancelled {
    border-color: var(--color-brand-ku-crimson-200);
    background: var(--ku-crimson-soft);
    color: var(--primary);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-filter.tone-active.is-active {
    border-color: var(--color-status-active-border);
    background: var(--color-status-active-bg);
    color: var(--color-status-active-text);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-filter.tone-danger.is-active,
  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-list .member-admin-row .status-chip.status-cancelled,
  .workspace.is-admin-shell [data-panel="admin-members"] .member-inspector .status-chip.status-cancelled {
    border-color: var(--color-brand-ku-crimson-200);
    background: var(--ku-crimson-soft);
    color: var(--primary);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-sort-toggle {
    min-height: var(--control-height-compact);
    margin-left: auto;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-control-small);
    background: var(--surface);
    color: var(--body);
    padding: 0 10px;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-emphasis);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-sort-toggle svg {
    width: 14px;
    height: 14px;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-workstation {
    grid-template-columns: minmax(480px, 1fr) minmax(340px, 420px);
    height: clamp(430px, calc(100dvh - 370px), 640px);
    min-height: 0;
    gap: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-list-column {
    min-width: 0;
    min-height: 0;
    display: grid;
    grid-template-rows: minmax(0, 1fr);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-account-section {
    --member-account-table-columns: minmax(150px, 1fr) minmax(56px, 72px) minmax(74px, 96px) minmax(86px, 108px) minmax(78px, 96px);
    min-width: 0;
    min-height: 0;
    overflow: hidden;
    padding: 0;
    display: grid;
    grid-template-rows: minmax(0, 1fr);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-list-board .admin-list-title {
    border-bottom: 0;
    padding: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-list-board .admin-list-title h2 {
    margin: 0;
    color: var(--ink);
    font-size: var(--font-size-title-sm);
    line-height: 1.25;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-account-list-head,
  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-list .member-admin-row {
    display: grid;
    grid-template-columns: var(--member-account-table-columns);
    align-items: center;
    column-gap: var(--member-table-gap);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-account-list-head {
    min-height: var(--control-height-small);
    padding: 0 var(--member-board-x);
    border-top: 1px solid var(--hairline);
    border-bottom: 1px solid var(--hairline);
    background: var(--color-bg-subtle);
    color: var(--muted);
    font-size: var(--font-size-sm);
    line-height: 1.2;
    font-weight: var(--font-weight-emphasis);
    position: sticky;
    top: 0;
    z-index: 1;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-account-list-head span {
    justify-self: center;
    text-align: center;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-list-board .member-admin-list {
    min-height: 0;
    display: grid;
    align-content: start;
    gap: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: var(--surface);
    overflow: visible;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-list-footer {
    min-height: var(--row-height-regular);
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-top: 1px solid var(--hairline);
    padding: 10px var(--member-board-x);
    color: var(--body);
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-strong);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-list .member-admin-row {
    width: 100%;
    min-height: 68px;
    border: 0;
    border-bottom: 1px solid var(--hairline);
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    align-items: center;
    padding: 10px var(--member-board-x);
    text-align: left;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-list .member-admin-row .member-identity-block {
    min-width: 0;
    display: grid;
    gap: 2px;
    justify-self: start;
    text-align: left;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-list .member-admin-row .member-identity-block small {
    min-width: 0;
    overflow: hidden;
    color: var(--muted);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-strong);
    line-height: 1.2;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-list .member-admin-row:hover,
  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-list .member-admin-row:focus-visible {
    background: var(--color-route-brand-tint-06);
    outline: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-list .member-admin-row.is-active {
    background: var(--color-route-brand-tint-06);
    box-shadow: inset 3px 0 0 var(--primary);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-list .member-admin-row .status-chip,
  .workspace.is-admin-shell [data-panel="admin-members"] .member-role-cell {
    justify-self: center;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-role-cell {
    min-width: 0;
    display: inline-flex;
    justify-content: center;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-cohort-cell,
  .workspace.is-admin-shell [data-panel="admin-members"] .member-department-cell {
    min-width: 0;
    max-width: 100%;
    justify-self: center;
    color: var(--body);
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-emphasis);
    line-height: 1.25;
    text-align: center;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-empty-wrap {
    margin: 12px;
    display: block;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-empty {
    padding: var(--space-4);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-empty.state-block {
    width: auto;
    align-self: start;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 6px;
    border-color: var(--hairline);
    background: var(--color-bg-subtle);
    text-align: left;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-empty.state-block strong,
  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-empty.state-block span {
    min-width: 0;
    display: block;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-admin-empty.state-block span {
    max-width: 38em;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-workspace > .admin-inspector {
    min-width: 0;
    height: clamp(520px, calc(100dvh - 160px), 760px);
    max-height: 100%;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-panel);
    background: var(--surface);
    gap: var(--space-3);
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-workspace > .member-inspector.is-empty {
    align-content: start;
    padding: var(--space-4);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-inspector-empty-card {
    width: 100%;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-panel);
    background: var(--color-bg-subtle);
    color: var(--body);
    padding: var(--space-panel-padding-md);
    display: grid;
    gap: 7px;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-inspector-empty-card strong {
    color: var(--ink);
    font-size: var(--font-size-lg);
    line-height: 1.35;
    font-weight: var(--font-weight-strong);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-inspector-empty-card span {
    color: var(--muted);
    font-size: var(--font-size-md);
    line-height: 1.5;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-inspector-identity {
    padding-bottom: 2px;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-inspector-title-row {
    align-items: center;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-inspector-facts,
  .workspace.is-admin-shell [data-panel="admin-members"] .member-policy-summary {
    gap: 7px;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-manager {
    padding: var(--space-3);
    gap: var(--space-3);
    background: var(--surface);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-memo {
    display: grid;
    gap: 6px;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-memo .input {
    width: 100%;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-memo-display {
    width: 100%;
    min-height: 34px;
    margin: 0;
    padding: 8px 10px;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-control);
    background: var(--color-bg-subtle);
    color: var(--ink);
    font-size: var(--font-size-sm);
    line-height: 1.45;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-memo-display.is-empty {
    color: var(--muted);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-inspector .admin-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-status-actions {
    padding-top: 2px;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-permission-manager {
    border: 1px solid var(--hairline);
    border-radius: var(--radius-panel);
    background: var(--surface);
    padding: var(--space-3);
    display: grid;
    gap: var(--space-3);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-permission-head {
    min-width: 0;
    position: relative;
    display: block;
    padding-right: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-permission-copy {
    min-width: 0;
    display: grid;
    gap: var(--space-2);
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-permission-head > .member-role-chip {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-permission-copy strong {
    color: var(--ink);
    font-size: var(--font-size-lg);
    line-height: 1.3;
    font-weight: var(--font-weight-strong);
    padding-right: 72px;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-permission-copy p {
    margin: 0;
    color: var(--muted);
    font-size: var(--font-size-sm);
    line-height: 1.45;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-permission-actions {
    padding-top: var(--space-2);
    border-top: 1px solid var(--hairline);
    justify-content: flex-end;
  }

  .workspace.is-admin-shell [data-panel="admin-members"] .member-permission-actions .member-role-action {
    min-width: 112px;
  }
}

@media (max-width: 1023px) {
  .member-page-heading {
    align-items: stretch;
    flex-direction: column;
    gap: var(--space-panel-gap-sm);
  }

  .member-page-titlebar {
    width: 100%;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
    gap: var(--space-2);
  }

  .member-page-titlebar h1 {
    min-width: 0;
    word-break: keep-all;
  }

  .member-inline-tabs {
    width: 100%;
    align-items: center;
    gap: 8px 12px;
  }

  .member-inline-tab {
    min-height: 28px;
    font-size: var(--font-size-lg);
    white-space: nowrap;
  }

  .member-page-heading .admin-heading-actions {
    width: 100%;
    justify-content: space-between;
    gap: var(--space-2);
  }

  .member-page-heading .admin-heading-actions .secondary-button {
    width: auto;
    min-width: 116px;
    max-width: 100%;
  }

  .admin-review-split,
  .admin-workstation-split,
  .admin-photo-meta-grid,
  .upload-progress-strip,
  .member-detail-grid,
  .member-inspector-facts,
  .member-policy-summary,
  .member-permission-head {
    grid-template-columns: 1fr;
  }

  .admin-photo-detail,
  .admin-inspector {
    position: static;
  }
}

@media (max-width: 520px) {
  .member-lane-tabs {
    grid-template-columns: 1fr;
  }

  .member-page-titlebar {
    gap: 8px 12px;
  }

  .member-inline-tabs {
    width: 100%;
    gap: var(--space-panel-gap-sm);
  }
}

/* bundled from styles/admin/confirm-actions.css */
/*
 * ADMIN CONFIRM ACTIONS CSS CONTRACT
 * Confirmation modal content, danger state, and submit action styles.
 */
.confirm-action-header {
  min-height: 74px;
  padding: 18px 18px 16px;
  align-items: flex-start;
}

.confirm-action-title-group {
  min-width: 0;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.confirm-action-title-copy {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.confirm-action-icon {
  width: 42px;
  height: 42px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  color: var(--muted);
  display: grid;
  place-items: center;
}

.confirm-action-icon .lucide {
  width: 20px;
  height: 20px;
  stroke-width: 2.4;
}

.confirm-action-modal.is-danger .confirm-action-icon {
  border-color: var(--color-state-red-200);
  background: var(--color-route-surface-red-25);
  color: var(--danger);
}

.confirm-action-modal.is-danger .section-kicker {
  color: var(--danger);
}

.confirm-action-body {
  min-height: 0;
  padding: 16px 18px 18px;
  display: grid;
  gap: 12px;
  overflow: auto;
}

.confirm-action-copy {
  margin: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  color: var(--body);
  padding: 12px 13px;
  font-size: 14px;
  font-weight: var(--font-weight-strong);
  line-height: 1.5;
}

.confirm-action-modal.is-danger .confirm-action-copy {
  border-color: var(--color-state-red-200);
  background: color-mix(in srgb, var(--color-route-surface-white) 97%, transparent);
}

.confirm-action-detail {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.confirm-action-row {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 10px 11px;
  display: grid;
  gap: 4px;
}

.confirm-action-row:first-child,
.confirm-action-row:nth-child(3),
.confirm-action-row:nth-child(n + 4) {
  grid-column: 1 / -1;
}

.confirm-action-row span {
  color: var(--muted);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
}

.confirm-action-row strong {
  color: var(--ink);
  font-size: 13px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.confirm-action-panel .approval-warning-actions {
  padding: 14px 18px 18px;
  border-top: 1px solid var(--hairline);
  background: var(--color-bg-subtle);
}

.confirm-action-submit.danger-button {
  border-color: var(--primary);
  background: var(--primary);
  color: var(--color-neutral-0);
}

.confirm-action-submit.danger-button:hover {
  background: var(--primary-hover);
}

/* bundled from styles/admin/status-states.css */
/*
 * ADMIN STATUS STATES CSS CONTRACT
 * Admin status tone classes shared by queue and rental records.
 */
.status-damaged,
.status-lost,
.status-pending {
  border-color: var(--color-state-red-200);
  background: var(--color-state-red-100);
  color: var(--color-route-text-red-700);
}

.status-approved {
  border-color: var(--color-state-blue-200);
  background: var(--color-state-blue-50);
  color: var(--color-state-blue-600);
}

.status-return_pending {
  border-color: var(--color-state-purple-200);
  background: var(--color-state-purple-50);
  color: var(--color-state-purple-700);
}

/* bundled from styles/admin/home.responsive.css */
/*
 * ADMIN HOME RESPONSIVE CSS CONTRACT
 * Admin home mobile workbench, task list, quick action, usage, and recent activity adjustments.
 */
@media (max-width: 1023px) {
  .admin-home-today-panel,
  .admin-home-status-panel,
  .admin-home-quick,
  .admin-home-priority-compact,
  .admin-home-task-row,
  .admin-recent-row,
  .admin-r2-system-panel,
  .admin-r2-signal-row,
  .admin-r2-sync-status-row {
    max-width: 100%;
    min-width: 0;
  }

  .admin-home-grid {
    gap: 10px;
  }

  .admin-home-quick,
  .admin-r2-usage-panel,
  .admin-recent-panel {
    padding: 18px 14px;
  }

  .admin-home-hero-count {
    font-size: 56px;
  }

  .admin-home-hero-count span {
    font-size: var(--font-size-title-lg);
  }

  .admin-home-task-list {
    gap: 9px;
  }

  .admin-home-task-row {
    min-height: 76px;
    grid-template-columns: 42px minmax(0, 1fr);
    grid-template-rows: auto auto;
    gap: 8px;
    padding: 10px 12px;
  }

  .admin-home-task-icon {
    grid-row: 1 / span 2;
    width: 42px;
    height: 42px;
  }

  .admin-home-task-icon svg {
    width: 24px;
    height: 24px;
  }

  .admin-home-task-main {
    grid-column: 2;
    grid-row: 1;
    display: flex;
    align-items: center;
    min-width: 0;
  }

  .admin-home-task-main strong {
    font-size: var(--font-size-lg);
    line-height: 1.2;
    white-space: normal;
  }

  .admin-home-task-due {
    grid-column: 2;
    grid-row: 2;
    color: var(--muted);
    font-size: 11px;
    text-align: left;
    white-space: normal;
  }

  .admin-quick-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
  }

  .admin-quick-card {
    min-height: 86px;
    grid-template-columns: 1fr;
    justify-items: center;
    align-content: center;
    gap: 8px;
    padding: 10px 6px;
  }

  .admin-quick-card[data-admin-quick-id="billing"],
  .admin-quick-card[data-admin-quick-id="archive"] {
    display: none;
  }

  .admin-quick-card strong {
    min-width: 0;
    font-size: 13px;
  }

  .admin-quick-icon {
    width: var(--control-height-filter);
    height: var(--control-height-filter);
  }

  .admin-quick-icon svg {
    width: 27px;
    height: 27px;
  }

  .admin-quick-card .admin-alert-badge,
  .admin-quick-card .admin-clear-badge {
    justify-self: center;
  }

  .admin-r2-usage-panel,
  .billing-r2-panel,
  .billing-status-card {
    gap: 10px;
  }

  .billing-main-grid {
    grid-template-columns: minmax(0, 1fr);
    gap: 10px;
  }

  .r2-usage-grid {
    grid-template-columns: minmax(0, 1fr);
    gap: 10px;
  }

  .r2-usage-metric-heading {
    align-items: flex-start;
    flex-direction: column;
    gap: 3px;
  }

  .r2-usage-metric {
    min-height: 112px;
    padding: 12px;
    gap: 9px;
  }

  .r2-usage-metric-label,
  .r2-usage-metric-limit,
  .r2-usage-value-caption,
  .r2-usage-meter-labels,
  .r2-usage-footer,
  .billing-status-row strong,
  .billing-status-row span {
    font-size: 11px;
  }

  .r2-usage-value-row > strong {
    font-size: var(--font-size-title-sm);
  }

  .r2-usage-footer,
  .billing-status-row {
    align-items: start;
    grid-template-columns: minmax(0, 1fr);
  }

  .r2-usage-footer {
    display: grid;
  }

  .billing-status-row > strong {
    text-align: left;
  }

  .admin-recent-row {
    min-height: 48px;
    grid-template-columns: 34px minmax(0, 1fr) auto;
    padding: 7px 8px;
    gap: 8px;
  }

  .admin-recent-icon {
    width: var(--control-height-compact);
    height: var(--control-height-compact);
  }

  .admin-recent-icon svg {
    width: 16px;
    height: 16px;
  }

  .admin-recent-main {
    gap: 7px;
    min-width: 0;
  }

  .admin-recent-main strong,
  .admin-recent-main span,
  .admin-recent-row time {
    font-size: 12px;
  }

}

@media (max-width: 520px) {
  .admin-r2-sync-status-row {
    grid-template-columns: 1fr;
  }

  .admin-r2-sync-status-row time {
    justify-self: start;
  }

  .admin-home-panel-heading .admin-home-hero-count {
    font-size: 28px;
  }

  .admin-home-panel-heading .admin-home-hero-count span {
    font-size: 13px;
  }

  .admin-quick-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .admin-home-priority-compact .admin-recent-row {
    grid-template-columns: 30px minmax(0, 1fr);
  }

  .admin-home-priority-compact .admin-priority-meta {
    grid-column: 2;
    white-space: normal;
  }
}

/* bundled from styles/admin/shared.legacy.css */
/*
 * ADMIN LEGACY CSS CONTRACT
 * Legacy media/calendar compatibility imports live here until scoped or removed.
 */
/* bundled from styles/admin/shared.media-calendar-legacy.css */
.photo-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(120px, 1fr));
  gap: 10px;
}

.event-log {
  display: grid;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  overflow: hidden;
}

.event-log div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--hairline);
  font-size: 13px;
}

.event-log div:last-child {
  border-bottom: 0;
}

.ledger-card {
  padding: 0;
  overflow: auto;
}

.audit-ledger-card {
  display: grid;
  gap: 0;
}

.ledger-heading {
  min-width: 760px;
  padding: 14px;
  border-bottom: 1px solid var(--hairline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: var(--color-bg-subtle);
}

.ledger-heading h2 {
  margin: 0;
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
}

table {
  width: 100%;
  border-collapse: collapse;
  min-width: 760px;
}

th,
td {
  border-bottom: 1px solid var(--hairline);
  padding: 12px 14px;
  text-align: left;
  font-size: 13px;
}

th {
  color: var(--muted);
  background: var(--color-bg-subtle);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

td {
  color: var(--body);
}

.toast {
  position: fixed;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%) translateY(18px);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--primary);
  color: var(--color-neutral-0);
  box-shadow: var(--shadow);
  padding: 11px 14px;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--motion-micro) ease, transform var(--motion-micro) ease;
  font-size: 13px;
  font-weight: var(--font-weight-strong);
  z-index: 80;
}

.toast.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

@keyframes sheetIn {
  from {
    opacity: 0;
    transform: translateY(14px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes chapterBodyIn {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes monthGridIn {
  from {
    opacity: 0.92;
    transform: translateX(42px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes monthGridInPrev {
  from {
    opacity: 0.92;
    transform: translateX(-42px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes todayJumpGridIn {
  from {
    opacity: 0.95;
    transform: translateY(8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes todayCellPulse {
  0% {
    transform: scale(0.98);
  }

  50% {
    transform: scale(1.06);
  }

  100% {
    transform: scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 1ms !important;
  }
}

@media (max-width: 1023px) {
  .view-calendar {
    grid-template-columns: 250px minmax(520px, 1fr);
  }

  .detail-panel {
    grid-column: 1 / -1;
    min-height: auto;
  }

  .rental-drawer {
    margin-top: 0;
  }
}

@media (max-width: 1023px) {
  .workspace {
    padding: 10px;
  }

  .view-calendar {
    grid-template-columns: 1fr;
    min-width: 0;
  }

  .resource-rail,
  .calendar-stage,
  .detail-panel {
    min-height: auto;
  }

  .resource-rail {
    order: 2;
  }

  .calendar-stage {
    order: 1;
  }

  .detail-panel {
    order: 3;
  }

  .calendar-toolbar,
  .calendar-meta,
  .page-heading,
  .upload-summary {
    align-items: stretch;
    flex-direction: column;
  }

  .month-controls {
    flex-wrap: wrap;
  }

  .toolbar-actions {
    min-width: 0;
    justify-content: stretch;
  }

  .toolbar-actions .primary-button,
  .toolbar-actions .segmented,
  .page-heading .secondary-button,
  .upload-summary .primary-button {
    width: calc(100vw - 58px);
    max-width: 100%;
  }

  .toolbar-actions .segmented {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .segmented-button[data-mode="agenda"] {
    display: none;
  }

  .segmented-button {
    min-width: 0;
    padding: 0 8px;
  }

  .calendar-weekdays,
  .calendar-grid {
    grid-template-columns: repeat(7, minmax(42px, 1fr));
  }

  .weekday {
    padding: 8px 5px;
    text-align: center;
  }

  .day-cell {
    min-height: 76px;
    padding: 5px;
  }

  .event-pill {
    padding: 3px 4px;
  }

  .event-pill strong {
    font-size: 10px;
  }

  .event-pill span {
    display: none;
  }

  .week-layout,
  .record-grid,
  .detail-proof-grid,
  .photo-grid,
  .upload-policy-board,
  .category-zone-grid,
  .admin-layout,
  .admin-home-grid,
  .admin-photo-grid,
  .admin-approval-grid,
  .approval-request-grid,
  .violation-case-grid,
  .equipment-admin-grid,
  .member-admin-grid,
  .photo-strip {
    grid-template-columns: 1fr;
  }

  .agenda-row {
    grid-template-columns: 1fr;
  }

  .rental-detail-masthead .status-chip {
    grid-column: auto;
    justify-self: end;
  }

  .detail-section-heading {
    display: grid;
  }

  .detail-resource-summary-list {
    justify-items: start;
    text-align: left;
  }

  .date-grid {
    grid-template-columns: 1fr;
  }

  .admin-subnav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .schedule-edit-grid,
  .edit-time-grid,
  .photo-compare-grid,
  .photo-version-list {
    grid-template-columns: 1fr;
  }

  .policy-grid {
    justify-content: flex-start;
  }
}

@media (max-width: 520px) {
  .rental-record .record-card-header {
    grid-template-columns: 1fr;
    row-gap: 6px;
  }

  .rental-record .status-chip {
    justify-self: start;
  }

  .detail-log-item {
    grid-template-columns: 1fr;
  }

  .privacy-note {
    display: none;
  }

  #calendarTitle {
    font-size: var(--font-size-title-sm);
  }

  .resource-card {
    grid-template-columns: 50px 1fr;
  }
}

/* bundled from styles/admin/shared.modal.css */
/*
 * ADMIN MODAL CSS CONTRACT
 * Rental modal, event summary, and project modal implementation imports live here.
 */
/* bundled from styles/admin/rental-modal-wheel.css */
/* Calendar modal iteration: keep the month grid fixed and move creation/detail into popups. */
.calendar-stage {
  height: 100%;
  padding-bottom: 0;
}

.calendar-surface {
  overflow: hidden;
}

.floating-create-button {
  right: 26px;
  bottom: 26px;
}

.rental-modal-panel {
  grid-template-rows: auto minmax(0, 1fr);
}

.day-detail-panel {
  width: min(820px, calc(100vw - 36px));
  grid-template-rows: auto auto auto minmax(0, 1fr) auto;
}

.event-summary-panel {
  width: min(560px, calc(100vw - 36px));
  grid-template-rows: auto minmax(0, 1fr);
}

.project-modal-panel {
  width: min(620px, calc(100vw - 36px));
  grid-template-rows: auto minmax(0, 1fr);
}

.user-profile-panel-modal {
  width: min(500px, calc(100vw - 36px));
  grid-template-rows: auto minmax(0, 1fr);
}

.user-profile-panel-body {
  padding: 16px;
  overflow-y: auto;
}

.user-profile-panel-card {
  display: grid;
  gap: 14px;
}

.user-profile-panel-hero {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 16px;
  display: flex;
  align-items: center;
  gap: 14px;
}

.user-profile-panel-avatar {
  width: 54px;
  height: 54px;
  border-radius: var(--radius-pill);
  background: var(--primary);
  color: var(--color-route-surface-white);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  font-size: var(--font-size-title-lg);
  font-weight: var(--font-weight-strong);
}

.user-profile-panel-hero h3 {
  margin: 2px 0 5px;
  color: var(--ink);
  font-size: var(--font-size-title-lg);
  line-height: 1.18;
}

.user-profile-panel-hero p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
  line-height: 1.45;
}

.user-profile-panel-facts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.user-profile-panel-facts div,
.user-profile-panel-note {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 13px;
}

.user-profile-panel-facts span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.user-profile-panel-facts strong {
  display: block;
  margin-top: 4px;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.user-profile-panel-note h4 {
  margin: 0 0 8px;
  color: var(--ink);
  font-size: var(--font-size-lg);
}

.user-profile-panel-note p {
  margin: 0;
  color: var(--body);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
  line-height: 1.55;
}

.user-profile-panel-actions {
  display: flex;
  justify-content: flex-end;
  padding-top: 2px;
}

@media (max-width: 520px) {
  .user-profile-panel-facts {
    grid-template-columns: 1fr;
  }

  .user-profile-panel-hero {
    align-items: flex-start;
  }

  .user-profile-panel-actions .primary-button {
    width: 100%;
  }
}

.modal-header {
  min-height: 62px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--hairline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.modal-header h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-title-sm);
  line-height: 1.25;
}

.event-summary-title-group {
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.event-summary-title-group h2 {
  min-width: 0;
}

.event-summary-title-group .status-chip {
  flex: 0 0 auto;
}

.modal-rental-form {
  --rental-neutral-border: var(--color-route-border-neutral-300);
  --rental-neutral-border-strong: var(--color-route-border-neutral-400);
  --rental-neutral-surface: var(--color-neutral-0);
  --rental-neutral-soft: var(--color-route-surface-slate-50);
  min-height: 0;
  padding: 14px;
  display: grid;
  gap: 14px;
  overflow: auto;
}

.rental-step-indicator {
  --rental-step-c1: 94px;
  --rental-step-c2: 18px;
  --rental-step-c3: 18px;
  --stepper-direction: 0;
  --stepper-chip-shift: 0px;
  --stepper-label-offset: 0px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: var(--control-height-small);
  padding: 4px 0;
  gap: 0;
}

.rental-step-indicator-content {
  width: 100%;
}

.side-rental-step-indicator {
  margin-bottom: 6px;
  position: relative;
}

.rental-step-indicator[data-stepper-step="time"] {
  --rental-step-c1: 36px;
  --rental-step-c2: 94px;
  --rental-step-c3: 18px;
}

.rental-step-indicator[data-stepper-step="equipment"] {
  --rental-step-c1: 18px;
  --rental-step-c2: 36px;
  --rental-step-c3: 94px;
}

.rental-step-indicator[data-stepper-step="review"] {
  --rental-step-c1: 18px;
  --rental-step-c2: 18px;
  --rental-step-c3: 36px;
}

.rental-step-indicator[data-stepper-motion="forward"] {
  --stepper-direction: 1;
}

.rental-step-indicator[data-stepper-motion="backward"] {
  --stepper-direction: -1;
}

.rental-step-indicator.is-animating-stepper {
  --stepper-chip-shift: calc(var(--stepper-direction) * 2px);
  --stepper-label-offset: calc(var(--stepper-direction) * 8px);
}

.rental-step-connector {
  flex: 0 0 var(--connector-size);
  inline-size: var(--connector-size);
  height: 1px;
  border-radius: var(--radius-pill);
  background: var(--color-route-neutral-line);
  transition:
    flex-basis var(--motion-panel-slide) var(--motion-spring-ease),
    inline-size var(--motion-panel-slide) var(--motion-spring-ease),
    background-color var(--motion-base) ease;
}

.rental-step-indicator .rental-step-connector[data-rental-step-connector="1"] {
  --connector-size: var(--rental-step-c1);
}

.rental-step-indicator .rental-step-connector[data-rental-step-connector="2"] {
  --connector-size: var(--rental-step-c2);
}

.rental-step-indicator .rental-step-connector[data-rental-step-connector="3"] {
  --connector-size: var(--rental-step-c3);
}

.rental-step-indicator[data-stepper-step="time"] .rental-step-connector[data-rental-step-connector="1"],
.rental-step-indicator[data-stepper-step="equipment"] .rental-step-connector[data-rental-step-connector="1"],
.rental-step-indicator[data-stepper-step="equipment"] .rental-step-connector[data-rental-step-connector="2"],
.rental-step-indicator[data-stepper-step="review"] .rental-step-connector {
  background: var(--color-route-brand-alt-tint-20);
}

.rental-step-chip {
  min-width: 0;
  border: 0;
  border-radius: var(--radius-pill);
  background: transparent;
  color: var(--muted);
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 12px;
  font-weight: var(--font-weight-strong);
  line-height: 1.2;
  text-align: left;
  transition:
    color var(--motion-base) ease,
    opacity var(--motion-base) ease,
    transform 280ms var(--motion-spring-ease);
}

.rental-step-chip .rental-step-bead {
  width: 26px;
  height: 26px;
  border-radius: var(--radius-pill);
  background: var(--color-neutral-0);
  border: 2px solid var(--color-route-neutral-line);
  color: inherit;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  line-height: 1;
  box-shadow: 0 0 0 5px var(--color-route-surface-neutral-25);
  transition:
    background-color var(--motion-base) ease,
    border-color var(--motion-base) ease,
    color var(--motion-base) ease,
    transform 280ms var(--motion-spring-ease);
}

.rental-step-chip em {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  max-width: 0;
  font-style: normal;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  border-radius: var(--radius-pill);
  background: var(--color-route-surface-neutral-25);
  padding: 0;
  opacity: 0;
  transform: translateX(var(--stepper-label-offset));
  transition:
    max-width 280ms var(--motion-spring-ease),
    padding 280ms var(--motion-spring-ease),
    opacity var(--motion-base) ease,
    transform 280ms var(--motion-spring-ease);
}

.side-rental-step-indicator .rental-step-chip {
  position: relative;
  z-index: 1;
}

.rental-step-chip.is-active em {
  max-width: 76px;
  padding: 0 4px;
  opacity: 1;
  transform: translateX(0);
}

.rental-step-chip.is-complete .rental-step-bead {
  border-color: var(--color-route-brand-alt-tint-22);
  background: var(--color-route-surface-pink-25);
  color: var(--color-route-text-muted-600);
}

.rental-step-chip.is-active {
  color: var(--primary);
  transform: translateX(var(--stepper-chip-shift));
}

.rental-step-chip.is-active .rental-step-bead {
  border-color: var(--primary);
  background: var(--primary);
  color: var(--color-neutral-0);
  transform: scale(1.04);
}

.rental-step-indicator.is-preparing-stepper,
.rental-step-indicator.is-preparing-stepper * {
  transition: none !important;
}

.rental-step-panel[hidden] {
  display: none !important;
}

.rental-step-actions {
  margin-top: 8px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.rental-time-assist,
.rental-time-tools {
  display: grid;
  gap: 12px;
}

.rental-time-tools {
  margin-top: 12px;
}

.rental-selected-project-strip,
.schedule-edit-selected-project {
  min-height: var(--control-height-compact);
  border: 1px solid var(--color-route-neutral-tint-10);
  border-radius: var(--radius-3);
  background: var(--color-route-surface-frosted);
  color: var(--ink);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  padding: 5px 8px;
  font-size: 12px;
  line-height: 1.2;
}

.rental-selected-project-strip strong,
.schedule-edit-selected-project strong {
  min-width: 0;
  overflow: hidden;
  color: var(--ink);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rental-selected-project-strip span,
.schedule-edit-selected-project span {
  min-width: 0;
  justify-self: end;
  overflow: hidden;
  color: var(--muted);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rental-time-approval-inline {
  margin-right: auto;
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--primary);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
  line-height: 1.2;
  white-space: nowrap;
}

.rental-time-approval-inline[hidden],
.rental-date-warning[hidden] {
  display: none;
}

.rental-time-approval-inline.is-invalid {
  color: var(--danger);
}

.rental-time-approval-inline span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rental-time-approval-inline svg {
  width: 14px;
  height: 14px;
  flex: 0 0 auto;
}

.rental-time-tools section {
  border: 1px solid var(--rental-neutral-border);
  border-radius: var(--radius-3);
  background: var(--rental-neutral-soft);
  padding: 10px;
  display: grid;
  gap: 8px;
}

.rental-time-tool-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.rental-time-tool-grid article {
  min-width: 0;
  display: grid;
  gap: 7px;
}

.rental-time-tool-grid article > strong {
  font-size: 13px;
  font-weight: var(--font-weight-strong);
}

.rental-wheel-section-title {
  color: var(--ink);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
  line-height: 1.25;
}

.rental-wheel-card-header {
  position: relative;
  min-height: var(--control-height-filter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.rental-wheel-card-header > strong {
  min-width: 0;
  font-size: 13px;
  font-weight: var(--font-weight-strong);
}

.rental-wheel-calendar-button {
  width: var(--control-height-filter);
  min-width: var(--control-height-filter);
  height: var(--control-height-filter);
  border-radius: var(--radius-3);
}

.rental-native-date-input {
  position: absolute;
  inset-inline-end: 0;
  inset-block-start: 100%;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.rental-wheel-group {
  display: grid;
  gap: 6px;
}

.rental-date-wheel-group {
  grid-template-columns: minmax(64px, 1.25fr) repeat(2, minmax(44px, 1fr));
}

.rental-time-wheel-group {
  width: 100%;
  max-width: 100%;
  grid-template-columns: repeat(2, minmax(44px, 1fr));
  justify-self: stretch;
}

.rental-wheel-column {
  min-width: 0;
  display: grid;
  gap: 5px;
}

.rental-wheel-column > span {
  color: var(--muted);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
}

.rental-wheel-values {
  height: 96px;
  overflow-y: auto;
  overscroll-behavior: contain;
  scroll-snap-type: y mandatory;
  scroll-padding-block: 32px;
  border: 1px solid var(--rental-neutral-border);
  border-radius: var(--radius-3);
  background:
    linear-gradient(
      to bottom,
      transparent 0,
      transparent 32px,
      var(--color-route-brand-alt-tint-08) 32px,
      var(--color-route-brand-alt-tint-08) 64px,
      transparent 64px
    ),
    var(--surface);
  display: flex;
  flex-direction: column;
  scrollbar-width: none;
  touch-action: none;
  cursor: grab;
  user-select: none;
  mask-image: linear-gradient(to bottom, transparent 0, var(--color-route-mask-solid) 18%, var(--color-route-mask-solid) 82%, transparent 100%);
}

.rental-wheel-values.is-pointer-active,
.rental-wheel-values.is-dragging {
  cursor: grabbing;
}

.rental-wheel-values::-webkit-scrollbar {
  width: 0;
  height: 0;
}

.rental-wheel-spacer {
  flex: 0 0 32px;
}

.rental-wheel-option {
  flex: 0 0 32px;
  min-height: var(--control-height-filter);
  border: 0;
  border-radius: var(--radius-control-small);
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-weight: var(--font-weight-strong);
  line-height: var(--control-height-filter);
  cursor: pointer;
  scroll-snap-align: center;
  display: grid;
  place-items: center;
  opacity: 0.58;
  transition:
    color var(--motion-fast) var(--motion-ease),
    opacity var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease);
}

.rental-wheel-option:hover {
  opacity: 0.82;
}

.rental-wheel-option.is-disabled,
.rental-wheel-option:disabled {
  color: var(--muted);
  cursor: not-allowed;
  opacity: 0.24;
}

.rental-wheel-option.is-selected {
  background: transparent;
  color: var(--primary);
  opacity: 1;
}

.rental-wheel-option.is-editing {
  padding: 0 4px;
}

.rental-wheel-inline-input {
  width: 100%;
  height: 28px;
  border: 1px solid var(--color-route-brand-tint-28);
  border-radius: var(--radius-control-small);
  background: var(--color-neutral-0);
  color: var(--primary);
  font: inherit;
  font-weight: var(--font-weight-strong);
  text-align: center;
  outline: none;
  box-shadow: 0 0 0 2px var(--color-route-brand-alt-tint-08);
}

.rental-wheel-inline-input:focus {
  border-color: var(--color-route-brand-tint-48);
  box-shadow: 0 0 0 3px var(--color-route-brand-alt-tint-12);
}

/* bundled from styles/admin/event-summary-actions.css */
@media (prefers-reduced-motion: reduce) {
  .rental-wheel-option {
    transition: none;
  }
}

.rental-date-warning {
  margin: -2px 0 0;
  color: var(--color-rental-date-warning-text);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

@media (max-width: 1023px) {
  .rental-time-tool-grid {
    grid-template-columns: 1fr;
  }
}

.modal-form-grid {
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(210px, 0.7fr) minmax(360px, 1.15fr) minmax(250px, 0.85fr);
  gap: var(--space-event-summary-grid-gap);
  align-items: start;
}

.modal-form-grid .project-context-card.is-active-step,
.modal-form-grid .time-range-card.is-active-step {
  grid-column: 1 / -1;
  max-width: 760px;
}

.modal-form-grid .resource-picker-compact.is-active-step {
  grid-column: span 2;
}

.time-range-card,
.project-context-card {
  border: 1px solid var(--rental-neutral-border);
  border-radius: var(--radius-3);
  background: var(--rental-neutral-soft);
  padding: var(--space-event-summary-card-padding);
  transition:
    border-color var(--motion-base) var(--motion-ease),
    background-color var(--motion-base) var(--motion-ease);
}

.resource-picker-compact {
  border: 1px solid var(--rental-neutral-border);
  border-radius: var(--radius-3);
  background: var(--rental-neutral-soft);
  padding: var(--space-event-summary-card-padding);
  transition:
    border-color var(--motion-base) var(--motion-ease),
    background-color var(--motion-base) var(--motion-ease);
}

.rental-chapter {
  display: grid;
  gap: 10px;
  transition:
    border-color var(--motion-base) var(--motion-ease),
    background-color var(--motion-base) var(--motion-ease);
}

.chapter-toggle {
  width: 100%;
  border: 0;
  border-radius: var(--radius-3);
  background: transparent;
  color: inherit;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  text-align: left;
  cursor: pointer;
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease);
}

.chapter-toggle strong {
  display: block;
  margin-top: 2px;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.25;
}

.chapter-chevron {
  width: 10px;
  height: 10px;
  border-right: 2px solid var(--muted);
  border-bottom: 2px solid var(--muted);
  transform: rotate(45deg);
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    transform var(--motion-base) var(--motion-ease);
  flex: 0 0 auto;
}

.rental-chapter.is-open .chapter-chevron {
  transform: rotate(225deg);
}

.chapter-summary {
  border: 1px solid var(--rental-neutral-border);
  border-radius: var(--radius-3);
  background: var(--rental-neutral-surface);
  color: var(--body);
  padding: 9px 10px;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  line-height: 1.35;
  transition:
    border-color var(--motion-base) var(--motion-ease),
    background-color var(--motion-base) var(--motion-ease),
    box-shadow var(--motion-base) var(--motion-ease);
}

.chapter-summary:hover {
  box-shadow: var(--shadow-chapter-summary-hover);
}

.rental-chapter.is-open .chapter-summary {
  display: none;
}

.rental-chapter.is-closed .chapter-body {
  display: none;
}

.rental-chapter.is-open .chapter-body {
  animation: chapterBodyIn var(--motion-base) var(--motion-ease);
}

.picker-count {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.date-time-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.date-time-grid[hidden],
.is-wheel-backing-inputs[hidden] {
  display: none !important;
}

.date-time-grid .selected-date-inline {
  margin-bottom: 0;
}

.rental-date-input-control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 40px;
  gap: 8px;
  align-items: center;
}

.rental-date-input-control .input {
  min-width: 0;
}

.date-picker-icon-button {
  width: 40px;
  min-width: 40px;
  height: 40px;
  border: 1px solid var(--rental-neutral-border);
  border-radius: var(--radius-3);
  background: var(--surface);
  color: var(--primary);
  display: inline-grid;
  place-items: center;
  cursor: pointer;
}

.date-picker-icon-button:hover {
  border-color: var(--color-route-brand-tint-34);
  background: var(--color-brand-tint-bg);
}

.date-picker-icon-button.rental-wheel-calendar-button {
  width: var(--control-height-filter);
  min-width: var(--control-height-filter);
  height: var(--control-height-filter);
}

.time-select {
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--muted) 50%),
    linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position:
    calc(100% - 16px) 50%,
    calc(100% - 11px) 50%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
}

.time-help {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: var(--font-size-md);
  line-height: 1.45;
}

.modal-submit-column {
  display: grid;
  gap: 10px;
}

.project-first-empty-state {
  border: 1px dashed var(--hairline-strong);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  color: var(--body);
  padding: 14px;
  display: grid;
  gap: 4px;
}

.project-first-empty-state strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
  line-height: 1.25;
}

.project-first-empty-state span {
  color: var(--muted);
  font-size: var(--font-size-md);
  line-height: 1.35;
}

.side-project-first-empty {
  margin-top: 2px;
}

.modal-submit-column .selection-summary {
  max-height: 142px;
  overflow: auto;
}

.modal-submit-column.is-project-gated .checkbox-line,
.modal-submit-column.is-project-gated #rentalSubmitButton {
  display: none;
}

.day-detail-mode-bar {
  padding: 10px 16px;
  border-bottom: 1px solid var(--hairline);
  display: flex;
  justify-content: flex-end;
}

.day-detail-mode-switch {
  width: fit-content;
}

.day-detail-mode-switch .segmented-button {
  min-height: var(--control-height-filter);
}

.day-timeline {
  min-height: 0;
  overflow: auto;
  display: grid;
  gap: 10px;
  padding: 14px 16px;
}

.day-timeline.is-time-map {
  display: block;
}

.modal-day-schedule {
  min-width: min(520px, 100%);
}

.time-row {
  display: grid;
  grid-template-columns: 118px minmax(0, 1fr);
  gap: 12px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 12px;
}

.time-row.is-empty {
  background: var(--surface-muted);
}

.time-row-time {
  color: var(--ku-crimson-dark);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  line-height: 1.35;
}

.time-row-body {
  display: grid;
  gap: 9px;
  min-width: 0;
}

.event-resource-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.event-resource-list span {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--body);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  padding: 5px 8px;
}

.event-summary-body {
  display: grid;
  gap: 12px;
  min-height: 0;
  overflow: auto;
  padding: 14px 16px 16px;
}

.event-summary-hero {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 12px;
  display: grid;
  gap: 6px;
}

.event-summary-period {
  display: grid;
  gap: 6px;
  min-width: 0;
  color: var(--ink);
  font-size: var(--font-size-title-sm);
  line-height: 1.25;
  font-weight: var(--font-weight-medium);
  overflow: hidden;
}

.period-row {
  display: flex;
  align-items: center;
  gap: 7px;
  min-width: 0;
  white-space: nowrap;
}

.period-date {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.period-time {
  flex: 0 0 auto;
  min-width: 0;
  font-variant-numeric: tabular-nums;
  text-align: left;
}

.period-separator {
  flex: 0 0 auto;
  color: var(--color-event-summary-period-muted-text);
  font-weight: var(--font-weight-medium);
}

.period-label {
  flex: 0 0 auto;
  color: var(--color-event-summary-period-label-text);
  font-size: 0.64em;
  font-weight: var(--font-weight-strong);
  line-height: 1;
  transform: translateY(1px);
}

.event-summary-period .weekday {
  display: inline;
  padding: 0;
  margin: 0;
  color: var(--color-event-summary-weekday-text);
  font-size: 1em;
  font-weight: inherit;
  letter-spacing: 0;
  text-align: inherit;
  vertical-align: baseline;
}

.event-summary-period .weekday.is-sat {
  color: var(--color-event-summary-weekday-saturday-text);
}

.event-summary-period .weekday.is-sun {
  color: var(--color-event-summary-weekday-sunday-text);
}

.photo-status-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.photo-status-row,
.event-summary-section {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: var(--space-event-summary-section-padding);
}

.photo-status-row {
  display: flex;
  min-width: 0;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  min-height: 52px;
}

.photo-status-row > span:first-child,
.event-summary-section h3 {
  margin: 0 0 4px;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.photo-status-row > span:first-child {
  margin: 0;
}

.photo-status-chip {
  min-width: 54px;
}

.event-summary-section {
  display: grid;
  gap: 7px;
}

.event-summary-section p,
.event-summary-empty {
  margin: 0;
  color: var(--body);
  font-size: var(--font-size-md);
  line-height: 1.45;
}

.event-summary-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
}

.event-summary-danger-zone,
.event-summary-main-actions,
.schedule-edit-save-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.event-summary-main-actions {
  justify-content: flex-end;
}

.event-summary-danger-zone .danger-button,
.rental-detail-delete-button,
.schedule-edit-delete-button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.memo-panel {
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-height: 42px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 10px;
}

.memo-panel.is-hidden,
.memo-input.is-hidden,
.memo-readonly.is-hidden {
  display: none;
}

.memo-label {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--muted);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
}

.memo-panel.is-editing .memo-label {
  color: var(--primary);
}

.memo-label::after {
  content: "|";
  color: var(--color-event-summary-period-muted-text);
  font-weight: var(--font-weight-medium);
}

.memo-input {
  width: 100%;
  min-width: 0;
  border: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-medium);
  outline: none;
}

.memo-readonly {
  margin: 0;
  min-width: 0;
  overflow: hidden;
  color: var(--body);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-medium);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.modal-actions {
  padding: 12px 16px;
  border-top: 1px solid var(--hairline);
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

@media (max-width: 520px) {
  .auth-route-map,
  .auth-guide-carousel {
    min-height: auto;
  }

  .auth-guide-slide {
    min-height: 250px;
  }

  .day-detail-mode-bar {
    justify-content: stretch;
  }

  .day-detail-mode-switch {
    width: 100%;
  }

  .day-detail-mode-switch .segmented-button {
    flex: 1;
    padding: 0 8px;
  }

  .event-summary-actions {
    justify-content: stretch;
  }

  .event-summary-danger-zone,
  .event-summary-main-actions {
    width: 100%;
  }

  .event-summary-actions .secondary-button,
  .event-summary-actions .primary-button,
  .event-summary-actions .ui-action-button {
    flex: 1 1 140px;
  }
}

@media (max-width: 1023px) {
  .modal-form-grid {
    grid-template-columns: 240px minmax(320px, 1fr);
  }

  .modal-submit-column {
    grid-column: 1 / -1;
  }
}

@media (min-width: 521px) and (max-width: 1023px) {
  .modal-form-grid .rental-chapter.is-closed .chapter-body {
    display: block;
  }

  .modal-form-grid .rental-chapter.is-closed .chapter-summary {
    display: none;
  }
}

@media (max-width: 1023px) {
  .calendar-stage {
    width: calc(100vw - 16px);
    max-width: 100%;
    height: 100%;
    padding-bottom: 0;
  }

  .floating-create-button {
    right: 18px;
    bottom: 18px;
    width: 50px;
    height: 50px;
  }

  .calendar-modal {
    align-items: end;
    padding: 10px;
  }

  .calendar-modal-panel {
    width: 100%;
    max-height: calc(100dvh - 26px);
  }

  .event-summary-panel {
    width: min(560px, calc(100vw - 44px));
    justify-self: center;
  }

  .project-modal-panel {
    width: min(620px, 100%);
    justify-self: center;
  }

  .modal-form-grid,
  .time-row {
    grid-template-columns: 1fr;
  }

  .compact-resource-list {
    max-height: 210px;
  }
}

@media (max-width: 520px) {
  .date-time-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px) {
  .rental-record .record-card-header {
    grid-template-columns: 1fr;
    row-gap: 6px;
  }

  .rental-record .status-chip {
    justify-self: start;
  }

  .calendar-stage {
    width: calc(100vw - 12px);
    max-width: calc(100vw - 12px);
    height: 100%;
  }

  .modal-header {
    align-items: flex-start;
    flex-direction: row;
  }

  .modal-header .icon-button {
    width: 44px;
    min-width: 44px;
    height: 44px;
    flex: 0 0 44px;
    align-self: flex-start;
  }

  .modal-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .modal-actions .primary-button,
  .modal-actions .secondary-button {
    width: 100%;
  }
}

/* bundled from styles/admin/shared.auth.css */
/*
 * ADMIN AUTH OWNER CSS CONTRACT
 * Contract-only file: auth selectors are owned by ../auth.css and
 * ../auth.responsive.css. Do not add .auth-* rules to admin modal files.
 */

/* bundled from styles/admin/shared.calendar.css */
/*
 * ADMIN CALENDAR OWNER CSS CONTRACT
 * Calendar split-pane compatibility imports live here until the file is moved
 * into routes/calendar ownership.
 */
/* bundled from styles/admin/calendar-split-pane.css */
/* Calendar split-pane iteration: desktop keeps month grid and selected-day workbench side by side. */
/* bundled from styles/admin/calendar-split-pane.profile.css */
/*
 * ADMIN CALENDAR SPLIT PANE OWNER CSS CONTRACT: calendar-split-pane.profile.css
 * Ordered chunk split from calendar-split-pane.css. Preserve import order.
 */
.visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.profile-area {
  position: relative;
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 8px;
}

.profile-pill {
  appearance: none;
}

.profile-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 220px;
  z-index: 60;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-3);
  background: var(--surface);
  box-shadow: 0 18px 44px var(--color-route-shadow-admin);
  padding: 8px;
  display: grid;
  gap: 4px;
}

.profile-menu:not(.is-hidden) {
  animation: sheetIn var(--motion-base) var(--motion-ease);
}

.profile-menu.is-hidden {
  display: none;
}

.profile-menu-heading {
  padding: 8px 8px 10px;
  border-bottom: 1px solid var(--hairline);
  display: grid;
  gap: 2px;
}

.profile-menu-heading strong {
  color: var(--ink);
  font-size: 14px;
}

.profile-menu-heading span {
  color: var(--muted);
  font-size: 12px;
}

.profile-menu button {
  border: 0;
  border-radius: var(--radius-control-small);
  background: transparent;
  min-height: 36px;
  padding: 0 9px;
  text-align: left;
  color: var(--ink);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
  transition:
    background-color var(--motion-fast) var(--motion-ease),
    color var(--motion-fast) var(--motion-ease);
}

.profile-menu button:hover {
  background: var(--ku-crimson-soft);
}

.calendar-stage {
  padding-bottom: 0;
}

.split-toolbar {
  min-height: 64px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
}

.toolbar-left {
  flex-wrap: nowrap;
}

.calendar-content-split {
  flex: 1;
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(var(--calendar-main-min-width), 1fr) 8px minmax(var(--calendar-side-panel-min-width), var(--calendar-side-panel-width));
  gap: 0;
}

.calendar-main-column {
  min-width: 0;
  min-height: 0;
  overflow: hidden;
}

.calendar-side-resizer {
  min-width: 8px;
  border-left: 1px solid var(--hairline);
  border-right: 1px solid var(--hairline);
  background: linear-gradient(90deg, var(--color-route-surface-neutral-25), var(--color-neutral-0));
  cursor: col-resize;
  touch-action: none;
  position: relative;
}

.calendar-side-resizer::after {
  content: "";
  position: absolute;
  inset: 50% auto auto 50%;
  width: 2px;
  height: var(--control-height-small);
  border-radius: var(--radius-pill);
  background: var(--hairline-strong);
  transform: translate(-50%, -50%);
}

.calendar-side-resizer:hover::after,
.is-resizing-calendar-panel .calendar-side-resizer::after {
  background: var(--primary);
}

.is-resizing-calendar-panel {
  cursor: col-resize;
  user-select: none;
}

.calendar-content-split .calendar-surface {
  height: 100%;
}

.calendar-content-split .calendar-weekdays,
.calendar-content-split .calendar-grid {
  grid-template-columns: repeat(7, minmax(64px, 1fr));
}

.calendar-surface.is-swipe-dragging {
  cursor: grabbing;
}

.calendar-surface.is-swipe-dragging .calendar-swipe-track,
.calendar-surface.is-swipe-canceling .calendar-swipe-track {
  will-change: transform;
}

.calendar-surface.is-swipe-dragging .calendar-swipe-track {
  transition: none;
}

.calendar-surface.is-swipe-canceling .calendar-swipe-track {
  transition: transform 190ms var(--motion-ease);
}

.calendar-surface.is-swipe-committing-next .calendar-swipe-track,
.calendar-surface.is-swipe-committing-prev .calendar-swipe-track {
  transition: transform 190ms var(--motion-ease);
  will-change: transform;
}

.calendar-surface.is-swipe-committing-next .calendar-swipe-track {
  transform: translateX(-66.666667%);
}

.calendar-surface.is-swipe-committing-prev .calendar-swipe-track {
  transform: translateX(0);
}

.calendar-surface.is-month-transitioning .calendar-weekdays,
.calendar-surface.is-month-transitioning .calendar-swipe-pane.is-current .calendar-grid {
  animation: monthGridIn var(--motion-base) var(--motion-ease);
}

.calendar-surface.month-direction-prev.is-month-transitioning .calendar-weekdays,
.calendar-surface.month-direction-prev.is-month-transitioning .calendar-swipe-pane.is-current .calendar-grid {
  animation-name: monthGridInPrev;
}

.calendar-surface.is-today-jump .calendar-weekdays,
.calendar-surface.is-today-jump .calendar-swipe-pane.is-current .calendar-grid {
  animation: todayJumpGridIn 260ms var(--motion-ease);
}

.calendar-surface.is-today-jump .day-cell.is-today .day-number {
  animation: todayCellPulse var(--motion-calendar-pulse) var(--motion-ease);
}

.calendar-side-panel {
  min-width: 0;
  min-height: 0;
  overflow: auto;
  background: var(--color-route-surface-warm);
  display: flex;
  flex-direction: column;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

.calendar-side-panel::-webkit-scrollbar {
  width: var(--scrollbar-size);
}

.calendar-side-panel::-webkit-scrollbar-track {
  background: var(--scrollbar-track);
}

/* bundled from styles/admin/calendar-split-pane.layout.css */
/*
 * ADMIN CALENDAR SPLIT PANE OWNER CSS CONTRACT: calendar-split-pane.layout.css
 * Ordered chunk split from calendar-split-pane.css. Preserve import order.
 */
.calendar-side-panel::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: var(--radius-pill);
}

.side-panel-header {
  padding: 10px 14px;
  border-bottom: 1px solid var(--hairline);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.side-panel-header > div:first-child {
  min-width: 0;
}

.side-panel-header h2 {
  margin: 0;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.side-header-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}

.side-panel-summary {
  min-height: 42px;
  padding: 9px 14px;
  border-bottom: 1px solid var(--hairline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.side-panel-modebar {
  min-height: 58px;
  padding-top: 0;
  padding-bottom: 0;
  align-items: center;
}

.side-panel-modebar > span {
  min-height: 58px;
  display: flex;
  align-items: center;
  line-height: 1;
}

.side-panel-modebar > .ui-count-badge {
  min-height: auto;
  padding: 4px 8px;
  color: var(--body);
}

.side-summary-action {
  min-height: var(--control-height-compact);
}

.side-timeline,
.side-rental-form,
.side-time-detail {
  padding: 10px 14px 14px;
  display: grid;
  gap: 10px;
}

.day-schedule {
  --schedule-lane-width: 92px;
  --schedule-lane-gap: 10px;
  --schedule-pad-x: 12px;
  --schedule-pad-y: 10px;
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 10px;
  min-width: 0;
}

.day-schedule-times {
  position: relative;
  height: var(--schedule-height);
  color: var(--muted);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
}

.day-schedule-times span {
  position: absolute;
  left: 0;
  transform: translateY(-0.65em);
}

.day-schedule-times span:nth-child(1) {
  transform: translateY(0);
}

.day-schedule-canvas {
  position: relative;
  min-width: 0;
  height: calc(var(--schedule-height) + (var(--schedule-pad-y) * 2));
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--color-neutral-0) 90%, transparent), var(--color-route-surface-slate-glass)),
    var(--surface);
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

.day-schedule-canvas::-webkit-scrollbar {
  height: var(--scrollbar-size);
}

.day-schedule-canvas::-webkit-scrollbar-track {
  background: var(--scrollbar-track);
}

.day-schedule-canvas::-webkit-scrollbar-thumb {
  border-radius: var(--radius-pill);
  background: var(--scrollbar-thumb);
}

.day-schedule-canvas-inner {
  position: relative;
  width: var(--schedule-scroll-width);
  height: calc(var(--schedule-height) + (var(--schedule-pad-y) * 2));
}

.day-schedule-slot {
  position: absolute;
  top: calc(var(--schedule-pad-y) + var(--slot-top));
  left: 0;
  right: 0;
  height: 1px;
  background: var(--hairline);
}

.schedule-event-block {
  --schedule-block-tone: var(--color-status-active-text);
  --schedule-block-bg: var(--color-status-active-bg);
  position: absolute;
  top: calc(var(--schedule-pad-y) + var(--block-top));
  left: var(--block-left);
  width: var(--block-width);
  min-width: 0;
  height: var(--block-height);
  border: 1px solid color-mix(in srgb, var(--schedule-block-tone) 30%, var(--hairline-strong));
  border-radius: var(--radius-control-small);
  background: color-mix(in srgb, var(--schedule-block-bg) 72%, var(--surface));
  padding: 9px 10px 8px;
  color: var(--ink);
  text-align: left;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    transform var(--motion-fast) var(--motion-ease);
}

.schedule-event-block:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
  z-index: 2;
}

.schedule-event-block:hover {
  transform: translateY(-1px);
  box-shadow: 0 7px 18px var(--color-route-shadow-admin-faint);
}

.schedule-event-block.is-active {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px var(--color-route-brand-tint-12);
}

.schedule-event-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  font-size: 12px;
  font-weight: var(--font-weight-strong);
  line-height: 1.34;
  overflow: hidden;
  text-overflow: ellipsis;
}

.schedule-event-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  color: var(--body);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
  line-height: 1.2;
  white-space: nowrap;
}

.schedule-event-meta span:last-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.schedule-event-dot {
  width: 7px;
  height: 7px;
  border-radius: var(--radius-pill);
  background: var(--schedule-block-tone);
  flex: 0 0 auto;
}

.schedule-event-block.event-approved,
.schedule-event-block.event-reserved {
  --schedule-block-tone: var(--color-status-reserved-text);
  --schedule-block-bg: var(--color-status-reserved-bg);
}

.schedule-event-block.event-extension_approval_needed {
  --schedule-block-tone: var(--color-status-approval-text);
  --schedule-block-bg: var(--color-status-approval-bg);
}

.schedule-event-block.event-checkout_photo_needed {
  --schedule-block-tone: var(--color-status-checkout-text);
  --schedule-block-bg: var(--color-status-checkout-bg);
}

.schedule-event-block.event-checked_out {
  --schedule-block-tone: var(--color-status-active-text);
  --schedule-block-bg: var(--color-status-active-bg);
}

.schedule-event-block.event-return_photo_needed {
  --schedule-block-tone: var(--color-status-return-text);
  --schedule-block-bg: var(--color-status-return-bg);
}

.schedule-event-block.event-returned,
.schedule-event-block.event-cancelled {
  --schedule-block-tone: var(--color-status-neutral-text);
  --schedule-block-bg: var(--color-status-neutral-bg);
}

.side-event-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 10px;
  display: grid;
  gap: 9px;
  cursor: pointer;
}

.side-event-card.is-empty {
  background: var(--surface-muted);
  cursor: default;
}

.side-event-time {
  color: var(--primary);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
}

/* bundled from styles/admin/calendar-split-pane.side-panel.css */
/*
 * ADMIN CALENDAR SPLIT PANE OWNER CSS CONTRACT: calendar-split-pane.side-panel.css
 * Ordered chunk split from calendar-split-pane.css. Preserve import order.
 */
.time-detail-row {
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr);
  gap: 10px;
  align-items: stretch;
}

.time-detail-clock {
  border-left: 3px solid var(--primary);
  padding-left: 8px;
  display: grid;
  align-content: start;
  gap: 2px;
}

.time-detail-clock strong {
  color: var(--ink);
  font-size: 14px;
  line-height: 1.1;
}

.time-detail-clock span {
  color: var(--muted);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
}

.time-detail-body {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 10px;
  min-width: 0;
}

.time-detail-body.has-overlap {
  background: var(--color-bg-subtle);
}

.time-overlap-note {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding-bottom: 8px;
  margin-bottom: 8px;
  border-bottom: 1px solid var(--hairline);
  color: var(--muted);
  font-size: 11px;
  font-weight: var(--font-weight-strong);
}

.time-overlap-note strong {
  color: var(--ink);
}

.time-detail-event-grid {
  display: grid;
  grid-template-columns: repeat(var(--time-lane-count, 1), minmax(128px, 1fr));
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 2px;
}

.time-detail-event-card {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.time-detail-body.has-overlap .time-detail-event-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 9px;
}

.time-detail-card-time {
  color: var(--primary);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.time-detail-row.is-empty .time-detail-clock {
  border-left-color: var(--hairline-strong);
}

.time-detail-row.is-empty .time-detail-body {
  background: var(--surface-muted);
}

.event-card-actions,
.side-edit-actions {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}

.event-card-actions {
  justify-content: flex-end;
}

.side-event-primary-actions {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-left: auto;
}

.schedule-edit-panel-actions {
  justify-content: space-between;
}

.schedule-edit-danger-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.permission-chip {
  border-radius: var(--radius-pill);
  background: var(--color-route-surface-neutral-50);
  color: var(--muted);
  padding: 6px 8px;
  font-size: 11px;
  font-weight: var(--font-weight-strong);
}

.side-edit-form {
  padding: 10px 14px 14px;
  display: grid;
  gap: 10px;
}

.schedule-edit-step-indicator {
  width: 100%;
}

.schedule-edit-step-indicator .rental-step-chip {
  appearance: none;
  cursor: pointer;
}

.schedule-edit-step-panel {
  display: grid;
  gap: 10px;
}

.permission-note {
  border: 1px solid var(--color-route-border-pink-200);
  border-radius: var(--radius-3);
  background: var(--color-bg-subtle);
  padding: 10px;
  display: grid;
  gap: 4px;
}

.permission-note strong {
  color: var(--ink);
  font-size: 13px;
}

.permission-note span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.permission-note.compact-note {
  background: var(--color-state-orange-50);
  border-color: var(--color-state-orange-200);
}

.event-resource-list {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 8px;
}

.event-resource-list span {
  border-radius: var(--radius-pill);
  background: var(--surface-muted);
  color: var(--body);
  padding: 4px 7px;
  font-size: 11px;
  font-weight: var(--font-weight-strong);
}

.schedule-edit-selected-project,
.schedule-edit-review-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 10px;
  display: grid;
  gap: 4px;
}

.schedule-edit-selected-project {
  display: grid;
  min-height: var(--control-height-compact);
  border-color: var(--color-route-neutral-tint-10);
  background: var(--color-route-surface-frosted);
  padding: 5px 8px;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.schedule-edit-review-card dt {
  color: var(--muted);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.schedule-edit-selected-project strong,
.schedule-edit-review-card strong,
.schedule-edit-review-card dd {
  color: var(--ink);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
}

.schedule-edit-selected-project strong {
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

/* bundled from styles/admin/calendar-split-pane.responsive.css */
/*
 * ADMIN CALENDAR SPLIT PANE OWNER CSS CONTRACT: calendar-split-pane.responsive.css
 * Ordered chunk split from calendar-split-pane.css. Preserve import order.
 */
.schedule-edit-review-card dl {
  margin: 4px 0 0;
  display: grid;
  gap: 7px;
}

.schedule-edit-review-card div {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 8px;
}

.schedule-edit-review-card dt,
.schedule-edit-review-card dd {
  margin: 0;
}

.schedule-edit-resource-summary-lines {
  display: grid;
  gap: 2px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.schedule-edit-resource-summary-line {
  display: block;
  line-height: 1.35;
}

.side-form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.side-project-context,
.project-context-card {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 12px;
  display: grid;
  gap: 10px;
}

.side-project-context > div:first-child,
.project-context-heading {
  display: grid;
  gap: 4px;
}

.side-project-context strong,
.project-context-heading strong {
  color: var(--ink);
  font-size: var(--font-size-lg);
  line-height: 1.25;
}

.side-project-context span,
.project-context-heading span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.project-choice-list {
  display: grid;
  gap: 8px;
  max-height: 188px;
  overflow-y: auto;
  padding-right: 2px;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

.project-choice-list::-webkit-scrollbar {
  width: var(--scrollbar-size);
}

.project-choice-list::-webkit-scrollbar-track {
  background: var(--scrollbar-track);
}

.project-choice-list::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: var(--radius-pill);
}

.project-choice-row {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-route-surface-white);
  color: var(--ink);
  min-height: 42px;
  padding: 8px 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 18px;
  align-items: center;
  gap: 8px;
  text-align: left;
  cursor: pointer;
}

.project-choice-row span {
  min-width: 0;
  display: grid;
}

.project-choice-row strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.project-choice-row i,
.project-choice-row svg {
  width: 18px;
  height: 18px;
  color: var(--muted);
}

.project-choice-row:hover,
.project-choice-row:focus-visible {
  border-color: var(--color-route-brand-alt-tint-42);
  outline: none;
}

.project-choice-row.is-selected {
  border-color: var(--available);
  background: var(--color-route-surface-white);
}

.project-choice-row.is-selected i,
.project-choice-row.is-selected svg {
  color: var(--available);
}

.project-choice-empty {
  border: 1px dashed var(--hairline);
  border-radius: var(--radius-3);
  background: var(--color-route-surface-white);
  padding: 10px;
  display: grid;
  gap: 4px;
}

.project-context-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.project-next-button {
  grid-column: 1 / -1;
}

.side-note {
  border: 1px solid var(--color-state-orange-200);
  border-radius: var(--radius-3);
  background: var(--color-state-orange-50);
  color: var(--color-route-text-orange-800);
  padding: 9px 10px;
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.side-resource-list {
  display: grid;
  gap: 8px;
  max-height: 240px;
  overflow: auto;
}

.side-resource-option {
  width: 100%;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  padding: 8px;
  display: grid;
  grid-template-columns: 58px 1fr;
  gap: 8px;
  align-items: center;
  text-align: left;
}

.side-resource-option.is-selected {
  border-color: var(--primary);
  background: var(--ku-crimson-soft);
}

.side-resource-option.is-blocked:not(.is-selected) {
  opacity: 0.72;
}

.side-resource-option:disabled,
.side-resource-option.is-disabled {
  cursor: not-allowed;
  border-style: dashed;
  background: var(--color-route-surface-neutral-50);
  color: var(--muted);
  opacity: 0.56;
}

.side-resource-option:disabled strong,
.side-resource-option.is-disabled strong {
  color: var(--muted);
}

.side-resource-option span {
  display: grid;
  gap: 3px;
}

.side-resource-option strong {
  color: var(--ink);
  font-size: 13px;
}

.side-resource-option small {
  color: var(--muted);
  font-size: 11px;
}

/* bundled from styles/admin/approvals.css */
/*
 * Admin approvals route.
 * Uses shared admin list-board and inspector primitives, then scopes layout-only
 * adjustments to the rental schedule approval route.
 */
.workspace.is-admin-shell [data-panel="admin-approvals"] .admin-workspace {
  min-height: 0;
  gap: 0;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .page-heading {
  display: none;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .admin-approval-board {
  min-height: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 0;
  overflow: visible;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .admin-approval-grid {
  min-width: 0;
  min-height: 0;
  padding: 0;
  grid-template-columns: minmax(0, 1fr);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .admin-approval-workstation {
  min-width: 0;
  min-height: 0;
  --admin-workstation-gap: var(--space-panel-gap-md);
  --admin-workstation-columns: minmax(620px, 1fr) minmax(340px, 420px);
  --admin-workstation-height: clamp(520px, calc(100dvh - 160px), 760px);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-list-board {
  min-height: 0;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-list-toolbar {
  gap: 0;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-list-toolbar .admin-list-title {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-panel-gap-sm);
  align-items: start;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-count-pill {
  white-space: nowrap;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-list-toolbar .admin-list-title h2 {
  margin: 0;
  font-size: var(--font-size-2xl);
  line-height: 1.25;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-list-head {
  min-height: var(--control-height-search);
  padding: 0 14px;
  border-bottom: 1px solid var(--hairline);
  background: var(--color-bg-subtle);
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-emphasis);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-list {
  display: grid;
  min-height: 0;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-empty {
  grid-template-columns: minmax(0, 1fr);
  min-height: 188px;
  margin: 12px 14px;
  align-content: center;
  justify-items: center;
  text-align: center;
  border-color: var(--color-route-border-pink-100);
  border-style: dashed;
  background: var(--color-route-surface-pink-75);
  gap: var(--space-panel-gap-sm);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-empty strong {
  font-size: var(--font-size-lg);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-empty-refresh {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-empty-refresh svg {
  width: 15px;
  height: 15px;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-row {
  min-width: 0;
  min-height: 58px;
  width: 100%;
  border: 0;
  border-bottom: 1px solid var(--hairline);
  background: transparent;
  color: inherit;
  padding: 9px 14px;
  text-align: left;
  cursor: pointer;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-row:hover,
.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-row.is-active {
  background: var(--color-bg-subtle);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-row-main {
  min-width: 0;
  display: inline-grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: var(--space-panel-gap-sm);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-icon {
  width: var(--control-size-icon-sm);
  height: var(--control-size-icon-sm);
  border: 1px solid var(--color-state-warning-border);
  border-radius: var(--radius-panel);
  background: var(--color-state-orange-50);
  color: var(--color-state-warning-text);
  display: grid;
  place-items: center;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-icon svg {
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
  stroke-width: 2.2;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-copy {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-copy strong {
  min-width: 0;
  overflow: hidden;
  color: var(--ink);
  font-size: var(--font-size-lg);
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-copy small,
.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-row-duration {
  min-width: 0;
  overflow: hidden;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-list-footer {
  padding: 0 14px;
  color: var(--muted);
  font-size: var(--font-size-sm);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-inspector {
  min-width: 0;
  min-height: 0;
  align-self: start;
  display: grid;
  grid-template-rows: auto auto auto;
  overflow: visible;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-inspector.is-empty {
  place-items: center;
  padding: 18px;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-inspector-empty {
  width: min(100%, 300px);
  min-height: 168px;
  align-content: center;
  justify-items: center;
  text-align: center;
  border-color: var(--color-route-border-pink-100);
  border-style: dashed;
  background: var(--color-route-surface-pink-75);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-inspector-head {
  min-width: 0;
  border-bottom: 1px solid var(--hairline);
  padding: var(--space-4);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-panel-gap-sm);
  align-items: start;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-inspector-head h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.25;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-inspector-body {
  min-height: 0;
  overflow: visible;
  padding: 14px 16px;
  display: grid;
  align-content: start;
  gap: var(--space-panel-gap-md);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-reason {
  margin: 0;
  border: 1px solid var(--color-route-border-pink-200);
  border-radius: var(--radius-panel);
  background: var(--color-bg-subtle);
  color: var(--primary);
  padding: 9px 11px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-emphasis);
  line-height: 1.45;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-facts {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-route-surface-white);
  overflow: hidden;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-facts div {
  min-width: 0;
  padding: 10px 12px;
  border-right: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  display: grid;
  gap: var(--space-1);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-facts div:nth-child(2n) {
  border-right: 0;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-facts div.is-wide {
  grid-column: 1 / -1;
  border-right: 0;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-facts div:last-child {
  border-bottom: 0;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-facts dt {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-emphasis);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-facts dd {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-emphasis);
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-review-note {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface-muted);
  padding: var(--space-3);
  display: grid;
  gap: var(--space-2);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-review-note > strong {
  color: var(--ink);
  font-size: var(--font-size-md);
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-review-list {
  display: grid;
  gap: 6px;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-review-list span {
  min-width: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.35;
}

.workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-actions {
  min-height: 0;
  border-top: 0;
  padding: 0 16px 16px;
  justify-content: flex-end;
}

@media (min-width: 1024px) {
  body:has([data-panel="admin-approvals"].is-visible) .workspace.is-admin-shell {
    height: calc(100dvh - var(--topbar-height-desktop));
    min-height: 0;
    align-items: stretch;
    overflow: hidden;
  }

  body:has([data-panel="admin-approvals"].is-visible) .workspace.is-admin-shell .admin-desktop-sidebar {
    height: 100%;
    min-height: 0;
  }

  body:has([data-panel="admin-approvals"].is-visible) .workspace.is-admin-shell [data-panel="admin-approvals"].compact-view {
    display: contents;
  }

  body:has([data-panel="admin-approvals"].is-visible) .workspace.is-admin-shell [data-panel="admin-approvals"].compact-view.is-visible > .admin-workspace {
    grid-column: 2;
    width: 100%;
    max-width: none;
    min-width: 0;
    height: 100%;
    min-height: 0;
    overflow: hidden;
  }

  body:has([data-panel="admin-approvals"].is-visible) .workspace.is-admin-shell [data-panel="admin-approvals"] .admin-workspace,
  body:has([data-panel="admin-approvals"].is-visible) .workspace.is-admin-shell [data-panel="admin-approvals"] .admin-approval-board,
  body:has([data-panel="admin-approvals"].is-visible) .workspace.is-admin-shell [data-panel="admin-approvals"] .admin-approval-grid,
  body:has([data-panel="admin-approvals"].is-visible) .workspace.is-admin-shell [data-panel="admin-approvals"] .admin-approval-workstation {
    height: 100%;
    min-height: 0;
    overflow: hidden;
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .admin-approval-grid {
    height: 100%;
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .admin-approval-workstation {
    height: var(--admin-workstation-height);
  }

  body:has([data-panel="admin-approvals"].is-visible) .workspace.is-admin-shell [data-panel="admin-approvals"] .admin-approval-workstation {
    height: var(--admin-workstation-height);
  }
}

@media (max-width: 1023px) {
  .workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-facts {
    grid-template-columns: 1fr;
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-facts div {
    border-right: 0;
    border-bottom: 1px solid var(--hairline);
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-facts div:last-child {
    border-bottom: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-list-head {
    display: none;
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-row {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: var(--space-2);
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-row-duration {
    grid-column: 1;
    padding-left: 44px;
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-status-chip {
    justify-self: end;
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-inspector {
    min-height: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-inspector-head {
    grid-template-columns: 1fr;
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-inspector-body {
    overflow: visible;
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-actions {
    align-items: stretch;
    justify-content: stretch;
  }

  .workspace.is-admin-shell [data-panel="admin-approvals"] .approval-request-actions button {
    flex: 1 1 100%;
  }
}

/* bundled from styles/admin/equipment.css */
/*
 * ADMIN ROUTE CSS CONTRACT: equipment
 * Admin equipment route CSS belongs here.
 */
/* bundled from styles/admin/equipment-polish.css */
/*
 * ADMIN EQUIPMENT POLISH CSS CONTRACT
 * Equipment admin responsive and production-density adjustments.
 */
@media (min-width: 1024px) {
  .photo-upload-mobile-shell {
    display: none;
  }
}

@media (max-width: 1023px) {
  body:has([data-panel="admin-equipment"].is-visible) .equipment-admin-table {
    overflow-x: clip;
  }

  body:has([data-panel="admin-equipment"].is-visible) .equipment-admin-table-head,
  body:has([data-panel="admin-equipment"].is-visible) .equipment-admin-list.admin-queue-list {
    display: none;
  }

  body:has([data-panel="admin-equipment"].is-visible) .equipment-admin-mobile-list {
    padding: 10px;
    display: grid;
    gap: var(--space-2);
  }
}

@media (min-width: 1024px) {
  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-grid {
    min-height: 0;
    height: calc(100dvh - var(--header-height, 72px) - 34px);
    grid-template-columns: minmax(640px, 1fr) minmax(300px, 360px);
    align-items: stretch;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-inspector {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto 1fr;
    gap: 10px;
    overflow: auto;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-board {
    min-height: 0;
    display: grid;
    grid-template-rows: minmax(0, 1fr);
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-table {
    height: 100%;
    min-height: 0;
    grid-template-rows: auto minmax(0, 1fr) auto;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-list {
    max-height: none;
    min-height: 0;
    overflow: visible;
  }
}

/* Admin equipment production polish: keep the workstation dense and aligned. */
@media (min-width: 1024px) {
  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-toolbar {
    padding: 10px 12px 0;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-toolbar-main {
    grid-template-columns: minmax(0, 1fr) 38px;
    gap: 10px;
    margin-bottom: 10px;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .admin-search-pill {
    min-height: var(--control-height-search);
    border-radius: var(--radius-control-small);
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-filter-toggle {
    width: var(--control-size-icon-md);
    min-width: var(--control-size-icon-md);
    min-height: var(--control-height-search);
    border-color: var(--color-route-neutral-line);
    background: var(--color-bg-subtle);
    color: var(--primary);
    box-shadow: none;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-filter-toggle:hover,
  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-filter-toggle[aria-pressed="true"] {
    border-color: var(--color-admin-filter-selected-border);
    background: var(--color-route-surface-white);
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-filterbar {
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-panel);
    background: var(--color-bg-subtle);
    overflow: hidden;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-category-tabs,
  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-status-tabs {
    display: flex;
    flex-wrap: nowrap;
    gap: var(--space-2);
    min-width: 0;
    padding: 10px;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-category-tabs::-webkit-scrollbar,
  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-status-tabs::-webkit-scrollbar {
    display: none;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-status-tabs {
    border-top: 1px solid var(--hairline);
    border-left: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-category-tab,
  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-status-tab {
    flex: 0 0 auto;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-table-head,
  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-row {
    grid-template-columns: var(--admin-list-columns, minmax(300px, 1fr) 96px 60px 112px);
    gap: 14px;
    align-items: center;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-table-head {
    padding: 10px 24px;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-table-head span:not(:first-child) {
    width: fit-content;
    justify-self: center;
    text-align: center;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-list {
    max-height: none;
    min-height: 0;
    padding: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-row {
    min-height: 72px;
    padding: 8px 24px;
    border-radius: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-row .equipment-admin-item {
    grid-template-columns: 50px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-row .equipment-thumb {
    width: 50px;
    height: 50px;
    min-width: 50px;
    min-height: 50px;
    padding: var(--space-1);
    align-self: center;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-compact-main {
    gap: 2px;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-number,
  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-status-chip,
  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-category-badge {
    justify-self: center;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-summary-content .equipment-thumb {
    width: 100%;
    height: auto;
    min-width: 0;
    min-height: 0;
    aspect-ratio: 4 / 3;
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-summary-content .equipment-thumb.no-photo {
    background: var(--color-route-surface-neutral-25);
    color: var(--color-route-text-muted-700);
  }

  .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-summary-content .equipment-thumb.no-photo svg {
    width: 28px;
    height: 28px;
    opacity: 0.64;
  }
}

.equipment-edit-stepper {
  gap: 0;
  align-items: center;
}

.equipment-edit-step-chip {
  position: relative;
  min-width: 0;
  padding: 0 10px;
}

.equipment-edit-step-chip + .equipment-edit-step-chip::before {
  content: "";
  width: var(--control-height-small);
  height: 1px;
  margin-right: 10px;
  background: var(--color-route-neutral-line);
}

/* Equipment board mock parity: keep the approved board shape stable on desktop. */
@media (min-width: 1024px) {
  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .admin-workspace,
  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .admin-section {
    height: auto;
    min-height: 0;
    overflow: visible;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-grid {
    width: 100%;
    max-width: 1158px;
    margin-inline: auto;
    min-height: 0;
    height: clamp(520px, calc(100dvh - 160px), 760px);
    grid-template-columns: minmax(0, 794px) minmax(300px, 340px);
    gap: var(--space-4);
    align-items: stretch;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-board,
  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-inspector {
    height: clamp(520px, calc(100dvh - 160px), 760px);
    min-height: 0;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-panel);
    background: var(--surface);
    overflow: hidden;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-board {
    display: grid;
    grid-template-rows: minmax(0, 1fr);
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-table {
    height: 100%;
    min-height: 0;
    grid-template-rows: auto minmax(0, 1fr) 48px;
    border: 0;
    border-radius: var(--radius-panel);
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-toolbar {
    display: grid;
    gap: 10px;
    padding: 16px 18px 14px;
    border-bottom: 1px solid var(--hairline);
    background: var(--surface);
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-toolbar-main {
    grid-template-columns: minmax(0, 1fr) 42px;
    gap: 10px;
    margin: 0;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .admin-search-pill,
  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-filter-toggle {
    min-height: 42px;
    border-radius: var(--radius-panel);
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-filter-toggle {
    width: 42px;
    min-width: 42px;
    background: var(--color-bg-subtle);
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-filterbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--space-2);
    border: 0;
    border-radius: 0;
    background: transparent;
    overflow: visible;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-category-tabs,
  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-status-tabs {
    display: flex;
    gap: var(--space-2);
    min-width: 0;
    padding: 0;
    border: 0;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-category-tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    padding-block: 5px;
    scrollbar-width: none;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-category-tabs::-webkit-scrollbar {
    display: none;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-status-tabs {
    flex-wrap: wrap;
    overflow: visible;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-category-tab,
  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-status-tab {
    min-height: var(--control-height-compact);
    flex: 0 0 auto;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .ui-filter-chip-count {
    min-width: 0;
    margin-left: 2px;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-table-head,
  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-row {
    grid-template-columns: var(--admin-list-columns, minmax(300px, 1fr) 96px 60px 112px);
    gap: 14px;
    align-items: center;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-table-head {
    min-height: var(--control-height-small);
    padding: 8px 14px;
    background: var(--color-bg-subtle);
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-table-head span:not(:first-child) {
    justify-self: center;
    text-align: center;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .admin-list-scroll-root {
    height: 100%;
    max-height: 100%;
    min-height: 0;
    overflow-y: auto;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-list {
    min-height: 0;
    max-height: none;
    padding: 0;
    gap: 0;
    overflow: visible;
    background: var(--surface);
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-row {
    min-height: 68px;
    padding: 10px 14px;
    border: 0;
    border-radius: 0;
    border-bottom: 1px solid var(--hairline);
    box-shadow: none;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-row.is-active {
    background: var(--ku-crimson-soft);
    box-shadow: inset 3px 0 0 var(--primary);
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-row .equipment-thumb {
    display: none;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-row .equipment-admin-item {
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
    align-items: center;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-main {
    min-width: 0;
    display: grid;
    gap: 0;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-main strong {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-category-badge {
    min-width: 0;
    border: 0;
    background: transparent;
    color: var(--ink);
    padding: 0;
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-medium);
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-admin-footer {
    min-height: 48px;
    padding: 10px 18px;
    border-top: 1px solid var(--hairline);
    background: var(--surface);
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-inspector {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto 1fr;
    gap: var(--space-2);
    padding: 14px;
    overflow: auto;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-management-card {
    gap: 10px;
  }

  body:has([data-panel="admin-equipment"].is-visible) .workspace.is-admin-shell [data-panel="admin-equipment"] .equipment-management-card p {
    line-height: 1.4;
  }
}

.equipment-edit-step-chip span {
  flex: 0 0 30px;
}

.photo-control {
  grid-template-columns: minmax(0, 1fr);
  align-items: center;
  gap: 10px;
}

.photo-preview {
  width: min(100%, 520px);
  justify-self: center;
}

.photo-actions {
  width: min(100%, 520px);
  justify-self: center;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.category-table-head,
.category-row {
  grid-template-columns: minmax(180px, 1fr) 88px 132px;
  gap: var(--space-3);
}

.category-table-head span:nth-child(2),
.category-table-head span:nth-child(3),
.category-row strong,
.category-row-actions {
  justify-self: center;
  text-align: center;
}

.category-row-actions {
  width: 132px;
  justify-content: center;
}

/* bundled from styles/admin/equipment.desktop.css */
/*
 * ADMIN DESKTOP ROUTE CSS CONTRACT: equipment
 *
 * Desktop-only admin equipment workstation CSS belongs here.
 */

/* bundled from styles/admin/equipment.mobile.css */
/*
 * ADMIN MOBILE ROUTE CSS CONTRACT: equipment
 *
 * Mobile-only admin equipment CSS belongs here.
 */

/* bundled from styles/admin/photos.desktop.css */
/*
 * ADMIN DESKTOP ROUTE CSS CONTRACT: photos
 *
 * Desktop-only admin photo upload CSS belongs here.
 */

@media (min-width: 1024px) {
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-workstation {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    gap: 0;
    min-height: 0;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--surface);
    overflow: hidden;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-workstation-toolbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    border: 0;
    border-bottom: 1px solid var(--hairline);
    border-radius: 0;
    margin-bottom: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-workstation-toolbar .admin-search-pill {
    grid-column: 1;
    min-width: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-refresh-button {
    grid-column: 2;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-review-shell {
    border: 0;
    border-radius: 0;
    height: min(640px, calc(100dvh - 292px));
    min-height: 480px;
    display: grid;
    grid-template-columns: minmax(300px, 340px) minmax(0, 1fr);
    align-items: stretch;
    overflow: hidden;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-review-list-board {
    min-width: 0;
    min-height: 0;
    border: 0;
    border-right: 1px solid var(--hairline);
    border-radius: 0;
    background: var(--color-bg-subtle);
    overflow: hidden;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-review-list-body,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-review-scroll {
    min-height: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-review-list-board .admin-photo-queue {
    border: 0;
    border-right: 0;
    border-radius: 0;
    background: transparent;
    overflow: visible;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-queue,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-inspector-body {
    min-height: 0;
    overflow-y: auto;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-inspector {
    min-width: 0;
    min-height: 0;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    overflow: hidden;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-inspector-head {
    display: grid;
    gap: 14px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-panel {
    display: grid;
    gap: 12px;
    align-content: start;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-summary {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 16px;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--surface);
    padding: 14px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-primary {
    display: grid;
    gap: 6px;
    min-width: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-label,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts dt {
    color: var(--muted);
    font-size: 11px;
    font-weight: var(--font-weight-strong);
    line-height: 1.35;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-title {
    color: var(--ink);
    font-size: 16px;
    font-weight: var(--font-weight-emphasis);
    line-height: 1.35;
    overflow-wrap: anywhere;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-status {
    display: grid;
    justify-items: end;
    gap: 6px;
    min-width: max-content;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--surface);
    overflow: hidden;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts > div {
    display: grid;
    gap: 6px;
    min-width: 0;
    padding: 12px 14px;
    border-right: 1px solid var(--hairline);
    border-bottom: 1px solid var(--hairline);
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts > div:nth-child(2n),
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts > div.is-wide {
    border-right: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts > div:nth-last-child(-n + 1) {
    border-bottom: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts .is-wide {
    grid-column: span 2;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts dd {
    margin: 0;
    color: var(--body);
    font-size: 13px;
    font-weight: var(--font-weight-medium);
    line-height: 1.45;
    overflow-wrap: anywhere;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-summary {
    display: grid;
    gap: 12px;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--surface);
    padding: 14px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-head span,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-captured-list > span {
    color: var(--muted);
    font-size: 11px;
    font-weight: var(--font-weight-strong);
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-head strong {
    color: var(--body);
    font-size: 13px;
    font-weight: var(--font-weight-emphasis);
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-checks,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-captured-list ul {
    display: grid;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-checks {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-checks li,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-captured-list li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    min-width: 0;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-2);
    background: var(--color-bg-subtle);
    padding: 10px 12px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-checks li.is-ready strong {
    color: var(--color-state-success-text);
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-checks span,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-captured-list li span {
    color: var(--muted);
    font-size: 12px;
    font-weight: var(--font-weight-medium);
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-checks strong,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-captured-list li strong {
    color: var(--body);
    font-size: 12px;
    font-weight: var(--font-weight-emphasis);
    overflow-wrap: anywhere;
    text-align: right;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-captured-list {
    display: grid;
    gap: 8px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-summary.is-empty p {
    margin: 0;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.5;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-note {
    display: grid;
    gap: 6px;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--color-bg-subtle);
    padding: 12px 14px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-note strong,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-note p {
    margin: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-note strong {
    color: var(--body);
    font-size: 12px;
    font-weight: var(--font-weight-emphasis);
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-note p {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.5;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-gallery {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    align-content: start;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-tile {
    aspect-ratio: 1 / 1;
    min-height: 0;
    width: 100%;
    padding: 0;
    overflow: hidden;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-tile .admin-photo-visual {
    width: 100%;
    height: 100%;
    border-radius: inherit;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-decision-bar {
    border-top: 1px solid var(--border-subtle);
    justify-content: flex-end;
    padding: 14px 0 0;
  }
}

/* bundled from styles/admin/photos.mobile.css */
/*
 * ADMIN MOBILE ROUTE CSS CONTRACT: photos
 *
 * Mobile-only admin photo upload CSS belongs here.
 */

@media (max-width: 1023px) {
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-workstation {
    display: grid;
    gap: 14px;
    min-width: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-workstation-toolbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-review-shell,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-inspector {
    display: grid;
    grid-template-columns: 1fr;
    min-width: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-review-list-board {
    height: auto;
    max-height: 360px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-review-scroll {
    max-height: 360px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-queue {
    max-height: 360px;
    overflow-y: auto;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-review-list-board .admin-photo-queue {
    max-height: none;
    overflow: visible;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-inspector {
    overflow: visible;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-inspector-head,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-inspector-body {
    min-width: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-panel {
    display: grid;
    gap: 12px;
    min-width: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-summary {
    display: grid;
    gap: 12px;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--surface);
    padding: 14px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-primary,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-status {
    display: grid;
    justify-items: start;
    gap: 6px;
    min-width: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-label,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts dt {
    color: var(--muted);
    font-size: 11px;
    font-weight: var(--font-weight-strong);
    line-height: 1.35;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-title {
    color: var(--ink);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-emphasis);
    line-height: 1.35;
    overflow-wrap: anywhere;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts {
    display: grid;
    grid-template-columns: 1fr;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--surface);
    overflow: hidden;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts > div {
    display: grid;
    gap: 6px;
    min-width: 0;
    padding: 12px 14px;
    border-bottom: 1px solid var(--hairline);
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts > div:last-child {
    border-bottom: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-facts dd {
    margin: 0;
    color: var(--body);
    font-size: 13px;
    font-weight: var(--font-weight-medium);
    line-height: 1.45;
    overflow-wrap: anywhere;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-summary {
    display: grid;
    gap: 12px;
    min-width: 0;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--surface);
    padding: 14px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-head span,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-captured-list > span {
    color: var(--muted);
    font-size: 11px;
    font-weight: var(--font-weight-strong);
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-head strong {
    color: var(--body);
    font-size: 13px;
    font-weight: var(--font-weight-emphasis);
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-checks,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-captured-list ul {
    display: grid;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-checks li,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-captured-list li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    min-width: 0;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-2);
    background: var(--color-bg-subtle);
    padding: 10px 12px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-checks li.is-ready strong {
    color: var(--color-state-success-text);
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-checks span,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-captured-list li span {
    color: var(--muted);
    font-size: 12px;
    font-weight: var(--font-weight-medium);
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-checks strong,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-captured-list li strong {
    color: var(--body);
    font-size: 12px;
    font-weight: var(--font-weight-emphasis);
    overflow-wrap: anywhere;
    text-align: right;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-captured-list {
    display: grid;
    gap: 8px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-evidence-summary.is-empty p {
    margin: 0;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.5;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-note {
    display: grid;
    gap: 6px;
    border: 1px solid var(--hairline);
    border-radius: var(--radius-3);
    background: var(--color-bg-subtle);
    padding: 12px 14px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-note strong,
  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-note p {
    margin: 0;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-note strong {
    color: var(--body);
    font-size: 12px;
    font-weight: var(--font-weight-emphasis);
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-info-note p {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.5;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-gallery {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-tile {
    aspect-ratio: 1 / 1;
    min-height: 0;
    padding: 0;
    overflow: hidden;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-tile .admin-photo-visual {
    width: 100%;
    height: 100%;
    border-radius: inherit;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-decision-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    border-top: 1px solid var(--border-subtle);
    padding-top: 14px;
  }

  .workspace.is-admin-shell [data-panel="admin-photos"] .admin-photo-decision-bar button {
    flex: 1 1 100%;
  }
}

/* bundled from styles/admin/signup.css */
/* Admin signup approval route. Keep signup-specific layout out of app.js and shared admin.css. */
.workspace.is-admin-shell [data-panel="admin-signup"] .page-heading,
.workspace.is-admin-shell [data-panel="admin-signup"] .admin-section-heading {
  display: none;
}

.workspace.is-admin-shell [data-panel="admin-signup"].compact-view,
.workspace.is-admin-shell [data-panel="admin-signup"] .admin-workspace,
.workspace.is-admin-shell [data-panel="admin-signup"] .admin-section,
.workspace.is-admin-shell [data-panel="admin-signup"] .member-admin-grid {
  min-height: 0;
  height: 100%;
}

.workspace.is-admin-shell [data-panel="admin-signup"].compact-view.is-visible {
  display: contents;
}

.workspace.is-admin-shell [data-panel="admin-signup"].compact-view.is-visible > .admin-workspace {
  grid-column: 2;
  width: 100%;
  max-width: none;
  min-width: 0;
}

.workspace.is-admin-shell [data-panel="admin-signup"] .admin-section {
  border: 0;
  background: transparent;
  padding: 0;
}

.workspace.is-admin-shell [data-panel="admin-signup"] .member-admin-grid {
  display: block;
}

.signup-approval-page {
  height: clamp(520px, calc(100dvh - 160px), 760px);
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(620px, 1fr) minmax(320px, 390px);
  gap: 14px;
  align-items: stretch;
}

.signup-detail-panel,
.signup-table-card {
  border: 1px solid var(--hairline);
  background: var(--surface);
  box-shadow: var(--shadow-soft);
}

.signup-main-panel {
  min-width: 0;
  min-height: 0;
  display: grid;
  grid-template-rows: minmax(0, 1fr);
  border: 0;
  border-radius: 0;
  padding: 0;
  background: transparent;
  box-shadow: none;
  overflow: hidden;
}

.signup-table-card {
  height: 100%;
  min-height: 0;
  border-radius: var(--radius-3);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  overflow: hidden;
}

.signup-table-toolbar {
  border-radius: 0;
  border-width: 0 0 1px;
  border-bottom: 1px solid var(--hairline);
}

.signup-table-toolbar-main {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.signup-search-pill {
  border-color: var(--hairline);
  color: var(--body);
}

.signup-search-pill .field-icon,
.signup-search-pill svg {
  width: 16px;
  height: 16px;
}

.signup-search-pill input {
  color: var(--ink);
  font-size: 13px;
  font-weight: var(--font-weight-medium);
}

.signup-filter-actions {
  justify-content: flex-end;
}

.signup-filter-actions .is-active {
  border-color: var(--ku-crimson);
  color: var(--ku-crimson);
  background: var(--color-state-danger-bg);
}

.signup-refresh-button {
  width: var(--control-size-icon-md);
  min-width: var(--control-size-icon-md);
  min-height: var(--control-height-search);
  padding: 0;
  display: inline-grid;
  place-items: center;
}

.signup-refresh-button svg {
  width: 16px;
  height: 16px;
  stroke-width: 2.3;
}

.signup-table-head,
.signup-table-row {
  display: grid;
  grid-template-columns: var(--admin-list-columns, minmax(230px, 1fr) 150px 112px);
  column-gap: 18px;
  row-gap: 8px;
  align-items: center;
}

.signup-table-head {
  padding: 10px 12px;
  color: var(--body);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
  border-bottom: 1px solid var(--hairline);
  background: var(--surface);
}

.signup-table-body {
  min-height: 0;
  overflow: visible;
}

.signup-table-row {
  width: 100%;
  min-height: 72px;
  border: 0;
  border-bottom: 1px solid var(--hairline);
  background: transparent;
  color: inherit;
  padding: 12px;
  text-align: left;
  font: inherit;
  cursor: pointer;
}

.signup-table-row:hover,
.signup-table-row.is-active {
  background: var(--color-state-red-75);
}

.signup-table-row.is-active {
  box-shadow: inset 3px 0 0 var(--ku-crimson);
}

.signup-user-cell strong,
.signup-user-cell small {
  display: block;
}

.signup-user-cell {
  min-width: 0;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.signup-user-copy {
  min-width: 0;
}

.signup-mini-avatar {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-pill);
  display: grid;
  place-items: center;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-strong);
}

.signup-mini-red {
  background: var(--color-state-red-50);
  color: var(--ku-crimson);
}

.signup-mini-blue {
  background: var(--color-state-info-bg);
  color: var(--color-state-blue-700);
}

.signup-mini-green {
  background: var(--color-state-green-100);
  color: var(--color-state-success-text);
}

.signup-user-cell strong {
  color: var(--ink);
  font-size: 14px;
  font-weight: var(--font-weight-strong);
}

.signup-user-cell small,
.signup-date-cell {
  color: var(--body);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
}

.signup-date-cell {
  white-space: nowrap;
  justify-self: center;
  text-align: center;
}

.signup-table-head span:nth-child(2),
.signup-table-head span:nth-child(3),
.signup-state-cell {
  justify-self: center;
}

.signup-detail-panel {
  min-width: 0;
  min-height: 0;
  height: 100%;
  border-radius: var(--radius-3);
  display: grid;
  grid-template-rows: auto auto auto auto;
  align-content: start;
  overflow: hidden;
}

.signup-detail-panel.is-empty {
  place-items: center;
  padding: 24px;
  text-align: center;
  color: var(--body);
}

.signup-detail-head {
  min-height: 64px;
  border-bottom: 1px solid var(--hairline);
  padding: 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.signup-detail-head strong {
  color: var(--ink);
  font-size: 18px;
  font-weight: var(--font-weight-strong);
}

.signup-detail-fields {
  margin: 0;
  padding: 18px;
  display: grid;
  gap: 12px;
}

.signup-detail-fields div {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.signup-detail-fields dt,
.signup-detail-fields dd {
  margin: 0;
  font-size: 13px;
  line-height: 1.35;
}

.signup-detail-fields dt {
  color: var(--muted);
  font-weight: var(--font-weight-emphasis);
}

.signup-detail-fields dd {
  color: var(--ink);
  font-weight: var(--font-weight-strong);
  overflow-wrap: anywhere;
}

.signup-check-card {
  margin: 0 18px 18px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  display: grid;
  overflow: hidden;
}

.signup-check-list {
  display: grid;
}

.signup-check-row {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 11px;
  align-items: center;
  padding: 12px 14px;
  border-bottom: 1px solid var(--hairline);
  color: var(--ink);
  font-size: 13px;
  font-weight: var(--font-weight-emphasis);
}

.signup-check-row:last-child {
  border-bottom: 0;
}

.signup-check-row.is-warning,
.signup-check-row.is-danger {
  align-items: start;
}

.signup-check-mark {
  width: 18px;
  height: 18px;
  border-radius: var(--radius-pill);
  display: grid;
  place-items: center;
  font-size: 11px;
  font-weight: var(--font-weight-strong);
}

.signup-check-row.is-warning .signup-check-mark,
.signup-check-row.is-danger .signup-check-mark {
  margin-top: 1px;
}

.signup-check-row.is-ok .signup-check-mark {
  border: 1px solid var(--color-state-success-border);
  background: var(--color-state-success-bg);
  color: var(--color-state-success-text);
}

.signup-check-row.is-warning .signup-check-mark {
  border: 1px solid var(--color-state-warning-border);
  background: var(--color-state-warning-bg);
  color: var(--color-state-warning-text);
}

.signup-check-row.is-danger .signup-check-mark {
  border: 1px solid var(--color-state-danger-border);
  background: var(--color-state-danger-bg);
  color: var(--danger);
}

.signup-check-copy {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.signup-check-copy strong {
  color: var(--ink);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
  line-height: 1.25;
}

.signup-check-copy small {
  color: var(--body);
  font-size: 12px;
  font-weight: var(--font-weight-strong);
  line-height: 1.35;
  text-align: left;
}

.signup-detail-actions {
  padding: 0 18px 18px;
  display: grid;
  gap: 10px;
  align-self: start;
  grid-auto-rows: 44px;
}

.signup-detail-actions .compact {
  width: 100%;
  min-height: 44px;
  height: 44px;
}

.signup-empty-row {
  margin: 12px;
}

.signup-detail-empty {
  height: 100%;
  place-content: center;
}

.signup-table-footer {
  min-height: 56px;
  padding: 14px 16px;
  border-top: 1px solid var(--hairline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--body);
  font-size: 13px;
  font-weight: var(--font-weight-emphasis);
}

.signup-table-footer strong {
  color: var(--ink);
  font-size: 13px;
  font-weight: var(--font-weight-strong);
}

@media (max-width: 1023px) {
  .signup-approval-page {
    height: auto;
    min-height: 0;
    grid-template-columns: 1fr;
  }

  .signup-table-toolbar-main,
  .signup-table-head,
  .signup-table-row {
    grid-template-columns: 1fr;
  }

  .signup-filter-actions {
    justify-content: flex-start;
    flex-wrap: wrap;
  }

  .signup-table-footer {
    align-items: flex-start;
    flex-direction: column;
  }
}

/* bundled from styles/admin/archive.css */
/*
 * ADMIN ROUTE CSS CONTRACT: archive
 *
 * Admin archive route CSS belongs here. Add archive-only rules here instead of
 * broad admin stylesheets.
 */

.archive-workbench {
  min-height: 0;
  height: 100%;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 12px;
}

body:has([data-panel="archive"].is-visible) {
  overflow: hidden;
}

body:has([data-panel="archive"].is-visible) .app-shell {
  min-height: 100dvh;
  height: 100dvh;
  overflow: hidden;
}

body:has([data-panel="archive"].is-visible) .workspace {
  flex: 0 0 calc(100dvh - var(--topbar-height-desktop));
  min-height: 0;
  height: calc(100dvh - var(--topbar-height-desktop));
  max-height: calc(100dvh - var(--topbar-height-desktop));
  overflow: hidden;
}

body:has([data-panel="archive"].is-visible) .workspace.is-admin-shell {
  align-items: stretch;
}

[data-panel="archive"].compact-view.is-visible {
  min-height: 0;
  height: 100%;
  max-height: 100%;
  overflow: hidden;
  grid-template-rows: auto minmax(0, 1fr);
}

.archive-workbench-table-panel,
.archive-workbench-detail {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
}

.archive-workbench-toolbar {
  padding: 0;
  display: grid;
  grid-template-columns: 156px 156px minmax(360px, 1fr);
  gap: 8px;
  align-items: center;
}

.archive-workbench-field,
.archive-workbench-query {
  min-width: 0;
}

.archive-workbench-query {
  justify-self: stretch;
  min-height: var(--control-height-filter);
}

.archive-workbench-field input {
  width: 100%;
  min-width: 0;
  height: var(--control-height-filter);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-2);
  background: var(--surface);
  color: var(--ink);
  padding: 0 9px;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
}

.archive-workbench-tabs {
  padding: 0;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}

.archive-workbench-tab {
  min-width: 0;
  min-height: 48px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  color: var(--ink);
  padding: 8px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font: inherit;
  font-weight: var(--font-weight-emphasis);
  cursor: pointer;
}

.archive-workbench-tab span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.archive-workbench-tab strong {
  color: var(--primary);
  font-size: var(--font-size-md);
}

.archive-workbench-tab.is-active {
  border-color: var(--primary);
  background: color-mix(in srgb, var(--primary) 6%, var(--color-route-surface-white));
  color: var(--primary);
}

.archive-readiness-metrics span {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 9px;
  display: grid;
  gap: 3px;
}

.archive-readiness-metrics small {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
}

.archive-readiness-metrics strong {
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.1;
}

.archive-workbench-layout {
  min-height: 0;
  height: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  gap: 12px;
  align-items: stretch;
}

.archive-workbench-table-panel,
.archive-workbench-detail {
  min-width: 0;
  min-height: 0;
  padding: 14px;
  display: grid;
  gap: 12px;
  overflow: hidden;
}

.archive-workbench-table-panel {
  --archive-workbench-row-height: var(--control-height-filter);
  --archive-workbench-head-height: var(--control-height-filter);
  grid-template-rows: auto minmax(0, 1fr) auto;
}

.archive-workbench-panel-head {
  min-width: 0;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

.archive-workbench-panel-controls {
  min-width: 180px;
  margin-left: auto;
}

.archive-workbench-panel-controls select {
  width: 100%;
  height: var(--control-height-filter);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-2);
  background: var(--surface);
  color: var(--ink);
  padding: 0 8px;
  font: inherit;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.archive-workbench-panel-head h2,
.archive-workbench-panel-head h3,
.archive-workbench-readiness h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.2;
}

.archive-workbench-panel-head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: var(--font-size-md);
}

.archive-workbench-table-scroll {
  min-height: 0;
  height: 100%;
  max-height: none;
  overflow-x: auto;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
}

.archive-workbench-footer {
  min-height: 36px;
  display: grid;
  grid-template-columns: minmax(96px, 1fr) auto minmax(132px, 1fr);
  gap: 8px;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.archive-workbench-pagination {
  min-width: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.archive-workbench-pagination-pages {
  min-width: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
}

.archive-workbench-pagination button {
  min-width: var(--control-height-compact);
  height: var(--control-height-compact);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  color: var(--ink);
  font: inherit;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-emphasis);
  padding: 0 8px;
  cursor: pointer;
}

.archive-workbench-pagination button:disabled {
  color: var(--muted);
  cursor: not-allowed;
  opacity: 0.5;
}

.archive-workbench-pagination button.is-active {
  border-color: var(--primary);
  background: color-mix(in srgb, var(--primary) 8%, var(--color-route-surface-white));
  color: var(--primary);
}

.archive-workbench-pagination-status,
.archive-workbench-pagination-gap {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-emphasis);
  line-height: var(--control-height-compact);
}

.archive-workbench-pagination-status {
  justify-self: end;
  min-width: 38px;
  text-align: right;
}

.archive-workbench-table {
  width: max(100%, 720px);
  border-collapse: collapse;
  table-layout: fixed;
}

.archive-workbench-table th,
.archive-workbench-table td {
  min-width: 0;
  height: var(--archive-workbench-row-height);
  border-bottom: 1px solid var(--hairline);
  padding: 5px 8px;
  text-align: left;
  vertical-align: middle;
  line-height: 1.15;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.archive-workbench-table tbody tr {
  height: var(--archive-workbench-row-height);
}

.archive-workbench-table tbody tr[data-archive-workbench-record-id] {
  cursor: pointer;
}

.archive-workbench-table tbody tr[data-archive-workbench-record-id]:hover {
  background: color-mix(in srgb, var(--primary) 4%, var(--color-route-surface-white));
}

.archive-workbench-table tbody tr[data-archive-workbench-record-id] td {
  user-select: none;
}

.archive-workbench-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--surface);
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-emphasis);
  height: var(--archive-workbench-head-height);
}

.archive-workbench-table td strong {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.archive-workbench-table tr.is-active {
  background: color-mix(in srgb, var(--primary) 6%, var(--color-route-surface-white));
  box-shadow: inset 4px 0 0 var(--primary);
}

.archive-workbench-detail {
  height: 100%;
  max-height: none;
  overflow: auto;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
}

.archive-workbench-detail-grid {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.archive-workbench-detail-grid div {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 9px;
}

.archive-workbench-detail-grid dt {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
}

.archive-workbench-detail-grid dd {
  margin: 3px 0 0;
  color: var(--ink);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  overflow-wrap: anywhere;
}

.archive-workbench-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.archive-workbench-readiness {
  border-top: 1px solid var(--hairline);
  padding-top: 12px;
  display: grid;
  gap: 10px;
}

.archive-readiness-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.archive-workbench-modal {
  position: fixed;
  inset: 0;
  z-index: 170;
  display: grid;
  place-items: center;
  padding: 24px;
}

.archive-workbench-modal-backdrop {
  position: fixed;
  inset: 0;
  border: 0;
  background: var(--color-route-overlay-modal);
  cursor: pointer;
}

.archive-workbench-modal-panel {
  position: relative;
  z-index: 1;
  width: min(760px, calc(100vw - 48px));
  max-height: min(720px, calc(100vh - 64px));
  overflow: hidden;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface);
  box-shadow: 0 24px 60px var(--color-route-shadow-modal-strong);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}

.archive-workbench-modal-head {
  border-bottom: 1px solid var(--hairline);
  padding: 14px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.archive-workbench-modal-head h2 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-2xl);
  line-height: 1.2;
}

.archive-workbench-modal-head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: var(--font-size-md);
}

.archive-workbench-modal-json {
  max-height: none;
  margin: 14px;
  overflow: auto;
}

.archive-subtype-list {
  min-height: 0;
  overflow: auto;
  padding: 14px;
  display: grid;
  gap: 8px;
}

.archive-subtype-item {
  min-width: 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-3);
  background: var(--surface-muted);
  padding: 10px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: start;
}

.archive-subtype-item strong,
.archive-subtype-item span {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.archive-subtype-item span {
  margin-top: 3px;
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
}

.archive-subtype-item p {
  grid-column: 1 / -1;
  margin: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.45;
}

.archive-raw-json {
  max-height: 180px;
  overflow: auto;
  border: 1px solid var(--color-route-slate-700);
  border-radius: var(--radius-3);
  background: var(--color-route-slate-950);
  color: var(--color-route-text-slate-200);
  padding: 10px;
  font-size: var(--font-size-xs);
  line-height: 1.45;
  white-space: pre-wrap;
}

.status-chip.status-archive-verified {
  background: var(--color-state-success-bg);
  color: var(--color-state-success-text);
}

.status-chip.status-archive-waiting {
  background: var(--color-state-orange-50);
  color: var(--color-route-text-orange-750);
}

.status-chip.status-archive-retain {
  background: var(--color-state-purple-50);
  color: var(--color-route-text-indigo-700);
}

.status-chip.status-archive-deleted {
  background: var(--color-route-surface-slate-100);
  color: var(--color-route-text-slate-700);
}

.archive-empty-state {
  color: var(--muted);
  padding: 14px;
  display: grid;
  gap: 4px;
}

.archive-empty-state strong {
  color: var(--ink);
}

.archive-raw-json,
.archive-subtype-list,
.archive-workbench-table-scroll,
.archive-workbench-detail {
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

.archive-raw-json,
.archive-subtype-list {
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
}


/* bundled from styles/equipment-picker.css */
.side-equipment-picker {
  min-height: 0;
  display: grid;
  gap: 10px;
}

.side-equipment-filter-box,
.side-equipment-resource-section,
.side-equipment-recommend-section,
.side-equipment-selected-tray {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-route-surface-white);
}

.side-equipment-filter-box {
  padding: var(--space-2);
  display: grid;
  gap: var(--space-2);
}

.side-equipment-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 36px 36px;
  gap: 6px;
}

.side-equipment-search {
  min-width: 0;
  min-height: 36px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-panel);
  background: var(--surface);
  display: grid;
  grid-template-columns: 15px minmax(0, 1fr);
  color: var(--muted);
  align-items: center;
  gap: 7px;
  padding: 0 10px;
  transition:
    border-color var(--motion-fast) var(--motion-ease),
    box-shadow var(--motion-fast) var(--motion-ease),
    background-color var(--motion-fast) var(--motion-ease);
}

.side-equipment-search:focus-within {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--color-route-brand-tint-16);
}

.side-equipment-search svg {
  width: 15px;
  height: 15px;
}

.side-equipment-search-input {
  min-width: 0;
  border: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: var(--font-size-sm);
  outline: 0;
  padding: 0;
}

.side-equipment-search-input:focus {
  box-shadow: none;
}

.side-equipment-reset-button {
  width: 36px;
  min-height: 36px;
  padding: 0;
  display: inline-grid;
  place-items: center;
}

.side-equipment-size-button {
  width: 36px;
  min-height: 36px;
  padding: 0;
  display: inline-grid;
  place-items: center;
}

.side-equipment-reset-button svg,
.side-equipment-size-button svg {
  width: 14px;
  height: 14px;
}

.side-equipment-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.side-equipment-filter-chip {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-route-surface-white);
  color: var(--ink);
  min-height: var(--control-height-compact);
  padding: 0 10px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
  cursor: pointer;
}

.side-equipment-filter-chip.is-active {
  border-color: var(--primary);
  color: var(--primary);
  background: var(--ku-crimson-soft);
}

.side-equipment-resource-section {
  min-height: 0;
  padding: var(--space-2);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: var(--space-2);
}

.side-equipment-resource-section.is-titleless {
  grid-template-rows: minmax(0, 1fr);
}

.side-equipment-resource-section.is-titleless .side-equipment-resource-list {
  min-height: 0;
  max-height: 190px;
}

.side-equipment-section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.side-equipment-section-title h3 {
  margin: 0;
  color: var(--ink);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-strong);
}

.side-equipment-section-title span {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
}

.side-equipment-resource-list {
  min-height: 168px;
  max-height: min(314px, 38vh);
  overflow-y: auto;
  padding-right: 3px;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

.side-equipment-resource-list::-webkit-scrollbar {
  width: var(--scrollbar-size);
}

.side-equipment-resource-list::-webkit-scrollbar-track {
  background: var(--scrollbar-track);
}

.side-equipment-resource-list::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: var(--radius-pill);
}

.side-equipment-item {
  flex: 0 0 auto;
  min-width: 0;
  min-height: 58px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-route-surface-white);
  overflow: hidden;
}

.side-equipment-item.is-selected {
  border-color: var(--color-route-green-tint-55);
  background: var(--color-state-green-50);
}

.side-equipment-item.is-disabled:not(.is-selected) {
  background: var(--color-bg-app);
}

.side-equipment-item-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 30px;
  gap: 5px;
  align-items: center;
  min-width: 0;
}

.side-equipment-row {
  border: 0;
  border-radius: 0;
  grid-template-columns: 42px minmax(0, 1fr) minmax(66px, auto);
  gap: 7px;
  min-height: 56px;
  min-width: 0;
  overflow: hidden;
  padding: 7px;
}

.side-equipment-row.is-selected {
  border-color: transparent;
  background: transparent;
}

.side-equipment-thumb {
  width: 42px;
  min-width: 42px;
  height: 42px;
  aspect-ratio: 1;
}

.side-equipment-copy {
  min-width: 0;
}

.side-equipment-copy strong,
.side-equipment-copy small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.side-equipment-status {
  justify-self: end;
  align-self: center;
  max-width: 82px;
  border-radius: var(--radius-pill);
  background: var(--color-route-surface-green-100);
  color: var(--color-route-text-green-650);
  padding: 4px 8px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.side-equipment-status.is-selected {
  background: var(--color-route-surface-blue-50);
  color: var(--color-state-blue-700);
}

.side-equipment-status.is-blocked {
  background: var(--color-state-orange-100);
  color: var(--color-state-orange-700);
  max-width: 98px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.side-equipment-info-button {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-route-surface-white);
  color: var(--muted);
  width: var(--control-size-icon-sm);
  min-width: var(--control-size-icon-sm);
  height: var(--control-size-icon-sm);
  min-height: var(--control-height-compact);
  margin: 0 6px 0 0;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-strong);
  cursor: pointer;
}

.side-equipment-info-button:hover,
.side-equipment-info-button:focus-visible,
.side-equipment-info-button[aria-expanded="true"] {
  border-color: var(--primary);
  color: var(--primary);
  outline: none;
}

.side-equipment-detail {
  border-top: 1px solid var(--hairline);
  background: var(--color-route-surface-white);
  padding: 9px 10px;
}

.side-equipment-detail dl {
  margin: 0;
  display: grid;
  gap: 6px;
}

.side-equipment-detail div {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: var(--space-2);
}

.side-equipment-detail dt,
.side-equipment-detail dd {
  margin: 0;
  font-size: var(--font-size-xs);
  line-height: 1.4;
}

.side-equipment-detail dt {
  color: var(--muted);
  font-weight: var(--font-weight-strong);
}

.side-equipment-detail dd {
  color: var(--ink);
  font-weight: var(--font-weight-medium);
}

.side-equipment-recommend-section,
.side-equipment-selected-tray {
  padding: var(--space-2);
  display: grid;
  gap: var(--space-2);
}

.side-equipment-recommend-grid {
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  cursor: grab;
  touch-action: pan-x;
  user-select: none;
}

.side-equipment-recommend-grid::-webkit-scrollbar {
  display: none;
}

.side-equipment-recommend-grid.is-dragging {
  cursor: grabbing;
}

.side-equipment-recommend-wrap {
  position: relative;
  flex: 0 0 118px;
  min-width: 118px;
}

.side-equipment-recommend-button {
  width: 100%;
  min-height: var(--control-height-small);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-route-surface-white);
  color: var(--ink);
  padding: 6px 8px;
  display: grid;
  align-items: center;
  text-align: left;
  cursor: pointer;
}

.side-equipment-recommend-button strong,
.side-equipment-recommend-button span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.side-equipment-recommend-button strong {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.side-equipment-recommend-button span {
  color: var(--muted);
  font-size: 10px;
  font-weight: var(--font-weight-medium);
}

.side-equipment-recommend-wrap.is-active .side-equipment-recommend-button,
.side-equipment-recommend-button:hover,
.side-equipment-recommend-button:focus-visible {
  border-color: var(--primary);
  color: var(--primary);
  background: var(--ku-crimson-soft);
  outline: none;
}

.side-equipment-recommend-wrap.is-pressing .side-equipment-recommend-button {
  box-shadow: inset 0 -3px 0 var(--color-route-brand-alt-tint-32);
}

.side-equipment-recommend-popover {
  position: absolute;
  z-index: 3;
  left: 0;
  bottom: calc(100% + 6px);
  min-width: 188px;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-route-surface-white);
  box-shadow: 0 10px 24px var(--color-route-shadow-picker);
  padding: var(--space-2);
  display: none;
  gap: 3px;
}

.side-equipment-floating-popover {
  position: fixed;
  z-index: 180;
  width: min(220px, calc(100vw - 16px));
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-route-surface-white);
  box-shadow: 0 12px 28px var(--color-route-shadow-picker-strong);
  padding: var(--space-2);
  display: grid;
  gap: 3px;
  pointer-events: none;
}

.side-equipment-floating-popover[hidden] {
  display: none;
}

.side-equipment-floating-popover strong {
  color: var(--ink);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.side-equipment-floating-popover span,
.side-equipment-floating-popover small {
  color: var(--muted);
  font-size: var(--font-size-xs);
  line-height: 1.35;
}

.side-equipment-recommend-popover strong {
  color: var(--ink);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.side-equipment-recommend-popover span,
.side-equipment-recommend-popover small {
  color: var(--muted);
  font-size: var(--font-size-xs);
  line-height: 1.35;
}

.side-equipment-modal {
  z-index: 120;
}

.side-equipment-modal-panel {
  width: min(760px, calc(100vw - 36px));
  grid-template-rows: auto minmax(0, 1fr);
}

.side-equipment-modal-close {
  width: var(--control-size-icon-md);
  min-width: var(--control-size-icon-md);
  height: var(--control-size-icon-md);
  min-height: var(--control-height-search);
}

.side-equipment-modal-close svg {
  width: 17px;
  height: 17px;
}

.side-equipment-modal-header p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.side-equipment-modal-body {
  min-height: 0;
  padding: var(--space-3);
  overflow-y: auto;
  display: grid;
  gap: 10px;
}

.side-equipment-modal .side-equipment-search-row {
  grid-template-columns: minmax(0, 1fr) 36px;
}

.side-equipment-modal .side-equipment-resource-section.is-titleless .side-equipment-resource-list {
  max-height: min(380px, 40vh);
}

.side-equipment-modal .side-equipment-item-main {
  grid-template-columns: minmax(0, 1fr) 34px;
  gap: var(--space-2);
  padding-right: 6px;
}

.side-equipment-modal .side-equipment-row {
  grid-template-columns: 42px minmax(0, 1fr) minmax(72px, max-content);
  padding: 7px 9px;
}

.side-equipment-modal .side-equipment-info-button {
  width: var(--control-size-icon-filter);
  min-width: var(--control-size-icon-filter);
  height: var(--control-size-icon-filter);
  min-height: var(--control-size-icon-filter);
  margin-right: 0;
}

.side-equipment-modal .side-equipment-recommend-grid {
  display: flex;
}

.side-equipment-modal .side-equipment-recommend-wrap {
  flex-basis: 132px;
  min-width: 132px;
}

.side-equipment-modal .side-equipment-selected-tray {
  min-height: 76px;
  align-content: start;
}

.side-equipment-tray-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.side-equipment-tray-chip {
  border: 1px solid var(--color-route-green-tint-42);
  border-radius: var(--radius-pill);
  background: var(--color-state-green-50);
  color: var(--color-route-text-green-650);
  padding: 5px 8px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-strong);
  cursor: pointer;
}

.side-equipment-selected-tray p,
.side-equipment-empty span {
  margin: 0;
  color: var(--muted);
  font-size: var(--font-size-sm);
  line-height: 1.4;
}

.rental-create-review-panel {
  display: grid;
  gap: 10px;
}

.rental-create-review-card {
  background: var(--color-route-surface-white);
}

.rental-create-review-equipment {
  background: var(--color-route-surface-white);
}

.rental-create-review-resource-list {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 6px;
  list-style: none;
}

.rental-create-review-resource-list li {
  border: 1px solid var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--surface-muted);
  padding: var(--space-2);
  display: grid;
  gap: 2px;
}

.rental-create-review-resource-list strong,
.rental-create-review-resource-list span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rental-create-review-resource-list strong {
  color: var(--ink);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-strong);
}

.rental-create-review-resource-list span {
  color: var(--muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
}

.side-equipment-empty {
  border: 1px dashed var(--hairline);
  border-radius: var(--radius-panel);
  background: var(--color-route-surface-white);
  padding: var(--space-3);
  display: grid;
  gap: var(--space-1);
}

.side-equipment-empty strong {
  color: var(--ink);
  font-size: var(--font-size-md);
}
