:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#1e293b;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}#root{width:100%}.auth-container{background-color:#f1f5f9;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-card{background:#fff;border-radius:16px;flex-direction:column;gap:1.25rem;width:100%;max-width:400px;padding:2.5rem;display:flex;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.oauth-buttons{flex-direction:column;gap:.75rem;display:flex}.oauth-btn{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;gap:.75rem;width:100%;padding:.75rem;font-size:.95rem;font-weight:500;transition:all .2s;display:flex}.oauth-btn:hover{background:#f8fafc;border-color:#cbd5e1}.oauth-btn img{width:18px;height:18px}.divider{text-align:center;align-items:center;margin:.5rem 0;display:flex}.divider:before,.divider:after{content:"";border-bottom:1px solid #e2e8f0;flex:1}.divider span{color:#94a3b8;text-transform:uppercase;padding:0 .75rem;font-size:.75rem}.auth-header h2{color:#1e293b;text-align:center;margin:0 0 .5rem;font-size:1.8rem;font-weight:700}.auth-header p{color:#64748b;text-align:center;margin:0;font-size:.95rem}.auth-form{flex-direction:column;gap:1.25rem;display:flex}.input-field{align-items:center;display:flex;position:relative}.input-icon{color:#94a3b8;position:absolute;left:1rem}.input-field input{border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:.75rem 1rem .75rem 2.75rem;font-size:1rem;transition:all .2s}.input-field input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.submit-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.8rem;font-weight:600;transition:background .2s;display:flex}.submit-btn:hover{background:#2563eb}.submit-btn:disabled{cursor:not-allowed;background:#94a3b8}.message{text-align:center;border-radius:6px;padding:.75rem;font-size:.9rem}.message.error{color:#ef4444;background:#fee2e2}.message.success{color:#10b981;background:#dcfce7}.auth-footer{text-align:center;border-top:1px solid #e2e8f0;padding-top:1.5rem}.toggle-btn{color:#64748b;cursor:pointer;background:0 0;border:none;padding:.5rem;font-size:.9rem;text-decoration:underline}.toggle-btn:hover{color:#3b82f6}:root{--primary:#3b82f6;--bg-color:#f8fafc;--card-bg:#fff;--text-main:#1e293b;--text-muted:#64748b;--border-color:#e2e8f0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--radius:12px}body{background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;margin:0;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif}.app-container{max-width:1200px;min-height:100vh;margin:0 auto;padding:2rem}.app-header{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;margin-bottom:3rem;display:flex;position:relative}.header-top{justify-content:flex-end;width:100%;display:flex;position:absolute;top:-1rem}.user-info{box-shadow:var(--shadow-sm);border:1px solid var(--border-color);background:#fff;border-radius:999px;align-items:center;gap:1rem;padding:.5rem 1rem;display:flex}.user-email{color:var(--text-muted);font-size:.875rem;font-weight:500}.logout-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:all .2s;display:flex}.logout-btn:hover{color:#ef4444;background:#fee2e2}.header-content h1{letter-spacing:-.025em;background:linear-gradient(135deg,#1e293b 0%,#3b82f6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0 0 .5rem;font-size:2.5rem;font-weight:800}.header-content p{color:var(--text-muted);margin:0;font-size:1.1rem}.input-group{background:var(--card-bg);width:100%;max-width:600px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);border-radius:16px;gap:.75rem;padding:.5rem;display:flex}.todo-input{background:0 0;border:none;outline:none;flex:1;padding:.75rem 1rem;font-size:1rem}.add-button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;transition:all .2s;display:flex}.add-button:hover{background:#2563eb;transform:translateY(-1px)}.board{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));align-items:start;gap:2rem;display:grid}.column{background:#f1f5f9;border:1px solid #e2e8f099;border-radius:20px;flex-direction:column;gap:1.25rem;min-height:500px;padding:1.25rem;display:flex}.column-header{padding:.25rem .5rem}.column-title{align-items:center;gap:.75rem;display:flex}.column-title h2{color:#334155;margin:0;font-size:1.125rem;font-weight:700}.count{box-shadow:var(--shadow-sm);background:#fff;border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:700}.column-content{flex-direction:column;gap:1rem;display:flex}.todo-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-md);border:1px solid var(--border-color);padding:1.25rem;transition:all .2s;position:relative}.todo-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.todo-card-text{color:var(--text-main);word-break:break-all;margin-bottom:1rem;font-size:1rem;line-height:1.5}.todo-card-footer{border-top:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding-top:.75rem;display:flex}.todo-date{color:var(--text-muted);align-items:center;gap:.4rem;font-size:.75rem;display:flex}.actions{gap:.4rem;display:flex}.action-btn{cursor:pointer;width:32px;height:32px;color:var(--text-muted);background:#f8fafc;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.action-btn:hover{color:var(--text-main);background:#f1f5f9}.action-btn.delete:hover{color:#ef4444;background:#fee2e2}.action-btn.next:hover{color:#10b981;background:#dcfce7}.action-btn.prev:hover{color:#f59e0b;background:#fef3c7}.empty-state{text-align:center;color:var(--text-muted);border-radius:var(--radius);border:2px dashed #cbd5e1;padding:3rem 1rem;font-size:.875rem}@media (width<=640px){.app-container{padding:1rem}.header-content h1{font-size:1.75rem}.board{grid-template-columns:1fr}}.loading-container{min-height:400px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.animate-spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.initial-loading{background-color:#f8fafc;justify-content:center;align-items:center;height:100vh;display:flex}.loading-content{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;display:flex}.app-logo{box-shadow:var(--shadow-lg);background:#fff;border-radius:24px;padding:1.5rem}.loading-content h2{color:#1e293b;margin:0;font-size:1.5rem;font-weight:800}.loading-content p{color:#64748b;font-size:.875rem}.home-container{background:radial-gradient(circle at 100% 0,#eff6ff 0%,#f8fafc 100%);flex-direction:column;min-height:100vh;display:flex}.home-hero{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4rem;padding:4rem 2rem;display:flex}.hero-text{text-align:center;max-width:800px}.badge{color:#2563eb;background:#dbeafe;border-radius:999px;margin-bottom:1.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:700;display:inline-block}.hero-text h1{color:#1e293b;letter-spacing:-.05em;margin-bottom:1.5rem;font-size:3.5rem;font-weight:900;line-height:1.2}.hero-text h1 span{color:#3b82f6}.hero-text p{color:#64748b;margin:0;font-size:1.25rem}.home-footer{text-align:center;color:#94a3b8;border-top:1px solid #e2e8f0;padding:2rem;font-size:.875rem}.title-area{align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.title-icon{color:#3b82f6}@media (width<=768px){.hero-text h1{font-size:2.5rem}.home-hero{gap:2rem;padding-top:2rem}}
