@import url(https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;600;700&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.btn{align-items:center;background-color:initial;border:1px solid #d1d5da;border-radius:.375rem;color:#24292e;cursor:pointer;display:inline-flex;font-size:.875rem;justify-content:center;line-height:1.25;padding:.5rem 1rem;transition:background-color .2s}.btn:hover{background-color:#e6e8ea}.btn-outline{border-color:#3b5cd3;color:#3b5cd3}.btn-outline:hover{background-color:#3b5cd3;color:#fff}.input,.select{background-color:#fff;border:1px solid #d1d5da;border-radius:.375rem;color:#24292e;display:block;font-size:.875rem;line-height:1.25;padding:.5rem .75rem;width:100%}.input-bordered,.select-bordered{border-color:#d1d5da}.bg-base-200{background-color:#f5f5f5}.text-base-content{color:#24292e}.shadow-lg{box-shadow:0 10px 15px #0000001a}.rounded-lg{border-radius:.5rem}.p-6{padding:1.5rem}:root{--sidebar-bg:#fff;--sidebar-text:#111827;--sidebar-active-bg:#f3f4f6;--content-bg:#fff;--primary-accent:#3b5cd3;--primary-accent-dark:#2d4bb3;--card-danger:#ff4d4f;--card-info:#3b5cd3;--card-success:#47cda9;--card-padding:16px;--card-radius:12px;--border-color:#d1d5da;--text-color:#374151;--hover-bg:#f3f4f6;--danger-color:#ef4444;--danger-color-dark:#dc2626;--bg-light:#fff;--bg-light-alt:#f8fafc;--bg-hover:#e6e8ea;--border:#d1d5da;--text-main:#1e293b;--text-muted:#6e6e6e;--sidepanel-width:360px;--sp-nav-width:72px;--sp-header-height:128px}.App{background-position:50%;background-repeat:no-repeat;background-size:cover;min-height:100vh;text-align:center}#root,body,html{font-family:Baloo\ 2,sans-serif;height:100%;margin:0;padding:0}.clock-container{-webkit-user-drag:none;height:420px;position:relative;-webkit-user-select:none;user-select:none;width:420px}.clock-action-buttons{animation:fadeInActions .3s ease-out forwards;display:flex;gap:12px;left:50%;opacity:0;position:absolute;top:50%;transform:translate(-50%,-50%) scale(1);transform:translate(-50%,-50%) scale(calc(100/var(--clock-scale, 100)));transform-origin:center;z-index:3100}.clock-action-buttons:before{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:radial-gradient(circle,#ffffffe6 0,#fff9 40%,#fff0 70%);border-radius:50%;content:"";height:120px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:120px;z-index:-1}@keyframes fadeInActions{0%{opacity:0;transform:translate(-50%,-50%) scale(1) translateY(10px);transform:translate(-50%,-50%) scale(calc(100/var(--clock-scale, 100))) translateY(10px)}to{opacity:1;transform:translate(-50%,-50%) scale(1) translateY(0);transform:translate(-50%,-50%) scale(calc(100/var(--clock-scale, 100))) translateY(0)}}.clock-action-btn{align-items:center;background:#fff;border:1px solid #d1d5da;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#374151;color:var(--text-color);cursor:pointer;display:flex;font-size:14px;font-weight:500;height:36px;justify-content:center;transition:all .2s ease;width:36px}.clock-action-btn:hover{background:#f3f4f6;background:var(--hover-bg);border-color:#3b5cd3;border-color:var(--primary-accent);box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.clock-action-btn:active{box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.clock-action-btn.create-btn{background:#3b5cd3;background:var(--primary-accent);border-color:#3b5cd3;border-color:var(--primary-accent);color:#fff}.clock-action-btn.create-btn:hover{background:#2d4bb3;background:var(--primary-accent-dark);border-color:#2d4bb3;border-color:var(--primary-accent-dark)}.clock-action-btn.delete-btn{background:#ef4444;background:var(--danger-color);border-color:#ef4444;border-color:var(--danger-color);color:#fff}.clock-action-btn.delete-btn:hover{background:#dc2626;background:var(--danger-color-dark);border-color:#dc2626;border-color:var(--danger-color-dark)}.clock-face{-webkit-user-drag:none!important;background-color:#fff;border-radius:50%;box-shadow:0 10px 30px #0000001a;height:300px;left:50%;pointer-events:auto;position:absolute;top:50%;transform:translate(-50%,-50%);-webkit-user-select:none!important;user-select:none!important;width:300px;z-index:10}.ghost-block-svg{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:5}.hand{bottom:50%;left:50%;position:absolute;transform-origin:50% 100%}.hour-hand{background-color:#ff006e;border-radius:4px;height:auto;margin-left:-3px;width:6px;z-index:2500}.minute-hand{background-color:#3a86ff;border-radius:3px;height:47%;margin-left:-2px;width:4px}.second-hand{background-color:#ffbe0b;height:40%;margin-left:-1px;width:2px}.number{-webkit-user-drag:none!important;color:#3a0ca3;font-size:20px;font-weight:600;pointer-events:none!important;position:absolute;transition:left .5s ease,top .5s ease;-webkit-user-select:none!important;user-select:none!important}.center-dot{background-color:#3a0ca3;border-radius:50%;cursor:move;height:12px;left:50%;pointer-events:auto;position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;z-index:3000}.minute-marks{height:100%;left:0;position:absolute;top:0;width:100%}.minute-mark{background-color:#8338ec;height:8px;left:50%;position:absolute;transform-origin:50% 150px;width:2px}.minute-mark.hour-mark{background-color:#000;height:14px;width:3px}.digital-time{-webkit-user-drag:none!important;background:#fff;border-radius:6px;box-shadow:0 5px 10px #fff,0 -5px 10px #fff;color:#3a0ca3;font-size:28px;font-weight:600;left:50%;padding:4px 8px;pointer-events:none!important;position:absolute;top:33%;transform:translate(-50%,-50%);-webkit-user-select:none!important;user-select:none!important;z-index:2600}.time-block{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:0}.time-block.selected{z-index:2000}.time-block-svg{height:100%;overflow:visible;pointer-events:none;width:100%}.time-block-arc{stroke-linejoin:round;stroke-linecap:round;cursor:pointer;paint-order:stroke fill;pointer-events:auto}.resize-handle{stroke:#000;stroke-width:2;cursor:ew-resize;display:none;pointer-events:auto}.time-block.selected .resize-handle{display:block;pointer-events:auto}.colors{display:flex;flex-wrap:wrap;gap:8px}.color-option{border:1px solid #ccc;height:24px;transition:border-color .2s;width:24px}.color-option:hover{border-color:#999}.submenu-header{align-items:center;border-bottom:1px solid #d1d5da;cursor:pointer;display:flex;justify-content:space-between;padding:8px 0}.submenu-header .section-title{color:#6e6e6e;font-size:12px;font-weight:500;margin:0;text-transform:uppercase}.side-panel-section input,.side-panel-section select,.side-panel-section>button{background:#fff;border:1px solid #d1d5da;border-radius:4px;box-sizing:border-box;color:#24292e;cursor:pointer;font-size:14px;margin:4px 0;padding:8px 12px;text-align:left;transition:background-color .2s}.side-panel-section input:hover,.side-panel-section select:hover,.side-panel-section>button:hover{background-color:#e6e8ea}.color-option{border:2px solid #0000;border-radius:50%;cursor:pointer;height:32px;transition:border-color .2s,transform .2s;width:32px}.color-option:hover{border-color:#3a86ff;transform:scale(1.1)}.plan-input{margin-bottom:8px}.plan-input,.plan-select{border:1px solid #e5e7eb;border-radius:4px;padding:6px 8px;width:100%}.plan-select{margin:8px 0}.submenu-content{display:flex;flex-direction:column;gap:8px;padding:8px 0 16px}.main-content{background:#0000;height:100vh;margin-left:0;overflow:hidden;position:relative;width:100%}.weekly-planner-container{cursor:move;position:absolute}.weekly-planner{align-items:stretch;display:flex;flex:none;gap:12px}.weekly-day{border:1px solid #000;border-radius:8px;box-shadow:0 10px 30px #0000001a;flex:1 1;overflow:hidden}.day-header,.weekly-day{display:flex;flex-direction:column}.day-header{align-items:center;background:#ffffffe6;border-bottom:1px solid #0000001a;justify-content:center;min-height:60px;padding:6px 4px;text-align:center}.day-name{color:#111827;font-size:1rem;font-weight:1000;text-transform:uppercase}.day-date,.day-name{display:block;-webkit-user-select:none;user-select:none}.day-date{color:#4b5563;font-size:.8rem;margin-top:1px}.day-header-buttons{align-items:center;display:flex;gap:8px;justify-content:center}.day-add-button,.day-delete-button{min-width:auto;padding:6px}.day-delete-button{border-color:#ef4444;color:#ef4444}.day-delete-button:hover{background-color:#ef4444;color:#fff}.day-content{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:6px;min-height:60px;padding:8px}.weekly-day.today{border-color:red!important;position:relative}.event-item{align-items:center;border-radius:8px;box-sizing:border-box;color:#3a0ca3;cursor:grab;display:flex;flex-direction:column;gap:8px;justify-content:center;min-height:120px;padding:4px 10px;-webkit-user-select:none;user-select:none;width:100%}.event-item:active{cursor:grabbing}.event-icons-container{-ms-overflow-style:none;scrollbar-width:none}.event-icons-container::-webkit-scrollbar{display:none}.event-image{border-radius:10px;display:block;height:auto;max-width:none;object-fit:contain;width:auto}.event-title{color:#3a0ca3;font-size:.9rem;text-align:center}.color-option-selected{background:#fff;border:2px solid #3a86ff;border-radius:50%;height:16px;position:absolute;width:16px}.colors{position:relative}.side-panel-wrapper{background:#fff;border-right:1px solid #e5e7eb;bottom:0;box-shadow:0 1px 4px #0000001a;display:flex;left:0;position:fixed;top:0;transition:left .3s ease,opacity .3s ease;width:432px;width:calc(var(--sidepanel-width) + var(--sp-nav-width));z-index:3000}.side-panel-wrapper.collapsed{left:-320px;left:calc((var(--sidepanel-width) - 40px)*-1);opacity:0}.side-panel-wrapper.collapsed:hover{left:0;opacity:1}.side-panel{color:#333;font-family:Baloo\ 2,sans-serif;height:100%;overflow-y:auto;padding:0 16px 16px;width:360px;width:var(--sidepanel-width)}.side-panel,.sp-header{display:flex;flex-direction:column}.sp-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 4px 10px #0f172a0d;gap:6px;margin:0 -16px 12px;min-height:128px;min-height:var(--sp-header-height);padding:12px 16px 10px;position:-webkit-sticky;position:sticky;top:0;z-index:2}.sp-logo{align-items:center;display:flex;gap:8px}.sp-logo-text{font-size:1.1rem;font-weight:600;line-height:40px}.sp-collapse-btn{background:none;border:none;color:#666;cursor:pointer}.sp-section{border-bottom:1px solid #e2e8f0;padding:24px 0}.sp-section:last-child{border-bottom:none}.sp-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.sp-section-title{color:#1e293b;font-size:1.125rem;font-weight:600}.sp-category-menu{align-items:center;background:#f8fafc;border-right:1px solid #e2e8f0;display:flex;flex:0 0 72px;flex:0 0 var(--sp-nav-width);flex-direction:column;gap:16px;height:100%;padding:132px 8px 16px;padding:calc(var(--sp-header-height) + 4px) 8px 16px;width:72px;width:var(--sp-nav-width)}.sp-category-menu.locked{opacity:.8}.sp-category-menu-items{display:flex;flex:1 1;flex-direction:column;gap:8px;overflow-y:auto;width:100%}.sp-category-btn{align-items:center;background:#0000;border:none;border-radius:10px;color:#475569;cursor:pointer;display:flex;flex-direction:column;font-size:.7rem;gap:4px;padding:8px 4px;text-align:center;transition:background-color .2s ease,color .2s ease;width:100%}.sp-category-btn svg{height:22px;width:22px}.sp-category-btn span{line-height:1.1}.sp-category-btn:hover{background:#0f172a14;color:#1e293b}.sp-category-btn.active{background:#3b5cd326;color:#1d3ccf;font-weight:600}.sp-section-anchor{scroll-margin-top:144px;scroll-margin-top:calc(var(--sp-header-height) + 16px)}.icon-visible{color:#333;cursor:pointer}.icon-hidden{color:#bbb;cursor:pointer}.sp-section-body{display:flex;flex-direction:column;gap:12px}.sp-section-body label,.sp-slider-label{color:#475569;display:block;font-size:.875rem;font-weight:500;margin-bottom:8px}.sp-input,.sp-select{background-color:#fff;border:1px solid #cbd5e1;border-radius:6px;color:#1e293b;font-size:.875rem;padding:8px 12px;width:100%}.sp-input:focus,.sp-select:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33;outline:none}.side-panel input[type=range]{-webkit-appearance:none;appearance:none;background-color:#e2e8f0;border-radius:9999px;height:8px;outline:none;width:100%}.side-panel input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background-color:#2563eb;border:2px solid #fff;border-radius:9999px;cursor:pointer;height:16px;width:16px}.side-panel input[type=range]::-moz-range-thumb{background-color:#2563eb;border:2px solid #fff;border-radius:9999px;cursor:pointer;height:16px;width:16px}.side-panel input[type=checkbox]{accent-color:#2563eb;border:1px solid #cbd5e1;border-radius:4px;height:16px;margin-right:8px;position:relative;top:-1px;vertical-align:middle;width:16px}.sp-slider-label input[type=checkbox]{margin-right:8px}.sidebar-icon-button,.sp-collapse-btn{background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;padding:4px}.sidebar-icon-button:hover,.sp-collapse-btn:hover{background-color:#e2e8f0;color:#1e293b}.sp-collapse-btn svg,.sp-collapse-btn svg path{stroke-width:2px}.sp-section-header svg,.sp-section-header svg path{stroke:currentColor!important;stroke-width:2px}.sp-section-header svg{border-radius:6px;color:#64748b;padding:4px}.sp-section-header svg:hover{background-color:#e2e8f0;color:#1e293b}.sp-section-header>svg{background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;padding:4px}.sp-section-header>svg:hover{background-color:#e2e8f0;color:#1e293b}.sp-button-row{display:flex;gap:8px}.btn-outline{align-items:center;background:#0000;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;display:inline-flex;font-size:.9rem;gap:4px;padding:6px 12px}.btn-outline.active{background:#3b5cd314;border-color:#3b5cd3;color:#1a237e}.btn-outline:disabled{border-color:#eee;color:#aaa;cursor:default}.sp-color-row{display:flex;gap:8px}.sp-color-btn{border:2px solid #0000;border-radius:9999px;cursor:pointer;height:24px;width:24px}.sp-icon-row{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(64px,1fr));width:100%}.sp-icon-btn{align-items:center;background:#fff;border:1px solid #d1d5da;border-radius:8px;cursor:pointer;display:flex;height:64px;justify-content:center;transition:background-color .2s,border-color .2s,transform .1s;width:100%}.sp-icon-btn:hover{background-color:#e6e8ea;border-color:#c1c5ca;transform:translateY(-1px)}.sp-icon-btn:active{transform:translateY(0)}.sp-icon-btn img,.sp-icon-btn svg{height:36px;width:36px}.sp-icon-btn.selected{border-color:#3b5cd3;border-color:var(--primary-accent);box-shadow:0 0 0 2px #3b5cd3;box-shadow:0 0 0 2px var(--primary-accent)}.sp-color-btn:hover{border-color:#2563eb}.sp-icon-btn.upload{border:1px solid #d1d5da;color:#6e6e6e}.sp-icon-btn.upload svg{fill:none;stroke:currentColor;stroke-width:1px}.sp-color-circle{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:none;border:2px solid #cbd5e1;border-radius:9999px;cursor:pointer;height:24px;padding:0;position:relative;width:24px}.sp-color-circle::-webkit-color-swatch-wrapper{padding:0}.sp-color-circle::-webkit-color-swatch{background:#0000;border:none;border-radius:9999px}.sp-color-circle:before{background:conic-gradient(red 0deg,#ff0 60deg,#0f0 120deg,#0ff 180deg,#00f 240deg,#f0f 300deg,red 1turn);border-radius:inherit;content:"";inset:0;pointer-events:none;position:absolute}.time-block-arc.past{filter:grayscale(100%)}@keyframes fadeOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOverlayOut{0%{opacity:1}to{opacity:0}}.countdown-container.selected,.event-item.selected,.time-block.selected .time-block-svg{border-radius:8px;outline:3px solid #3b5cd3;outline:3px solid var(--primary-accent);outline-offset:2px}.time-block.selected .time-block-arc{stroke:#3b5cd3!important;stroke:var(--primary-accent)!important;stroke-width:4px!important}.background-layer{background-position:50%;background-repeat:no-repeat;background-size:cover;inset:0;pointer-events:none;position:fixed;z-index:-1}.bg-options{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));margin-top:8px}.bg-option{background-position:50%;background-size:cover;border:2px solid #0000;border-radius:4px;box-sizing:border-box;cursor:pointer;height:0;padding-top:56%;position:relative;width:100%}.bg-option .bg-delete-btn{background-color:#fffc;border:none;border-radius:4px;cursor:pointer;padding:2px;position:absolute;right:4px;top:4px}.bg-option .bg-delete-btn svg{pointer-events:none}.bg-option.selected{border-color:#3b5cd3;border-color:var(--primary-accent)}.upload-option{background-color:#f0f0f0;box-sizing:border-box;position:relative}.upload-option:hover{background-color:#e0e0e0}.upload-option svg{fill:none;stroke:currentColor;stroke-width:1px;color:#6e6e6e;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.countdown-container{align-items:center;cursor:move;display:flex;gap:4px;pointer-events:auto;position:absolute;-webkit-user-select:none;user-select:none}.countdown-number{color:#3a0ca3;display:inline-block;font-size:24px;font-weight:700;text-align:center;width:2ch}.countdown-icon{height:56px;object-fit:contain;pointer-events:none;width:56px}.countdown-arrow{font-size:20px;pointer-events:none}.countdown-background{align-items:center;border-radius:8px;display:flex;flex-direction:column;overflow:hidden}.countdown-row,.countdown-row-top{align-items:center;display:flex;justify-content:center}.countdown-row-top{background:#ffffffe6;border-bottom:1px solid #0000001a;box-sizing:border-box;gap:4px;padding:8px;width:100%}.countdown-row-arrow{padding:4px 0}.countdown-arrow-down{font-size:40px;font-weight:600;line-height:1}.countdown-mult{color:#3a0ca3;font-size:24px;font-weight:700}.countdown-row-bottom{padding:4px 0 8px}.plan-input,.plan-select,.side-panel input,.side-panel select,.side-panel textarea,.sp-input,.sp-select{box-sizing:border-box}.sp-group-box{border:1px solid #e2e8f0;border-radius:6px;margin-bottom:12px;padding:8px}.clock-container,.countdown-container,.weekly-planner-container{position:absolute;z-index:10!important}.side-panel.locked{pointer-events:none}.side-panel.locked:after{background:#c8c8c866;content:"";inset:0;pointer-events:none;position:absolute;z-index:1}.side-panel.locked .sp-header{opacity:1;pointer-events:auto;position:relative;z-index:2}.lock-overlay{background:#0000;bottom:0;cursor:not-allowed;left:432px;left:calc(var(--sidepanel-width) + var(--sp-nav-width));pointer-events:all;position:fixed;right:0;top:0;z-index:5000}.sync-icon{cursor:pointer;height:24px;transition:color .3s;width:24px}.sync-icon.idle{color:#888}.sync-icon.syncing{animation:spin 1s linear infinite;color:#f5a623}.sync-icon.ok{color:#4caf50}.sync-icon.error{color:#f44336}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.spinner{animation:spin 1s linear infinite;border:2px solid;border-radius:50%;border-top:2px solid #0000;display:inline-block;height:1em;vertical-align:middle;width:1em}.visually-hidden{clip:rect(0 0 0 0)!important;border:0!important;height:1px!important;margin:-1px!important;overflow:hidden!important;padding:0!important;position:absolute!important;width:1px!important}.modal-backdrop{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;max-width:400px;padding:16px;width:100%}.sp-tabs{border-bottom:1px solid #d1d5da;border-bottom:1px solid var(--border);display:flex;gap:8px;margin-bottom:12px}.sp-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#6e6e6e;color:var(--text-muted);cursor:pointer;font-size:.875rem;font-weight:500;padding:8px 12px}.sp-tab.active{border-bottom-color:#3b5cd3;border-bottom-color:var(--primary-accent);color:#3b5cd3;color:var(--primary-accent)}.onboarding-overlay{background:#0000004d;z-index:10000}.onboarding-card{box-shadow:0 4px 16px #0000001a;max-width:600px;padding:24px;text-align:center;width:80%}.onboarding-card h2{margin-bottom:1rem}.onboarding-card p{margin-bottom:1.5rem}.time-block-arc:focus,.time-block-arc:focus-visible,.time-block-svg:focus,.time-block-svg:focus-visible{outline:none!important}.time-block.selected .time-block-arc,.time-block.selected .time-block-svg{outline:none!important}.time-block.selected .resize-handle{stroke:#3b5cd3!important;stroke:var(--primary-accent)!important;stroke-width:4px!important;opacity:1!important}.time-block.selected.level-outer .resize-handle{paint-order:markers fill stroke!important}.onboarding-overlay{background:#00000080;height:100%;left:0;top:0;width:100%}.onboarding-card{background:#fff;overflow:hidden}.onboarding-overlay{align-items:center;background-color:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:4000}.onboarding-card{background-color:#fff;border-radius:8px;box-shadow:0 4px 16px #0003;padding:16px;position:relative;z-index:4001}.onboarding-close-btn{background:none;border:none;color:#333;cursor:pointer;position:absolute;right:8px;top:8px;z-index:4002}.onboarding-content .sp-input{background-color:#fff;background-color:var(--bg-light);border:1px solid #d1d5da;border:1px solid var(--border);border-radius:.375rem;box-sizing:border-box;color:var(--text-base-content);font-size:.875rem;line-height:1.25;min-height:3rem;padding:.5rem .75rem;resize:vertical;width:100%}.onboarding-content .sp-input:focus{border-color:#3b5cd3;border-color:var(--primary-accent);box-shadow:0 0 0 2px #3b5cd333;outline:none}.clock-container.dragging,.countdown-container.dragging,.weekly-planner-container.dragging{cursor:grabbing!important;opacity:.9;-webkit-user-select:none;user-select:none;z-index:1000}.countdown-container.dragging{transform-origin:0 0}.clock-container:not(.dragging),.countdown-container:not(.dragging),.weekly-planner-container:not(.dragging){transition:transform .1s ease-out}.dragging-active,.dragging-active *{user-select:none!important;-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important}.local-app[data-mode=local] .mode-indicator,.synced-app[data-mode=synced] .mode-indicator{border-radius:4px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:12px;padding:4px 8px;position:fixed;right:10px;top:10px;z-index:9999}.sync-activation-overlay{animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sync-activation-modal{animation:slideUp .4s ease-out;box-shadow:0 20px 60px #0006;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.sync-activation-step h3{color:#333;font-size:20px;font-weight:600;margin:0 0 16px}.sync-activation-step p{color:#666;line-height:1.5;margin:0 0 16px}.sync-activation-step input{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;outline:none;transition:border-color .2s}.sync-activation-step input:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.sync-activation-step button{background:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;outline:none;padding:12px 24px;transition:all .2s}.sync-activation-step button:hover{background:#45a049;transform:translateY(-1px)}.sync-activation-step button:disabled{background:#ccc;cursor:not-allowed;transform:none}.sync-activation-step .secondary-button{background:#757575}.sync-activation-step .secondary-button:hover{background:#616161}.sync-activation-step .error-message{background:#ffebee;border-radius:6px;color:#f44336;font-size:14px;margin-bottom:16px;padding:8px 12px}.loading-spinner{animation:spin 1s linear infinite;font-size:24px}.room-manager{background:#fff;background:var(--sidebar-bg);border:1px solid #d1d5da;border:1px solid var(--border);border-radius:8px;margin-bottom:16px;padding:16px}.room-manager-header{align-items:center;border-bottom:1px solid #d1d5da;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.room-manager-header h3{align-items:center;color:#1e293b;color:var(--text-main);display:flex;font-size:1.25rem;font-weight:600;margin:0}.create-room-button{align-items:center;background-color:#3b5cd3;background-color:var(--primary-accent);border:1px solid #3b5cd3;border-color:var(--primary-accent);border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;font-size:.85rem;gap:6px;justify-content:center;line-height:1.25;padding:6px 12px;transition:all .2s ease}.create-room-button:hover{background-color:#2c4fd6;border-color:#2c4fd6;transform:scale(1.05)}.create-room-button svg{height:14px;width:14px}.current-room-info{background:#f8fafc;background:var(--bg-light-alt);border-left:4px solid #3b5cd3;border-left:4px solid var(--primary-accent);border-radius:6px;margin-bottom:16px;padding:12px}.current-room-label{color:#6e6e6e;color:var(--text-muted);font-size:.75rem;margin-bottom:4px}.current-room-name{align-items:center;color:#1e293b;color:var(--text-main);display:flex;font-size:.9rem;font-weight:600}.room-section{margin-bottom:20px}.room-section-header{align-items:center;border-bottom:1px solid #d1d5da;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:8px;padding-bottom:4px}.section-title{align-items:center;color:#1e293b;color:var(--text-main);display:flex;font-size:.85rem;font-weight:600}.section-count{color:#6e6e6e;color:var(--text-muted);font-size:.75rem}.room-list{display:flex;flex-direction:column;gap:4px}.room-list-item{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:flex;min-height:60px;padding:12px;position:relative;transition:all .2s ease}.room-list-item:hover{background:#e6e8ea;background:var(--bg-hover);border-color:#d1d5da;border-color:var(--border)}.room-list-item.active{background:#f3f4f6;background:var(--sidebar-active-bg);border-color:#3b5cd3;border-color:var(--primary-accent);box-shadow:0 2px 4px #3b5cd31a}.room-main-content{align-items:center;display:flex;flex:1 1;gap:12px;min-width:0;padding-right:80px}.room-type-icon{align-items:center;display:flex;height:24px;justify-content:center;width:24px}.room-icon{height:20px;opacity:.7;width:20px}.room-icon svg{height:100%;width:100%}.sync-icon{stroke:currentColor;color:#3b5cd3;color:var(--primary-accent);height:16px;width:16px}.modal-header h3 svg,.modal-header h4 svg{vertical-align:middle}.radio-label svg{flex-shrink:0}.room-type-icon svg{display:block}.room-info{flex:1 1;min-width:0;overflow:hidden}.room-name{color:var(--text-main);font-size:.9rem;font-weight:600;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-meta{align-items:center;color:#6e6e6e;color:var(--text-muted);display:flex;font-size:.75rem;gap:8px}.room-type{background:#f8fafc;background:var(--bg-light-alt);border-radius:3px;font-size:.7rem;padding:2px 6px}.room-protected{font-size:12px}.room-last-used{font-size:.7rem}.active-indicator{align-items:center;display:flex;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.active-dot{animation:pulse 2s infinite;color:#3b5cd3;color:var(--primary-accent);font-size:16px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.room-actions{background:#fff;background:var(--sidebar-bg);border-radius:4px;box-shadow:0 2px 8px #0000001a;display:flex;gap:4px;opacity:0;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:opacity .2s ease}.room-list-item:hover .room-actions{opacity:1;z-index:10}.room-list-item:hover .active-indicator{opacity:0}.room-action-button{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s ease}.room-action-button:hover{background:#e6e8ea;background:var(--bg-hover)}.action-icon{height:14px;opacity:.7;width:14px}.action-icon svg{height:100%;width:100%}.action-icon,.share-icon{stroke:currentColor;height:16px;width:16px}.empty-rooms-state{color:#6e6e6e;color:var(--text-muted);padding:32px 16px;text-align:center}.empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}.empty-text{font-size:.9rem;margin-bottom:16px}.create-first-room-button{align-items:center;background-color:#3b5cd3;background-color:var(--primary-accent);border:1px solid #3b5cd3;border-color:var(--primary-accent);border-radius:.375rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;justify-content:center;line-height:1.25;padding:.5rem 1rem;transition:background-color .2s}.create-first-room-button:hover{background-color:#2c4fd6;border-color:#2c4fd6}.join-room-section{border-top:1px solid #d1d5da;border-top:1px solid var(--border);margin-top:20px;padding-top:16px}.join-room-button{align-items:center;background-color:#3b5cd3;background-color:var(--primary-accent);border:1px solid #3b5cd3;border-color:var(--primary-accent);border-radius:.375rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;gap:6px;justify-content:center;line-height:1.25;padding:.5rem 1rem;transition:all .2s ease;width:100%}.join-room-button:hover{background-color:#2c4fd6;border-color:#2c4fd6}.join-room-modal{max-height:90vh;overflow-y:auto;width:420px}.join-description{color:#6e6e6e;color:var(--text-muted);font-size:.9rem;line-height:1.4;margin-bottom:20px}.error-message{background-color:#ffebee;border:1px solid #f44336;border-radius:4px;color:#c62828;font-size:.9rem;margin-bottom:16px;padding:12px}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.modal-content{animation:slideUp .3s ease;background:#fff;border-radius:12px;box-shadow:0 20px 40px #0003;max-height:90vh;max-width:90vw;overflow:hidden}.room-modal{width:480px}.share-modal{width:420px}.modal-header{align-items:center;background:#f8fafc;background:var(--bg-light-alt);border-bottom:1px solid #d1d5da;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px}.modal-header h3,.modal-header h4{color:#1e293b;color:var(--text-main);font-size:1.1rem;font-weight:600;margin:0}.modal-close{background:none;border:none;border-radius:4px;color:#6e6e6e;color:var(--text-muted);cursor:pointer;font-size:24px;padding:4px;transition:all .2s ease}.modal-close:hover{background:#e6e8ea;background:var(--bg-hover);color:#1e293b;color:var(--text-main)}.modal-body{max-height:60vh;overflow-y:auto;padding:24px}.modal-footer{align-items:center;background:#f8fafc;background:var(--bg-light-alt);border-top:1px solid #d1d5da;border-top:1px solid var(--border);display:flex;justify-content:space-between;padding:16px 24px}.footer-left,.footer-right{display:flex;gap:8px}.form-group{margin-bottom:20px}.form-group label{color:#1e293b;color:var(--text-main);display:block;font-size:.9rem;font-weight:600;margin-bottom:6px}.form-group small{color:#6e6e6e;color:var(--text-muted);display:block;font-size:.75rem;margin-top:2px}.form-group input[type=password],.form-group input[type=text]{border:1px solid #d1d5da;border:1px solid var(--border);border-radius:6px;font-size:.9rem;padding:10px 12px;transition:border-color .2s ease;width:100%}.form-group input[type=password]:focus,.form-group input[type=text]:focus{border-color:#3b5cd3;border-color:var(--primary-accent);box-shadow:0 0 0 3px #3b5cd31a;outline:none}.form-group input.error{border-color:#ff4d4f;border-color:var(--card-danger)}.error-text{color:#ff4d4f;color:var(--card-danger);display:block;font-size:.75rem;margin-top:4px}.radio-group{display:flex;flex-direction:column;gap:8px}.radio-group.horizontal{flex-direction:row;gap:16px}.radio-option{align-items:flex-start;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:8px;transition:background .2s ease}.radio-option:hover{background:#f8fafc;background:var(--bg-light-alt)}.radio-option input[type=radio]{margin:2px 0 0}.radio-label{display:flex;flex-direction:column;gap:2px}.radio-label small{color:#6e6e6e;color:var(--text-muted);font-size:.75rem}.room-type-display{display:flex;flex-direction:column;gap:16px}.current-room-type{align-items:center;background:#f8fafc;background:var(--bg-light-alt);border:1px solid #d1d5da;border:1px solid var(--border);border-radius:6px;display:flex;gap:8px;padding:12px}.room-type-icon{font-size:1.2rem}.room-type-label{color:#1e293b;color:var(--text-main);font-weight:600;margin-right:8px}.room-type-description{color:#6e6e6e;color:var(--text-muted);font-size:.8rem}.convert-section{background:#fff;background:var(--bg-light);border:1px solid #d1d5da;border:1px solid var(--border);border-radius:6px;display:flex;flex-direction:column;gap:12px;padding:16px}.convert-info p{color:#1e293b;color:var(--text-main);font-size:.9rem;line-height:1.4;margin:0 0 8px}.convert-warning{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;color:#856404;font-size:.85rem;padding:12px}.convert-warning p{line-height:1.4;margin:0}.convert-success{background:#d1edff;border:1px solid #bee5eb;border-radius:6px;color:#0c5460;font-size:.9rem;padding:12px}.convert-success p{font-weight:600;margin:0 0 4px}.convert-success small{color:#0c5460;opacity:.8}.convert-button{align-items:center;background-color:#47cda9;background-color:var(--card-success);border:1px solid #47cda9;border-color:var(--card-success);border-radius:.375rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;justify-content:center;line-height:1.25;margin-top:8px;padding:.5rem 1rem;transition:background-color .2s}.convert-button:hover{background-color:#3db89a;border-color:#3db89a}.cancel-button{align-items:center;background-color:initial;border:1px solid #d1d5da;border-radius:.375rem;color:#24292e;cursor:pointer;display:inline-flex;font-size:.875rem;justify-content:center;line-height:1.25;padding:.5rem 1rem;transition:background-color .2s}.cancel-button:hover{background-color:#e6e8ea}.save-button{align-items:center;background-color:#3b5cd3;background-color:var(--primary-accent);border:1px solid #3b5cd3;border-color:var(--primary-accent);border-radius:.375rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;justify-content:center;line-height:1.25;padding:.5rem 1rem;transition:background-color .2s}.save-button:hover{background-color:#2c4fd6;border-color:#2c4fd6}.delete-button{align-items:center;background-color:#ff4d4f;background-color:var(--card-danger);border:1px solid #ff4d4f;border-color:var(--card-danger);border-radius:.375rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;gap:6px;justify-content:center;line-height:1.25;padding:.5rem 1rem;transition:background-color .2s}.delete-button svg{stroke:currentColor;height:16px;width:16px}.delete-button:hover{background-color:#e63946;border-color:#e63946}.delete-confirm{align-items:center;display:flex;font-size:.8rem;gap:8px}.delete-confirm-yes{background-color:#ff4d4f;background-color:var(--card-danger);border:1px solid #ff4d4f;border-color:var(--card-danger);border-radius:.25rem;color:#fff}.delete-confirm-no,.delete-confirm-yes{align-items:center;cursor:pointer;display:inline-flex;font-size:.75rem;justify-content:center;line-height:1.25;padding:.25rem .5rem;transition:background-color .2s}.delete-confirm-no{background-color:#e6e8ea;border:1px solid #d1d5da;border-radius:.25rem;color:#24292e}.share-description{color:#6e6e6e;color:var(--text-muted);font-size:.85rem;line-height:1.4;margin-bottom:20px}.share-item{margin-bottom:20px}.share-item label{color:#1e293b;color:var(--text-main);display:block;font-size:.9rem;font-weight:600;margin-bottom:6px}.share-input-group{display:flex;gap:8px}.share-input{background:#f8fafc;background:var(--bg-light-alt);border:1px solid #d1d5da;border:1px solid var(--border);border-radius:6px;color:#1e293b;color:var(--text-main);flex:1 1;font-size:.85rem;padding:8px 12px}.copy-button{align-items:center;background-color:#3b5cd3;background-color:var(--primary-accent);border:1px solid #3b5cd3;border-color:var(--primary-accent);border-radius:.375rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;justify-content:center;line-height:1.25;min-width:40px;padding:.5rem 1rem;transition:background-color .2s}.copy-button svg{stroke:currentColor;height:16px;width:16px}.copy-button:hover{background-color:#2c4fd6;border-color:#2c4fd6}.copy-button.copied{background-color:#47cda9;background-color:var(--card-success);border-color:#47cda9;border-color:var(--card-success)}.share-item small{color:#6e6e6e;color:var(--text-muted);display:block;font-size:.75rem;margin-top:4px}.share-warning{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;color:#856404;font-size:.85rem;margin:16px 0;padding:12px}.share-instructions{background:#f8fafc;background:var(--bg-light-alt);border-radius:6px;margin-top:20px;padding:16px}.share-instructions h5{color:#1e293b;color:var(--text-main);font-size:.9rem;margin:0 0 8px}.share-instructions ul{color:#6e6e6e;color:var(--text-muted);font-size:.8rem;line-height:1.4;margin:0;padding-left:20px}.share-instructions li{margin-bottom:4px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.time-block-action-buttons{opacity:0;pointer-events:none;transition:opacity .3s ease-in-out}.time-block:hover .time-block-action-buttons{animation:fadeInTimeBlockActions .4s ease-out;opacity:1;pointer-events:auto}@keyframes fadeInTimeBlockActions{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.action-block-segment{cursor:pointer;transition:opacity .2s ease}.action-block-segment:hover{opacity:.8}.plus-symbol{pointer-events:none}.time-block:not(:hover) .time-block-action-buttons{animation:fadeOutTimeBlockActions .3s ease-in forwards}@keyframes fadeOutTimeBlockActions{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}.toast{align-items:center;animation:slideInRight .3s ease-out;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;justify-content:space-between;line-height:1.4;max-width:500px;min-width:300px;padding:16px;position:fixed;right:20px;top:20px;z-index:10000}.toast-error{background-color:#fee;border:1px solid #fcc;color:#722}.toast-success{background-color:#efe;border:1px solid #cfc;color:#272}.toast-warning{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.toast-info{background-color:#e3f2fd;border:1px solid #bbdefb;color:#0277bd}.toast-content{align-items:center;display:flex;flex:1 1;gap:8px}.toast-icon{flex-shrink:0;font-size:16px}.toast-message{word-wrap:break-word;flex:1 1}.toast-actions{align-items:center;display:flex;gap:4px;margin-left:12px}.toast-close-btn,.toast-retry-btn{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;opacity:.7;padding:4px;transition:opacity .2s}.toast-close-btn:hover,.toast-retry-btn:hover{opacity:1}.toast-retry-btn{font-size:14px}.toast-close-btn svg{height:16px;width:16px}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.toast-container{display:flex;flex-direction:column;gap:8px;pointer-events:none;position:fixed;right:20px;top:20px;z-index:10000}.toast-container .toast{pointer-events:all;position:relative;right:auto;top:auto}.backup-modal{max-width:600px;width:90vw}.backup-tabs{border-bottom:1px solid #e2e8f0;display:flex;margin-bottom:24px}.backup-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;display:flex;font-size:14px;font-weight:500;padding:12px 16px;transition:all .2s ease}.backup-tab:hover{background-color:#f8fafc}.backup-tab.active,.backup-tab:hover{color:#3b5cd3;color:var(--primary-accent)}.backup-tab.active{border-bottom-color:#3b5cd3;border-bottom-color:var(--primary-accent)}.export-options{display:flex;flex-direction:column;gap:12px;margin-top:8px}.export-option{align-items:center;cursor:pointer;display:flex;font-size:14px;gap:8px}.export-option input[type=checkbox]{margin:0}.export-option span{-webkit-user-select:none;user-select:none}.backup-actions{display:flex;gap:12px;margin-top:24px}.create-backup-button,.download-backup-button{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;justify-content:center;padding:10px 16px;transition:all .2s ease}.create-backup-button{background:#3b5cd3;background:var(--primary-accent);border-color:#3b5cd3;border-color:var(--primary-accent);color:#fff}.create-backup-button:hover:not(:disabled){background:color-mix(in srgb,#3b5cd3 85%,#000);background:color-mix(in srgb,var(--primary-accent) 85%,#000);border-color:color-mix(in srgb,#3b5cd3 85%,#000);border-color:color-mix(in srgb,var(--primary-accent) 85%,#000)}.create-backup-button:disabled{background:#9ca3af;border-color:#9ca3af;cursor:not-allowed}.download-backup-button{background:#10b981;border-color:#10b981;color:#fff}.download-backup-button:hover{background:#059669;border-color:#059669}.backup-preview,.import-preview{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:24px;padding:16px}.backup-preview h5,.import-preview h5{color:#1e293b;font-size:16px;font-weight:600;margin:0 0 12px}.backup-info{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.backup-stat{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;justify-content:space-between;padding:8px 12px}.stat-label{color:#64748b;font-size:13px;font-weight:500}.stat-value{color:#1e293b;font-size:14px;font-weight:600}.room-selection{display:flex;flex-direction:column;gap:8px;margin-top:8px}.room-checkbox{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:8px;transition:background-color .2s ease}.room-checkbox:hover{background-color:#f8fafc}.room-checkbox input[type=checkbox]{margin:0}.room-checkbox-label{display:flex;flex-direction:column;gap:2px}.room-name{color:#1e293b;font-size:14px;font-weight:500}.room-type{color:#64748b;font-size:12px}.download-options{display:flex;flex-direction:column;gap:16px;margin-top:16px}.symbol-download-options{border-top:1px solid #e2e8f0;padding-top:16px}.symbol-download-options h6{color:#374151;font-size:14px;font-weight:600;margin:0 0 12px}.symbol-download-buttons{display:flex;gap:8px;margin-bottom:8px}.download-symbols-button{align-items:center;background-color:#f8fafc;border:1px solid #d1d5da;border-radius:6px;color:#374151;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;justify-content:center;padding:8px 12px;text-decoration:none;transition:all .2s ease}.download-symbols-button:hover:not(:disabled){background-color:#e6e8ea;border-color:#3b5cd3;color:#3b5cd3}.download-symbols-button:disabled{cursor:not-allowed;opacity:.6}.symbol-download-options small{color:#6b7280;display:block;font-size:12px;line-height:1.4}@media (max-width:768px){.mobile-onboarding{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative;width:100%}.onboarding-container{flex:1 1;flex-direction:column;margin:0 auto;max-width:90%;padding:20px}.onboarding-container,.slides-container{align-items:center;display:flex;justify-content:center}.slides-container{flex:1 1;overflow:hidden;position:relative;width:100%}.slides-wrapper{display:flex;transition:transform .3s ease-in-out;width:300%}.slide{align-items:center;display:flex;flex-shrink:0;justify-content:center;padding:20px;text-align:center;width:33.333%}.onboarding-slide{max-width:600px;width:100%}.logo-container{margin-bottom:20px}.logo{background:#fff;border:3px solid #fff;border-radius:50%;height:80px;padding:10px;width:80px}.onboarding-slide h2{font-size:2.5em;font-weight:700;margin:20px 0 10px}.onboarding-slide p{font-size:1.2em;margin:10px 0;opacity:.9}.info-box{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:15px;margin:20px 0;padding:20px}.info-box p{font-size:1.1em;margin:10px 0}.features-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr;margin:20px 0}.feature{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff1a;border:1px solid #fff3;border-radius:15px;padding:20px;text-align:center}.feature-icon{display:block;font-size:2.5em;margin-bottom:10px}.feature h3{font-size:1.4em;margin:10px 0}.feature p{font-size:1em;opacity:.8}.join-form{display:flex;flex-direction:column;gap:15px;margin:20px 0;max-width:400px;width:100%}.join-input{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff1a;border:2px solid #ffffff4d;border-radius:10px;color:#fff;font-size:1.1em;padding:15px;transition:border-color .3s ease}.join-input::placeholder{color:#ffffffb3}.join-input:focus{background:#fff3;border-color:#fffc;outline:none}.join-button{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fff3;border:2px solid #ffffff80;border-radius:10px;color:#fff;cursor:pointer;font-size:1.2em;font-weight:700;padding:15px 30px;transition:all .3s ease}.join-button:hover:not(:disabled){background:#ffffff4d;border-color:#fffc;transform:translateY(-2px)}.join-button:disabled{cursor:not-allowed;opacity:.5}.error-message{background:#ff6b6b1a;border:1px solid #ff6b6b4d;border-radius:8px;color:#ff6b6b;font-size:1em;padding:10px;text-align:center}.skip-text{font-size:1em;margin-top:20px;opacity:.8}.skip-button{background:none;border:none;color:#fff;cursor:pointer;font-size:1em;text-decoration:underline;transition:opacity .3s ease}.skip-button:hover{opacity:.7}.navigation{align-items:center;display:flex;flex-direction:column;gap:20px;margin-top:30px}.dots-container{display:flex;gap:10px;justify-content:center}.dot{background:#0000;border:2px solid #ffffff80;border-radius:50%;cursor:pointer;height:12px;transition:all .3s ease;width:12px}.dot.active{background:#fff;border-color:#fff}.dot:hover{border-color:#fffc}.nav-buttons{display:flex;gap:15px;justify-content:center}.nav-button{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fff3;border:2px solid #ffffff80;border-radius:25px;color:#fff;cursor:pointer;font-size:1.1em;padding:12px 24px;transition:all .3s ease}.nav-button:hover:not(:disabled){background:#ffffff4d;border-color:#fffc;transform:translateY(-2px)}.nav-button:disabled{cursor:not-allowed;opacity:.5}.nav-button.complete{background:#4caf504d;border-color:#4caf50cc}.nav-button.complete:hover:not(:disabled){background:#4caf5080}.mobile-onboarding.landscape{padding:10px}.mobile-onboarding.landscape .features-grid{grid-template-columns:repeat(3,1fr)}.mobile-onboarding.landscape .join-form{max-width:500px}.mobile-onboarding.landscape .onboarding-slide h2{font-size:2em}}@media (max-width:568px) and (orientation:landscape){.mobile-onboarding.landscape .features-grid{grid-template-columns:1fr}.mobile-onboarding.landscape .onboarding-slide h2{font-size:1.8em}.mobile-onboarding.landscape .feature{padding:15px}.mobile-onboarding.landscape .logo{height:60px;width:60px}}@media (max-width:768px){.mobile-room-modal{align-items:center;box-sizing:border-box;display:flex;height:100%;justify-content:center;padding:20px;width:100%}.room-modal-content{display:flex;flex-direction:column;gap:25px;max-width:400px;width:100%}.current-room-section,.join-room-section{background:#fff;border:1px solid #e0e0e0;border-radius:15px;box-shadow:0 4px 15px #0000001a;padding:20px}.current-room-section h3,.join-room-section h3{color:#333;font-size:1.2em;margin:0 0 15px;text-align:center}.room-info-card{background:#f8f9fa;border:2px solid #e9ecef;border-radius:10px;padding:15px;text-align:center}.room-info-card.offline{background:#ffeaea;border-color:#ffcdd2}.room-name{color:#333;font-size:1.3em;font-weight:700;margin-bottom:5px}.room-code{color:#666;font-family:monospace;font-size:.9em;margin-bottom:10px}.room-status{align-items:center;display:flex;font-size:.9em;font-weight:500;gap:6px;justify-content:center}.room-status.connected{color:#4caf50}.room-status.disconnected{color:#f44336}.status-dot{border-radius:50%;display:inline-block;height:8px;width:8px}.room-status.connected .status-dot{background:#4caf50;box-shadow:0 0 6px #4caf5099}.room-status.disconnected .status-dot{background:#f44336;box-shadow:0 0 6px #f4433699}.join-room-button{background:#2196f3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1em;padding:12px;transition:background-color .3s ease;width:100%}.join-room-button:hover{background:#1976d2}.join-form{display:flex;flex-direction:column;gap:12px}.join-input{border:2px solid #e0e0e0;border-radius:8px;font-size:1em;padding:12px;transition:border-color .3s ease}.join-input:focus{border-color:#2196f3;outline:none}.error-message{background:#ffebee;border:1px solid #ffcdd2;border-radius:6px;color:#f44336;font-size:.9em;padding:8px;text-align:center}.join-buttons{display:flex;gap:10px}.join-button{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:.9em;padding:10px;transition:all .3s ease}.join-button.primary{background:#4caf50;color:#fff}.join-button.primary:hover:not(:disabled){background:#45a049}.join-button.primary:disabled{background:#ccc;cursor:not-allowed}.join-button.secondary{background:#f5f5f5;border:1px solid #ddd;color:#666}.join-button.secondary:hover{background:#e0e0e0}.quick-actions{background:#2196f31a;border:1px solid #2196f333;border-radius:10px;padding:15px;text-align:center}.action-hint{color:#1976d2;font-size:.9em;font-style:italic}.mobile-room-modal.landscape .room-modal-content{max-width:500px}.mobile-room-modal.landscape .current-room-section,.mobile-room-modal.landscape .join-room-section{padding:15px}}@media (max-width:568px) and (orientation:landscape){.mobile-room-modal.landscape .room-modal-content{gap:20px;max-width:400px}.mobile-room-modal.landscape .current-room-section h3,.mobile-room-modal.landscape .join-room-section h3{font-size:1.1em}.mobile-room-modal.landscape .room-name{font-size:1.2em}}@media (max-width:768px){.mobile-clock{box-sizing:border-box;height:100%;justify-content:center;padding:10px}.mobile-clock,.mobile-clock-container{align-items:center;display:flex;width:100%}.mobile-clock-container{flex-direction:column;gap:12px;max-width:320px}.mobile-clock-svg{filter:drop-shadow(0 4px 15px rgba(0,0,0,.1));height:auto;max-width:280px;width:100%}.mobile-clock-info{font-family:Baloo\ 2,sans-serif;text-align:center}.block-count{color:#3a0ca3;font-size:.9em;font-weight:600}.mobile-clock.landscape{padding:5px}.mobile-clock.landscape .mobile-clock-container{flex-direction:row;gap:20px;max-width:none}.mobile-clock.landscape .mobile-clock-svg{max-width:200px}.mobile-clock.landscape .mobile-clock-info{text-align:left}}@media (max-width:568px) and (orientation:landscape){.mobile-clock.landscape .mobile-clock-svg{max-width:160px}.mobile-clock.landscape .block-count{font-size:.8em}}@media (max-width:375px){.mobile-clock .mobile-clock-svg{max-width:240px}}@media (max-width:768px){.mobile-weekly-planner{align-items:center;box-sizing:border-box;display:flex;font-family:Baloo\ 2,sans-serif;height:100%;justify-content:center;padding:10px;width:100%}.mobile-weekly-container{max-width:100%;overflow-x:auto;width:100%}.mobile-weekly-planner-grid{display:flex;gap:6px;min-width:-webkit-min-content;min-width:min-content}.mobile-weekly-day{border-radius:8px;box-shadow:0 4px 12px #0000001a;display:flex;flex:0 0 auto;flex-direction:column;min-height:120px;overflow:hidden;width:70px}.mobile-weekly-day.today{border-color:red!important}.mobile-day-header{align-items:center;background:#ffffffe6;border-bottom:1px solid #0000001a;display:flex;flex-direction:column;justify-content:center;min-height:40px;padding:6px 4px;text-align:center}.mobile-day-name{color:#111827;display:block;font-size:.7rem;font-weight:700;line-height:1.2;text-transform:uppercase}.mobile-day-date{color:#4b5563;display:block;font-size:.6rem;margin-top:2px}.mobile-day-content{flex:1 1;min-height:60px;padding:6px}.mobile-day-content,.mobile-event-item{align-items:center;display:flex;flex-direction:column;gap:4px}.mobile-event-item{border-radius:6px;box-sizing:border-box;justify-content:center;padding:4px 6px;width:100%}.mobile-event-icons{align-items:center;display:flex;flex-wrap:wrap;gap:2px;justify-content:center}.mobile-event-image{border-radius:6px;object-fit:contain}.mobile-event-emoji{line-height:1}.mobile-event-title{color:#3a0ca3;font-size:.65rem;text-align:center;word-break:break-word}.mobile-no-events{align-items:center;color:#999;display:flex;font-size:.8rem;height:100%;justify-content:center}.mobile-weekly-planner.landscape{padding:5px}.mobile-weekly-planner.landscape .mobile-weekly-planner-grid{gap:8px}.mobile-weekly-planner.landscape .mobile-weekly-day{min-height:100px;width:80px}.mobile-weekly-planner.landscape .mobile-day-header{min-height:35px;padding:4px}.mobile-weekly-planner.landscape .mobile-day-content{padding:4px}}@media (max-width:568px) and (orientation:landscape){.mobile-weekly-planner.landscape .mobile-weekly-day{min-height:80px;width:65px}.mobile-weekly-planner.landscape .mobile-day-name{font-size:.6rem}.mobile-weekly-planner.landscape .mobile-day-date{font-size:.5rem}}@media (max-width:375px){.mobile-weekly-planner .mobile-weekly-day{width:60px}.mobile-weekly-planner .mobile-day-name{font-size:.6rem}}@media (max-width:768px){.mobile-countdowns{align-items:center;box-sizing:border-box;display:flex;font-family:Baloo\ 2,sans-serif;height:100%;justify-content:center;padding:10px;width:100%}.mobile-countdowns-container{max-width:100%;overflow-x:auto;width:100%}.mobile-countdowns-list{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;min-width:-webkit-min-content;min-width:min-content;padding:5px}.mobile-countdown-widget{align-items:center;border-radius:8px;box-shadow:0 4px 12px #0000001a;display:flex;flex-direction:column;min-width:100px;overflow:hidden}.mobile-countdown-widget.expired{filter:grayscale(50%);opacity:.6}.mobile-countdown-top{align-items:center;background:#ffffffe6;border-bottom:1px solid #0000001a;box-sizing:border-box;display:flex;gap:4px;justify-content:center;padding:8px;width:100%}.mobile-countdown-number{color:#3a0ca3;display:inline-block;font-size:20px;font-weight:700;text-align:center;width:2ch}.mobile-countdown-mult{color:#3a0ca3;font-size:18px;font-weight:700}.mobile-countdown-icons{align-items:center;display:flex;flex-wrap:wrap;gap:4px;justify-content:center}.mobile-countdown-icon{object-fit:contain;-webkit-user-select:none;user-select:none}.mobile-countdown-arrow{align-items:center;display:flex;justify-content:center;padding:4px 0}.mobile-countdown-arrow span{color:#3a0ca3;font-size:28px;font-weight:600;line-height:1}.mobile-countdown-bottom{box-sizing:border-box;display:flex;justify-content:center;padding:4px 8px 8px;width:100%}.mobile-no-countdowns{padding:40px 20px;text-align:center}.mobile-no-countdowns .no-countdowns-icon{display:block;font-size:48px;margin-bottom:16px;opacity:.5}.mobile-no-countdowns h3{color:#333;font-size:1.2em;margin:0 0 8px}.mobile-no-countdowns p{color:#666;font-size:.9em;margin:0}.mobile-countdowns.landscape .mobile-countdowns-list{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto}.mobile-countdowns.landscape .mobile-countdown-widget{min-width:90px}.mobile-countdowns.landscape .mobile-countdown-number{font-size:18px}.mobile-countdowns.landscape .mobile-countdown-arrow span{font-size:24px}}@media (max-width:568px) and (orientation:landscape){.mobile-countdowns.landscape .mobile-countdown-widget{min-width:80px}.mobile-countdowns.landscape .mobile-countdown-top{padding:6px}.mobile-countdowns.landscape .mobile-countdown-number{font-size:16px}.mobile-countdowns.landscape .mobile-countdown-arrow span{font-size:20px}.mobile-countdowns.landscape .mobile-countdown-bottom{padding:4px 6px 6px}}@media (max-width:768px){.mobile-slider{background:#fff;display:flex;flex-direction:column;font-family:Baloo\ 2,sans-serif;height:100%;overflow:hidden;position:relative;width:100%}.room-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #0000001a;box-shadow:0 2px 10px #0000000d;display:flex;justify-content:space-between;padding:10px 15px;z-index:100}.room-info{display:flex;flex-direction:column;gap:2px}.room-name{color:#3a0ca3;font-size:1.1em;font-weight:700}.room-code{color:#666;font-family:monospace;font-size:.85em}.connection-status{align-items:center;display:flex;gap:8px}.status-dot{border-radius:50%;display:inline-block;height:10px;width:10px}.status-dot.connected{background:#4caf50;box-shadow:0 0 8px #4caf5099}.status-dot.disconnected{background:#f44336;box-shadow:0 0 8px #f4433699}.status-text{color:#666;font-size:.85em;font-weight:500}.slides-container{background:#f8fafc;flex:1 1;overflow:hidden;position:relative;touch-action:pan-x}.slides-wrapper{transition:transform .3s ease-out}.slide,.slides-wrapper{display:flex;height:100%}.slide{align-items:center;background:#f8fafc;flex-shrink:0;justify-content:center;position:relative}.slide:not(:last-child){border-right:1px solid #e0e0e0}.slide.active{z-index:10}.slide-content{box-sizing:border-box;height:100%;justify-content:center;padding:15px;width:100%}.navigation,.slide-content{align-items:center;display:flex}.navigation{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-top:1px solid #0000001a;flex-direction:column;gap:8px;padding:12px 15px}.dots-container{align-items:center;display:flex;gap:12px;justify-content:center}.dot{background:#0000;border:2px solid #3a0ca3;border-radius:50%;cursor:pointer;height:12px;position:relative;transition:all .3s ease;width:12px}.dot:hover{border-color:#8338ec;transform:scale(1.1)}.dot.active{background:#3a0ca3;border-color:#3a0ca3;box-shadow:0 0 8px #3a0ca366}.dot.active:after{animation:pulse 2s infinite;border:1px solid #3a0ca34d;border-radius:50%;bottom:-4px;content:"";left:-4px;position:absolute;right:-4px;top:-4px}@keyframes pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.1;transform:scale(1.2)}}.slide-title{color:#3a0ca3;font-size:1em;font-weight:600;min-height:1.5em;text-align:center}.arrow-nav,.slide-title{align-items:center;display:flex;justify-content:center}.arrow-nav{gap:20px}.nav-arrow{align-items:center;background:#fff;border:2px solid #3a0ca3;border-radius:50%;color:#3a0ca3;cursor:pointer;display:flex;font-size:1.1em;font-weight:600;height:36px;justify-content:center;transition:all .3s ease;width:36px}.nav-arrow:hover:not(:disabled){background:#f8f0ff;border-color:#8338ec;color:#8338ec;transform:scale(1.05)}.nav-arrow:disabled{cursor:not-allowed;opacity:.3}.mobile-slider.landscape .room-header{padding:8px 20px}.mobile-slider.landscape .navigation{flex-direction:row;justify-content:space-between;padding:8px 15px}.mobile-slider.landscape .dots-container{gap:15px}.mobile-slider.landscape .dot{height:14px;width:14px}.mobile-slider.landscape .slide-content{padding:10px}.slide-content.loading{opacity:.6;pointer-events:none}.slide-content.loading:after{animation:spin 1s linear infinite;border:2px solid #ccc;border-radius:50%;border-top-color:#3a0ca3;content:"";height:20px;left:50%;margin:-10px 0 0 -10px;position:absolute;top:50%;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.slide-enter{opacity:0;transform:translateX(100%)}.slide-enter-active{transition:all .3s ease-out}.slide-enter-active,.slide-exit{opacity:1;transform:translateX(0)}.slide-exit-active{opacity:0;transform:translateX(-100%);transition:all .3s ease-out}.slides-container:active{cursor:grabbing}.slide-content:active{transform:scale(.99);transition:transform .1s ease}}@media (max-width:568px) and (orientation:landscape){.mobile-slider.landscape .room-header{padding:6px 15px}.mobile-slider.landscape .room-name{font-size:1em}.mobile-slider.landscape .navigation{padding:6px 10px}.mobile-slider.landscape .dots-container{gap:10px}.mobile-slider.landscape .dot{height:10px;width:10px}.mobile-slider.landscape .slide-title{font-size:.9em}.mobile-slider.landscape .nav-arrow{font-size:1em;height:30px;width:30px}}@media (max-width:768px){.mobile-app{background:#f5f5f5;font-family:Baloo\ 2,sans-serif;height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100vw}.mobile-app.landscape{justify-content:center}.mobile-app.landscape,.mobile-app.portrait{align-items:center;display:flex;flex-direction:column}.mobile-app.portrait{justify-content:flex-start;padding-top:0}.mobile-app{font-size:14px}.mobile-app.landscape{padding:0}.mobile-beta-overlay{align-items:center;background:#0009;bottom:0;box-sizing:border-box;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.mobile-beta-popup{animation:popupSlideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000004d;max-width:340px;padding:24px;position:relative;text-align:center;width:100%}@keyframes popupSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.mobile-beta-close{align-items:center;background:#f0f0f0;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;line-height:1;position:absolute;right:12px;top:12px;transition:all .2s ease;width:32px}.mobile-beta-close:hover{background:#e0e0e0;color:#333}.mobile-beta-close:active{transform:scale(.95)}.mobile-beta-icon{font-size:48px;margin-bottom:12px}.mobile-beta-title{color:#3a0ca3;font-size:1.4em;font-weight:700;margin:0 0 16px}.mobile-beta-text{color:#555;font-size:.95em;line-height:1.5;margin:0 0 12px}.mobile-beta-text strong{color:#3a0ca3}.mobile-beta-button{background:#3a0ca3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:Baloo\ 2,sans-serif;font-size:1em;font-weight:600;margin-top:8px;padding:12px 32px;transition:all .2s ease}.mobile-beta-button:hover{background:#2d0a7d;transform:translateY(-1px)}.mobile-beta-button:active{transform:translateY(0)}}@media (max-width:480px){.mobile-app{font-size:12px}.mobile-beta-popup{max-width:300px;padding:20px}.mobile-beta-icon{font-size:40px}.mobile-beta-title{font-size:1.2em}.mobile-beta-text{font-size:.9em}}@media (max-width:568px) and (orientation:landscape){.mobile-app.landscape{padding:0}.mobile-beta-popup{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;gap:12px;max-width:400px;padding:16px 20px}.mobile-beta-close{font-size:20px;height:28px;right:8px;top:8px;width:28px}.mobile-beta-icon{font-size:36px;margin-bottom:0}.mobile-beta-title{flex:1 1;font-size:1.1em;margin:0;text-align:left}.mobile-beta-text{font-size:.85em;margin-bottom:8px;width:100%}.mobile-beta-button{font-size:.9em;padding:10px 24px}}