:root{--primary-contrast:#374151;--secondary-contrast:#6b7280;--background-gradient:linear-gradient(135deg,#fef7ff,#f3e8ff,#e0e7ff);--background:#fefcff;--muted:rgba(167,139,250,.15);--surface:#fff;--border:#e5e7eb;--top-gradient:#a78bfa33;--bottom-gradient-top:#c4b5fd75;--bottom-gradient-bottom:#a78bfa50;--button:linear-gradient(135deg,#a78bfa,#8b5cf6)}.dark-theme{--primary-contrast:#f8fafc;--secondary-contrast:#cbd5e1;--background-gradient:linear-gradient(135deg,#1e1b4b,#312e81,#3730a3);--background:#1e1b4b;--muted:rgba(167,139,250,.25);--surface:#312e81;--border:#4c1d95;--top-gradient:#a78bfa33;--bottom-gradient-top:#c4b5fd;--bottom-gradient-bottom:#a78bfa50;--button:linear-gradient(135deg,#a78bfa,#8b5cf6)}*{margin:0;font-family:Google Sans}html{background:var(--background)}body{color:var(--primary-contrast);background:var(--background-gradient);min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center}.dots{pointer-events:none;height:100%;background-image:radial-gradient(circle at center,var(--muted) 2px,transparent 2px);background-size:30px 30px;background-position:12px 12px;-webkit-mask-image:linear-gradient(180deg,#000 0,transparent 50%);mask-image:linear-gradient(180deg,#000 0,transparent 50%)}.dots,.top-gradient{position:absolute;top:0;left:0;width:100%}.top-gradient{height:25vh;background:linear-gradient(180deg,transparent 0,var(--top-gradient) 50%);-webkit-clip-path:polygon(0 0,100% 0,100% 100%,0 calc(100% - 10vw));clip-path:polygon(0 0,100% 0,100% 100%,0 calc(100% - 10vw))}.bottom-gradient{position:fixed;bottom:0;width:90%;height:900px;margin-bottom:-550px;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;--top:var(--bottom-gradient-top);--bottom:var(--bottom-gradient-bottom);--first:conic-gradient(from 90deg at 0% 50%,var(--top),var(--bottom));--second:conic-gradient(from 270deg at 100% 50%,var(--bottom),var(--top));-webkit-mask-image:radial-gradient(closest-side at 50% 50%,var(--background),transparent);mask-image:radial-gradient(closest-side at 50% 50%,var(--background),transparent);background-image:var(--first),var(--second);background-position-x:0,100%;background-position-y:100%,0;background-repeat:no-repeat;opacity:.4;transform:translateY(-200px) rotate(180deg) translateZ(0);transform-origin:center center}.header{position:absolute;top:4vh;justify-content:center}.header svg,.logo{padding:16px 25px}.logo{display:flex;align-items:center;gap:12px;font-family:Google Sans,sans-serif}.logo-icon{font-size:28px}.logo-text{display:flex;flex-direction:column;line-height:1.2}.logo-title{font-size:24px;font-weight:600;color:var(--primary-contrast)}.logo-subtitle{font-size:14px;font-weight:400;color:var(--secondary-contrast);opacity:.8}.heading{font-size:48px;font-weight:600;letter-spacing:-2%;text-align:center;color:var(--primary-contrast);margin-bottom:16px}.subtitle{font-size:20px;font-weight:400;color:var(--secondary-contrast);text-align:center;margin-bottom:24px}.hero-description{text-align:center;margin-bottom:48px}.hero-description p{font-size:18px;color:var(--secondary-contrast);max-width:600px;margin:0 auto;line-height:1.6}.cta-section{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:48px}.cta-button{background:var(--button);color:#fff;border:none;border-radius:12px;padding:16px 32px;font-size:18px;font-weight:600;font-family:Google Sans,sans-serif;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px rgba(167,139,250,.3)}.cta-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(167,139,250,.4)}.cta-description{font-size:14px;color:var(--secondary-contrast);margin:0;opacity:.8}.user-greeting{text-align:center;margin-bottom:48px}.greeting-text{font-size:32px;font-weight:600;color:var(--primary-contrast);margin-bottom:16px;line-height:1.2}.app-description{font-size:18px;color:var(--secondary-contrast);line-height:1.6;max-width:500px;margin:0 auto}.regenerate-button{color:var(--background);background:var(--button)}.back-button{position:fixed;top:32px;left:32px;color:var(--primary-contrast);background-color:var(--surface);display:flex;align-items:center;gap:6px;text-decoration:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.button{font-size:15px;line-height:1.3;font-weight:500;padding:11px 16px;border-radius:100px;border:none;cursor:pointer;transition:scale .2s,filter .2s}.button:hover{filter:brightness(1.1)}.button:active{scale:.97}.content{margin:120px 12px;justify-content:center;gap:80px}.content,.content header{display:flex;flex-direction:column;align-items:center}.content header{gap:32px}.content header h2{font-size:20px;font-weight:400}.data-container,.features{display:grid;grid-gap:10px;gap:10px}.features{display:flex;flex-direction:column;gap:16px;text-wrap:balance;max-width:600px;margin:0 auto}.data-container{grid-template-columns:repeat(2,1fr);text-wrap:pretty}.card{flex-direction:column;padding:24px;gap:12px;max-width:360px}.card h2{font-size:24px;line-height:1.2;font-weight:500;letter-spacing:-2%}.card p{font-size:13px;line-height:1.5;color:var(--secondary-contrast);letter-spacing:-1%}.card p a,.link{color:var(--primary-contrast);text-decoration:underline;text-underline-offset:2px}.links-container{padding-top:24px;gap:24px}.links,.links-container{display:flex;flex-wrap:wrap}.links{gap:10px}.links a{padding:14px 15px;color:var(--primary-contrast);font-size:14px;font-weight:500;text-decoration:none;white-space:nowrap;justify-content:center;align-items:center;gap:4px}.card,.links a{position:relative;border-radius:16px;background:var(--surface);border:1px solid var(--border);box-shadow:0 2px 8px rgba(0,0,0,.05);display:flex;transition:all .2s ease}.card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(167,139,250,.15)}@media only screen and (max-width:1023px){.heading{font-size:36px}.back-button{top:10px;left:10px}.data-container{grid-template-columns:1fr}.greeting-text{font-size:24px}.app-description{font-size:16px}.bottom-gradient,.top-gradient{width:150%;height:400px;margin-bottom:-450px}}.auth-form-container{display:flex;justify-content:center;align-items:center;min-height:70vh;padding:2rem}.auth-form{background:var(--surface);padding:2rem;border-radius:16px;border:1px solid var(--border);box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 0 0 1px hsla(0,0%,100%,.05);width:100%;max-width:400px}.auth-form h2{font-size:1.875rem;font-weight:700;color:var(--primary-contrast)}.auth-form h2,.form-description{margin-bottom:1.5rem;text-align:center}.form-description{color:var(--secondary-contrast);font-size:.875rem;line-height:1.5}.form-group{margin-bottom:1rem}.form-group label{display:block;color:var(--primary-contrast);font-weight:500;margin-bottom:.5rem;font-size:.875rem}.form-group input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:8px;background:var(--background);color:var(--primary-contrast);font-size:1rem;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus{outline:none;border-color:#a78bfa;box-shadow:0 0 0 3px rgba(167,139,250,.1)}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-group input::placeholder{color:var(--secondary-contrast)}.auth-button{width:100%;padding:.875rem;background:var(--button);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease;margin-bottom:1.5rem}.auth-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 15px -3px rgba(167,139,250,.3)}.auth-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-links{text-align:center;display:flex;flex-direction:column;gap:.5rem}.auth-links a{color:#a78bfa;text-decoration:none;font-size:.875rem;transition:color .2s ease}.auth-links a:hover{color:#8b5cf6;text-decoration:underline}.error-message{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);color:#ef4444;border-radius:8px}.error-message,.success-message{padding:.75rem;font-size:.875rem;margin-bottom:1rem;text-align:center}.success-message{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2);color:#22c55e;border-radius:8px;line-height:1.5}.logout-button{padding:.5rem 1rem;background:rgba(239,68,68,.9);color:#fff;border:none;border-radius:6px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease}.logout-button:hover:not(:disabled){background:rgba(220,38,38,.9);transform:translateY(-1px)}.logout-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:50vh;padding:2rem;text-align:center}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top:3px solid #a78bfa;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.auth-loading p{color:var(--secondary-contrast);font-size:.875rem;margin:0}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.header{justify-content:space-between;width:100%;max-width:1200px;margin:0 auto;padding:0 2rem}.header,.header-auth,.user-menu{display:flex;align-items:center}.user-menu{gap:1rem}.user-email{color:var(--secondary-contrast)}.header-logout-btn,.user-email{font-size:.875rem;font-weight:500}.header-logout-btn{padding:.375rem .75rem;background:rgba(239,68,68,.1);color:#ef4444;border:1px solid rgba(239,68,68,.2);border-radius:6px;cursor:pointer;transition:all .2s ease}.header-logout-btn:hover:not(:disabled){background:rgba(239,68,68,.2);transform:none}.auth-buttons{display:flex;align-items:center;gap:1rem}.header-auth-link{color:var(--secondary-contrast);text-decoration:none;font-size:.875rem;font-weight:500;padding:.375rem .75rem;border-radius:6px;transition:color .2s ease}.header-auth-link:hover{color:var(--primary-contrast)}.header-auth-btn{background:var(--button);color:#fff;text-decoration:none;font-size:.875rem;font-weight:600;padding:.375rem 1rem;border-radius:6px;transition:all .2s ease}.header-auth-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px rgba(167,139,250,.3)}.cta-button{display:inline-block;text-decoration:none;text-align:center}.auth-quick-links{margin-top:1rem;text-align:center}.auth-link{color:#a78bfa;text-decoration:none;font-size:.875rem;transition:color .2s ease}.auth-link:hover{color:#8b5cf6;text-decoration:underline}@media only screen and (max-width:768px){.header{padding:0 1rem}.user-menu{flex-direction:column;gap:.5rem;align-items:flex-end}.user-email{font-size:.75rem}.auth-buttons{gap:.5rem}.header-auth-btn,.header-auth-link{font-size:.75rem;padding:.25rem .5rem}}.firebase-status{position:fixed;bottom:1rem;right:1rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1rem;max-width:400px;font-size:.875rem;z-index:1000;box-shadow:0 4px 12px rgba(0,0,0,.15)}.firebase-status h3{margin:0 0 .75rem;font-size:1rem;color:var(--primary-contrast)}.firebase-status h4{margin:.5rem 0 .25rem;font-size:.875rem;color:var(--primary-contrast);font-weight:600}.status-section{margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.status-section:last-child{border-bottom:none;margin-bottom:0}.status-success{color:#22c55e;font-weight:500}.status-error{color:#ef4444;font-weight:500}.status-error div{margin-bottom:.25rem}.status-info{color:#3b82f6;font-weight:500}.status-loading{font-style:italic}.status-loading,.user-details{color:var(--secondary-contrast)}.user-details{margin-top:.5rem;font-size:.75rem}.user-details div{margin-bottom:.25rem}.config-details{font-size:.75rem;color:var(--secondary-contrast);font-family:monospace}.config-details div{margin-bottom:.25rem;word-break:break-all}.help-section a{color:#a78bfa;text-decoration:none;font-size:.75rem}.help-section a:hover{color:#8b5cf6;text-decoration:underline}@media only screen and (max-width:768px){.firebase-status{position:static;margin:1rem;max-width:none}}.daily-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:1rem;gap:1rem;margin:1.5rem 0;padding:1.5rem;background:hsla(0,0%,100%,.05);border-radius:12px;border:1px solid var(--border)}.summary-item{display:flex;flex-direction:column;align-items:center;text-align:center}.summary-label{font-size:.875rem;color:var(--secondary-contrast);margin-bottom:.5rem}.summary-value{font-size:1.5rem;font-weight:700;color:#a78bfa}.recent-logs{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.recent-logs h4{font-size:.875rem;color:var(--primary-contrast);margin-bottom:.75rem;font-weight:600}.log-item{padding:.5rem;margin-bottom:.5rem;background:hsla(0,0%,100%,.05);border-radius:6px;font-size:.875rem;color:var(--secondary-contrast)}.dev-info{margin-top:2rem;padding:1rem;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2);border-radius:8px;font-size:.875rem}.dev-info h4{margin:0 0 .5rem;color:#22c55e;font-size:1rem}.dev-info p{margin:.25rem 0;color:var(--secondary-contrast);font-family:monospace}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-modal-container{background:var(--surface);border-radius:16px;box-shadow:0 25px 50px -12px rgba(0,0,0,.25);border:1px solid var(--border);width:100%;max-width:420px;max-height:90vh;overflow-y:auto;position:relative;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.auth-modal-header{display:flex;justify-content:flex-end;padding:1rem 1rem 0}.auth-modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--secondary-contrast);border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s}.auth-modal-close:hover{background:rgba(0,0,0,.05);color:var(--primary-contrast)}.auth-modal-close:focus{outline:2px solid #a78bfa;outline-offset:2px}.auth-tabs{display:flex;margin:0 1rem;border-bottom:1px solid var(--border);position:relative}.auth-tab{flex:1 1;padding:1rem;background:none;border:none;font-size:1rem;font-weight:500;color:var(--secondary-contrast);cursor:pointer;transition:all .2s;position:relative;border-radius:0}.auth-tab:hover{color:var(--primary-contrast);background:rgba(167,139,250,.05)}.auth-tab.active{color:#a78bfa;font-weight:600}.auth-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:linear-gradient(135deg,#a78bfa,#8b5cf6);border-radius:1px}.auth-tab:focus{outline:2px solid #a78bfa;outline-offset:-2px;background:rgba(167,139,250,.05)}.auth-tab-content{padding:0 1rem 1rem}.auth-tab-content .auth-form{margin:0;padding:1.5rem 0 .5rem}.auth-tab-content .auth-form h2{text-align:center;margin-bottom:1.5rem;color:var(--primary-contrast);font-size:1.5rem;font-weight:600}.auth-link-button{background:none;border:none;color:#a78bfa;text-decoration:none;font-size:.875rem;cursor:pointer;transition:color .2s;padding:0;font-family:inherit}.auth-link-button:hover{color:#8b5cf6;text-decoration:underline}.auth-link-button:focus{outline:2px solid #a78bfa;outline-offset:2px;border-radius:3px}@media only screen and (max-width:768px){.auth-modal-overlay{padding:.5rem}.auth-modal-container{max-height:95vh}.auth-tab{padding:.875rem .5rem;font-size:.9375rem}.auth-tab-content .auth-form h2{font-size:1.375rem}.daily-summary{grid-template-columns:1fr;gap:.75rem;padding:1rem}.summary-value{font-size:1.25rem}}.dark-theme .auth-modal-close:hover{background:hsla(0,0%,100%,.1)}.dark-theme .auth-tab:focus,.dark-theme .auth-tab:hover{background:rgba(167,139,250,.1)}