:root{--primary: #818cf8;--primary-light: #a5b4fc;--primary-dark: #6366f1;--primary-glow: rgba(129, 140, 248, .4);--accent-teal: #2dd4bf;--accent-rose: #fb7185;--accent-gold: #fbbf24;--accent-purple: #a78bfa;--success: #34d399;--success-light: #d1fae5;--warning: #fbbf24;--warning-light: #fef3c7;--error: #f87171;--error-light: #fee2e2;--black: #0f172a;--dark: #1e293b;--gray-900: #1e293b;--gray-800: #334155;--gray-700: #475569;--gray-600: #64748b;--gray-500: #94a3b8;--gray-400: #cbd5e1;--gray-300: #e2e8f0;--gray-200: #f1f5f9;--gray-100: #f8fafc;--white: #ffffff;--bg-color: #f3f4f6;--glass-surface: rgba(255, 255, 255, .65);--glass-border: rgba(255, 255, 255, .4);--glass-shadow: 0 8px 32px 0 rgba(31, 38, 135, .15);--glass-blur: blur(20px);--font-family: "Outfit", system-ui, -apple-system, sans-serif;--radius-sm: 12px;--radius-md: 16px;--radius-lg: 24px;--radius-xl: 32px;--radius-full: 9999px;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--bg-card: var(--glass-surface);--bg-glass: var(--glass-surface);--bg-main: transparent;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: var(--glass-shadow);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .08);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .12);--border-light: var(--glass-border);--border-color: var(--glass-border);--ease-elastic: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--transition-base: .25s ease;--transition-bounce: .4s cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box}body{margin:0;font-family:var(--font-family);font-size:16px;line-height:1.7;color:var(--gray-800);background:var(--bg-color);overflow-x:hidden;-webkit-font-smoothing:antialiased}.aurora-background{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:-1;background-color:#f3f4f6;background-image:radial-gradient(at 0% 0%,rgba(167,139,250,.4) 0,transparent 50%),radial-gradient(at 50% 0%,rgba(129,140,248,.4) 0,transparent 50%),radial-gradient(at 100% 0%,rgba(244,114,182,.4) 0,transparent 50%),radial-gradient(at 0% 100%,rgba(34,211,238,.4) 0,transparent 50%),radial-gradient(at 100% 100%,rgba(52,211,153,.4) 0,transparent 50%);background-size:200% 200%;animation:auroraFlow 20s ease infinite alternate}@keyframes auroraFlow{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:50% 100%}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 20px var(--primary-glow)}50%{box-shadow:0 0 40px var(--primary-glow)}}.app-wrapper{display:flex;flex-direction:column;min-height:100vh;position:relative}.app-container{max-width:1200px;margin:0 auto;padding:2rem;flex:1;width:100%}.checkin-layout{display:grid;grid-template-columns:1.2fr 1fr;gap:var(--space-6);align-items:start}.app-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:100;margin-bottom:1.5rem}.landing-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 2rem;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:100}.logo-container{display:flex;align-items:center;gap:.5rem;flex-shrink:0;cursor:pointer}.header-logo{width:28px;height:28px;object-fit:contain}.logo-text{font-weight:600;font-size:1.1rem;color:var(--dark)}h1{font-weight:600;font-size:1.25rem;color:var(--dark);margin:0}.console-badge{font-size:.7rem;font-weight:500;color:var(--primary);background:var(--primary-glow);padding:.15rem .5rem;border-radius:var(--radius-sm);margin-left:.5rem;vertical-align:middle}nav{display:flex;gap:.25rem;align-items:center}nav button{padding:.5rem .875rem;border:none;background:transparent;color:var(--gray-600);font-family:inherit;font-weight:500;font-size:.875rem;cursor:pointer;border-radius:var(--radius-sm);transition:all .2s ease}nav button:hover{color:var(--primary);background:var(--gray-100)}nav button.active{color:var(--primary);background:var(--primary-glow)}.card{background:var(--glass-surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);padding:2rem;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);transition:transform .4s var(--ease-elastic),box-shadow .4s ease}.card:hover{transform:translateY(-5px);box-shadow:0 15px 40px #00000014}.primary-btn{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--white);padding:1rem 2rem;border:none;border-radius:var(--radius-full);font-weight:600;font-size:1rem;cursor:pointer;box-shadow:0 4px 15px var(--primary-glow);transition:all .3s var(--ease-elastic);display:flex;align-items:center;justify-content:center;gap:.5rem}.primary-btn:hover{transform:scale(1.02);box-shadow:0 8px 25px var(--primary-glow)}.secondary-btn{background:#ffffff80;color:var(--gray-700);padding:.75rem 1.5rem;border:1px solid var(--gray-200);border-radius:var(--radius-full);font-weight:500;cursor:pointer;transition:all .2s var(--ease-smooth)}.secondary-btn:hover{background:var(--white);color:var(--primary);border-color:var(--primary-light)}.mood-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.mood-bubble{border-radius:var(--radius-xl);border:2px solid transparent;background:#ffffffb3;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;cursor:pointer;transition:all .4s var(--ease-elastic);position:relative;height:140px}.mood-bubble:hover{transform:translateY(-8px) scale(1.02);background:var(--white)}.mood-bubble.selected{background:var(--white);border-color:var(--mood-color);box-shadow:0 0 30px var(--mood-glow)}.mood-emoji{font-size:3rem;margin-bottom:.5rem;transition:transform .4s var(--ease-elastic)}.mood-bubble:hover .mood-emoji{transform:scale(1.2)}.insight-card{position:relative;overflow:hidden}.insight-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--accent-teal),var(--primary));opacity:.8}.tip-content blockquote{font-size:1.25rem;font-weight:300;font-style:italic;color:var(--gray-800);border-left:4px solid var(--primary-light);margin:1.5rem 0;padding-left:1.5rem;background:#ffffff4d;padding:1rem;border-radius:0 var(--radius-md) var(--radius-md) 0}.modal-overlay{background:#0f172a66;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.ai-response-modal{background:#fff;border-radius:var(--radius-xl);box-shadow:0 20px 60px #00000026;border:1px solid rgba(255,255,255,.8)}.ai-modal-header{background:linear-gradient(135deg,rgba(129,140,248,.1) 0%,transparent 100%);padding:2rem;border-bottom:1px solid rgba(0,0,0,.03)}.ai-message{font-size:1.15rem;line-height:1.8;color:var(--gray-700)}.fade-in{animation:fadeIn .5s var(--ease-smooth) forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .5s var(--ease-elastic) forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}textarea{width:100%;background:#fff9;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:var(--space-3);font-family:inherit;font-size:var(--font-size-base);resize:vertical;min-height:100px;transition:all .3s ease}.note-input-wrapper{position:relative;margin-bottom:var(--space-4)}.voice-btn{position:absolute;bottom:var(--space-3);right:var(--space-3);background:var(--white);border:1px solid var(--gray-200);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 5px #0000000d;font-size:1.2rem}.voice-btn:hover{transform:scale(1.1);border-color:var(--primary);color:var(--primary)}.voice-btn.active{background:var(--error-light);color:var(--error);border-color:var(--error);animation:pulse 1.5s infinite}.log-btn{width:100%;padding:var(--space-3);font-size:var(--font-size-lg);font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-top:var(--space-4);background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .3s var(--ease-spring);box-shadow:0 4px 12px var(--primary-glow)}.log-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px var(--primary-glow)}.log-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}textarea:focus{background:var(--white);border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.form-group label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--gray-700);margin-bottom:var(--space-2)}.save-success{background:var(--success-light);color:#059669;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin-top:var(--space-4);text-align:center;font-weight:500;border:1px solid var(--success)}.auth-notice{text-align:center;color:var(--gray-600);margin-bottom:var(--space-6)}.auth-notice .hint{font-size:var(--font-size-sm);color:var(--gray-500)}.auth-section,.user-menu{display:flex;align-items:center;gap:var(--space-3)}.user-email{font-size:var(--font-size-sm);color:var(--gray-600)}.auth-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--gray-200);background:var(--white);color:var(--gray-600);cursor:pointer;font-family:inherit;font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-base)}.auth-btn:hover{background:var(--gray-50)}.auth-btn.primary{background:var(--primary);color:var(--white);border-color:var(--primary)}.auth-btn.primary:hover{background:var(--primary-dark)}.tips-panel{height:fit-content;position:sticky;top:120px}.coach-toggle{display:flex;gap:var(--space-2);background:var(--gray-100);padding:var(--space-1);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.coach-btn{flex:1;padding:var(--space-2) var(--space-3);border:none;background:transparent;color:var(--gray-600);font-family:inherit;font-size:var(--font-size-sm);font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-base)}.coach-btn:hover{color:var(--gray-800)}.coach-btn.active{background:var(--white);color:var(--primary);box-shadow:var(--shadow-sm)}.time-greeting{color:var(--gray-600);margin:0 0 var(--space-4) 0}.time-greeting span{color:var(--primary);font-weight:500}.mood-context{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--gray-100);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--gray-600);margin-bottom:var(--space-4)}.mood-context.positive{background:var(--success-light);color:var(--success)}.tip-content{margin-top:var(--space-4)}.tip-content blockquote{margin:0 0 var(--space-4) 0;padding:var(--space-4);background:linear-gradient(135deg,var(--primary-glow) 0%,var(--gray-100) 100%);border-left:4px solid var(--primary);border-radius:0 var(--radius-md) var(--radius-md) 0;font-style:italic;color:var(--gray-700)}.exercise-box{background:var(--gray-50);border-radius:var(--radius-md);padding:var(--space-4)}.exercise-box h4{margin:0 0 var(--space-2) 0;font-size:var(--font-size-base);font-weight:600}.exercise-box .duration{font-size:var(--font-size-sm);color:var(--gray-500);margin:0 0 var(--space-3) 0}.exercise-steps{margin:0 0 var(--space-3) 0;padding-left:var(--space-5)}.exercise-steps li{margin-bottom:var(--space-2);color:var(--gray-700)}.exercise-box .benefits{font-size:var(--font-size-sm);color:var(--gray-600);margin:0}.productivity-tip{background:var(--gray-50);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-3)}.productivity-tip:last-child{margin-bottom:0}.productivity-tip h4{display:flex;align-items:center;gap:var(--space-2);margin:0 0 var(--space-2) 0;font-size:var(--font-size-base);font-weight:600}.tip-icon{font-size:1.25rem}.productivity-tip p{margin:0;color:var(--gray-600);font-size:var(--font-size-sm);line-height:1.6}.journal-page{display:flex;flex-direction:column;gap:var(--space-4);max-width:800px;margin:0 auto}.journal-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);align-items:start}.ai-insight-card{position:relative}.journal-input-section textarea{width:100%;min-height:200px;padding:var(--space-4);border:2px solid var(--gray-200);border-radius:var(--radius-lg);font-family:inherit;font-size:var(--font-size-base);resize:vertical;transition:all var(--transition-base)}.journal-input-section textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.journal-entries-section h3{font-size:var(--font-size-lg);font-weight:600;margin:0 0 var(--space-4) 0;color:var(--gray-800)}.journal-entry-card{background:var(--gray-50);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-3);transition:all var(--transition-base)}.journal-entry-card:hover{background:var(--white);box-shadow:var(--shadow-md)}.journal-entry-date{font-size:var(--font-size-xs);color:var(--gray-500);margin-bottom:var(--space-2)}.journal-entry-content{color:var(--gray-700);line-height:1.6;margin-bottom:var(--space-3)}.journal-ai-insight{background:var(--primary-glow);padding:var(--space-3);border-radius:var(--radius-sm);border-left:3px solid var(--primary)}.journal-ai-insight h5{font-size:var(--font-size-xs);font-weight:600;color:var(--primary);margin:0 0 var(--space-1) 0}.journal-ai-insight p{font-size:var(--font-size-sm);color:var(--gray-700);margin:0}.insights-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6);align-items:start}.about-section{max-width:800px;margin:0 auto}.about-section h2{font-size:var(--font-size-3xl);text-align:center;margin-bottom:var(--space-8);background:linear-gradient(135deg,var(--primary) 0%,var(--accent-purple) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.benefits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.benefit-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-5);border:1px solid var(--gray-200);transition:all var(--transition-base)}.benefit-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-glow)}.benefit-icon{font-size:2rem;margin-bottom:var(--space-3)}.benefit-card h3{font-size:var(--font-size-lg);font-weight:600;color:var(--gray-900);margin:0 0 var(--space-2) 0}.benefit-card p{font-size:var(--font-size-sm);color:var(--gray-600);margin:0;line-height:1.6}.app-footer{background:linear-gradient(180deg,var(--gray-900) 0%,#0f172a 100%);color:var(--gray-400);margin-top:auto}.footer-inner{max-width:1200px;margin:0 auto;padding:var(--space-10) var(--space-6) var(--space-6)}.footer-top{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-8);padding-bottom:var(--space-8);border-bottom:1px solid rgba(255,255,255,.1)}.footer-brand{display:flex;align-items:center;gap:var(--space-3)}.footer-logo{font-size:2.5rem}.brand-name{display:block;font-size:1.25rem;font-weight:700;color:var(--white)}.brand-tagline{display:block;font-size:var(--font-size-sm);color:var(--gray-500)}.footer-nav{display:flex;gap:var(--space-6)}.footer-nav a{color:var(--gray-400);text-decoration:none;font-size:var(--font-size-sm);font-weight:500;transition:color var(--transition-base)}.footer-nav a:hover{color:var(--white)}.footer-social{display:flex;gap:var(--space-2)}.footer-social a{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:var(--radius-md);color:var(--gray-400);font-weight:700;font-size:.9rem;text-decoration:none;transition:all var(--transition-base)}.footer-social a:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-6);gap:var(--space-4)}.footer-copy{font-size:var(--font-size-sm);color:var(--gray-500);margin:0}.footer-powered{display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-sm);color:var(--gray-500)}.tech-badge{background:#818cf826;color:var(--primary-light);padding:4px 10px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.hackathon-text{font-size:var(--font-size-sm);color:var(--primary-light);font-weight:500;margin:0}@media (max-width: 768px){.footer-top{flex-direction:column;align-items:center;text-align:center;gap:var(--space-6)}.footer-brand{flex-direction:column}.footer-nav{flex-wrap:wrap;justify-content:center}.footer-bottom{flex-direction:column;text-align:center}}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-main)}.loading-spinner{width:48px;height:48px;border:4px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:var(--space-4)}.placeholder-text{color:var(--gray-400);text-align:center;padding:var(--space-6);font-style:italic}.badge{background:var(--primary);color:var(--white);font-size:var(--font-size-xs);font-weight:600;padding:2px 8px;border-radius:var(--radius-full);margin-left:var(--space-2)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-5px) rotate(2deg)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes borderPulse{0%,to{border-color:var(--error)}50%{border-color:#fca5a5}}@keyframes voicePulse{0%,to{transform:translateY(-50%) scale(1)}50%{transform:translateY(-50%) scale(1.1)}}.fade-in{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-up{animation:slideUp .4s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.card-header{margin-bottom:var(--space-6)}.card h2{font-size:var(--font-size-xl);font-weight:600;color:var(--gray-900);margin:0 0 var(--space-2) 0}.card .subtitle{font-size:var(--font-size-sm);color:var(--gray-500);margin:0}.mood-wheel-section{display:flex;flex-direction:column;gap:var(--space-6)}.mood-input-card{max-width:100%}.mood-label{font-size:var(--font-size-sm);font-weight:500;color:var(--gray-600);text-transform:capitalize}.mood-bubble.selected .mood-label,.mood-btn.selected .mood-label{color:var(--mood-color, var(--primary));font-weight:600}.success-toast{background:var(--success-light);color:var(--success);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;text-align:center;margin-top:var(--space-4)}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.btn-loading{display:flex;align-items:center;gap:var(--space-2)}.mood-history{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--gray-200)}.mood-history h3{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-500);margin:0 0 var(--space-3) 0;text-transform:uppercase;letter-spacing:.05em}.history-strip{display:flex;gap:var(--space-2);overflow-x:auto;padding-bottom:var(--space-2)}.history-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-3);background:var(--gray-100);border:2px solid var(--gray-200);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);min-width:64px}.history-item:hover{background:var(--white);border-color:var(--mood-color, var(--gray-300));transform:translateY(-2px);box-shadow:var(--shadow-md)}.history-emoji{font-size:1.5rem}.history-time{font-size:var(--font-size-xs);color:var(--gray-500)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:var(--space-6)}.modal-close{position:absolute;top:var(--space-4);right:var(--space-4);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:none;border-radius:var(--radius-full);font-size:1.5rem;color:var(--gray-500);cursor:pointer;transition:all var(--transition-base);z-index:10}.modal-close:hover{background:var(--gray-200);color:var(--gray-700)}.modal-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-6);border-bottom:1px solid var(--gray-200)}.modal-body{padding:var(--space-6)}.modal-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--gray-200)}.ai-response-modal{background:var(--white);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:var(--shadow-xl)}.ai-modal-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-6);background:linear-gradient(135deg,var(--primary-glow) 0%,transparent 100%);border-bottom:1px solid var(--gray-200)}.ai-avatar-large{width:64px;height:64px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent-purple) 100%);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2rem;box-shadow:var(--shadow-md)}.ai-modal-header h2{font-size:var(--font-size-xl);font-weight:700;color:var(--gray-900);margin:0}.ai-subtitle{font-size:var(--font-size-sm);color:var(--gray-500);margin:var(--space-1) 0 0 0}.ai-message p{margin:0}.detected-mood-tag{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);border:1px solid;font-size:var(--font-size-sm);margin-top:var(--space-6)}.detected-mood-tag .intensity{color:var(--gray-500)}.mood-detail-modal{background:var(--white);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:var(--shadow-xl)}.mood-detail-modal h3{font-size:var(--font-size-xl);font-weight:600;margin:0}.modal-time{font-size:var(--font-size-sm);color:var(--gray-500);margin:var(--space-1) 0 0 0}.modal-section{margin-bottom:var(--space-5)}.modal-section:last-child{margin-bottom:0}.modal-section h4{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-500);margin:0 0 var(--space-2) 0}.modal-section p{margin:0;color:var(--gray-700);line-height:1.6}.modal-section.ai-section{background:var(--gray-100);padding:var(--space-4);border-radius:var(--radius-md);border-left:3px solid var(--primary)}.action-btn{padding:var(--space-3) var(--space-5);background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-200);border-radius:var(--radius-full);font-family:inherit;font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;gap:var(--space-2)}.action-btn:hover{background:var(--gray-200);transform:translateY(-1px)}.action-btn.primary{background:var(--primary);color:var(--white);border-color:var(--primary)}.action-btn.primary:hover{background:var(--primary-dark)}.auth-modal{background:var(--white);border-radius:var(--radius-xl);width:100%;max-width:420px;padding:var(--space-8);position:relative;box-shadow:var(--shadow-xl)}.auth-modal h2{text-align:center;margin-bottom:var(--space-2)}.auth-subtitle{text-align:center;color:var(--gray-500);margin-bottom:var(--space-6)}.auth-benefits{background:linear-gradient(135deg,var(--primary-glow) 0%,rgba(167,139,250,.1) 100%);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-6)}.benefit-item{font-size:var(--font-size-sm);color:var(--gray-700);padding:var(--space-1) 0}.form-group{margin-bottom:var(--space-4)}.form-group input{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--gray-200);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-base);transition:all var(--transition-base)}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.auth-error{background:var(--error-light);color:var(--error);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-4)}.auth-success{background:var(--success-light);color:var(--success);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-4)}.auth-switch{text-align:center;color:var(--gray-500);font-size:var(--font-size-sm);margin-top:var(--space-4)}.auth-switch button{background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer;font-family:inherit}.auth-guest-note{margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--gray-200);text-align:center}.auth-guest-note p{font-size:var(--font-size-sm);color:var(--gray-500);margin:0}@media (max-width: 1024px){.checkin-layout{grid-template-columns:1fr;gap:var(--space-8)}.tips-panel{position:static;margin-top:var(--space-6)}.insights-grid,.journal-layout{grid-template-columns:1fr}}@media (max-width: 768px){.app-container{padding:var(--space-4)}.app-header{flex-direction:column;gap:var(--space-4);position:static;margin-bottom:var(--space-4)}nav{flex-wrap:wrap;justify-content:center;width:100%}nav button{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm)}.mood-grid{grid-template-columns:repeat(2,1fr)}h1{font-size:var(--font-size-xl)}.benefits-grid{grid-template-columns:1fr}.footer-content{flex-direction:column;text-align:center;gap:var(--space-4)}.auth-section{width:100%;justify-content:center}.ai-response-modal,.mood-detail-modal,.auth-modal{margin:var(--space-4);max-height:calc(100vh - var(--space-8))}}@media (max-width: 480px){.mood-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.mood-btn{padding:var(--space-3)}.mood-emoji{font-size:2rem}.modal-actions{flex-direction:column}.action-btn{width:100%;justify-content:center}}.app-wrapper.landing{min-height:100vh}.landing-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-8);position:sticky;top:0;z-index:100;background:var(--glass-surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border)}.landing-header .logo-container{display:flex;align-items:center;gap:var(--space-2);cursor:pointer}.logo-emoji{font-size:2rem}.logo-text{font-size:1.5rem;font-weight:700;color:var(--gray-900)}.landing-nav{display:flex;gap:var(--space-2)}.landing-nav button{padding:var(--space-2) var(--space-4);background:transparent;border:none;color:var(--gray-700);font-family:inherit;font-size:.95rem;font-weight:500;cursor:pointer;border-radius:var(--radius-full);transition:all var(--transition-base)}.landing-nav button:hover{background:var(--gray-100);color:var(--primary)}.landing-page{max-width:1200px;margin:0 auto;padding:0 var(--space-6)}.hero-section{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-10);align-items:center;min-height:80vh;padding:var(--space-10) 0}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:linear-gradient(135deg,var(--primary-glow) 0%,rgba(167,139,250,.2) 100%);border:1px solid var(--primary-light);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;color:var(--primary-dark);margin-bottom:var(--space-4)}.hero-title{font-size:3.5rem;font-weight:800;line-height:1.1;color:var(--gray-900);margin:0 0 var(--space-6) 0}.gradient-text{background:linear-gradient(135deg,var(--primary) 0%,var(--accent-purple) 50%,var(--accent-rose) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.25rem;color:var(--gray-600);line-height:1.7;margin:0 0 var(--space-8) 0}.hero-cta{display:flex;gap:var(--space-4);align-items:center;margin-bottom:var(--space-8)}.cta-primary{padding:var(--space-4) var(--space-8);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border:none;border-radius:var(--radius-full);color:#fff;font-family:inherit;font-size:1.1rem;font-weight:600;cursor:pointer;box-shadow:0 4px 20px var(--primary-glow);transition:all var(--transition-base)}.cta-primary:hover{box-shadow:0 8px 30px var(--primary-glow);transform:translateY(-2px)}.cta-primary.large{padding:var(--space-5) var(--space-10);font-size:1.2rem}.cta-secondary{color:var(--primary);font-weight:600;text-decoration:none;font-size:1rem}.cta-secondary:hover{text-decoration:underline}.hero-stats{display:flex;gap:var(--space-8)}.stat{display:flex;flex-direction:column}.stat-number{font-size:2rem;font-weight:800;color:var(--gray-900)}.stat-label{font-size:var(--font-size-sm);color:var(--gray-500)}.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:400px}.floating-emojis{position:relative;width:300px;height:300px}.float-emoji{position:absolute;font-size:4rem;filter:drop-shadow(0 10px 30px rgba(0,0,0,.1))}.float-emoji.e1{top:0;left:50%;transform:translate(-50%)}.float-emoji.e2{top:50%;right:0;transform:translateY(-50%)}.float-emoji.e3{bottom:0;left:50%;transform:translate(-50%)}.float-emoji.e4{top:50%;left:0;transform:translateY(-50%)}.features-section{padding:var(--space-10) 0}.section-header{text-align:center;margin-bottom:var(--space-10)}.section-header h2{font-size:2.5rem;font-weight:700;color:var(--gray-900);margin:0 0 var(--space-3) 0}.section-header p{font-size:1.1rem;color:var(--gray-500);margin:0}.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6)}.feature-card{background:var(--glass-surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-6);text-align:center;transition:all var(--transition-base)}.feature-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-xl)}.feature-icon{font-size:3rem;margin-bottom:var(--space-4)}.feature-card h3{font-size:1.25rem;font-weight:600;color:var(--gray-900);margin:0 0 var(--space-3) 0}.feature-card p{font-size:var(--font-size-sm);color:var(--gray-600);line-height:1.6;margin:0}.tech-section{padding:var(--space-10) 0;background:linear-gradient(135deg,var(--gray-100) 0%,var(--white) 100%);border-radius:var(--radius-xl);margin:var(--space-10) 0}.tech-content{text-align:center;padding:var(--space-8)}.tech-content h2{font-size:2rem;font-weight:700;color:var(--gray-900);margin:0 0 var(--space-8) 0}.tech-stack{display:flex;justify-content:center;gap:var(--space-6);flex-wrap:wrap}.tech-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);background:var(--white);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.tech-icon{font-size:2rem}.tech-item strong{font-size:1rem;color:var(--gray-900)}.tech-item p{font-size:var(--font-size-sm);color:var(--gray-500);margin:0}.cta-section{padding:var(--space-10) 0;text-align:center}.cta-content{background:linear-gradient(135deg,var(--primary) 0%,var(--accent-purple) 100%);border-radius:var(--radius-xl);padding:var(--space-10);color:#fff}.cta-content h2{font-size:2.5rem;font-weight:700;margin:0 0 var(--space-4) 0}.cta-content p{font-size:1.2rem;opacity:.9;margin:0 0 var(--space-6) 0}.cta-content .cta-primary{background:#fff;color:var(--primary)}.cta-content .cta-primary:hover{background:var(--gray-100)}.console-badge{font-size:.7rem;background:var(--primary-glow);color:var(--primary);padding:2px 8px;border-radius:var(--radius-full);margin-left:var(--space-2);font-weight:600}.contact-page{padding:var(--space-8) 0;max-width:1000px;margin:0 auto}.contact-header{text-align:center;margin-bottom:var(--space-8)}.contact-header h1{font-size:2.5rem;font-weight:700;color:var(--gray-900);margin:0 0 var(--space-3) 0}.contact-header p{font-size:1.1rem;color:var(--gray-500);margin:0}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}.contact-form-card,.connect-card{padding:var(--space-6)}.contact-form-card h2,.connect-card h2{font-size:1.5rem;font-weight:600;margin:0 0 var(--space-4) 0;color:var(--gray-900)}.contact-form-card form{display:flex;flex-direction:column;gap:var(--space-4)}.contact-form-card label{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-700);margin-bottom:var(--space-1);display:block}.contact-form-card input,.contact-form-card textarea{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--gray-200);border-radius:var(--radius-md);font-family:inherit;font-size:1rem;transition:all var(--transition-base)}.contact-form-card input:focus,.contact-form-card textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.submit-btn{margin-top:var(--space-2)}.success-message{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-6);background:var(--success-light);border-radius:var(--radius-md);text-align:center}.success-icon{font-size:2rem}.success-message p{margin:0;color:var(--success);font-weight:500}.connect-intro{color:var(--gray-600);margin-bottom:var(--space-6)}.social-links{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3);margin-bottom:var(--space-6)}.social-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--gray-100);border-radius:var(--radius-md);text-decoration:none;color:var(--gray-700);font-weight:500;transition:all var(--transition-base)}.social-link:hover{background:var(--gray-200)}.social-link .social-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--gray-200);border-radius:var(--radius-sm);font-weight:700}.social-link.x .social-icon{background:#000;color:#fff}.social-link.linkedin .social-icon{background:#0077b5;color:#fff}.social-link.instagram .social-icon{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:#fff}.social-link.facebook .social-icon{background:#1877f2;color:#fff}.contact-info{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--gray-200)}.info-item{display:flex;align-items:center;gap:var(--space-3)}.info-icon{font-size:1.5rem}.info-item strong{font-size:var(--font-size-sm);color:var(--gray-900)}.info-item p{margin:0;font-size:var(--font-size-sm);color:var(--gray-500)}.hackathon-badge{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:linear-gradient(135deg,var(--primary-glow) 0%,rgba(167,139,250,.15) 100%);border:1px solid var(--primary-light);border-radius:var(--radius-md)}.badge-icon{font-size:2rem}.hackathon-badge strong{color:var(--primary);font-size:var(--font-size-sm)}.hackathon-badge p{margin:0;color:var(--gray-500);font-size:var(--font-size-xs)}.hamburger-btn{display:none;flex-direction:column;justify-content:center;gap:4px;width:36px;height:36px;padding:6px;background:transparent;border:none;cursor:pointer;z-index:1001;margin-left:auto}.hamburger-line{display:block;width:22px;height:2px;background:var(--gray-700);border-radius:2px;transition:all .3s ease}.hamburger-line.open:nth-child(1){transform:rotate(45deg) translate(4px,4px)}.hamburger-line.open:nth-child(2){opacity:0}.hamburger-line.open:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.mobile-nav-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999}.mobile-nav{position:fixed;top:0;right:0;width:260px;max-height:100vh;background:var(--white);padding:0;display:flex;flex-direction:column;box-shadow:-10px 0 40px #00000026;z-index:1000}.mobile-nav-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--gray-200);background:linear-gradient(135deg,var(--primary-glow) 0%,var(--white) 100%)}.mobile-nav-brand{display:flex;align-items:center;gap:var(--space-2)}.mobile-logo{width:28px;height:28px;object-fit:contain}.mobile-nav-brand span{font-weight:700;font-size:1.1rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.close-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--gray-300);border-radius:var(--radius-full);font-size:1.25rem;font-weight:300;color:var(--gray-500);cursor:pointer;transition:all var(--transition-base)}.close-btn:hover{background:var(--gray-100);color:var(--gray-900);border-color:var(--gray-400)}.mobile-nav-links{display:flex;flex-direction:column;padding:var(--space-4);gap:var(--space-1)}.mobile-nav-links button{width:100%;padding:var(--space-4);background:transparent;border:none;border-radius:var(--radius-md);text-align:left;font-family:inherit;font-size:1rem;font-weight:500;color:var(--gray-700);cursor:pointer;transition:all var(--transition-base)}.mobile-nav-links button:hover{background:var(--gray-100);color:var(--primary)}.mobile-auth{padding:var(--space-4) var(--space-5);border-top:1px solid var(--gray-200);margin-top:auto;display:flex;flex-direction:column;gap:var(--space-3)}.mobile-auth .user-email{font-size:var(--font-size-sm);color:var(--gray-500);text-align:center}.auth-btn-mobile{width:100%;padding:var(--space-3) var(--space-4);background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-family:inherit;font-weight:500;font-size:.95rem;text-align:center;cursor:pointer;transition:all var(--transition-base)}.auth-btn-mobile:hover{background:var(--gray-200)}.auth-btn-mobile.primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;border:none}.auth-btn-mobile.primary:hover{opacity:.9;transform:translateY(-1px)}@media (max-width: 768px){.hamburger-btn{display:flex!important;margin-left:auto}.desktop-nav,.desktop-auth,.app-header nav,.app-header .auth-section,.landing-nav{display:none!important}.landing-header{display:flex!important;flex-direction:row!important;justify-content:space-between!important;align-items:center!important;padding:.5rem 1rem!important;width:100%}.landing-header .logo-container{margin-right:auto}.landing-header .logo-text{font-size:.95rem}.app-header{display:flex!important;flex-direction:row!important;justify-content:space-between!important;align-items:center!important;padding:.5rem 1rem!important;margin-bottom:1rem;flex-wrap:nowrap!important}.app-header .logo-container{margin-right:auto}.app-header h1{font-size:.95rem;white-space:nowrap}.console-badge{font-size:.55rem;padding:.1rem .3rem;margin-left:.25rem}.header-logo{width:22px;height:22px}.app-container{padding:1rem}}@media (min-width: 769px){.hamburger-btn,.mobile-nav-overlay,.mobile-nav{display:none}}.footer-social{display:flex;gap:var(--space-3);margin:var(--space-4) 0}.social-icon-link{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border-radius:var(--radius-full);text-decoration:none;color:var(--gray-600);font-weight:700;font-size:1rem;transition:all var(--transition-base)}.social-icon-link:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}.footer-powered{text-align:center;padding:var(--space-4) 0;border-top:1px solid var(--gray-200);margin-top:var(--space-4)}.footer-powered p{margin:0 0 var(--space-2) 0;color:var(--gray-500);font-size:var(--font-size-sm)}.powered-logos{display:flex;align-items:center;justify-content:center;gap:var(--space-3)}.powered-item{font-weight:600;color:var(--gray-700);font-size:var(--font-size-sm)}.powered-separator{color:var(--gray-400)}@media (max-width: 1024px){.hero-section{grid-template-columns:1fr;text-align:center;min-height:auto;padding:var(--space-8) 0}.hero-visual{display:none}.hero-cta,.hero-stats{justify-content:center}.features-grid{grid-template-columns:repeat(2,1fr)}.tech-stack{flex-direction:column;align-items:center}}@media (max-width: 768px){.landing-header{flex-direction:column;gap:var(--space-4);padding:var(--space-4)}.landing-nav{flex-wrap:wrap;justify-content:center}.hero-title{font-size:2.5rem}.features-grid,.contact-content,.social-links{grid-template-columns:1fr}}
