@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700&family=Space+Grotesk:wght@500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;width:100%;min-height:100vh}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--color-primary: #6366f1;--color-primary-dark: #4f46e5;--color-accent: #f59e0b;--color-accent-hover: #fbbf24;--color-surface-dark: #0f0f1a;--color-surface-light: #f8fafc;--gradient-main: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);--gradient-dark: linear-gradient(135deg, #1e1b4b 0%, #312e81 100%);--font-display: "Space Grotesk", sans-serif;--font-body: "DM Sans", sans-serif}.landing-page{width:100%;min-height:100vh;background:var(--gradient-main);color:#fff;font-family:var(--font-body);overflow-x:hidden}.landing-header{padding:1rem 2rem;position:fixed;top:0;left:0;right:0;z-index:100;background:#6366f1d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.1)}.landing-header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.landing-logo{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-weight:700;font-size:1.25rem;letter-spacing:-.02em}.landing-logo .logo-icon{font-weight:800}.landing-nav{display:flex;gap:.75rem;align-items:center}.nav-link{color:#ffffffe6;text-decoration:none;font-weight:500;font-size:.95rem;transition:all .2s;background:none;border:none;cursor:pointer;padding:.6rem 1rem;border-radius:8px}.nav-link:hover{color:#fff;background:#ffffff1a}.sign-in-link{background:#ffffff26;border:1px solid rgba(255,255,255,.2)}.sign-in-link:hover{background:#ffffff40;border-color:#ffffff4d}.hero-section{padding:8rem 2rem 4rem;max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:3rem;align-items:center}.hero-content{max-width:560px}.hero-title{font-family:var(--font-display);font-size:3.5rem;font-weight:700;line-height:1.08;margin-bottom:1.5rem;letter-spacing:-.03em}.hero-subtitle{font-size:1.25rem;line-height:1.6;opacity:.9;margin-bottom:.75rem}.hero-friction-reducer{font-size:1rem;opacity:.75;margin-bottom:2rem;font-weight:500}.hero-cta{display:flex;gap:1rem}.cta-button{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;border-radius:10px;font-family:var(--font-display);font-weight:600;font-size:1rem;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);border:none;cursor:pointer}.cta-button.primary{background:#fff;color:var(--color-primary)}.cta-button.primary:hover{background:#fffffff2;transform:translateY(-2px);box-shadow:0 12px 32px #0003}.cta-button.accent{background:var(--color-accent);color:#1a1a2e}.cta-button.accent:hover{background:var(--color-accent-hover);transform:translateY(-2px);box-shadow:0 12px 32px #f59e0b59}.cta-button.secondary{background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.25)}.cta-button.secondary:hover{background:#fff3;border-color:#fff6}.cta-button.large{padding:1.1rem 2.25rem;font-size:1.1rem}.cta-arrow{transition:transform .2s;font-size:1.1em}.cta-button:hover .cta-arrow{transform:translate(4px)}.hero-image{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 0}.screenshot-stack{position:relative;width:100%;max-width:600px;aspect-ratio:16 / 10}.screenshot-layer{position:absolute;border-radius:12px;overflow:hidden;box-shadow:0 25px 50px -12px #0006,0 0 0 1px #ffffff1a;transition:all .4s cubic-bezier(.4,0,.2,1)}.screenshot-layer .screenshot-image{width:100%;height:auto;display:block}.screenshot-layer.layer-1{width:85%;top:-12%;left:0;z-index:1;opacity:.6;filter:brightness(.7)}.screenshot-layer.layer-2{width:88%;top:-6%;left:4%;z-index:2;opacity:.75;filter:brightness(.8)}.screenshot-layer.layer-3{width:92%;top:0%;left:6%;z-index:3;opacity:.9}.screenshot-layer.layer-4{width:96%;top:6%;left:4%;z-index:4;box-shadow:0 30px 60px -15px #00000080,0 0 0 1px #ffffff26,0 0 80px #6366f126}.screenshot-stack:hover .screenshot-layer.layer-1{transform:translate(-8px,-8px) rotate(-1deg);opacity:.7}.screenshot-stack:hover .screenshot-layer.layer-2{transform:translate(-4px,-4px) rotate(-.5deg);opacity:.85}.screenshot-stack:hover .screenshot-layer.layer-3{transform:translate(2px,2px) rotate(.3deg);opacity:.95}.screenshot-stack:hover .screenshot-layer.layer-4{transform:translate(6px,6px) scale(1.02);box-shadow:0 35px 70px -15px #00000080,0 0 0 1px #fff3,0 0 100px #6366f133}.value-section{padding:4rem 2rem;background:#0000001f;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}.value-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}.value-card{text-align:center;padding:2rem 1.5rem;background:#ffffff0f;border-radius:16px;border:1px solid rgba(255,255,255,.08);transition:all .25s ease}.value-card:hover{background:#ffffff1a;transform:translateY(-4px);border-color:#ffffff26}.value-icon{width:80px;height:80px;margin:0 auto 1.25rem;background:linear-gradient(135deg,#ffffff26,#ffffff0d);border-radius:20px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.1)}.value-icon svg{width:40px;height:40px}.value-card h3{font-family:var(--font-display);font-size:1.35rem;margin-bottom:.6rem;letter-spacing:-.02em}.value-card p{opacity:.8;line-height:1.6;font-size:.95rem}.section-title{font-family:var(--font-display);font-size:2rem;text-align:center;margin-bottom:2.5rem;letter-spacing:-.02em}.pricing-section{padding:4rem 2rem;max-width:900px;margin:0 auto}.pricing-section .section-title{margin-bottom:2rem}.pricing-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.pricing-card{background:#ffffff14;border-radius:20px;padding:2rem 1.75rem;position:relative;display:flex;flex-direction:column;transition:all .25s ease;border:1px solid rgba(255,255,255,.1)}.pricing-card:hover{transform:translateY(-4px);background:#ffffff1f}.pricing-card.pro-card{background:linear-gradient(135deg,#f59e0b26,#fbbf2414);border:1px solid rgba(245,158,11,.3)}.pricing-card.pro-card:hover{background:linear-gradient(135deg,#f59e0b33,#fbbf241f);box-shadow:0 20px 40px #f59e0b26}.pricing-header{text-align:center;margin-bottom:1.25rem}.pricing-header h3{font-family:var(--font-display);font-size:1.5rem;margin-bottom:.25rem;letter-spacing:-.02em}.pricing-tagline{opacity:.65;font-size:.875rem;margin-bottom:.75rem}.pricing-price{display:flex;align-items:baseline;justify-content:center;gap:.25rem}.pricing-price .price{font-family:var(--font-display);font-size:2.75rem;font-weight:700;letter-spacing:-.03em}.pricing-price .period{font-size:1rem;opacity:.6}.pricing-features{list-style:none;padding:0;margin:0;flex:1}.pricing-features li{display:flex;align-items:center;gap:.65rem;padding:.45rem 0;font-size:.9rem}.pricing-features li svg{width:18px;height:18px;flex-shrink:0;color:#fff9}.pricing-features li.highlight{font-weight:600;color:var(--color-accent-hover)}.pricing-features li.highlight svg{color:var(--color-accent-hover)}.pricing-card .cta-button{display:flex;width:100%;justify-content:center;margin-top:1.5rem;box-sizing:border-box;padding-top:1.5rem}.premium-spotlight{padding:4rem 2rem;background:linear-gradient(180deg,#00000026,#00000040);border-top:1px solid rgba(255,255,255,.08)}.spotlight-content{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}.spotlight-text h2{font-family:var(--font-display);font-size:2rem;margin-bottom:1rem;letter-spacing:-.02em}.spotlight-text p{font-size:1.05rem;line-height:1.7;opacity:.85;margin-bottom:1.25rem}.spotlight-features{list-style:none;padding:0;margin:0}.spotlight-features li{padding:.4rem 0 .4rem 1.5rem;position:relative;font-size:.95rem}.spotlight-features li:before{content:"→";position:absolute;left:0;color:var(--color-accent);font-weight:600}.spotlight-visual{display:flex;justify-content:center;align-items:center}.spotlight-image{width:100%;max-width:500px;height:auto;border-radius:16px;box-shadow:0 25px 50px #00000059,0 0 0 1px #ffffff1a;transition:transform .3s ease,box-shadow .3s ease}.spotlight-image:hover{transform:scale(1.02);box-shadow:0 30px 60px #0006,0 0 0 1px #ffffff26}.cta-section{padding:4.5rem 2rem;text-align:center;max-width:600px;margin:0 auto}.cta-section h2{font-family:var(--font-display);font-size:2.25rem;margin-bottom:.75rem;letter-spacing:-.02em}.cta-section p{font-size:1.15rem;opacity:.85;margin-bottom:1.75rem}.landing-footer{padding:2.5rem 2rem;background:#00000040;border-top:1px solid rgba(255,255,255,.08)}.footer-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.25rem}.footer-brand{display:flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:600}.footer-links{display:flex;gap:1.75rem}.footer-links a{color:#ffffffb3;text-decoration:none;font-size:.9rem;transition:color .2s}.footer-links a:hover{color:#fff}.footer-copyright{opacity:.5;font-size:.85rem}@media(max-width:968px){.hero-section{grid-template-columns:1fr;text-align:center;padding-top:7rem;padding-bottom:3rem;gap:2.5rem}.hero-content{max-width:100%}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.hero-cta{justify-content:center}.hero-image{max-width:550px;margin:0 auto;align-items:center;padding:1rem 0 3rem}.screenshot-stack{max-width:480px}.value-grid{grid-template-columns:1fr;gap:1.25rem;max-width:450px;margin:0 auto}.value-card{padding:1.5rem}.pricing-grid{grid-template-columns:1fr;max-width:380px;margin:0 auto;gap:1.25rem}.spotlight-content{grid-template-columns:1fr;text-align:center;gap:2rem}.spotlight-features{display:inline-block;text-align:left}.spotlight-visual{order:-1}.spotlight-image{max-width:400px}}@media(max-width:600px){.landing-header{padding:.875rem 1.25rem}.landing-header-content{gap:.75rem}.landing-logo{font-size:1.1rem}.landing-nav{gap:.5rem}.nav-link{padding:.5rem .75rem;font-size:.875rem}.hero-section{padding:6rem 1.25rem 2.5rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.hero-friction-reducer{font-size:.9rem}.cta-button{padding:.75rem 1.25rem;font-size:.9rem}.screenshot-stack{max-width:100%}.screenshot-layer.layer-1{width:88%;top:0;left:0}.screenshot-layer.layer-2{width:90%;top:6%;left:3%}.screenshot-layer.layer-3{width:94%;top:12%;left:4%}.screenshot-layer.layer-4{width:98%;top:18%;left:2%}.value-section,.pricing-section,.premium-spotlight,.cta-section{padding:3rem 1.25rem}.section-title{font-size:1.6rem}.value-icon{width:64px;height:64px}.value-icon svg{width:32px;height:32px}.value-card h3{font-size:1.15rem}.pricing-card{padding:1.5rem 1.25rem}.pricing-header h3{font-size:1.35rem}.pricing-price .price{font-size:2.25rem}.spotlight-text h2{font-size:1.6rem}.spotlight-text p{font-size:.95rem}.cta-section h2{font-size:1.75rem}.cta-section p{font-size:1rem}.footer-content{flex-direction:column;text-align:center;gap:1rem}.footer-links{flex-wrap:wrap;justify-content:center;gap:1.25rem}}:root{--row-height: 70px;--month-label-width: 50px;--weekend-color: rgba(130, 88, 159, .25);--border-color: #e0e0e0;--bg-color: #f9f9f9;--event-bar-height: 18px;--milestone-size: 16px;--event-baseline-offset: 10px;--event-lane-gap: 2px}.calendar-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background-color:#f5f0f1;padding:20px;color:#333;min-height:100vh;display:flex;flex-direction:column;justify-content:center;box-sizing:border-box}.edit-toggle-btn{padding:8px 20px;font-size:14px;font-weight:600;border:2px solid #4a90d9;border-radius:6px;background:#fff;color:#4a90d9;cursor:pointer;transition:all .2s ease}.edit-toggle-btn:hover,.edit-toggle-btn.active{background:#4a90d9;color:#fff}.calendar-container{width:100%;background:#fff;padding:20px;box-sizing:border-box;transition:box-shadow .3s ease}.calendar-container.edit-mode-active{box-shadow:0 0 0 3px #4a90d9}.calendar-wrapper{width:100%}.grid-row{display:grid;grid-template-columns:var(--month-label-width) repeat(var(--total-columns),1fr) var(--month-label-width)}.month-label-right{position:sticky;right:0;border-left:2px solid var(--border-color);border-right:none;box-shadow:-2px 0 5px #0000000d}.calendar-header-row{height:40px;border-bottom:2px solid var(--border-color);font-weight:700;color:#666;position:sticky;top:0;background:#fff;z-index:10}.header-cell{display:flex;align-items:center;justify-content:center;border-right:1px solid var(--border-color);font-size:10px}.header-cell.weekend-header{background-color:var(--weekend-color)}.month-row-container{position:relative;height:var(--row-height);border-bottom:1px solid var(--border-color)}.month-label-cell{position:sticky;left:0;background:#fff;z-index:5;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;border-right:2px solid var(--border-color);box-shadow:2px 0 5px #0000000d}.day-cell{height:100%;border-right:1px solid var(--border-color);background-color:var(--bg-color);position:relative;display:flex;align-items:flex-start;justify-content:center;padding-top:2px}.day-cell.empty-cell{background-color:#eee}.day-number{font-size:9px;color:#666}.day-cell.weekend{background-color:var(--weekend-color)}.day-cell.weekend.empty-cell{background-color:#82589f1a}.day-cell.today{background-color:#ffdf0080;border:2px solid gold}.today-marker{position:absolute;bottom:2px;left:50%;transform:translate(-50%);font-size:9px;font-weight:700;background:gold;padding:2px 4px;border-radius:4px}.event-bar{position:absolute;height:var(--event-bar-height);border-radius:3px;padding:0 6px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 1px 3px #00000026;box-sizing:border-box;z-index:2;opacity:.9;transition:all .2s ease;cursor:pointer}.event-bar:hover{opacity:1;z-index:10;box-shadow:0 4px 8px #00000040}.user-panel{background:#f8f9fa;border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;margin-bottom:16px}.user-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-weight:600;font-size:14px;color:#555}.add-user-btn{padding:4px 12px;font-size:12px;font-weight:600;border:1px solid #4a90d9;border-radius:4px;background:#fff;color:#4a90d9;cursor:pointer;transition:all .2s ease}.add-user-btn:hover{background:#4a90d9;color:#fff}.user-list{display:flex;flex-wrap:wrap;gap:8px}.user-item{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border-color);border-radius:6px;padding:6px 10px}.user-color-swatch{width:16px;height:16px;border-radius:50%;flex-shrink:0}.user-name-input{border:none;background:transparent;font-size:13px;width:80px;padding:2px 4px;border-radius:4px}.user-name-input:focus{outline:none;background:#f0f0f0}.delete-user-btn{border:none;background:transparent;color:#999;font-size:18px;cursor:pointer;padding:0 4px;line-height:1;transition:color .2s}.delete-user-btn:hover{color:#d9534f}.calendar-layout{display:flex;gap:16px}.calendar-layout .calendar-wrapper{flex:1;min-width:0}.event-sidebar{width:140px;flex-shrink:0;background:#f8f9fa;border:1px solid var(--border-color);border-radius:8px;padding:12px;height:fit-content;position:sticky;top:20px}.sidebar-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:13px;color:#555;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.sidebar-header .add-type-btn{width:22px;height:22px;border:1px solid #4a90d9;border-radius:4px;background:#fff;color:#4a90d9;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:all .2s ease}.sidebar-header .add-type-btn:hover{background:#4a90d9;color:#fff}.add-type-form{display:flex;gap:6px;padding:8px;background:#fff;border:1px solid var(--border-color);border-radius:6px;margin-bottom:10px}.add-type-form input[type=text]{flex:1;min-width:0;padding:4px 8px;border:1px solid var(--border-color);border-radius:4px;font-size:12px}.add-type-form input[type=color]{width:28px;height:28px;padding:0;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;flex-shrink:0}.add-type-form button{padding:4px 10px;border:1px solid #4a90d9;border-radius:4px;background:#4a90d9;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.add-type-form button:hover{background:#3a7bc8}.event-type-card{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#fff;border:1px solid var(--border-color);border-radius:6px;margin-bottom:8px;cursor:grab;transition:all .2s ease;-webkit-user-select:none;user-select:none}.event-type-card:hover{border-color:#4a90d9;box-shadow:0 2px 4px #0000001a}.event-type-card.dragging{opacity:.5;cursor:grabbing}.type-color-swatch{width:14px;height:14px;border-radius:3px;flex-shrink:0;pointer-events:none}.type-color-picker{width:20px;height:20px;padding:0;border:none;border-radius:4px;cursor:pointer;flex-shrink:0}.type-name{font-size:12px;font-weight:500;color:#333;pointer-events:none;flex:1}.delete-type-btn{margin-left:auto;width:18px;height:18px;border:none;background:transparent;color:#999;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;padding:0;transition:all .2s ease}.delete-type-btn:hover{background:#ffebee;color:#d9534f}.sidebar-hint{font-size:10px;color:#888;margin-top:8px;line-height:1.4}.day-cell.can-create{cursor:pointer}.day-cell.can-create:hover{background-color:#4a90d926}.event-bar.editable{cursor:grab}.event-bar.editable:hover{outline:2px solid white}.event-bar.selected{outline:2px solid #4a90d9;z-index:15}.event-bar.dragging{opacity:.5;cursor:grabbing}.event-bar.resizing{opacity:.7}.event-bar.resize-preview{opacity:.4;border:2px dashed rgba(255,255,255,.8);pointer-events:none;z-index:1}.resize-handle{position:absolute;top:0;bottom:0;width:8px;cursor:ew-resize;z-index:5;opacity:0;transition:opacity .2s}.event-bar.editable:hover .resize-handle{opacity:1}.resize-handle-left{left:0;border-radius:3px 0 0 3px;background:linear-gradient(to right,rgba(255,255,255,.4),transparent)}.resize-handle-right{right:0;border-radius:0 3px 3px 0;background:linear-gradient(to left,rgba(255,255,255,.4),transparent)}.resize-handle:hover{background:#ffffff80}.popover-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99}.event-popover{position:absolute;z-index:100;background:#fff;border:1px solid var(--border-color);border-radius:8px;padding:16px;box-shadow:0 4px 20px #00000026;min-width:240px}.popover-field{margin-bottom:12px}.popover-field label{display:block;font-size:11px;font-weight:600;color:#666;margin-bottom:4px;text-transform:uppercase}.popover-field input,.popover-field select{width:100%;padding:8px 10px;border:1px solid var(--border-color);border-radius:4px;font-size:13px;box-sizing:border-box}.popover-field input:focus,.popover-field select:focus{outline:none;border-color:#4a90d9}.popover-dates{display:flex;gap:12px}.popover-dates .popover-field{flex:1}.popover-delete-btn{width:100%;padding:8px;margin-top:8px;border:1px solid #d9534f;border-radius:4px;background:#fff;color:#d9534f;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.popover-delete-btn:hover{background:#d9534f;color:#fff}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}.header-left{display:flex;align-items:center;gap:8px}.header-left h1{margin:0;font-size:24px}.header-right{display:flex;align-items:center;gap:8px}.year-nav-btn{padding:6px 12px;font-size:14px;font-weight:600;border:1px solid var(--border-color);border-radius:4px;background:#fff;color:#333;cursor:pointer;transition:all .2s ease}.year-nav-btn:hover{background:#f0f0f0;border-color:#999}.year-nav-btn.today-btn{margin-left:8px;color:#4a90d9;border-color:#4a90d9}.year-nav-btn.today-btn:hover{background:#4a90d9;color:#fff}.header-btn{padding:6px 12px;font-size:13px;font-weight:500;border:1px solid var(--border-color);border-radius:4px;background:#fff;color:#555;cursor:pointer;transition:all .2s ease}.header-btn:hover{background:#f0f0f0}.header-btn:disabled{opacity:.4;cursor:not-allowed}.header-btn.active{background:#4a90d9;color:#fff;border-color:#4a90d9}.export-dropdown{position:relative}.export-dropdown .export-menu{display:none;position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:100;min-width:160px;overflow:hidden}.export-dropdown:hover .export-menu{display:block}.export-menu button{display:block;width:100%;padding:10px 14px;font-size:13px;text-align:left;border:none;background:#fff;color:#333;cursor:pointer;transition:background .2s}.export-menu button:hover{background:#f0f0f0}.calendar-grid-body{position:relative}.user-panel-section{margin-bottom:12px}.user-panel-section:last-child{margin-bottom:0}.settings-section{padding-top:12px;border-top:1px solid var(--border-color)}.toggle-setting{display:flex;align-items:center;gap:8px;font-size:13px;color:#555;cursor:pointer}.toggle-setting input[type=checkbox]{width:16px;height:16px;cursor:pointer}.event-bar.milestone{width:var(--milestone-size)!important;height:var(--milestone-size);padding:0;transform:rotate(45deg);border-radius:2px;margin:0}.event-bar.milestone .event-title,.event-bar.milestone .resize-handle{display:none}.inline-edit-input{background:transparent;border:none;color:inherit;font-size:inherit;font-weight:inherit;width:100%;padding:0;outline:none}.inline-edit-input:focus{background:#fff3;border-radius:2px}.event-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.dark-mode{background-color:#1a1a2e;color:#e0e0e0}.dark-mode .calendar-wrapper{background:#16213e}.dark-mode .calendar-header-row{background:#16213e;color:#a0a0a0}.dark-mode .month-label-cell{background:#16213e;color:#a0a0a0;border-color:#2a2a4a}.dark-mode .day-cell{background-color:#1a1a2e;border-color:#2a2a4a}.dark-mode .day-cell.empty-cell{background-color:#12121f}.dark-mode .day-cell.weekend{background-color:#82589f26}.dark-mode .day-cell.weekend.empty-cell{background-color:#82589f14}.dark-mode .day-cell.today{background-color:#ffdf0040;border-color:gold}.dark-mode .day-number{color:#888}.dark-mode .header-cell,.dark-mode .month-row-container,.dark-mode .month-label-right{border-color:#2a2a4a}.dark-mode .user-panel{background:#16213e;border-color:#2a2a4a}.dark-mode .user-item{background:#1a1a2e;border-color:#2a2a4a}.dark-mode .user-name-input{color:#e0e0e0}.dark-mode .user-name-input:focus{background:#2a2a4a}.dark-mode .settings-section{border-color:#2a2a4a}.dark-mode .toggle-setting{color:#a0a0a0}.dark-mode .event-sidebar{background:#16213e;border-color:#2a2a4a}.dark-mode .event-type-card{background:#1a1a2e;border-color:#2a2a4a;color:#e0e0e0}.dark-mode .event-type-card:hover{border-color:#4a90d9}.dark-mode .sidebar-header{color:#a0a0a0;border-color:#2a2a4a}.dark-mode .sidebar-header .add-type-btn{background:#16213e}.dark-mode .sidebar-header .add-type-btn:hover{background:#4a90d9}.dark-mode .add-type-form{background:#1a1a2e;border-color:#2a2a4a}.dark-mode .add-type-form input[type=text]{background:#16213e;border-color:#2a2a4a;color:#e0e0e0}.dark-mode .add-type-form input[type=color]{border-color:#2a2a4a}.dark-mode .type-name{color:#e0e0e0}.dark-mode .delete-type-btn{color:#666}.dark-mode .delete-type-btn:hover{background:#d9534f33;color:#ef4444}.dark-mode .sidebar-hint{color:#666}.dark-mode .event-popover{background:#16213e;border-color:#2a2a4a}.dark-mode .popover-field label{color:#888}.dark-mode .popover-field input,.dark-mode .popover-field select{background:#1a1a2e;border-color:#2a2a4a;color:#e0e0e0}.dark-mode .year-nav-btn{background:#16213e;border-color:#2a2a4a;color:#e0e0e0}.dark-mode .year-nav-btn:hover{background:#2a2a4a}.dark-mode .header-btn{background:#16213e;border-color:#2a2a4a;color:#e0e0e0}.dark-mode .header-btn:hover{background:#2a2a4a}.dark-mode .header-btn.active{background:#4a90d9;color:#fff;border-color:#4a90d9}.dark-mode .export-menu{background:#16213e;border-color:#2a2a4a}.dark-mode .export-menu button{background:#16213e;color:#e0e0e0}.dark-mode .export-menu button:hover{background:#2a2a4a}.dark-mode .edit-toggle-btn{background:#16213e;border-color:#4a90d9;color:#4a90d9}.dark-mode .edit-toggle-btn:hover,.dark-mode .edit-toggle-btn.active{background:#4a90d9;color:#fff}.dark-mode .add-user-btn{background:#16213e}.dark-mode .add-user-btn:hover{background:#4a90d9}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000}.pdf-export-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;z-index:1001;width:90%;max-width:480px;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.modal-close-btn{width:28px;height:28px;border:none;background:transparent;font-size:24px;color:#999;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close-btn:hover{background:#f0f0f0;color:#333}.modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.modal-body{padding:20px}.modal-description{margin:0 0 20px;font-size:14px;color:#666;line-height:1.5}.paper-size-selector label:first-child{display:block;font-size:13px;font-weight:600;color:#555;margin-bottom:12px;text-transform:uppercase}.paper-size-options{display:flex;flex-direction:column;gap:8px}.paper-size-option{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s}.paper-size-option:hover{border-color:#4a90d9;background:#f8fafc}.paper-size-option.selected{border-color:#4a90d9;background:#4a90d914}.paper-size-option input[type=radio]{width:18px;height:18px;cursor:pointer}.paper-size-name{flex:1;font-size:14px;color:#333}.recommended-badge{font-size:11px;font-weight:600;color:#16a34a;background:#16a34a1a;padding:4px 8px;border-radius:4px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid var(--border-color);background:#f8f9fa}.modal-cancel-btn{padding:10px 20px;font-size:14px;font-weight:500;border:1px solid var(--border-color);border-radius:6px;background:#fff;color:#555;cursor:pointer;transition:all .2s}.modal-cancel-btn:hover{background:#f0f0f0}.modal-cancel-btn:disabled{opacity:.5;cursor:not-allowed}.modal-export-btn{padding:10px 24px;font-size:14px;font-weight:600;border:none;border-radius:6px;background:#4a90d9;color:#fff;cursor:pointer;transition:all .2s}.modal-export-btn:hover{background:#3a7bc8}.modal-export-btn:disabled{background:#a0c4e8;cursor:not-allowed}.dark-mode .pdf-export-modal{background:#16213e}.dark-mode .modal-header{border-color:#2a2a4a}.dark-mode .modal-header h3{color:#e0e0e0}.dark-mode .modal-close-btn{color:#888}.dark-mode .modal-close-btn:hover{background:#2a2a4a;color:#e0e0e0}.dark-mode .modal-description,.dark-mode .paper-size-selector label:first-child{color:#a0a0a0}.dark-mode .paper-size-option{border-color:#2a2a4a;background:#1a1a2e}.dark-mode .paper-size-option:hover{border-color:#4a90d9;background:#1f1f3a}.dark-mode .paper-size-option.selected{border-color:#4a90d9;background:#4a90d926}.dark-mode .paper-size-name{color:#e0e0e0}.dark-mode .modal-footer{border-color:#2a2a4a;background:#1a1a2e}.dark-mode .modal-cancel-btn{background:#16213e;border-color:#2a2a4a;color:#a0a0a0}.dark-mode .modal-cancel-btn:hover{background:#2a2a4a}@media print{body{background:#fff!important;padding:0!important;margin:0!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color-adjust:exact!important}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color-adjust:exact!important}.calendar-container{box-shadow:none!important;padding:10mm!important}.calendar-header{page-break-after:avoid}.header-right button:not(.edit-toggle-btn),.export-dropdown,.user-panel,.event-sidebar,.popover-backdrop,.event-popover,.pdf-export-modal,.modal-backdrop{display:none!important}.edit-toggle-btn{display:none!important}.calendar-layout{display:block!important}.month-row-container{page-break-inside:avoid}.day-cell.weekend,.day-cell.today,.event-bar,.header-cell.weekend-header{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color-adjust:exact!important}.dark-mode{background-color:#fff!important;color:#333!important}.dark-mode .calendar-wrapper,.dark-mode .calendar-header-row,.dark-mode .month-label-cell,.dark-mode .day-cell{background:#fff!important;color:#333!important}.dark-mode .day-cell.weekend{background-color:#82589f40!important}}.auth-modal-overlay,.upgrade-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-modal,.upgrade-modal{background:#fff;border-radius:12px;padding:32px;width:100%;max-width:400px;position:relative;box-shadow:0 20px 60px #0000004d}.dark-mode .auth-modal,.dark-mode .upgrade-modal{background:#1a1a2e;color:#e0e0e0}.auth-modal-close,.upgrade-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:24px;cursor:pointer;color:#666;line-height:1;padding:4px}.dark-mode .auth-modal-close,.dark-mode .upgrade-modal-close{color:#aaa}.auth-modal h2,.upgrade-modal h2{margin:0 0 8px;font-size:24px;font-weight:600}.auth-subtitle{color:#666;margin-bottom:24px;font-size:14px}.dark-mode .auth-subtitle{color:#aaa}.google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:12px;border:1px solid #ddd;border-radius:8px;background:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s}.google-btn:hover{background:#f5f5f5;border-color:#ccc}.google-btn:disabled{opacity:.6;cursor:not-allowed}.dark-mode .google-btn{background:#2a2a3e;border-color:#444;color:#e0e0e0}.dark-mode .google-btn:hover{background:#3a3a4e}.auth-divider{display:flex;align-items:center;margin:20px 0;color:#999;font-size:12px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ddd}.dark-mode .auth-divider:before,.dark-mode .auth-divider:after{background:#444}.auth-divider span{padding:0 12px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500}.form-group input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#4a90d9;box-shadow:0 0 0 3px #4a90d91a}.dark-mode .form-group input{background:#2a2a3e;border-color:#444;color:#e0e0e0}.dark-mode .form-group input:focus{border-color:#4a90d9}.auth-error{background:#fee2e2;color:#dc2626;padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:16px}.auth-message{background:#dcfce7;color:#16a34a;padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:16px}.dark-mode .auth-error{background:#dc262633}.dark-mode .auth-message{background:#16a34a33}.auth-submit-btn{width:100%;padding:12px;background:#4a90d9;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.auth-submit-btn:hover{background:#3a7bc8}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed}.auth-toggle{text-align:center;margin-top:20px;font-size:14px;color:#666}.dark-mode .auth-toggle{color:#aaa}.auth-toggle button{background:none;border:none;color:#4a90d9;font-weight:600;cursor:pointer;font-size:14px}.auth-toggle button:hover{text-decoration:underline}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:8px;padding:6px 12px;background:none;border:1px solid #ddd;border-radius:20px;cursor:pointer;font-size:13px}.dark-mode .user-menu-trigger{border-color:#444;color:#e0e0e0}.user-avatar{width:28px;height:28px;border-radius:50%;background:#4a90d9;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px}.user-email{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:100;overflow:hidden}.dark-mode .user-menu-dropdown{background:#1a1a2e;border-color:#444}.user-menu-dropdown button{width:100%;padding:10px 20px;background:none;border:none;text-align:left;cursor:pointer;font-size:14px}.user-menu-dropdown button:hover{background:#f5f5f5}.dark-mode .user-menu-dropdown button{color:#e0e0e0}.dark-mode .user-menu-dropdown button:hover{background:#2a2a3e}.sign-in-prompt{padding:8px 16px;background:transparent;border:1px solid #4a90d9;color:#4a90d9;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.sign-in-prompt:hover{background:#4a90d9;color:#fff}.upgrade-icon{text-align:center;margin-bottom:16px;color:#4a90d9}.upgrade-description{color:#666;margin-bottom:24px;font-size:14px;text-align:center}.dark-mode .upgrade-description{color:#aaa}.upgrade-features{margin-bottom:24px}.upgrade-feature{display:flex;align-items:center;gap:12px;padding:8px 0;font-size:14px}.upgrade-feature svg{color:#22c55e;flex-shrink:0}.upgrade-pricing{text-align:center;margin-bottom:20px}.upgrade-price{font-size:48px;font-weight:700;color:#333}.dark-mode .upgrade-price{color:#e0e0e0}.upgrade-period{font-size:14px;color:#666}.dark-mode .upgrade-period{color:#aaa}.upgrade-error{background:#fee2e2;color:#dc2626;padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:16px;text-align:center}.dark-mode .upgrade-error{background:#dc262633}.upgrade-btn{width:100%;padding:14px;background:linear-gradient(135deg,#4a90d9,#7c3aed);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.upgrade-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4a90d966}.upgrade-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.upgrade-note{text-align:center;margin-top:16px;font-size:12px;color:#999}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.loading-spinner p{color:#666;font-size:14px}.dark-mode .loading-spinner p{color:#999}.spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#4a90d9;border-radius:50%;animation:spin .8s linear infinite}.dark-mode .spinner{border-color:#333;border-top-color:#4a90d9}@keyframes spin{to{transform:rotate(360deg)}}.calendar-container.syncing:after{content:"";position:fixed;top:10px;right:10px;width:8px;height:8px;background:#4a90d9;border-radius:50%;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:10px;max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:8px;background:#fff;box-shadow:0 4px 20px #00000026;animation:toast-in .2s ease-out}.toast-exit{animation:toast-out .2s ease-in forwards}@keyframes toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toast-out{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.toast-error{border-left:4px solid #ef4444}.toast-success{border-left:4px solid #22c55e}.toast-info{border-left:4px solid #3b82f6}.toast-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.toast-error .toast-icon{background:#fef2f2;color:#ef4444}.toast-success .toast-icon{background:#f0fdf4;color:#22c55e}.toast-info .toast-icon{background:#eff6ff;color:#3b82f6}.toast-message{flex:1;font-size:14px;color:#333;line-height:1.4}.toast-close{background:none;border:none;font-size:20px;color:#999;cursor:pointer;padding:0;line-height:1}.toast-close:hover{color:#666}.dark-mode .toast{background:#2a2a3e}.dark-mode .toast-message{color:#e0e0e0}.dark-mode .toast-close{color:#666}.dark-mode .toast-close:hover{color:#999}.legal-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9000;padding:20px}.legal-modal{background:#fff;border-radius:12px;max-width:700px;width:100%;max-height:80vh;overflow-y:auto;position:relative}.legal-modal-header{position:sticky;top:0;background:#fff;padding:24px 24px 16px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center}.legal-modal-header h2{margin:0;font-size:24px;color:#333}.legal-modal-close{background:none;border:none;font-size:28px;color:#999;cursor:pointer;padding:0;line-height:1}.legal-modal-close:hover{color:#666}.legal-modal-content{padding:24px;font-size:14px;line-height:1.7;color:#444}.legal-modal-content h3{font-size:16px;color:#333;margin:24px 0 12px}.legal-modal-content h3:first-child{margin-top:0}.legal-modal-content p{margin:0 0 12px}.legal-modal-content ul{margin:0 0 12px;padding-left:24px}.legal-modal-content li{margin-bottom:6px}.legal-modal-content a{color:#4a90d9}.dark-mode .legal-modal{background:#1a1a2e}.dark-mode .legal-modal-header{background:#1a1a2e;border-color:#333}.dark-mode .legal-modal-header h2{color:#e0e0e0}.dark-mode .legal-modal-content{color:#bbb}.dark-mode .legal-modal-content h3{color:#e0e0e0}.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:#fff;box-shadow:0 -4px 20px #0000001a;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px;z-index:8000;animation:slide-up .3s ease-out}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.cookie-banner-text{flex:1;font-size:14px;color:#444;line-height:1.5}.cookie-banner-text a{color:#4a90d9;text-decoration:underline}.cookie-banner-buttons{display:flex;gap:12px;flex-shrink:0}.cookie-btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.cookie-btn-accept{background:#4a90d9;color:#fff;border:none}.cookie-btn-accept:hover{background:#3a7bc8}.cookie-btn-decline{background:transparent;color:#666;border:1px solid #ddd}.cookie-btn-decline:hover{background:#f5f5f5}.dark-mode .cookie-banner{background:#1a1a2e}.dark-mode .cookie-banner-text{color:#bbb}.dark-mode .cookie-btn-decline{color:#999;border-color:#444}.dark-mode .cookie-btn-decline:hover{background:#2a2a3e}.app-footer{margin-top:30px;padding:20px;text-align:center;font-size:12px;color:#888}.app-footer a{color:#666;text-decoration:none;margin:0 12px}.app-footer a:hover{color:#4a90d9;text-decoration:underline}.dark-mode .app-footer{color:#666}.dark-mode .app-footer a{color:#888}.dark-mode .app-footer a:hover{color:#4a90d9}@media(max-width:600px){.cookie-banner{flex-direction:column;text-align:center}.cookie-banner-buttons{width:100%;justify-content:center}}
