:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "SF Mono", "Fira Code", "Fira Mono", "Roboto Mono", monospace;--text-xs: .6875rem;--text-sm: .8125rem;--text-base: .875rem;--text-lg: 1rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--gray-50: #FAFAF9;--gray-100: #F5F5F4;--gray-150: #EEEEEC;--gray-200: #E7E5E4;--gray-300: #D6D3D1;--gray-400: #A8A29E;--gray-500: #78716C;--gray-600: #57534E;--gray-700: #44403C;--gray-800: #292524;--gray-900: #1C1917;--gray-950: #0C0A09;--accent-50: #F0FDFA;--accent-100: #CCFBF1;--accent-200: #99F6E4;--accent-300: #5EEAD4;--accent-400: #2DD4BF;--accent-500: #14B8A6;--accent-600: #0D9488;--accent-700: #0F766E;--accent-800: #115E59;--accent-900: #134E4A;--color-booked: #4F6EF7;--color-booked-light: #E8EEFF;--color-booked-text: #2B3F8E;--color-blocked: #A8A29E;--color-blocked-light: #F5F5F4;--color-blocked-text: #57534E;--color-available: transparent;--color-error: #EF4444;--color-error-light: #FEE2E2;--color-success: #22C55E;--color-success-light: #DCFCE7;--label-col-width: 220px;--row-height: 48px;--header-height: 48px;--toolbar-height: 52px;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--border-color: var(--gray-200);--border-subtle: var(--gray-150);--transition-fast: .12s ease;--transition-normal: .18s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--gray-900);background:#f7f7f6;line-height:1.5;min-height:100dvh;letter-spacing:-.006em}#root{min-height:100dvh;display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer;border:none;background:none;font-size:inherit;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit;text-decoration:none}.tabular-nums{font-variant-numeric:tabular-nums}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.timeline-container{flex:1;overflow:hidden;position:relative;min-height:0;display:flex;flex-direction:column;background:linear-gradient(180deg,#fff,#fbfaf8)}.timeline-header-shell{display:flex;flex-shrink:0;min-width:0;position:relative;background:#fffffff5;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid var(--border-color);box-shadow:0 10px 28px #1c19170a}.timeline-header-fixed{width:var(--label-col-width);min-width:var(--label-col-width);flex-shrink:0;border-right:1px solid var(--border-color);background:#fffffffa}.timeline-header-fixed-row{display:flex}.timeline-header-fixed-row-months{height:36px;background:linear-gradient(180deg,#fff,#fbfaf8);border-bottom:1px solid var(--border-color)}.timeline-header-fixed-row-days{height:var(--header-height);align-items:center;padding:0 14px}.timeline-header-scroll{flex:1;min-width:0;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.timeline-header-scroll::-webkit-scrollbar{display:none}.timeline-body-shell{flex:1;min-height:0;display:flex;overflow:hidden}.timeline-property-column{width:var(--label-col-width);min-width:var(--label-col-width);flex-shrink:0;overflow-y:auto;overflow-x:hidden;border-right:1px solid var(--border-color);background:linear-gradient(180deg,#fff,#fbfaf8);scrollbar-width:none}.timeline-property-column::-webkit-scrollbar{display:none}.timeline-property-row{min-height:var(--row-height);border-bottom:1px solid rgba(231,229,228,.9);transition:background var(--transition-fast)}.timeline-property-row.is-hovered{background:#14b8a606}.timeline-body{flex:1;min-height:0;overflow:auto;position:relative}.timeline-header{position:relative;z-index:20;min-width:max-content;background:transparent}.timeline-header-row{display:flex;min-width:max-content}.timeline-header-row-months{height:36px;background:linear-gradient(180deg,#fff,#fbfaf8)}.timeline-header.is-year-view .timeline-header-row-months{height:40px}.timeline-header-row-days{height:var(--header-height)}.timeline-side-label{font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.08em;text-transform:uppercase;color:var(--gray-500)}.timeline-header-months{display:flex;flex:1}.timeline-header-month{display:flex;align-items:flex-end;padding:0 12px 8px;font-size:.9375rem;font-weight:var(--font-semibold);color:var(--gray-800);border-right:1px solid rgba(214,211,209,.68);white-space:nowrap}.timeline-header.is-year-view .timeline-header-month{align-items:center;justify-content:flex-start;padding:0 6px;font-size:.6875rem;letter-spacing:.08em;text-transform:uppercase}.timeline-header-days{display:flex;flex:1}.timeline-header-day{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:5px;height:var(--header-height);padding:6px 0 8px;font-variant-numeric:tabular-nums;border-right:1px solid var(--border-subtle);-webkit-user-select:none;user-select:none;position:relative;background:#ffffffe0}.timeline-header-day.is-weekend{background:#1c191706}.timeline-header-day.is-today{background:linear-gradient(180deg,#14b8a61f,#14b8a608)}.timeline-header-day.is-month-start{border-left:1px solid var(--gray-300)}.timeline-header-day .day-name{font-size:.6875rem;font-weight:var(--font-medium);color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em;line-height:1}.timeline-header-day .day-number{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;font-size:.8125rem;font-weight:var(--font-semibold);color:var(--gray-800);line-height:1}.timeline-header-day.is-today .day-number{color:#fff;background:linear-gradient(135deg,#129f98,#0f766e);box-shadow:0 10px 18px #0f766e33}.timeline-row{display:flex;border-bottom:1px solid rgba(231,229,228,.9);transition:background var(--transition-fast);min-height:var(--row-height)}.timeline-row:hover,.timeline-row.is-hovered{background:#14b8a606}.property-cell{width:100%;min-width:0;min-height:var(--row-height);background:linear-gradient(180deg,#fff,#fcfcfb);display:flex;align-items:center;gap:10px;padding:0 14px;cursor:pointer;transition:background var(--transition-fast)}.property-cell .property-info{min-width:0;flex:1}.property-cell .property-name{font-size:.875rem;font-weight:var(--font-semibold);color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.property-cell .property-meta{font-size:.6875rem;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;margin-top:1px}.property-cell .sync-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 3px #fffffff2}.sync-dot.success{background:var(--color-success)}.sync-dot.error{background:var(--color-error)}.sync-dot.running{background:var(--accent-400);animation:pulse 1.5s infinite}.sync-dot.idle{background:var(--gray-300)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.event-rail{flex:1;position:relative;min-height:var(--row-height);background:linear-gradient(180deg,#ffffffeb,#fcfaf8e6)}.rail-day{position:absolute;top:0;bottom:0;border-right:1px solid rgba(231,229,228,.95)}.rail-day.is-weekend{background:#1c191705}.rail-day.is-today{background:linear-gradient(180deg,#14b8a616,#14b8a606)}.rail-day.is-today:after{content:"";position:absolute;top:0;bottom:0;left:50%;width:2px;transform:translate(-1px);background:#0d948829}.rail-day.is-month-start{border-left:1px solid var(--gray-300)}.event-bar{position:absolute;top:9px;height:30px;border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;gap:6px;padding:0 9px;overflow:hidden;z-index:2;transition:background-color var(--transition-fast),border-color var(--transition-fast);min-width:14px;border:1px solid transparent}.event-bar:hover{z-index:5}.event-bar.is-clipped-start{border-top-left-radius:0;border-bottom-left-radius:0;padding-left:8px}.event-bar.is-clipped-end{border-top-right-radius:0;border-bottom-right-radius:0;padding-right:8px}.event-bar.booked{background:#118b94;color:#fff;border-color:#0f7b83;z-index:4}.event-bar.booked:hover{background:#0f7f87;border-color:#0d7077}.event-bar.blocked{background:#5e5b57;color:#fff;border-color:#514d49;z-index:3}.event-bar.blocked:hover{background:#55514d;border-color:#494643}.event-bar .event-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;background:#ffffffeb}.event-bar .event-dot.booked{background:#fffffff5}.event-bar .event-dot.blocked{background:#ffffffd1}.event-bar .event-label{font-size:.625rem;font-weight:var(--font-semibold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.02em}.toolbar{display:flex;align-items:center;gap:var(--space-3);height:52px;padding:0 20px;border-bottom:1px solid var(--border-color);background:#fff;flex-shrink:0}.toolbar-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--gray-900);letter-spacing:-.02em;margin-right:var(--space-4);white-space:nowrap}.toolbar-group{display:flex;align-items:center;gap:var(--space-2)}.toolbar-separator{width:1px;height:24px;background:var(--border-color);margin:0 var(--space-2)}.toolbar-spacer{flex:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:32px;padding:0 var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn-default{background:#fff;border:1px solid var(--border-color);color:var(--gray-700)}.btn-default:hover{background:var(--gray-50);border-color:var(--gray-300)}.btn-default.active{background:var(--gray-900);border-color:var(--gray-900);color:#fff}.btn-primary{background:var(--gray-900);color:#fff;box-shadow:0 1px 2px #00000026}.btn-primary:hover{background:var(--gray-800);box-shadow:0 1px 3px #0003}.btn-ghost{color:var(--gray-600)}.btn-ghost:hover{background:var(--gray-100);color:var(--gray-900)}.btn-icon{width:32px;padding:0}.search-input{height:34px;padding:0 12px;border:1px solid transparent;border-radius:var(--radius-md);font-size:var(--text-sm);background:var(--gray-100);width:200px;outline:none;transition:all var(--transition-fast);color:var(--gray-900)}.search-input::placeholder{color:var(--gray-400)}.search-input:focus{border-color:var(--gray-300);background:#fff;box-shadow:0 0 0 3px #00000008;width:260px}.zoom-group{display:flex;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.zoom-btn{height:30px;padding:0 var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--gray-600);border-right:1px solid var(--border-color);transition:all var(--transition-fast);font-variant-numeric:tabular-nums}.zoom-btn:last-child{border-right:none}.zoom-btn:hover{background:var(--gray-50)}.zoom-btn.active{background:var(--gray-900);color:#fff}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;z-index:40;animation:fadeIn var(--transition-normal)}.drawer-content{position:fixed;top:0;right:0;bottom:0;width:380px;max-width:100vw;background:#fff;z-index:50;box-shadow:-8px 0 32px #0000001a;display:flex;flex-direction:column;animation:slideIn var(--transition-normal)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(16px);opacity:0}to{transform:translate(0);opacity:1}}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.drawer-header h2{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--gray-900);letter-spacing:-.01em}.drawer-body{flex:1;overflow-y:auto;padding:20px}.drawer-field{margin-bottom:20px}.drawer-field .field-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1)}.drawer-field .field-value{font-size:var(--text-base);color:var(--gray-900)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);height:22px;padding:0 var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium)}.badge-booked{background:var(--color-booked-light);color:var(--color-booked-text)}.badge-blocked{background:var(--color-blocked-light);color:var(--color-blocked-text)}.badge-success{background:var(--color-success-light);color:#166534}.badge-error{background:var(--color-error-light);color:#991b1b}.sync-pill{display:inline-flex;align-items:center;gap:var(--space-2);height:28px;padding:0 var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--gray-600);background:var(--gray-100);white-space:nowrap}.sync-pill .sync-indicator{width:6px;height:6px;border-radius:50%;background:var(--color-success)}.sync-pill.syncing .sync-indicator{background:var(--accent-400);animation:pulse 1.5s infinite}.app-nav{display:flex;align-items:center;gap:2px;height:48px;padding:0 20px;background:var(--gray-950);flex-shrink:0}.app-nav .nav-brand{font-size:.8125rem;font-weight:var(--font-semibold);color:#fff;margin-right:1.25rem;letter-spacing:-.03em;white-space:nowrap}.app-nav .nav-link{height:34px;padding:0 14px;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);color:#ffffff80;display:flex;align-items:center;transition:all var(--transition-fast)}.app-nav .nav-link:hover{color:#ffffffd9;background:#ffffff14}.app-nav .nav-link.active{color:#fff;background:#ffffff1f}.page-container{flex:1;padding:2rem 2.5rem;max-width:960px;margin:0 auto;width:100%}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.page-header h1{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--gray-900);letter-spacing:-.02em}.data-table{width:100%;border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;background:#fff}.data-table table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:10px 16px;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;background:var(--gray-50);border-bottom:1px solid var(--border-color)}.data-table td{padding:12px 16px;font-size:var(--text-sm);color:var(--gray-700);border-bottom:1px solid var(--border-subtle)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--gray-50)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--gray-700);margin-bottom:var(--space-1)}.form-input{width:100%;height:40px;padding:0 12px;border:1px solid var(--gray-200);border-radius:var(--radius-md);font-size:var(--text-sm);background:var(--gray-50);outline:none;transition:all var(--transition-fast);color:var(--gray-900)}.form-input:focus{border-color:var(--gray-400);background:#fff;box-shadow:0 0 0 3px #0000000a}.form-input::placeholder{color:var(--gray-400)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem var(--space-4);text-align:center;color:var(--gray-500)}.empty-state h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--gray-700);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--text-sm);max-width:360px;margin-bottom:var(--space-4)}.onboarding-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;background:#fff;color:var(--gray-500)}.onboarding-empty .onboarding-icon{color:var(--gray-300);margin-bottom:1.5rem}.onboarding-empty h3{font-size:1.25rem;font-weight:var(--font-semibold);color:var(--gray-800);margin-bottom:.5rem;letter-spacing:-.01em}.onboarding-empty p{font-size:var(--text-base);color:var(--gray-500);max-width:340px;line-height:1.6}.quick-jumps{position:relative}.quick-jumps-menu{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:30;min-width:160px;padding:var(--space-1) 0;animation:fadeIn var(--transition-fast)}.quick-jumps-item{display:block;width:100%;text-align:left;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--gray-700);transition:background var(--transition-fast)}.quick-jumps-item:hover{background:var(--gray-50)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:40;display:flex;align-items:center;justify-content:center;animation:fadeIn var(--transition-normal)}.modal-content{background:#fff;border-radius:12px;box-shadow:0 24px 48px #00000029,0 0 0 1px #0000000a;width:480px;max-width:calc(100vw - 32px);max-height:calc(100vh - 64px);overflow-y:auto;animation:modalIn var(--transition-normal)}@keyframes modalIn{0%{transform:scale(.97);opacity:0}to{transform:scale(1);opacity:1}}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--gray-900);letter-spacing:-.01em}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:var(--space-3)}
