.infinite-calendar-wrapper{width:100%;height:calc(100vh - 70px);display:flex;flex-direction:column}.control-group input[type=month]{padding:.5rem .75rem;border-radius:6px;border:1px solid rgba(0,0,0,.2);background-color:#0000000d;color:inherit;font-size:.95rem;cursor:pointer;transition:all .2s}.control-group input[type=month]:hover{background-color:#00000014;border-color:#0000004d}.control-group input[type=month]:focus{outline:none;border-color:#3b82f699;box-shadow:0 0 0 3px #3b82f61a}.day-cell.selected{background-color:#dc262699!important;border-color:#dc2626cc!important;font-weight:600}.day-cell.selected:hover{background-color:#dc2626b3!important}.clear-selection-btn{padding:.5rem 1rem;border-radius:6px;border:1px solid rgba(220,38,38,.4);background-color:#dc262626;color:#f87171;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.clear-selection-btn:hover{background-color:#dc262640;border-color:#dc262699;color:#fca5a5}.clear-selection-btn:active{transform:scale(.98)}.minimal-view{max-width:900px;margin:0 auto;padding:0 2rem}.minimal-view .weekday-header-fixed{grid-template-columns:60px calc(50px + (100% - 110px + 28px) / 35) repeat(35,1fr);padding:.75rem 0rem;padding-left:30px}.minimal-view .month-spacer{padding-left:0}.minimal-view .weekday-cell{font-size:.6rem;min-width:0;overflow:hidden;text-overflow:clip}.minimal-view .year-view{padding:0;margin-bottom:0}.minimal-view .year-content{padding:.5rem 2rem;gap:.5rem}.minimal-view .year-grid{gap:1px}.minimal-view .month-row{grid-template-columns:50px repeat(35,1fr);gap:1px}.minimal-view .month-label{padding-left:0}.minimal-view .day-cell{background:#fff;border:1px solid rgba(0,0,0,.08);aspect-ratio:1;min-height:0;min-width:0;padding:0;font-size:.65rem}.minimal-view .day-cell.weekend:not(.empty){background-color:#26c6dc0a}.minimal-view .day-cell.empty{border:none}.minimal-view .day-cell.out-of-range:not(.empty){background-color:#00000005;border-color:#00000026;opacity:.5}.minimal-view .day-cell.out-of-range:not(.empty):hover{background-color:#0000000a;transform:none}.minimal-view .day-cell.out-of-range.weekend:not(.empty){background-color:#26c6dc33;opacity:.7}.minimal-view .day-cell.out-of-range.weekend:not(.empty):hover{background-color:#26c6dc40}.minimal-view .day-cell.out-of-range.selected{background-color:#3b82f6cc!important;border-color:#3b82f6e6!important;color:#fff;opacity:1}.minimal-view .day-cell.out-of-range.selected:hover{background-color:#3b82f699!important}.minimal-view .day-cell.in-range:not(.empty){background-color:#0000;border-color:#000c}.minimal-view .day-cell.in-range.weekend:not(.empty){background-color:#26c6dc0a}.minimal-view .day-cell.in-range:not(.empty):hover{background-color:#3b82f640;border-color:#3b82f666}.minimal-view .day-cell .day-number{opacity:0;transition:opacity .2s}.minimal-view .day-cell:hover .day-number,.minimal-view .day-cell.today .day-number{opacity:1}.minimal-view .day-cell.selected{background-color:#dc2626e6!important;border-color:#dc2626cc!important;color:#fff}.minimal-view .day-cell.selected .day-number{opacity:1;font-weight:600}.minimal-view .day-cell.selected:hover{background-color:#dc2626b3!important}.minimal-view .day-cell.in-selected-range{background-color:#93b22b80!important;border-color:#17190fcc!important;color:#93b22b00}.minimal-view .day-cell.in-selected-range .day-number{opacity:1;font-weight:500}.minimal-view .day-cell.in-selected-range:hover{background-color:#93b22bcc!important;border-color:#7c3aedbf!important;color:#3a4711cc}.minimal-view .day-cell.range-start-temp{background-color:#93b22bcc!important;border-color:#3fa32b!important;box-shadow:0 0 8px #5bed3a99;animation:pulse-range 1s ease-in-out infinite}@keyframes pulse-range{0%,to{box-shadow:0 0 8px #93b22b99}50%{box-shadow:0 0 16px #93b22be6}}.minimal-view .day-cell.empty .day-number,.minimal-view .day-cell.empty:hover .day-number{opacity:0}.base-calendar-view{width:100%;height:100%;display:flex;flex-direction:column}.calendar-fixed-header{position:sticky;top:0;z-index:50;background:#fff;padding:1rem 20px .5rem;border-bottom:2px solid #e5e7eb}.header-tagline{text-align:center;font-size:1.125rem;color:#333;font-weight:400;letter-spacing:.01em;margin-bottom:1rem}.header-grid-container{display:flex;justify-content:space-between}.header-month-label{width:30px;background:#fff}.header-grid{flex:1;max-width:780px;display:grid;grid-template-columns:repeat(35,1fr);gap:2px}.header-cell{position:relative;width:100%;padding-bottom:100%;background:#f9fafb;border:1px solid #e5e7eb;border-radius:2px;display:flex;align-items:center;justify-content:center}.header-cell.weekend{background:#fee2e2;border-color:#fecaca}.weekday-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:500;color:#6b7280;-webkit-user-select:none;user-select:none}.header-cell.weekend .weekday-label{color:#dc2626}.header-spacer{width:0}.years-container{flex:1;overflow-y:auto;padding:20px}.year-single{position:relative;border-top:2px solid #000;padding:15px 0}.year-header{position:absolute;left:0;font-size:24px;font-weight:700;margin-bottom:16px;color:#333;background:#fff;top:-15px;font-size:18px;padding-right:10px}.year-divider{width:100%;height:2px;background:#000;margin:5px 0}.months-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.month-block{padding:12px;background:#f0f0f0;border-radius:8px}.month-name{font-size:14px;font-weight:600;color:#666;text-align:center;width:30px;background:#fff}.month-grid{flex:1;max-width:780px;display:grid;grid-template-columns:repeat(35,1fr);gap:2px}.month-single{display:flex;justify-content:space-between;padding-bottom:2px}.day-single-cell{position:relative;width:100%;padding-bottom:100%;background:#fff;border:1px solid #cbcbcb;border-radius:2px;box-sizing:border-box;cursor:pointer;display:flex;justify-content:center}.day-single-cell:hover{background-color:#3b82f633;border-color:#3b82f680}.day-single-cell.empty{background-color:#eee;border:1px solid #eee;cursor:default}.day-single-cell .date{color:#fff;display:none;margin:0 auto;position:absolute;font-size:10px;font-weight:700}.day-single-cell.selected .date{color:#fff!important}.day-single-cell.in-global-range{background-color:#fff}.day-single-cell.in-global-range.empty{background-color:#ececec}.day-single-cell.in-global-range:not(.empty){border:1px solid #79937d}.day-single-cell.today{background:#3265d4;border:1px solid #3265d4!important}.day-single-cell.today .date{display:inline;color:#fff}.day-single-cell.start-date{background:#22c55e;border:1px solid #22c55e!important}.day-single-cell.start-date .date{display:inline;color:#fff}.day-single-cell.selected .date{display:inline}@media (max-width: 780px){.header-tagline{font-size:.625rem;margin-bottom:.5rem}.weekday-label{font-size:.5rem}.header-grid,.month-grid{gap:1px}.month-single{padding-bottom:1px}.month-name{font-size:10px}.day-single-cell .date{font-size:6px;font-weight:400}}.year-scale-widget{position:fixed;right:20px;top:50%;transform:translateY(-50%);background:#fffffff2;border:1px solid #e0e0e0;border-radius:8px;padding:12px;box-shadow:0 2px 8px #0000001a;z-index:100;max-height:80vh;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.year-scale-content{display:flex;flex-direction:column;gap:8px}.year-scale-title{font-size:11px;font-weight:600;color:#666;text-align:center;letter-spacing:.5px}.year-scale-bars{display:flex;flex-direction:column;gap:2px;max-height:calc(80vh - 60px);overflow-y:auto;padding-right:4px;align-items:center}.year-scale-bars::-webkit-scrollbar{width:4px}.year-scale-bars::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.year-scale-bars::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.year-scale-bars::-webkit-scrollbar-thumb:hover{background:#999}.year-bar{position:relative;height:12px;background:linear-gradient(to right,#4caf50,#4caf50 calc(var(--activity) * 100%),#e0e0e0 calc(var(--activity) * 100%),#e0e0e0);cursor:pointer;transition:all .2s ease;width:35px;display:flex;align-items:center;padding:0 6px;overflow:hidden}.year-bar:hover{transform:translate(-3px);box-shadow:0 2px 4px #00000026;z-index:1}.year-bar.current{outline:2px solid #2196f3;box-shadow:0 0 8px #2196f34d;font-weight:700;background:#b8b8b8}.year-scale-widget .year-label{font-size:8px!important;padding-top:0!important;font-weight:500;color:#333;white-space:nowrap;position:relative;z-index:1;text-shadow:0 0 3px rgba(255,255,255,.8);pointer-events:none}.year-bar.current .year-label{font-size:11px;font-weight:700;color:#2196f3}.year-bar:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transform:translate(-100%);transition:transform .6s ease}.year-bar:hover:after{transform:translate(100%)}.paywall-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.paywall-card{background:#fff;border-radius:16px;padding:40px;max-width:450px;width:100%;box-shadow:0 20px 60px #0000004d;text-align:center}.paywall-badge{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:6px 16px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:20px}.paywall-card h2{margin:0 0 12px;font-size:28px;color:#333}.paywall-card>p{margin:0 0 32px;color:#666;font-size:16px;line-height:1.5}.paywall-features{display:flex;flex-direction:column;gap:16px;margin-bottom:32px;text-align:left}.feature{display:flex;align-items:center;gap:12px;font-size:15px;color:#444}.feature-icon{font-size:24px}.paywall-price{margin-bottom:24px;display:flex;align-items:baseline;justify-content:center;gap:4px}.price{font-size:48px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.period{font-size:18px;color:#999}.upgrade-button{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-bottom:12px}.upgrade-button:hover{transform:translateY(-2px);box-shadow:0 10px 30px #667eea66}.upgrade-button-disabled{background:#ccc;cursor:not-allowed;opacity:.6}.upgrade-button-disabled:hover{transform:none;box-shadow:none}.paywall-notice{background:#f0f4ff;border-left:3px solid #667eea;padding:12px 16px;margin:20px 0;border-radius:4px;font-size:14px;line-height:1.6;color:#555;text-align:left}.paywall-notice a{color:#667eea;text-decoration:none;font-weight:500}.paywall-notice a:hover{text-decoration:underline}.paywall-cancel{width:100%;background:#f3f4f6;border:2px solid #e5e7eb;color:#374151;cursor:pointer;padding:14px;font-size:15px;font-weight:600;border-radius:8px;transition:all .2s}.paywall-cancel:hover{background:#e5e7eb;border-color:#d1d5db;color:#1f2937}.color-picker{padding:0;background:transparent;border-radius:0;box-shadow:none;margin:0}.color-picker h3{display:none}.color-instruction{margin:0 0 12px;font-size:.85rem;color:#666}.color-options{display:flex;gap:12px;flex-wrap:wrap}.color-option{width:48px;height:48px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;position:relative}.color-option:hover{transform:scale(1.1);border-color:#0003}.color-option.active{border-color:#333;transform:scale(1.15)}.color-option.locked{opacity:.4;filter:grayscale(.3)}.color-option.locked:hover{opacity:.5}.checkmark{color:#fff;font-size:24px;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.3)}.color-hint{margin:16px 0 0;font-size:14px;color:#999;display:flex;align-items:center;gap:8px}.premium-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}@media (max-width: 768px){.color-picker{padding:12px 16px;margin:12px}.color-picker h3,.color-instruction{display:none}.color-options{gap:8px}.color-option{width:40px;height:40px;border-width:2px}.checkmark{font-size:20px}.color-hint{font-size:13px;margin:12px 0 0}.premium-badge{font-size:10px;padding:2px 6px}}@media (max-width: 480px){.color-picker{padding:10px 12px;margin:10px}.color-picker h3,.color-instruction{display:none}.color-options{gap:6px}.color-option{width:36px;height:36px}.checkmark{font-size:18px}.color-hint{font-size:12px;margin:10px 0 0}.premium-badge{font-size:9px;padding:1px 5px}}.infinite-calendar-wrapper{width:100%;height:100vh;display:flex;position:relative}.calendar-tagline{position:fixed;top:2rem;left:50%;transform:translate(-50%);z-index:100;font-size:1.125rem;color:#333;text-align:center;font-weight:400;letter-spacing:.01em;padding:0 2rem;pointer-events:none}.sidebar-toggle{position:fixed;left:0;top:35px;z-index:1001;background:#000c;color:#fff;border:none;border-radius:0 8px 8px 0;padding:1rem .5rem;cursor:pointer;transition:all .3s ease;font-size:.5rem}.sidebar-toggle.open{left:295px}.sidebar-toggle:hover{background:#000000e6;padding-right:.75rem}.calendar-sidebar{position:fixed;left:-285px;top:0;width:300px;height:100vh;background:#fff;border-right:none;transition:left .3s ease;z-index:1000;overflow-y:auto}.calendar-sidebar:after{content:"";position:absolute;right:0;top:0;bottom:0;width:5px;background-image:url("data:image/svg+xml,%3csvg%20width='5'%20height='20'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%205%2020'%20preserveAspectRatio='none'%3e%3c!--%20Perfect%20sine%20wave:%20starts%20and%20ends%20at%20center%20(x=2.5),%20seamless%20tiling%20--%3e%3cpath%20d='M%202.5,0%20C%203.5,1.6625%204.25,3.3375%204.5,5%20C%204.25,6.6625%203.5,8.3375%202.5,10%20C%201.5,11.6625%200.75,13.3375%200.5,15%20C%200.75,16.6625%201.5,18.3375%202.5,20'%20stroke='rgba(102,%20126,%20234,%200.8)'%20stroke-width='0.625'%20fill='none'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c!--%20Glow%20layer%20--%3e%3cpath%20d='M%202.5,0%20C%203.5,1.6625%204.25,3.3375%204.5,5%20C%204.25,6.6625%203.5,8.3375%202.5,10%20C%201.5,11.6625%200.75,13.3375%200.5,15%20C%200.75,16.6625%201.5,18.3375%202.5,20'%20stroke='rgba(102,%20126,%20234,%200.25)'%20stroke-width='1'%20fill='none'%20stroke-linecap='round'%20stroke-linejoin='round'/%3e%3c/svg%3e");background-repeat:repeat-y;background-size:5px 20px;background-position:right center;pointer-events:none}.calendar-sidebar.open{left:0}.calendar-sidebar.open:after{display:block}.sidebar-content{padding:1.5rem;display:flex;flex-direction:column;gap:1rem;min-height:100%}.sidebar-header{padding:1rem 0;text-align:center}.sidebar-header h1{margin:0;font-size:1.5rem;font-family:Pixelify Sans,sans-serif;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem}.app-logo{font-size:1.8rem;color:#667eea}.app-motto{margin:.5rem 0 0;font-size:.75rem;font-family:inherit;font-weight:400;color:#666;letter-spacing:.5px;font-style:italic}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem}.sidebar-link{padding:.75rem 1rem;color:inherit;text-decoration:none;border-radius:8px;transition:background-color .2s;font-size:.95rem}.sidebar-link:hover{background-color:#0000000d}.sidebar-link.login-link{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:500;text-align:center}.sidebar-link.login-link:hover{background:linear-gradient(135deg,#5568d3,#653a8a)}.sidebar-user{padding:.75rem 1rem;background:#00000008;border-radius:8px;font-size:.9rem}.sidebar-user .user-email{color:#666;word-break:break-all}.sidebar-btn{padding:.75rem 1rem;background:#0000000d;border:1px solid rgba(0,0,0,.1);border-radius:8px;cursor:pointer;transition:background-color .2s;font-size:.9rem;width:100%}.sidebar-btn:hover{background:#0000001a}.sidebar-divider{height:1px;background:#0000001a;margin:.5rem 0}.sidebar-section{display:flex;flex-direction:column;gap:1rem}.sidebar-section h3{margin:0;font-size:1rem;font-weight:600;color:#333}.sidebar-section .date-range-controls{display:flex;flex-direction:column;gap:1rem;padding:0;background:none;border:none}.sidebar-section .control-group{display:flex;flex-direction:column;align-items:stretch;gap:.5rem}.sidebar-section .control-group label{font-weight:500;font-size:.85rem;color:#555}.sidebar-section .control-group input[type=date]{padding:.6rem;border-radius:6px;border:1px solid rgba(0,0,0,.2);background-color:#fff;color:inherit;font-size:.9rem;width:100%}.sidebar-section .control-group input[type=date]:focus{outline:none;border-color:#3b82f699;box-shadow:0 0 0 3px #3b82f61a}.sidebar-footer{margin-top:auto;padding-top:1.5rem;text-align:center}.sidebar-footer .footer-links{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.sidebar-footer .footer-links a{color:#666;text-decoration:none;font-size:.85rem;padding:.5rem;border-radius:4px;transition:background-color .2s}.sidebar-footer .footer-links a:hover{background-color:#0000000d;color:#333}.sidebar-footer .footer-copy{font-size:.75rem;color:#999;margin:0}.calendar-main{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;transition:all .3s ease;overflow:hidden}.calendar-main.sidebar-open{left:300px;width:calc(100vw - 300px)}.date-range-controls{display:flex;gap:2rem;padding:1.5rem 2rem;background-color:#00000008;border-bottom:1px solid rgba(0,0,0,.1);flex-wrap:wrap;justify-content:center}.control-group{display:flex;align-items:center;gap:.75rem}.control-group label{font-weight:500;font-size:.95rem}.control-group input[type=month],.control-group input[type=date],.control-group select.view-selector{padding:.5rem .75rem;border-radius:6px;border:1px solid rgba(0,0,0,.2);background-color:#0000000d;color:inherit;font-size:.95rem;cursor:pointer;transition:all .2s}.control-group input[type=month]:hover,.control-group input[type=date]:hover,.control-group select.view-selector:hover{background-color:#00000014;border-color:#0000004d}.control-group input[type=month]:focus,.control-group input[type=date]:focus,.control-group select.view-selector:focus{outline:none;border-color:#3b82f699;box-shadow:0 0 0 3px #3b82f61a}@media (max-width: 768px){.control-group label{display:none}}.infinite-calendar-container{width:100%;flex:1;overflow-y:auto;overflow-x:hidden;scroll-behavior:smooth;position:relative}.weekday-header-fixed{position:sticky;top:0;z-index:100;background-color:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:grid;grid-template-columns:60px 50px repeat(35,1fr);gap:2px;padding:.75rem 2rem;border-bottom:1px solid rgba(0,0,0,.15)}.month-spacer{display:flex;align-items:center;justify-content:flex-start;padding-left:.5rem;font-weight:500;font-size:.75rem;color:#0009}.weekday-cell{display:flex;align-items:center;justify-content:center;font-weight:500;font-size:.7rem;color:#0009;text-transform:uppercase}.weekday-cell.weekend{color:#c83232bf}.observer-trigger{height:100px;display:flex;align-items:center;justify-content:center}.loading{padding:1rem;color:#0009;font-style:italic}.calendar-content{max-width:100%;margin:0 auto;padding:1rem;min-width:max-content}.year-view{margin-bottom:0;background-color:transparent;border-radius:0;padding:0;box-shadow:none;border-bottom:2px solid rgba(0,0,0,.2)}.year-content{display:grid;grid-template-columns:60px 1fr;gap:1rem;padding:1.5rem 2rem;align-items:start}.year-label{font-size:1.2rem;font-weight:600;color:#0009;position:sticky;top:1.5rem;padding-top:.5rem}.year-grid{display:flex;flex-direction:column;gap:2px}.month-row{display:grid;grid-template-columns:50px repeat(35,1fr);gap:2px;margin-bottom:2px}.month-row.out-of-range{opacity:.3}.month-row.out-of-range .month-label{opacity:.5}.month-row.out-of-range .day-cell:not(.empty){background-color:#00000003;cursor:default}.month-row.out-of-range .day-cell:not(.empty):hover{background-color:#00000003;transform:none}.month-label{display:flex;align-items:center;justify-content:flex-start;padding-left:.5rem;font-weight:500;font-size:.75rem;color:#00000080;background-color:transparent;border-radius:0;position:sticky;left:0;z-index:1}.day-cell{min-height:40px;display:flex;align-items:center;justify-content:center;background-color:#00000008;border-radius:2px;font-size:.85rem;cursor:pointer;transition:all .15s}.day-cell.weekend{background-color:#c832320a}.day-cell:not(.empty):hover{background-color:#0000001a;transform:scale(1.03)}.day-cell.weekend:not(.empty):hover{background-color:#c832321f}.day-cell.empty{background-color:transparent;cursor:default}.day-cell.today{background-color:#3b82f633;border:2px solid rgba(59,130,246,.6);font-weight:600}@media (max-width: 768px){.date-range-controls{padding:1rem;gap:1rem}.control-group{flex-direction:column;align-items:flex-start;gap:.5rem}.calendar-content{padding:.5rem}.weekday-header-fixed{grid-template-columns:50px 40px repeat(35,1fr);padding:.5rem 1rem;font-size:.65rem}.year-content{grid-template-columns:50px 1fr;padding:1rem;gap:.5rem}.year-label{font-size:1rem}.month-row{grid-template-columns:40px repeat(35,1fr)}.day-cell{min-height:36px;font-size:.75rem}.month-label{font-size:.7rem}}@media (max-width: 768px){.sidebar-toggle.open{left:280px}.calendar-sidebar{width:280px}.calendar-main.sidebar-open{margin-left:0!important}}@media (max-width: 640px){.infinite-calendar-wrapper{height:calc(100vh - 80px)}.calendar-sidebar{width:100%;left:calc(-100% + 10px)}.calendar-sidebar.open{left:0}.sidebar-toggle{left:10px;top:35px;border-radius:8px;padding:.75rem}.sidebar-toggle.open{left:calc(100% - 50px)}.calendar-main,.calendar-main.sidebar-open{margin-left:0!important}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-card{background:#fff;border-radius:12px;padding:40px;width:100%;max-width:400px;box-shadow:0 10px 40px #0000001a}.auth-card h2{margin:0 0 8px;font-size:28px;color:#333}.auth-subtitle{margin:0 0 32px;color:#666;font-size:14px}.auth-error{background:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#333;font-size:14px}.form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:16px;transition:border-color .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}.auth-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s}.auth-button:hover:not(:disabled){transform:translateY(-1px)}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;text-align:center;margin:24px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid #ddd}.auth-divider span{padding:0 10px;color:#999;font-size:12px;font-weight:500}.google-button{width:100%;padding:14px;background:#fff;color:#333;border:1px solid #ddd;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:background-color .2s,border-color .2s}.google-button:hover:not(:disabled){background-color:#f8f8f8;border-color:#ccc}.google-button:disabled{opacity:.6;cursor:not-allowed}.google-icon{width:20px;height:20px}.auth-toggle{margin-top:24px;text-align:center;color:#666;font-size:14px}.toggle-button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;padding:0;font-size:14px;text-decoration:underline}.toggle-button:hover{color:#764ba2}.landing-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;position:relative;overflow:hidden}.landing-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 1px,transparent 1px);background-size:50px 50px;animation:drift 30s linear infinite}@keyframes drift{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.landing-content{max-width:600px;width:100%;text-align:center;position:relative;z-index:1;animation:fadeInUp 1s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.landing-hero{margin-bottom:60px}.landing-icon{font-size:80px;color:#fff;margin-bottom:20px;display:inline-block;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.landing-title{font-size:48px;font-weight:700;color:#fff;margin:0 0 20px;line-height:1.2;text-shadow:0 2px 20px rgba(0,0,0,.2)}.landing-subtitle{font-size:20px;color:#fffffff2;line-height:1.6;margin:0;text-shadow:0 1px 10px rgba(0,0,0,.1)}.landing-action{background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;margin-bottom:40px}.date-label{display:block;font-size:18px;font-weight:600;color:#333;margin-bottom:16px}.date-input{width:100%;padding:16px;font-size:18px;border:2px solid #e0e0e0;border-radius:12px;outline:none;transition:border-color .3s,box-shadow .3s;font-family:inherit;color:#333}.date-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.date-hint{font-size:14px;color:#666;margin:12px 0 24px;font-style:italic}.enter-button{width:100%;padding:18px;font-size:18px;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 15px #667eea66}.enter-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea80}.enter-button:active:not(:disabled){transform:translateY(0)}.enter-button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.landing-footer{animation-delay:.5s;animation:fadeIn 1s ease-out backwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.landing-tagline{font-size:16px;color:#ffffffe6;margin:0;font-style:italic;letter-spacing:1px}@media (max-width: 768px){.landing-title{font-size:32px}.landing-subtitle{font-size:16px}.landing-icon{font-size:60px}.landing-action{padding:30px 24px}.date-label{font-size:16px}.date-input{font-size:16px;padding:14px}.enter-button{font-size:16px;padding:16px}}.app{width:100%;min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;justify-content:center;align-items:center;padding:1rem;background-color:#0000000d;border-bottom:1px solid rgba(0,0,0,.1);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.app-header h1{margin:0;font-size:1.8rem;font-family:Pixelify Sans,sans-serif;font-weight:600}.logo-link{text-decoration:none;color:inherit;transition:opacity .2s}.logo-link:hover{opacity:.8}@media (max-width: 768px){.app-header h1{font-size:1.5rem}}@media (max-width: 480px){.app-header{padding:.75rem}.app-header h1{font-size:1.2rem}}.navbar{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#0000000d;border-bottom:1px solid rgba(0,0,0,.1);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);gap:1rem;flex-wrap:wrap}.navbar h1{margin:0;font-size:1.5rem;white-space:nowrap;min-width:0;font-family:Pixelify Sans,sans-serif;font-weight:600}.nav-links{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.nav-links a{color:inherit;text-decoration:none;padding:.5rem .75rem;border-radius:4px;transition:background-color .2s;white-space:nowrap}.nav-links a:hover{background-color:#0000000d}.user-email{font-size:.9rem;color:#666;overflow:hidden;text-overflow:ellipsis;max-width:150px}.logout-btn{padding:.5rem .75rem;background:#0000000d;border:1px solid rgba(0,0,0,.1);border-radius:4px;cursor:pointer;transition:background-color .2s;white-space:nowrap;font-size:.9rem}.logout-btn:hover{background:#0000001a}.login-link{padding:.5rem .75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff!important;border-radius:6px;font-weight:500;transition:transform .2s;white-space:nowrap;font-size:.9rem}.login-link:hover{transform:translateY(-1px);background:linear-gradient(135deg,#667eea,#764ba2)!important}@media (max-width: 768px){.navbar{padding:.75rem}.navbar h1{font-size:1.2rem}.nav-links{gap:.5rem}.nav-links a,.logout-btn,.login-link{padding:.4rem .6rem;font-size:.85rem}.user-email{max-width:200px;font-size:.85rem}}@media (max-width: 480px){.navbar{padding:.5rem}.navbar h1{font-size:1rem}.nav-links{gap:.4rem}.nav-links a,.logout-btn,.login-link{padding:.3rem .5rem;font-size:.8rem}.user-email{max-width:150px;font-size:.8rem}}.page{padding:2rem;max-width:1200px;margin:0 auto}.about-page,.legal-page{max-width:800px;line-height:1.6}.about-content .tagline{font-size:1.1rem;color:#666;margin-bottom:2rem}.about-section{margin-bottom:2rem}.about-section h3{margin-bottom:.75rem;color:#333}.about-section ul{list-style:none;padding-left:0}.about-section ul li{padding:.5rem 0 .5rem 1.5rem;position:relative}.about-section ul li:before{content:"✓";position:absolute;left:0;color:#667eea;font-weight:700}.legal-page h3{margin-top:1.5rem;margin-bottom:.75rem}.legal-page p{margin-bottom:1rem}.footer{margin-top:auto;padding:2rem 1rem;background-color:#00000005;border-top:1px solid rgba(0,0,0,.1);text-align:center}.footer-links{display:flex;justify-content:center;gap:2rem;margin-bottom:1rem;flex-wrap:wrap}.footer-links a{color:inherit;text-decoration:none;transition:opacity .2s}.footer-links a:hover{opacity:.7}@media (max-width: 768px){.page{padding:1.5rem}.footer-links{gap:1rem}.footer{padding:1.5rem 1rem}}@media (max-width: 480px){.page{padding:1rem}.about-page,.legal-page{font-size:.95rem}.footer{padding:1rem .5rem}.footer-links{flex-direction:column;gap:.5rem}}.footer-copy{font-size:.85rem;color:#999;margin:0}@media (max-width: 768px){.page{padding:1.5rem}.footer-links{gap:1rem}}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}
