body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{-webkit-tap-highlight-color:transparent;box-sizing:border-box;margin:0;padding:0}:root{--primary:#667eea;--primary-dark:#5568d3;--secondary:#764ba2;--success:#10b981;--danger:#ef4444;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-400:#9ca3af;--gray-600:#4b5563;--gray-900:#111827;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--touch-target:48px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:16px;line-height:1.5;overflow-x:hidden}.App,body{min-height:100vh}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffffa;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);padding:.75rem 1rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.navbar h1{color:#667eea;color:var(--primary);font-size:1.25rem;font-weight:700}.navbar nav{flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.nav-link,.navbar nav{align-items:center;display:flex}.nav-link{border-radius:8px;color:#4b5563;color:var(--gray-600);font-size:.9rem;min-height:48px;min-height:var(--touch-target);padding:.5rem .75rem;text-decoration:none;transition:all .2s}.nav-link:active{background:#f3f4f6;background:var(--gray-100);transform:scale(.95)}.btn{align-items:center;border:none;border-radius:12px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;justify-content:center;min-height:48px;min-height:var(--touch-target);padding:.875rem 1.25rem;text-align:center;transition:all .2s;user-select:none;-webkit-user-select:none}.btn:active{transform:scale(.95)}.btn-primary{background:#667eea;background:var(--primary);box-shadow:0 4px 12px #667eea4d;color:#fff}.btn-primary:active{background:#5568d3;background:var(--primary-dark)}.btn-secondary{background:#f3f4f6;background:var(--gray-100);color:#111827;color:var(--gray-900)}.btn-danger{background:#ef4444;background:var(--danger);color:#fff}.btn-success{background:#10b981;background:var(--success);color:#fff}.btn-sm{font-size:.875rem;min-height:40px;padding:.625rem 1rem}.container{margin:0 auto;padding:0 1rem;width:100%}.card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);padding:1.25rem}.card,.card h2{margin-bottom:1rem}.card h2{color:#111827;color:var(--gray-900);font-size:1.25rem}.card h3{color:#667eea;color:var(--primary);font-size:1.125rem;margin-bottom:.5rem}.form-group{margin-bottom:1.25rem}.form-group label{color:#111827;color:var(--gray-900);display:block;font-size:.9375rem;font-weight:500;margin-bottom:.5rem}.form-control{-webkit-appearance:none;appearance:none;border:2px solid #e5e7eb;border:2px solid var(--gray-200);border-radius:12px;font-size:1rem;min-height:48px;min-height:var(--touch-target);padding:.875rem;transition:border-color .2s;width:100%}.form-control:focus{border-color:#667eea;border-color:var(--primary);box-shadow:0 0 0 3px #667eea1a;outline:none}select.form-control{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;cursor:pointer;padding-right:2.5rem}textarea.form-control{min-height:100px;resize:vertical}.auth-container{align-items:center;display:flex;justify-content:center;min-height:calc(100vh - 80px);padding:1rem}.auth-card{background:#fff;border-radius:20px;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);max-width:400px;padding:2rem 1.5rem;width:100%}.auth-card h2{color:#667eea;color:var(--primary);font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.welcome{color:#fff;padding:2rem 1rem;text-align:center}.welcome h1{font-size:2rem;line-height:1.2;margin-bottom:.75rem}.welcome p{font-size:1.0625rem;margin-bottom:1.5rem;opacity:.95}.welcome-actions{display:flex;flex-direction:column;gap:.75rem;padding:0 1rem}.welcome-actions .btn{font-size:1.0625rem;padding:1rem 1.5rem;width:100%}.dashboard-new{padding:1rem 0;width:100%}.dashboard-header{margin-bottom:1.5rem;padding:0 1rem}.header-left h1{color:#fff;font-size:1.75rem;margin:0 0 .25rem}.month-display{color:#ffffffe6;font-size:.9375rem}.header-right{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.view-toggle{background:#ffffff26;border-radius:12px;display:flex;gap:.25rem;padding:.25rem}.toggle-btn{background:#0000;border:none;border-radius:10px;color:#fffc;cursor:pointer;flex:1 1;font-size:.9375rem;font-weight:500;min-height:44px;padding:.625rem .75rem;transition:all .2s}.toggle-btn:active{transform:scale(.95)}.toggle-btn.active{background:#fff;box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#667eea;color:var(--primary);font-weight:600}.add-habit-btn{width:100%}.habits-calendar-grid{display:flex;flex-direction:column;gap:1rem;padding:0 1rem}.habit-calendar-wrapper{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);overflow:hidden}.habit-calendar-wrapper:active{transform:scale(.98);transition:transform .1s}.habit-calendar-card{padding:1.25rem}.habit-title-row{align-items:center;display:flex;gap:.625rem;margin-bottom:1rem}.habit-emoji{font-size:1.75rem}.habit-title-row h3{color:#111827;color:var(--gray-900);flex:1 1;font-size:1.125rem;margin:0}.calendar-grid{margin:1rem 0}.calendar-weekdays{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(7,1fr);margin-bottom:2px}.calendar-weekday{color:#9ca3af;color:var(--gray-400);font-size:.6875rem;font-weight:600;padding:.375rem .125rem;text-align:center;text-transform:uppercase}.calendar-days{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(7,1fr)}.calendar-day{align-items:center;aspect-ratio:1;background:#f9fafb;background:var(--gray-50);border-radius:8px;color:#9ca3af;color:var(--gray-400);display:flex;font-size:.875rem;font-weight:500;justify-content:center;min-height:36px;position:relative;transition:all .15s}.calendar-day:active{transform:scale(.9)}.calendar-day.empty{background:#0000}.calendar-day.completed{background:linear-gradient(135deg,#667eea,#764ba2);background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;font-weight:600}.calendar-day.today{border:2px solid #667eea;border:2px solid var(--primary);box-shadow:0 0 0 3px #667eea1a;font-weight:700}.calendar-day.missed{background:#ffebee;color:#c62828}.habit-stats-row{border-top:1px solid #f3f4f6;border-top:1px solid var(--gray-100);display:flex;justify-content:space-around;margin-top:1rem;padding-top:1rem}.stat-item{align-items:center;display:flex;flex-direction:column;gap:.25rem}.stat-icon{font-size:1.5rem}.stat-value{color:#667eea;color:var(--primary);font-size:1.125rem;font-weight:700}.stat-label{color:#4b5563;color:var(--gray-600);font-size:.75rem;text-align:center}.habit-actions-bottom{background:#f9fafb;background:var(--gray-50);border-top:1px solid #f3f4f6;border-top:1px solid var(--gray-100);display:flex;gap:.5rem;padding:1rem}.habit-actions-bottom .btn{flex:1 1;font-size:.875rem;padding:.75rem .5rem}.modal-overlay{align-items:flex-end;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:0;position:fixed;right:0;top:0;z-index:1000}.modal{animation:slideUp .3s ease-out;background:#fff;border-radius:20px 20px 0 0;max-height:90vh;overflow-y:auto;padding:1.5rem;width:100%}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal h2{color:#667eea;color:var(--primary);font-size:1.375rem;margin-bottom:1.5rem}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem}.modal-actions .btn{flex:1 1}.loading{color:#fff;font-size:1.125rem;padding:2rem 1rem;text-align:center}.error,.success{border-radius:12px;font-size:.9375rem;margin:0 1rem 1rem;padding:1rem}.error{background:#fee;border-left:4px solid #c33;color:#c33}.success{background:#efe;border-left:4px solid #2d5;color:#2d5}.empty-state{background:#fff;border-radius:16px;margin:1rem;padding:3rem 1.5rem;text-align:center}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-state h2{color:#111827;color:var(--gray-900);font-size:1.25rem;margin-bottom:.5rem}.empty-state p{color:#4b5563;color:var(--gray-600);font-size:.9375rem;margin-bottom:1.5rem}@media (min-width:768px){.container{max-width:720px;padding:0 2rem}.navbar{padding:1rem 2rem}.navbar h1{font-size:1.5rem}.navbar nav{margin-top:0}.dashboard-header{align-items:center;display:flex;justify-content:space-between}.header-right{flex-direction:row;margin-top:0}.add-habit-btn{width:auto}.habits-calendar-grid{display:grid;grid-template-columns:repeat(2,1fr)}.welcome-actions{flex-direction:row;justify-content:center;margin:0 auto;max-width:400px}.welcome-actions .btn{flex:1 1;width:auto}.modal-overlay{align-items:center;padding:1rem}.modal{animation:fadeIn .3s ease-out;border-radius:20px;max-width:500px}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.calendar-day{font-size:.9375rem;min-height:40px}.auth-card{padding:3rem 2.5rem}}@media (min-width:1024px){.container{max-width:960px}.dashboard-new{margin:0 auto;max-width:1200px}.habits-calendar-grid{gap:1.5rem;grid-template-columns:repeat(3,1fr)}.habit-calendar-wrapper:hover{box-shadow:0 12px 24px #00000026;transform:translateY(-4px)}.btn:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-2px)}.toggle-btn:hover{background:#ffffff1a}.calendar-day{font-size:1rem;min-height:44px}}@media (min-width:1280px){.container{max-width:1200px}.dashboard-new{max-width:1400px}.habits-calendar-grid{grid-template-columns:repeat(4,1fr)}}.oauth-divider{margin:1.5rem 0;position:relative;text-align:center}.oauth-divider:before{background:#e5e7eb;background:var(--gray-200);content:"";height:1px;left:0;position:absolute;right:0;top:50%}.oauth-divider span{background:#fff;color:#9ca3af;color:var(--gray-400);font-size:.875rem;padding:0 1rem;position:relative;z-index:1}.oauth-buttons{display:flex;flex-direction:column;gap:.75rem}.btn-oauth{align-items:center;background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:8px;color:#111827;color:var(--gray-900);cursor:pointer;display:flex;font-weight:500;justify-content:center;min-height:48px;min-height:var(--touch-target);padding:.75rem 1rem;transition:all .2s;width:100%}.btn-oauth:hover:not(:disabled){background:#f9fafb;background:var(--gray-50);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-oauth:active:not(:disabled){transform:translateY(0)}.btn-oauth:disabled{cursor:not-allowed;opacity:.5}.btn-github svg,.btn-google svg{flex-shrink:0}@media (max-width:767px){.oauth-divider{margin:1.25rem 0}.oauth-buttons{gap:.625rem}}@media (hover:none) and (pointer:coarse){.btn,.form-control{min-height:48px}.form-control{font-size:16px}.btn-oauth,.toggle-btn{min-height:48px}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
/*# sourceMappingURL=main.618666ed.css.map*/