:root{--bg-primary:#0a0a0f;--bg-secondary:#111119;--bg-surface:#16161f;--bg-card:#1c1c2a;--bg-card-hover:#24243a;--bg-input:#1a1a28;--accent-primary:#7c5cff;--accent-primary-hover:#9178ff;--accent-primary-glow:#7c5cff4d;--accent-secondary:#00d4aa;--accent-secondary-hover:#00eabb;--accent-danger:#ff4d6a;--text-primary:#e8e8f0;--text-secondary:#8888a0;--text-muted:#555568;--text-inverse:#0a0a0f;--border-color:#2a2a3a;--border-color-hover:#3a3a5a;--common-range-bg:#00d4aa1f;--common-range-border:#00d4aa66;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--font-family:"Rubik", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.25rem;--font-size-xl:1.6rem;--font-size-2xl:2.2rem;--font-size-3xl:2.8rem;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px var(--accent-primary-glow);--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease}*,:before,:after{box-sizing:border-box;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;margin:0;padding:0}input,textarea{-webkit-user-select:text;user-select:text}html{-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;line-height:1.6;overflow-x:hidden}#app{flex-direction:column;min-height:100dvh;display:flex}body:before{content:"";z-index:-1;background:radial-gradient(at 30% 20%,#7c5cff0f 0%,#0000 50%),radial-gradient(at 70% 80%,#00d4aa0a 0%,#0000 50%);width:200%;height:200%;animation:20s ease-in-out infinite alternate bgShift;position:fixed;top:-50%;left:-50%}@keyframes bgShift{0%{transform:translate(0)}to{transform:translate(-5%,-3%)}}.page{width:100%;max-width:600px;padding:var(--space-md);padding-bottom:calc(var(--space-2xl) + env(safe-area-inset-bottom,0px));flex-direction:column;flex:1;margin:0 auto;display:flex}.page--wide{max-width:800px}.page-header{text-align:center;margin-bottom:var(--space-xl);padding-top:var(--space-lg)}.page-header__logo{font-size:var(--font-size-3xl);background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));-webkit-text-fill-color:transparent;letter-spacing:-1px;margin-bottom:var(--space-xs);-webkit-background-clip:text;background-clip:text;font-weight:800}.page-header__subtitle{color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:400}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);transition:border-color var(--transition-normal), box-shadow var(--transition-normal)}.card:hover{border-color:var(--border-color-hover)}.card+.card{margin-top:var(--space-md)}.card__title{font-size:var(--font-size-lg);margin-bottom:var(--space-md);align-items:center;gap:var(--space-sm);font-weight:500;display:flex}.card__title svg{width:20px;height:20px;color:var(--accent-primary)}.form-group{margin-bottom:var(--space-md)}.form-group label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-xs);font-weight:400;display:block}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.form-input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-size-base);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);appearance:none;outline:none;padding:12px 16px}.form-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}.form-input::placeholder{color:var(--text-muted)}input[type=date]::-webkit-calendar-picker-indicator{filter:invert();cursor:pointer}.form-row{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-tap-highlight-color:transparent;border:1px solid #0000;outline:none;padding:12px 24px;font-weight:600;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn--primary{background:linear-gradient(135deg, var(--accent-primary), #6548e0);color:#fff;box-shadow:var(--shadow-glow)}.btn--primary:hover{background:linear-gradient(135deg, var(--accent-primary-hover), #7858f0);box-shadow:0 0 30px var(--accent-primary-glow)}.btn--secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.btn--secondary:hover{background:var(--bg-card-hover);border-color:var(--border-color-hover)}.btn--success{background:linear-gradient(135deg, var(--accent-secondary), #00b89a);color:var(--text-inverse)}.btn--success:hover{background:linear-gradient(135deg, var(--accent-secondary-hover), #00d4aa)}.btn--ghost{color:var(--text-secondary);background:0 0;padding:8px 16px}.btn--ghost:hover{background:var(--bg-card);color:var(--text-primary)}.btn--block{width:100%}.btn--sm{font-size:var(--font-size-sm);padding:8px 16px}.btn svg{width:18px;height:18px}.event-list{margin-top:var(--space-md);list-style:none}.event-list__item{align-items:center;gap:var(--space-md);border-radius:var(--radius-md);background:var(--bg-surface);border:1px solid var(--border-color);margin-bottom:var(--space-sm);transition:border-color var(--transition-fast);cursor:pointer;padding:12px 16px;display:flex}.event-list__item:hover{border-color:var(--border-color-hover)}.event-list__info{flex:1;min-width:0}.event-list__title{font-weight:500;font-size:var(--font-size-base);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.event-list__dates{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:2px}.event-list__actions{gap:var(--space-xs);flex-shrink:0;display:flex}.event-list__btn{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;display:flex}.event-list__btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.event-list__btn--danger:hover{border-color:var(--accent-danger);color:var(--accent-danger)}.event-list__btn svg{width:14px;height:14px}.modal-backdrop{z-index:200;padding:var(--space-md);background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);width:100%;max-width:400px;animation:.3s fadeUp}.modal__title{font-size:var(--font-size-lg);margin-bottom:var(--space-md);font-weight:500}.modal__text{color:var(--text-secondary);font-size:var(--font-size-base);margin-bottom:var(--space-lg)}.modal__actions{gap:var(--space-sm);justify-content:flex-end;display:flex}.btn--danger{background:var(--accent-danger);color:#fff}.btn--danger:hover{background:#ff6680}.edit-panel{margin-top:var(--space-md);margin-bottom:var(--space-md);padding:var(--space-md);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);animation:.3s fadeUp}.edit-panel .form-group:last-of-type{margin-bottom:var(--space-md)}.edit-panel__actions{gap:var(--space-sm);display:flex}.datepicker-wrapper{position:relative}.datepicker-display{cursor:pointer;text-align:left;justify-content:space-between;align-items:center;display:flex}.datepicker-display:after{content:"";border-left:5px solid #0000;border-right:5px solid #0000;border-top:5px solid var(--text-muted);width:0;height:0;margin-left:var(--space-sm);flex-shrink:0}.datepicker-dropdown{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);min-width:280px;padding:var(--space-md);z-index:50;box-shadow:var(--shadow-lg);animation:.2s fadeUp;position:absolute;top:calc(100% + 6px);left:0;right:0}.datepicker-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.datepicker-month{font-size:var(--font-size-base);font-weight:500}.datepicker-nav{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;display:flex}.datepicker-nav svg{width:16px;height:16px}.datepicker-nav:hover{background:var(--bg-card-hover);border-color:var(--border-color-hover)}.datepicker-weekdays{margin-bottom:var(--space-xs);grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.datepicker-weekday{text-align:center;font-size:var(--font-size-xs);color:var(--text-muted);padding:2px 0}.datepicker-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.datepicker-day{text-align:center;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);padding:6px 0}.datepicker-day:hover{background:var(--bg-card-hover)}.datepicker-day--empty{cursor:default}.datepicker-day--empty:hover{background:0 0}.datepicker-day--today{border:1px solid var(--accent-primary)}.datepicker-day--selected{color:#fff;background:var(--accent-primary)!important}.share-section{margin-top:var(--space-lg);animation:.5s forwards fadeUp}.share-link{align-items:center;gap:var(--space-sm);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--space-md);padding:10px 14px;display:flex}.share-link__url{font-size:var(--font-size-sm);color:var(--accent-secondary);word-break:break-all;flex:1;font-family:SF Mono,Fira Code,monospace}.share-link__copy{background:var(--accent-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);font-weight:600;font-family:var(--font-family);transition:all var(--transition-fast);border:none;flex-shrink:0;padding:8px 12px}.share-link__copy:hover{background:var(--accent-primary-hover)}.share-link__copy--copied{color:var(--text-inverse);background:var(--accent-secondary)!important}.participants-list{margin-top:var(--space-md);list-style:none}.participant-item{align-items:center;gap:var(--space-md);border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer;padding:12px 16px;display:flex}.participant-item:hover{background:var(--bg-card-hover)}.participant-item__dot{border-radius:var(--radius-full);flex-shrink:0;width:14px;height:14px}.participant-item__name{flex:1;font-weight:500}.participant-item__action{font-size:var(--font-size-sm);color:var(--accent-primary);font-weight:500}.divider{align-items:center;gap:var(--space-md);margin:var(--space-lg) 0;color:var(--text-muted);font-size:var(--font-size-sm);display:flex}.divider:before,.divider:after{content:"";background:var(--border-color);flex:1;height:1px}.calendar-grid{-webkit-user-select:none;user-select:none;grid-template-columns:24px repeat(7,1fr);gap:6px;display:grid}.calendar__label{writing-mode:vertical-lr;text-orientation:mixed;color:var(--text-muted);letter-spacing:1px;justify-content:center;align-items:center;font-size:12px;font-weight:500;display:flex;transform:rotate(180deg)}.calendar__weekday{text-align:center;font-size:var(--font-size-xs);color:var(--text-muted);padding:var(--space-xs) 0;font-weight:400}.calendar__day{border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;background:var(--bg-surface);touch-action:none;border:1px solid #0000;flex-direction:column;justify-content:flex-start;align-items:center;min-height:40px;padding-top:5px;padding-bottom:3px;font-weight:500;transition:background .15s,border-color .15s;display:flex;position:relative}.calendar__day:hover{background:#22223a}.calendar__day--empty{cursor:default;touch-action:auto;background:0 0}.calendar__day--empty:hover{background:0 0}.calendar__day--outside{opacity:.2;cursor:not-allowed;touch-action:auto;background:0 0}.calendar__day--outside:hover{background:0 0}.calendar__day--today{border-color:var(--accent-primary)}.calendar__day--self-selected{background:#7c5cff33!important}.calendar__day--self-selected:hover{background:#7c5cff4d!important}.calendar__day--common{box-shadow:inset 0 0 0 2px var(--common-range-border)}.calendar__day--deselecting{background:#121218!important}.calendar__day-number{font-size:var(--font-size-sm);z-index:1;line-height:1}.calendar__day-dots{flex-wrap:wrap;justify-content:center;gap:2px;max-width:100%;margin-top:3px;padding:0 2px;transition:opacity .15s;display:flex}.calendar__day-dot{border-radius:var(--radius-full);flex-shrink:0;width:10px;height:10px;transition:opacity .15s,transform .15s}.legend{gap:var(--space-sm);padding:var(--space-md) 0;flex-wrap:wrap;display:flex}.legend__item{font-size:var(--font-size-sm);color:var(--text-secondary);background:var(--bg-card);border-radius:var(--radius-full);border:1px solid var(--border-color);align-items:center;gap:6px;padding:4px 10px;display:flex}.legend__dot{border-radius:var(--radius-full);flex-shrink:0;width:10px;height:10px}.legend__item--self{border-color:var(--accent-primary);color:var(--text-primary)}.common-ranges{margin-top:var(--space-lg)}.common-ranges__title{font-size:var(--font-size-base);margin-bottom:var(--space-md);align-items:center;gap:var(--space-sm);font-weight:500;display:flex}.common-ranges__title svg{width:20px;height:20px;color:var(--accent-secondary)}.common-range-item{align-items:center;gap:var(--space-md);background:var(--common-range-bg);border:1px solid var(--common-range-border);border-radius:var(--radius-md);margin-bottom:var(--space-sm);padding:12px 16px;animation:.3s forwards fadeUp;display:flex}.common-range-item__dates{color:var(--accent-secondary);font-weight:400;font-size:var(--font-size-sm)}.common-range-item__duration{font-size:var(--font-size-sm);color:var(--text-secondary);background:var(--bg-card);border-radius:var(--radius-full);margin-left:auto;padding:4px 10px}.no-ranges{text-align:center;color:var(--text-muted);font-size:var(--font-size-base);padding:var(--space-lg);background:var(--bg-surface);border-radius:var(--radius-md);border:1px dashed var(--border-color)}.toolbar{padding:var(--space-sm) 0;margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.toolbar__title{font-size:var(--font-size-lg);background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.toolbar__user{align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--text-secondary);display:flex}.toolbar__user-dot{border-radius:var(--radius-full);width:10px;height:10px}.event-header{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--space-md);justify-content:space-between;align-items:center;gap:var(--space-md);padding:14px 16px;display:flex}.event-header__title{font-size:var(--font-size-lg);color:var(--text-primary);font-weight:500}.event-header__dates{font-size:var(--font-size-sm);color:var(--text-secondary);text-align:right;line-height:1.4}.info-bar{align-items:center;gap:var(--space-sm);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:var(--font-size-sm);color:var(--text-secondary);padding:10px 14px;display:flex}.info-bar svg{width:16px;height:16px;color:var(--accent-primary);flex-shrink:0}@media (width>=768px){.page{padding:var(--space-xl)}.calendar__day{min-height:48px;padding-top:6px}.calendar__day-dot{width:10px;height:10px}.calendar__day-number{font-size:var(--font-size-base)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-up{animation:.4s forwards fadeUp}.animate-fade-in{animation:.3s forwards fadeIn}.stagger-item{opacity:0;animation:.3s forwards fadeUp}.stagger-item:first-child{animation-delay:50ms}.stagger-item:nth-child(2){animation-delay:.1s}.stagger-item:nth-child(3){animation-delay:.15s}.stagger-item:nth-child(4){animation-delay:.2s}.stagger-item:nth-child(5){animation-delay:.25s}.stagger-item:nth-child(6){animation-delay:.3s}.toast{bottom:calc(24px + env(safe-area-inset-bottom,0px));background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-primary);box-shadow:var(--shadow-lg);z-index:1000;white-space:nowrap;padding:12px 20px;font-weight:500;transition:transform .3s cubic-bezier(.34,1.56,.64,1);position:fixed;left:50%;transform:translate(-50%)translateY(100px)}.toast--visible{transform:translate(-50%)translateY(0)}.loading{padding:var(--space-2xl);color:var(--text-muted);justify-content:center;align-items:center;display:flex}.loading:after{content:"";border:2px solid var(--border-color);border-top-color:var(--accent-primary);width:24px;height:24px;margin-left:var(--space-sm);border-radius:50%;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.quick-actions{gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}#counter,.logo{display:none!important}
