:root{--hour-height: 60px;--danwel-color: #0D9488}*{box-sizing:border-box}body.calendar-page{font-family:Figtree,sans-serif;background:#f8f9fa;height:100vh;margin:0;display:flex;flex-direction:column}header{background:#fff;border-bottom:1px solid #e5e7eb}.header-container{max-width:100%;display:flex;justify-content:space-between;align-items:center;height:64px;padding:0 16px}.header-left{display:flex;align-items:center;gap:24px}.logo{font-size:18px;font-weight:600;color:#0d9488;text-decoration:none}.logo:hover{color:#0f766e}.header-nav{display:flex;gap:8px}.header-nav-link{font-size:14px;color:#6b7280;text-decoration:none;padding:8px 12px;border-radius:4px;border-bottom:2px solid transparent}.header-nav-link:hover{color:#374151;background:#f9fafb}.week-nav{display:flex;align-items:center;gap:8px;position:relative}.week-label{font-size:13px;color:#495057;min-width:120px;text-align:center;cursor:pointer;padding:4px 8px;border-radius:4px}.week-label:hover{background:#e9ecef}.btn{padding:6px 12px;border-radius:4px;font-size:13px;border:none;cursor:pointer;text-decoration:none}.btn-secondary{background:#e9ecef;color:#495057}.btn-primary{background:var(--danwel-color);color:#fff}.btn-primary:hover{background:#0f766e}.btn-nav{padding:4px 10px;font-size:12px}.header-actions{display:flex;gap:8px;align-items:center}.calendar{flex:1;display:flex;overflow:hidden}.time-gutter{width:100px;background:#f8f9fa;border-right:1px solid #dee2e6}.time-gutter-header{height:40px}.time-label{height:var(--hour-height);font-size:10px;color:#868e96;text-align:right;padding:2px 8px 0 0}.days{flex:1;display:grid;grid-template-columns:repeat(var(--work-days-count, 7),1fr)}.day{border-right:1px solid #dee2e6;display:flex;flex-direction:column}.day:last-child{border-right:none}.day-header{height:50px;padding:8px;background:#fff;border-bottom:1px solid #dee2e6;text-align:center}.day-header.today{background:#e7f5f4}.day-name{font-size:12px;font-weight:600;color:#495057}.day-date{font-size:10px;color:#868e96}.day-body{flex:1;position:relative;background:#fff}.hour-row{position:absolute;left:0;right:0;height:var(--hour-height);border-bottom:1px solid #e9ecef;cursor:pointer}.hour-row:after{content:"";position:absolute;left:0;right:0;top:50%;border-bottom:1px dotted #dee2e6}.hour-row:nth-child(2n){background:#fafbfc}.hour-row:hover{background:#f0f7ff}.time-block{position:absolute;background:var(--danwel-color);border-radius:4px;padding:4px 6px;font-size:11px;color:#fff;cursor:grab;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden}.time-block:not(.external):hover{filter:brightness(.9)}.time-block.external{cursor:pointer;opacity:.85}.time-block.hidden-details{cursor:not-allowed;background:#9ca3af!important}.time-block.dragging{opacity:.9;box-shadow:0 4px 12px #00000026;z-index:100}.time-block-time{font-size:9px;opacity:.85;pointer-events:none}.time-block-title{font-weight:500;pointer-events:none}.time-block-meta{font-size:9px;opacity:.75;margin-top:2px;pointer-events:none}.time-block-delete{position:absolute;top:2px;right:4px;opacity:0;cursor:pointer;font-size:14px}.time-block:hover .time-block-delete{opacity:.7}.time-block-delete:hover{opacity:1}.time-block .resize-handle{position:absolute;left:0;right:0;height:4px;cursor:ns-resize}.time-block .resize-handle-top{top:0}.time-block .resize-handle-bottom{bottom:0}.modal-overlay{display:none;position:fixed;inset:0;background:#0006;z-index:1000;align-items:center;justify-content:center}.modal-overlay.open{display:flex}.modal{background:#fff;border-radius:8px;padding:20px;width:320px}.modal h2{font-size:16px;margin:0 0 16px}.form-group{margin-bottom:12px}.form-group label{display:block;font-size:12px;font-weight:500;margin-bottom:4px;color:#495057}.form-group input,.form-group select{width:100%;padding:8px;border:1px solid #dee2e6;border-radius:4px;font-size:13px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.select-with-add{display:flex;gap:6px}.select-with-add select{flex:1}.btn-add{width:36px;padding:0;background:#e9ecef;border:1px solid #dee2e6;border-radius:4px;font-size:18px;cursor:pointer;color:#495057}.btn-add:hover{background:#dee2e6}.summary{display:flex;background:#fff;border-top:1px solid #dee2e6;font-size:12px;color:#495057}.summary-gutter{width:100px;padding:8px;text-align:right;font-weight:600;color:#212529;border-right:1px solid #dee2e6}.summary-days{flex:1;display:grid;grid-template-columns:repeat(var(--work-days-count, 7),1fr)}.summary-day{padding:8px;text-align:center;border-right:1px solid #dee2e6}.summary-day:last-child{border-right:none}.summary-day strong{color:#212529}.summary-income{font-size:11px;color:#059669;font-weight:500;margin-top:2px}.user-menu{position:relative}.user-menu-btn{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;font-size:13px}[x-cloak]{display:none!important}.user-menu-dropdown{position:absolute;right:0;top:100%;margin-top:4px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;min-width:160px;z-index:1000}.user-menu-dropdown a{display:block;padding:10px 16px;color:#374151;text-decoration:none;font-size:13px}.user-menu-dropdown a:hover{background:#f3f4f6}.user-menu-dropdown form button{width:100%;text-align:left;padding:10px 16px;background:none;border:none;cursor:pointer;color:#ef4444;font-size:13px}.user-menu-dropdown form button:hover{background:#fef2f2}.week-picker{display:none;position:absolute;top:100%;left:0;margin-top:8px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;padding:12px;z-index:1000;width:280px}.week-picker.open{display:block}.week-picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.week-picker-header button{background:none;border:1px solid #e5e7eb;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:12px}.week-picker-header button:hover{background:#e9ecef}.week-picker-month{font-weight:600;font-size:13px}.week-picker-grid{display:grid;grid-template-columns:28px repeat(7,1fr);gap:2px}.week-picker-week-num{font-size:11px;color:#6b7280;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px;padding:4px 2px}.week-picker-week-num:hover{background:#e9ecef}.week-picker-day-label{font-size:10px;color:#9ca3af;text-align:center;padding:4px;font-weight:500}.week-picker-day{font-size:12px;text-align:center;padding:6px 4px;cursor:pointer;border-radius:4px}.week-picker-day:hover{background:#e9ecef}.week-picker-day.other-month{color:#adb5bd}.week-picker-day.today{font-weight:600;color:#0d9488}.week-picker-day.in-week{background:#e7f5f4}.mobile-only{display:none}.desktop-only{display:flex}.mobile-controls{align-items:center;gap:8px}.mobile-add-btn{background:var(--danwel-color);border:none;border-radius:6px;padding:8px;cursor:pointer;color:#fff}.mobile-add-btn:hover{background:#0f766e}.mobile-add-btn svg{width:24px;height:24px}.mobile-menu-btn{background:none;border:1px solid #e5e7eb;border-radius:6px;padding:8px;cursor:pointer;color:#374151}.mobile-menu-btn:hover{background:#f3f4f6}.mobile-menu-btn svg{width:24px;height:24px}.mobile-menu{position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 4px 12px #0000001a;z-index:1000;padding:8px 0}.mobile-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;text-decoration:none;color:#374151;font-size:14px;background:none;border:none;cursor:pointer;text-align:left}.mobile-menu-item:hover{background:#f3f4f6}.mobile-menu-item svg{width:20px;height:20px}.btn-primary-mobile{background:#0d9488;color:#fff;margin:8px 16px;width:calc(100% - 32px);border-radius:6px;justify-content:center;font-weight:500}.btn-primary-mobile:hover{background:#0f766e}.mobile-menu-divider{height:1px;background:#e5e7eb;margin:8px 0}.mobile-menu-logout{color:#ef4444}.mobile-menu-logout:hover{background:#fef2f2}@media(max-width:768px){.mobile-only{display:block}.mobile-controls.mobile-only{display:flex}.desktop-only{display:none!important}:root{--hour-height: 50px}header{position:relative;padding:8px;flex-wrap:wrap;gap:8px}.header-container{padding:0 8px;height:auto}.header-left{flex:1;min-width:0}.logo{display:none}.week-nav{gap:4px}.week-label{font-size:14px;min-width:auto;padding:6px 10px;font-weight:500}.btn-nav{padding:4px 8px;font-size:11px}.header-actions{gap:6px}.header-actions .btn-primary,.user-menu-btn{padding:6px 10px;font-size:12px}.user-menu-btn svg{display:none}.time-gutter{width:30px}.time-gutter-header{height:32px}.time-label{font-size:7px;padding:2px 2px 0 0}.summary{display:none}.day-header{height:32px;padding:4px 2px}.day-name{font-size:9px}.day-date{font-size:8px}.time-block{font-size:10px;padding:3px 4px}.time-block-time{font-size:8px}.time-block-meta{display:none}.summary-gutter{width:70px;padding:6px 4px;font-size:11px}.summary-day{padding:6px 2px;font-size:10px}.modal{width:90%;max-width:320px;padding:16px}.week-picker{width:260px;left:-20px}}@media(max-width:480px){:root{--hour-height: 40px}header{padding:8px 10px}.logo{font-size:13px}.week-nav{gap:2px}.week-label{font-size:12px;min-width:auto;padding:4px 6px}.btn-nav{padding:3px 6px;font-size:10px}.header-actions .btn-primary{padding:5px 8px;font-size:11px}.header-actions .btn-primary:before{content:"+"}.header-actions .btn-primary{font-size:0}.header-actions .btn-primary:before{font-size:16px}.user-menu-btn{padding:5px 8px;font-size:11px}.time-gutter{width:30px}.time-gutter-header{height:32px}.time-label{font-size:7px;padding:1px 2px 0 0}.day-header{height:32px;padding:4px 2px}.day-name{font-size:9px}.day-date{font-size:8px}.time-block{font-size:9px;padding:2px 3px;left:1px;right:1px}.time-block-time{font-size:7px}.time-block-title{font-size:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.time-block-delete{font-size:12px;top:1px;right:2px}.summary-gutter{width:60px;padding:4px 2px;font-size:10px}.summary-day{padding:4px 1px;font-size:9px}.modal{width:95%;padding:14px;margin:10px}.modal h2{font-size:15px}.form-group label{font-size:11px}.form-group input,.form-group select{padding:6px;font-size:12px}.week-picker{width:240px;left:50%;transform:translate(-50%);padding:10px}.week-picker-header button{padding:3px 6px;font-size:11px}.week-picker-month{font-size:12px}.week-picker-grid{grid-template-columns:24px repeat(7,1fr);gap:1px}.week-picker-week-num{font-size:9px;padding:3px 1px}.week-picker-day-label{font-size:8px;padding:2px}.week-picker-day{font-size:10px;padding:4px 2px}}@media(max-width:360px){.logo{display:none}.week-label{font-size:10px;padding:3px 4px}.btn-nav{padding:3px 4px}.day-name{font-size:8px}.time-block-title{font-size:7px}}.context-menu{position:fixed;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:150px;z-index:1000;overflow:hidden;border:1px solid #e5e7eb}.context-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;background:none;border:none;text-align:left;font-size:14px;color:#374151;cursor:pointer;transition:background-color .15s}.context-menu-item:hover{background-color:#f3f4f6}.context-menu-item-danger{color:#dc2626}.context-menu-item-danger:hover{background-color:#fef2f2}.context-menu-item svg{width:16px;height:16px;flex-shrink:0}.time-block.duplicating{opacity:.7;border:2px dashed white}.current-time-indicator{position:absolute;left:0;right:0;height:2px;background:#dc2626;z-index:50;pointer-events:none}.current-time-indicator:before{content:"";position:absolute;left:-5px;top:-4px;width:10px;height:10px;background:#dc2626;border-radius:50%}.onboarding-modal{max-width:580px;width:90%;padding:32px;position:relative}.onboarding-modal h2{font-size:18px;font-weight:600;margin:0 0 6px;color:#111827}.onboarding-modal p{font-size:14px;line-height:1.5}.onboarding-modal .form-group label{font-size:13px}.onboarding-welcome-screen{text-align:center}.onboarding-icon{width:72px;height:72px;margin:0 auto 24px;background:linear-gradient(135deg,#e0f2f1,#f0fdfa);border-radius:20px;display:flex;align-items:center;justify-content:center;color:var(--danwel-color)}.onboarding-icon svg{width:36px;height:36px}.onboarding-logo{display:block;height:28px;margin:0 auto 16px}.onboarding-modal .onboarding-welcome-screen h2{font-size:24px;font-weight:600;margin:0 0 12px;color:#111827}.onboarding-modal .onboarding-welcome-screen p{font-size:15px;line-height:1.6;margin:0 0 8px;color:#6b7280}.onboarding-welcome-screen .btn-welcome{margin-top:20px;padding:12px 40px;font-size:15px;font-weight:500}.onboarding-welcome-screen .btn-skip{display:block;margin:16px auto 0;background:none;border:none;color:#9ca3af;font-size:13px;cursor:pointer}.onboarding-welcome-screen .btn-skip:hover{color:#6b7280}.onboarding-actions.welcome-actions{display:none}.onboarding-close{position:absolute;top:16px;right:16px;background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;border-radius:4px;line-height:0}.onboarding-close:hover{color:#6b7280;background:#f3f4f6}.onboarding-steps{display:flex;justify-content:center;gap:8px;margin-bottom:24px}.onboarding-step{display:flex;align-items:center;gap:6px}.onboarding-step-dot{width:8px;height:8px;border-radius:50%;background:#e5e7eb;transition:all .2s}.onboarding-step.active .onboarding-step-dot{background:var(--danwel-color);width:10px;height:10px}.onboarding-step.completed .onboarding-step-dot{background:var(--danwel-color)}.onboarding-step-label{display:none}.onboarding-actions{display:flex;gap:8px;margin-top:28px;padding-top:20px;border-top:1px solid #f3f4f6}.onboarding-day-toggle{display:inline-flex;cursor:pointer}.onboarding-day-toggle input{display:none}.onboarding-day-toggle span{padding:6px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:12px;color:#6b7280;background:#fff;transition:all .15s}.onboarding-day-toggle input:checked+span{background:var(--danwel-color);border-color:var(--danwel-color);color:#fff}.onboarding-day-toggle:hover span{border-color:#9ca3af}.onboarding-items-list{min-height:60px;max-height:150px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:8px;padding:8px;background:#f9fafb}.onboarding-items-list:empty:before{content:"No items added yet";color:#9ca3af;font-size:12px;display:block;text-align:center;padding:16px}.onboarding-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:#fff;border-radius:6px;margin-bottom:4px;border:1px solid #e5e7eb}.onboarding-item:last-child{margin-bottom:0}.onboarding-item span{font-size:13px;color:#374151}.onboarding-item-remove{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:18px;line-height:1;padding:0 4px}.onboarding-item-remove:hover{color:#ef4444}.onboarding-integration{padding:12px;border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb}.onboarding-integration-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center}.btn-sm{padding:6px 12px;font-size:12px}.btn-finish{padding:12px 32px;font-size:16px;flex:1}.form-input{padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;width:100%}.form-input:focus{outline:none;border-color:var(--danwel-color);box-shadow:0 0 0 2px #0d94881a}.flex{display:flex}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.text-sm{font-size:14px}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-green-600{color:#059669}.font-medium{font-weight:500}.space-y-4>*+*{margin-top:16px}.text-center{text-align:center}@media(max-width:480px){.onboarding-modal{padding:16px}.onboarding-steps{margin-bottom:16px;padding-bottom:12px}.onboarding-step-label{font-size:9px}.onboarding-step-dot{width:16px;height:16px}.onboarding-day-toggle span{padding:4px 8px;font-size:11px}.onboarding-integration{padding:10px}.onboarding-integration-icon{width:32px;height:32px}.onboarding-integration-icon svg{width:18px;height:18px}}
