.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5;padding:16px}.login-card{background-color:#fff;border-radius:8px;padding:24px;width:100%;max-width:400px;box-shadow:0 2px 8px #0000001a}.login-title{font-size:32px;font-weight:700;text-align:center;margin-bottom:8px;color:#333}.login-subtitle{font-size:16px;color:#666;text-align:center;margin-bottom:24px}.login-input{width:100%;border:1px solid #ddd;border-radius:6px;padding:12px;margin-bottom:16px;font-size:16px;font-family:inherit;box-sizing:border-box}.login-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-button{width:100%;background-color:#4caf50;color:#fff;border:none;border-radius:6px;padding:14px;font-size:16px;font-weight:600;cursor:pointer;margin-top:8px;margin-bottom:16px;transition:background-color .3s}.login-button:hover:not(:disabled){background-color:#45a049}.login-button-disabled{opacity:.6;cursor:not-allowed}.login-link{width:100%;background:none;color:#4caf50;text-align:center;font-size:14px;text-decoration:underline;cursor:pointer;padding:8px;border:none;font-family:inherit;transition:color .3s}.login-link:hover:not(:disabled){color:#45a049}.login-link:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#d32f2f;margin-bottom:16px;padding:12px;background-color:#ffebee;border-radius:6px;font-size:14px}.signup-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5;padding:16px}.signup-card{background-color:#fff;border-radius:8px;padding:32px;width:100%;max-width:420px;box-shadow:0 2px 12px #0000001a}.signup-title{font-size:32px;font-weight:700;text-align:center;margin-bottom:8px;color:#333;letter-spacing:-.5px}.signup-subtitle{font-size:16px;color:#666;text-align:center;margin-bottom:28px;font-weight:500}.signup-error{display:flex;justify-content:space-between;align-items:center;color:#d32f2f;margin-bottom:20px;padding:12px 14px;background-color:#ffebee;border:1px solid #ef5350;border-radius:6px;font-size:14px;line-height:1.4}.signup-error-close{background:none;border:none;color:#d32f2f;font-size:18px;cursor:pointer;padding:0;margin-left:12px;display:flex;align-items:center;transition:color .2s}.signup-error-close:hover{color:#c62828}.signup-form{display:flex;flex-direction:column}.signup-form-group{margin-bottom:18px}.signup-label{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:6px}.signup-input{width:100%;border:1px solid #ddd;border-radius:6px;padding:12px 14px;font-size:16px;font-family:inherit;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.signup-input:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.signup-input:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.signup-button{width:100%;background-color:#4caf50;color:#fff;border:none;border-radius:6px;padding:14px;font-size:16px;font-weight:600;cursor:pointer;margin-top:8px;margin-bottom:20px;transition:background-color .3s,box-shadow .3s}.signup-button:hover:not(:disabled){background-color:#45a049;box-shadow:0 2px 8px #4caf504d}.signup-button:active:not(:disabled){background-color:#3d8b40}.signup-button-disabled{opacity:.6;cursor:not-allowed}.signup-footer{text-align:center}.signup-footer-text{margin:0 0 8px;font-size:14px;color:#666}.signup-link{background:none;color:#4caf50;font-size:14px;cursor:pointer;padding:0;border:none;font-family:inherit;transition:color .3s}.signup-link:hover:not(:disabled){color:#45a049}.signup-link:disabled{opacity:.6;cursor:not-allowed}.signup-link-highlight{font-weight:600}.password-strength-container{margin-top:12px;padding:12px;background-color:#fafafa;border-radius:6px;border:1px solid #e0e0e0}.password-strength-meter{height:6px;background-color:#e0e0e0;border-radius:3px;overflow:hidden;margin-bottom:8px}.password-strength-bar{height:100%;width:0%;transition:width .2s ease,background-color .2s ease;border-radius:3px}.password-strength-label{font-size:13px;font-weight:600;margin:0 0 10px;letter-spacing:.3px}.password-requirements{margin-top:10px}.requirements-title{font-size:12px;font-weight:700;color:#666;margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px}.requirements-list{display:flex;flex-direction:column;gap:6px}.requirement{display:flex;align-items:center;font-size:13px;color:#d32f2f;transition:color .2s}.requirement.passed{color:#4caf50}.requirement-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;margin-right:6px;font-size:12px;font-weight:700;border-radius:3px;background-color:#d32f2f1a}.requirement.passed .requirement-icon{background-color:#4caf501a;color:#4caf50}.requirement span:last-child{flex:1}.verify-email-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#48bb78,#38a169);padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.verify-email-card{background:#fff;border-radius:12px;padding:48px 40px;box-shadow:0 20px 60px #0000004d;max-width:480px;width:100%;text-align:center}.verify-email-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto 32px;background:#c6f6d5;border-radius:50%;color:#48bb78}.verify-email-spinner{width:40px;height:40px;border:4px solid #c6f6d5;border-top-color:#48bb78;border-radius:50%;animation:spin 1s linear infinite}.verify-email-check{animation:scaleIn .4s cubic-bezier(.34,1.56,.64,1)}.verify-email-error{animation:slideIn .3s ease-out}@keyframes scaleIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.verify-email-title{margin:0 0 16px;font-size:28px;font-weight:700;color:#1a202c}.verify-email-message{margin:0 0 24px;font-size:16px;color:#4a5568;line-height:1.6}.verify-email-confirmed{background:#f0fdf4;border:2px solid #86efac;border-radius:8px;padding:16px;margin:24px 0}.verify-email-confirmed-label{margin:0 0 8px;font-size:12px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.verify-email-confirmed-email{margin:0;font-size:16px;color:#22863a;font-weight:600;word-break:break-all}.verify-email-actions{margin-top:32px}.verify-email-button{padding:12px 24px;background:#48bb78;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;width:100%;margin-bottom:16px}.verify-email-button:hover{background:#38a169;transform:translateY(-2px);box-shadow:0 8px 16px #48bb7866}.verify-email-button:disabled{opacity:.6;cursor:not-allowed}.verify-email-button-primary{background:#48bb78}.verify-email-button-primary:hover{background:#38a169}.verify-email-button-secondary{background:#f7fafc;color:#2d3748;border:1px solid #cbd5e0}.verify-email-button-secondary:hover{background:#edf2f7;border-color:#a0aec0}.verify-email-note{margin:0;font-size:13px;color:#718096;line-height:1.6}.verify-email-error-note{margin:0;font-size:13px;color:#c53030;line-height:1.6}@media(max-width:480px){.verify-email-card{padding:32px 24px}.verify-email-title{font-size:24px}.verify-email-icon{width:64px;height:64px;margin-bottom:24px}}.verification-pending-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.verification-pending-card{background:#fff;border-radius:12px;padding:48px 40px;box-shadow:0 20px 60px #0000004d;max-width:480px;width:100%;text-align:center}.verification-pending-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto 32px;background:#f0f4ff;border-radius:50%;color:#667eea}.verification-pending-icon svg{animation:float 3s ease-in-out infinite}.verification-pending-title{margin:0 0 12px;font-size:28px;font-weight:700;color:#1a202c}.verification-pending-subtitle{margin:0 0 8px;font-size:14px;color:#718096;font-weight:500}.verification-pending-email{margin:0 0 24px;font-size:16px;color:#2d3748;font-weight:600;background:#f7fafc;padding:12px 16px;border-radius:8px;word-break:break-all}.verification-pending-instructions{margin:24px 0;text-align:left;background:#f0f4ff;border-left:4px solid #667eea;padding:16px;border-radius:4px}.verification-pending-instructions p{margin:0 0 12px;font-size:14px;color:#2d3748;line-height:1.6}.verification-pending-instructions p:last-child{margin:0}.verification-pending-spam-tip{font-size:13px;color:#5a67d8;margin-top:12px!important}.verification-pending-error{display:flex;align-items:flex-start;gap:12px;margin:20px 0;padding:12px 16px;background-color:#fed7d7;color:#c53030;border-radius:8px;font-size:14px;border-left:4px solid #c53030;animation:slideIn .3s ease-out}.verification-pending-success{display:flex;align-items:flex-start;gap:12px;margin:20px 0;padding:12px 16px;background-color:#c6f6d5;color:#22543d;border-radius:8px;font-size:14px;border-left:4px solid #48bb78;animation:slideIn .3s ease-out}.verification-pending-error-close{background:none;border:none;color:inherit;cursor:pointer;font-size:18px;padding:0;flex-shrink:0;opacity:.7;transition:opacity .2s}.verification-pending-error-close:hover{opacity:1}.verification-pending-actions{display:flex;flex-direction:column;gap:12px;margin:32px 0}.verification-pending-resend-button,.verification-pending-back-button{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-transform:none}.verification-pending-resend-button{background:#667eea;color:#fff}.verification-pending-resend-button:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 8px 16px #667eea66}.verification-pending-resend-button:disabled{opacity:.6;cursor:not-allowed}.verification-pending-back-button{background:#f7fafc;color:#2d3748;border:1px solid #cbd5e0}.verification-pending-back-button:hover:not(:disabled){background:#edf2f7;border-color:#a0aec0}.verification-pending-back-button:disabled{opacity:.6;cursor:not-allowed}.verification-pending-note{margin:24px 0 0;font-size:13px;color:#718096;line-height:1.6}@media(max-width:480px){.verification-pending-card{padding:32px 24px}.verification-pending-title{font-size:24px}.verification-pending-icon{width:64px;height:64px;margin-bottom:24px}.verification-pending-icon svg{width:40px;height:40px}}.not-verified-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#f97316,#ea580c);padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.not-verified-card{background:#fff;border-radius:12px;padding:48px 40px;box-shadow:0 20px 60px #0000004d;max-width:480px;width:100%;text-align:center}.not-verified-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto 32px;background:#fef3c7;border-radius:50%;color:#f97316}.not-verified-icon svg{animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.not-verified-title{margin:0 0 12px;font-size:28px;font-weight:700;color:#1a202c}.not-verified-subtitle{margin:0 0 24px;font-size:14px;color:#f97316;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.not-verified-instructions{margin:24px 0;text-align:left;background:#fef3c7;border-left:4px solid #f97316;padding:16px;border-radius:4px}.not-verified-instructions p{margin:0 0 12px;font-size:14px;color:#92400e;line-height:1.6}.not-verified-instructions p:last-child{margin:0}.not-verified-spam-tip{font-size:13px;color:#ea580c;margin-top:12px!important}.not-verified-error{display:flex;align-items:flex-start;gap:12px;margin:20px 0;padding:12px 16px;background-color:#fed7d7;color:#c53030;border-radius:8px;font-size:14px;border-left:4px solid #c53030;animation:slideIn .3s ease-out}.not-verified-success{display:flex;align-items:flex-start;gap:12px;margin:20px 0;padding:12px 16px;background-color:#c6f6d5;color:#22543d;border-radius:8px;font-size:14px;border-left:4px solid #48bb78;animation:slideIn .3s ease-out}.not-verified-error-close{background:none;border:none;color:inherit;cursor:pointer;font-size:18px;padding:0;flex-shrink:0;opacity:.7;transition:opacity .2s}.not-verified-error-close:hover{opacity:1}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.not-verified-actions{display:flex;flex-direction:column;gap:12px;margin:32px 0}.not-verified-resend-button,.not-verified-back-button{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-transform:none}.not-verified-resend-button{background:#f97316;color:#fff}.not-verified-resend-button:hover:not(:disabled){background:#ea580c;transform:translateY(-2px);box-shadow:0 8px 16px #f9731666}.not-verified-resend-button:disabled{opacity:.6;cursor:not-allowed}.not-verified-back-button{background:#f7fafc;color:#2d3748;border:1px solid #cbd5e0}.not-verified-back-button:hover:not(:disabled){background:#edf2f7;border-color:#a0aec0}.not-verified-back-button:disabled{opacity:.6;cursor:not-allowed}.not-verified-note{margin:24px 0 0;font-size:13px;color:#718096;line-height:1.6}@media(max-width:480px){.not-verified-card{padding:32px 24px}.not-verified-title{font-size:24px}.not-verified-icon{width:64px;height:64px;margin-bottom:24px}.not-verified-icon svg{width:40px;height:40px}}@keyframes skeletonLoading{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeletonLoading 1.5s infinite}.dashboard-skeleton{display:flex;flex-direction:column;gap:20px;padding:16px}.stats-grid-skeleton{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.stat-card.skeleton{display:flex;flex-direction:column;gap:8px;padding:16px;border-radius:8px;background-color:#f5f5f5}.stat-value-skeleton{height:32px;background-color:#e0e0e0;border-radius:4px}.stat-label-skeleton{height:14px;background-color:#e0e0e0;border-radius:4px;width:70%}.stat-row-skeleton{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:#f5f5f5;border-radius:8px}.streak-info-skeleton{display:flex;flex-direction:column;gap:12px;padding:16px;background-color:#f5f5f5;border-radius:8px}.add-button-skeleton{height:40px;background-color:#e0e0e0;border-radius:6px}.entries-skeleton{display:flex;flex-direction:column;gap:12px}.entry-item.skeleton{display:flex;flex-direction:column;gap:12px;padding:16px;background-color:#f5f5f5;border-radius:8px;border:1px solid #e0e0e0}.entry-header-skeleton{display:flex;justify-content:space-between;align-items:center;gap:12px}.entry-date-skeleton{height:18px;width:120px;background-color:#e0e0e0;border-radius:4px}.entry-actions-skeleton{display:flex;gap:8px}.skeleton-button{height:32px;width:32px;background-color:#e0e0e0;border-radius:4px}.entry-content-skeleton{display:flex;flex-direction:column;gap:8px}.skeleton-line{height:14px;background-color:#e0e0e0;border-radius:4px;width:100%}.skeleton-line.short{width:70%}.streak-heatmap{padding:20px;background:#fafbfc;border-radius:8px;border:1px solid #e1e4e8;margin:20px auto;display:flex;flex-direction:column;align-items:center}.heatmap-header{display:flex;justify-content:center;align-items:center;margin-bottom:16px;flex-direction:column;gap:8px;width:100%;text-align:center}.heatmap-header h3{margin:0;font-size:16px;font-weight:600;color:#24292e}.heatmap-stats{display:flex;gap:20px;font-size:12px;color:#586069;justify-content:center;flex-wrap:wrap;width:100%}.heatmap-container{display:flex;gap:4px;margin-bottom:16px;overflow-x:auto;padding-bottom:8px;justify-content:center;width:100%}.heatmap-labels{display:flex;flex-direction:column;justify-content:flex-start;gap:2px;margin-right:4px;min-width:30px}.day-label{width:30px;height:12px;font-size:11px;color:#586069;text-align:right;padding-top:1px}.heatmap-grid{display:flex;gap:2px}.heatmap-week{display:flex;flex-direction:column;gap:2px}.heatmap-day{width:12px;height:12px;border-radius:2px;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.heatmap-day:hover{border-color:#0366d6;box-shadow:0 0 8px #0366d64d}.heatmap-day:focus{outline:2px solid #0366d6;outline-offset:2px}.heatmap-legend{display:flex;align-items:center;justify-content:center;gap:8px;font-size:12px;color:#586069;width:100%}.legend-cell{width:12px;height:12px;border-radius:2px}@media(max-width:768px){.streak-heatmap{padding:12px}.heatmap-header{flex-direction:column;align-items:flex-start;gap:8px}.heatmap-stats{flex-direction:column;gap:4px}.heatmap-day,.legend-cell{width:10px;height:10px}.day-label{width:24px;font-size:10px}}.dashboard-container{width:100%;height:100vh;display:flex;flex-direction:column;background-color:#f5f5f5}.dashboard-header{background-color:#fff;padding:20px 16px 16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eee;box-shadow:0 2px 4px #0000000d}.dashboard-title{font-size:24px;font-weight:700;color:#333;margin:0}.dashboard-subtitle{font-size:14px;color:#666;margin-top:4px}.dashboard-header-actions{display:flex;gap:8px;align-items:center}.settings-button{padding:8px 14px;background-color:#e0e0e0;color:#333;border:1px solid #d0d0d0;border-radius:6px;font-weight:500;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}.settings-button:hover{background-color:#d0d0d0;border-color:silver}.logout-button{padding:8px 14px;background-color:#e0e0e0;color:#666;border:1px solid #d0d0d0;border-radius:6px;font-weight:500;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}.logout-button:hover{background-color:#d0d0d0;border-color:silver}.dashboard-content{flex:1;padding:16px;overflow-y:auto}.form-error-message{position:fixed;bottom:20px;right:20px;display:flex;justify-content:space-between;align-items:center;color:#fff;padding:14px 16px;background-color:#d32f2f;border:none;border-radius:8px;font-size:14px;line-height:1.4;box-shadow:0 4px 12px #d32f2f4d;z-index:999;max-width:400px;animation:slideInUp .3s ease}.error-close-btn{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;padding:0;margin-left:12px;display:flex;align-items:center;transition:opacity .2s;flex-shrink:0}.error-close-btn:hover{opacity:.8}.form-success-message{position:fixed;bottom:20px;right:20px;display:flex;justify-content:space-between;align-items:center;color:#fff;padding:14px 16px;background-color:#2e7d32;border:none;border-radius:8px;font-size:14px;line-height:1.4;box-shadow:0 4px 12px #2e7d324d;z-index:999;max-width:400px;animation:slideInUp .3s ease}@keyframes slideInUp{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}.form-group{margin-bottom:16px}.form-label{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:6px}.form-input{width:100%;border:1px solid #ddd;border-radius:6px;padding:12px;font-size:16px;font-family:inherit;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.form-input:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.form-textarea{resize:vertical;min-height:100px}.form-actions{display:flex;gap:12px;margin-top:16px}.form-button,.cancel-button{flex:1;padding:12px 16px;border:none;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer;transition:background-color .3s,box-shadow .3s}.form-button{background-color:#4caf50;color:#fff}.form-button:hover:not(:disabled){background-color:#45a049;box-shadow:0 2px 8px #4caf504d}.cancel-button{background-color:#f0f0f0;color:#333;border:1px solid #ddd}.cancel-button:hover:not(:disabled){background-color:#e8e8e8}.entries-list{margin-top:32px}.entries-container{max-height:500px;overflow-x:auto;overflow-y:auto;background-color:transparent}.entries-table{width:100%;border-collapse:collapse;font-size:14px}.entries-table thead{background:linear-gradient(to bottom,#2d5016,#3d6b1f);border-bottom:2px solid #2d5016;position:sticky;top:0}.entries-table th{padding:14px 16px;text-align:left;font-weight:700;color:#fff;letter-spacing:.5px;font-size:12px;text-transform:uppercase}.entries-table tbody tr{border-bottom:1px solid #e8e8e8;transition:all .2s ease;background-color:#fafafa}.entries-table tbody tr:hover{background-color:#f5fdf2}.entry-date-cell{font-weight:700;color:#1b5e20;width:140px;padding:14px 16px!important;white-space:nowrap}.entry-words-cell{font-weight:700;color:#2e7d32;width:130px;padding:14px 16px!important;font-size:15px;white-space:nowrap}.entry-notes-cell{color:#555;flex:1;min-width:300px;word-break:break-word;white-space:normal;padding:14px 16px!important;font-size:13px;line-height:1.4}.entry-actions-cell{width:130px;display:flex;gap:6px;padding:14px 16px!important;flex-shrink:0}.entries-table td{padding:14px 16px}.edit-button,.delete-button{padding:8px;border:1px solid;border-radius:5px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px}.edit-button{background-color:#f5f5f5;color:#666;border-color:#ddd}.edit-button:hover:not(:disabled){background-color:#eee;box-shadow:0 2px 6px #0000001a;transform:translateY(-1px)}.delete-button{background-color:#f5f5f5;color:#666;border-color:#ddd}.delete-button:hover:not(:disabled){background-color:#eee;box-shadow:0 2px 6px #0000001a;transform:translateY(-1px)}.edit-button:disabled,.delete-button:disabled{opacity:.5;cursor:not-allowed;transform:none}@media(max-width:768px){.entries-container{display:grid;gap:12px;max-width:100%;max-height:none;overflow:visible;border:none;background-color:transparent;box-shadow:none}.entries-table{display:grid;max-width:none;gap:12px}.entries-table thead{display:none;background:none}.entries-table tbody{display:grid;gap:12px}.entries-table tr{display:grid;gap:0;border:1px solid #d0d0d0;border-radius:8px;padding:16px;background-color:#fff;border-bottom:none;box-shadow:0 1px 3px #00000014}.entries-table tr:hover{background-color:#f8fdf5;box-shadow:0 2px 6px #0000001f;box-shadow:inset 0 0}.entries-table td{display:grid;grid-template-columns:80px 1fr;gap:8px;align-items:start;padding:8px 0!important;margin-bottom:0}.entries-table td:last-child{margin-bottom:0;grid-template-columns:1fr}.entries-table td:before{content:attr(data-label);font-weight:700;color:#1b5e20;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.entry-date-cell:before{content:"Date"}.entry-words-cell:before{content:"Words"}.entry-notes-cell:before{content:"Notes"}.entry-actions-cell{display:flex;gap:8px;margin-top:8px;width:100%;padding:0!important}.entry-actions-cell:before{display:none}.edit-button,.delete-button{flex:1;padding:10px 12px;font-size:13px}}.loading-state{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:400px}.spinner{border:4px solid #f3f3f3;border-top:4px solid #4caf50;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.welcome-card{background-color:#fff;border-radius:12px;padding:24px;text-align:center;margin-bottom:24px;box-shadow:0 2px 8px #0000001a}.welcome-emoji{font-size:48px;margin-bottom:16px;display:block}.welcome-title{font-size:24px;font-weight:700;color:#333;margin-bottom:12px}.welcome-text{font-size:16px;color:#666;margin-bottom:8px;line-height:1.5}.welcome-subtext{font-size:14px;color:#999;margin-bottom:20px}.start-button{background-color:#4caf50;color:#fff;border:none;border-radius:6px;padding:12px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s;min-width:180px}.start-button:hover{background-color:#45a049}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:24px}.stat-card{background-color:#fff;border-radius:8px;padding:16px;text-align:center;box-shadow:0 2px 4px #0000000d}.stat-label{font-size:12px;color:#666;margin-bottom:8px;text-transform:uppercase}.stat-value{font-size:32px;font-weight:700;color:#4caf50}.stat-subtitle{font-size:12px;color:#999;margin-top:4px}.section{margin-bottom:24px}.section-title{font-size:18px;font-weight:600;color:#333;margin-bottom:12px}.totals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.total-item{background-color:#fff;border-radius:8px;padding:16px;text-align:center;box-shadow:0 2px 4px #0000000d}.total-label{font-size:12px;color:#666;margin-bottom:8px}.total-value{font-size:24px;font-weight:700;color:#333}.entry-form-section{background-color:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.form-input{width:100%;border:1px solid #ddd;border-radius:6px;padding:12px;margin-bottom:16px;font-size:16px;font-family:inherit;box-sizing:border-box}.form-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-textarea{min-height:80px;resize:vertical}.form-button{width:100%;background-color:#4caf50;color:#fff;border:none;border-radius:6px;padding:12px;font-size:16px;font-weight:600;cursor:pointer;margin-top:8px;transition:background-color .3s}.form-button:hover:not(:disabled){background-color:#45a049}.form-button-disabled{opacity:.6;cursor:not-allowed}.cancel-button{width:100%;background-color:#f0f0f0;color:#666;border:none;border-radius:6px;padding:10px;font-size:14px;font-weight:500;cursor:pointer;margin-top:8px;transition:background-color .3s}.cancel-button:hover:not(:disabled){background-color:#e0e0e0}.cancel-button:disabled{opacity:.6;cursor:not-allowed}.action-button{width:100%;background-color:#4caf50;color:#fff;border:none;border-radius:6px;padding:16px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s}.action-button:hover{background-color:#45a049}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:450px;width:90%;overflow:hidden;animation:slideIn .3s ease}.modal-header{background:linear-gradient(to bottom,#2d5016,#3d6b1f);color:#fff;padding:20px;border-bottom:2px solid #2d5016}.modal-header h2{margin:0;font-size:18px;font-weight:700}.modal-body{padding:24px}.modal-body>p{margin:0 0 16px;color:#333;font-size:14px}.modal-comparison{background-color:#f9fdf5;border:1px solid #d0d0d0;border-radius:8px;padding:16px;margin:16px 0}.comparison-item{display:flex;gap:12px;margin-bottom:12px}.comparison-item:last-child{margin-bottom:0}.comparison-item label{font-weight:700;color:#1b5e20;min-width:100px;text-transform:uppercase;font-size:11px;letter-spacing:.5px}.comparison-value{color:#333;font-weight:600;font-size:15px}.comparison-notes{font-size:13px;color:#666;margin-top:4px;font-style:italic;padding:6px 8px;background-color:#fff;border-radius:4px}.modal-question{margin:16px 0 0!important;text-align:center;font-weight:600;color:#333}.modal-actions{display:flex;gap:12px;padding:16px 24px;border-top:1px solid #eee;background-color:#f5f5f5}.modal-cancel-button,.modal-confirm-button{flex:1;padding:11px 16px;border:1px solid;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s ease}.modal-cancel-button{background-color:#f5f5f5;color:#666;border-color:#ddd}.modal-cancel-button:hover{background-color:#eee;box-shadow:0 2px 6px #0000001a;transform:translateY(-1px)}.modal-confirm-button{background-color:#2e7d32;color:#fff;border-color:#1b5e20}.modal-confirm-button:hover{background-color:#1b5e20;box-shadow:0 2px 6px #2d50164d;transform:translateY(-1px)}.import-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.import-modal-content{background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:600px;width:90%;max-height:85vh;overflow-y:auto;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.import-modal-header{background:linear-gradient(to bottom,#2d5016,#3d6b1f);color:#fff;padding:20px;border-bottom:2px solid #2d5016;display:flex;justify-content:space-between;align-items:flex-start;position:sticky;top:0;z-index:10}.import-modal-header h2{margin:0 0 4px;font-size:18px;font-weight:700;color:#fff}.import-modal-header p{margin:0;font-size:13px;color:#b3e5b3;opacity:.9}.import-modal-close{background:none;border:none;color:#fff;font-size:28px;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:opacity .2s;font-weight:300;line-height:1;flex-shrink:0;margin-left:16px}.import-modal-close:hover{opacity:.8}.import-modal-close:disabled{opacity:.5;cursor:not-allowed}.import-modal-body{padding:24px}.import-file-section{display:flex;flex-direction:column;gap:16px}.import-format-info{background-color:#f0f7f0;border:1px solid #c8e6c9;border-radius:8px;padding:16px;font-size:13px;color:#2d5016}.import-format-info p{margin:0 0 8px;font-weight:600}.import-format-info div{margin:4px 0;font-family:monospace;font-size:12px}.import-format-info code{background-color:#fff;border:1px solid #a5d6a7;border-radius:3px;padding:2px 6px;font-size:12px}.import-file-input{display:none}.import-upload-area{display:block;border:2px solid #ccc;border-radius:8px;padding:32px 16px;text-align:center;cursor:pointer;transition:all .2s;background-color:#fafafa}.import-upload-area:hover{background-color:#f0f7f0;border-color:#4caf50}.import-upload-area.disabled{opacity:.5;cursor:not-allowed}.import-upload-icon{font-size:40px;margin-bottom:12px;display:block}.import-upload-text{margin:0 0 4px;font-size:15px;font-weight:600;color:#333}.import-upload-subtext{margin:0;font-size:13px;color:#666}.import-preview-section{display:flex;flex-direction:column;gap:20px}.import-strategy-section{display:flex;flex-direction:column;gap:12px}.import-strategy-label{margin:0 0 8px;font-weight:600;color:#333;font-size:14px}.import-strategy-option{display:flex;align-items:flex-start;gap:12px;padding:12px;border:1px solid #ddd;border-radius:8px;cursor:pointer;transition:all .2s}.import-strategy-option:hover{background-color:#f9f9f9;border-color:#4caf50}.import-strategy-option input[type=radio]{margin-top:4px;cursor:pointer;flex-shrink:0}.import-strategy-option-title{margin:0 0 4px;font-weight:600;color:#333;font-size:14px}.import-strategy-option-desc{margin:0;font-size:12px;color:#666;line-height:1.4}.import-entries-section{display:flex;flex-direction:column;gap:8px}.import-entries-title{margin:0;font-weight:600;color:#333;font-size:14px}.import-entries-table{border:1px solid #ddd;border-radius:8px;max-height:300px;overflow-y:auto}.import-entries-table table{width:100%;border-collapse:collapse;font-size:13px}.import-entries-table thead{position:sticky;top:0;background-color:#f5f5f5;border-bottom:1px solid #ddd}.import-entries-table th{padding:10px 12px;text-align:left;font-weight:600;color:#666;font-size:12px}.import-entries-table td{padding:10px 12px;border-bottom:1px solid #f0f0f0}.import-entries-table tbody tr:hover{background-color:#fafafa}.import-entries-table code{font-family:monospace;color:#2d5016;font-size:12px}.import-rejected-section{display:flex;flex-direction:column;gap:8px}.import-rejected-title{margin:0;font-weight:600;color:#d32f2f;font-size:14px}.import-rejected-table{border:1px solid #ffcdd2;border-radius:8px;max-height:300px;overflow-y:auto}.import-rejected-table table{width:100%;border-collapse:collapse;font-size:13px}.import-rejected-table thead{position:sticky;top:0;background-color:#ffebee;border-bottom:1px solid #ffcdd2}.import-rejected-table th{padding:10px 12px;text-align:left;font-weight:600;color:#c62828;font-size:12px}.import-rejected-table td{padding:10px 12px;border-bottom:1px solid #f5f5f5}.import-rejected-table tbody tr:hover{background-color:#fff5f5}.import-success-box{background-color:#e8f5e9;border:1px solid #4caf50;border-radius:8px;padding:12px}.import-success-title{margin:0 0 4px;color:#2e7d32;font-weight:600;font-size:14px}.import-success-message{margin:0;color:#558b2f;font-size:13px}.import-error-box{background-color:#ffebee;border:1px solid #ef5350;border-radius:8px;padding:12px;color:#d32f2f;font-size:13px}.import-error-box p{margin:0 0 4px;font-weight:600}.import-error-message{margin:0;line-height:1.4}.import-modal-footer{display:flex;gap:12px;padding:16px 24px;border-top:1px solid #eee;background-color:#f5f5f5;justify-content:flex-end;position:sticky;bottom:0;z-index:10}.import-button{padding:11px 16px;border:1px solid;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s ease}.import-button-secondary{background-color:#f5f5f5;color:#666;border-color:#ddd}.import-button-secondary:hover:not(:disabled){background-color:#eee;box-shadow:0 2px 6px #0000001a;transform:translateY(-1px)}.import-button-secondary:disabled{opacity:.5;cursor:not-allowed}.import-button-primary{background-color:#4caf50;color:#fff;border-color:#4caf50}.import-button-primary:hover:not(:disabled){background-color:#45a049;box-shadow:0 2px 6px #00000026;transform:translateY(-1px)}.import-button-primary:disabled{opacity:.5;cursor:not-allowed}.settings-container{min-height:100vh;background-color:#f5f5f5}.settings-header{display:flex;justify-content:space-between;align-items:center;background-color:#fff;padding:24px;border-bottom:1px solid #eee;box-shadow:0 2px 4px #0000000d}.settings-title{font-size:28px;font-weight:700;color:#333;margin:0 0 4px}.settings-subtitle{font-size:14px;color:#666;margin:0}.settings-logout-button{background-color:#f44336;color:#fff;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .3s}.settings-logout-button:hover{background-color:#d32f2f}.settings-content{max-width:600px;margin:24px auto;padding:0 16px}.settings-card{background-color:#fff;border-radius:8px;padding:32px;box-shadow:0 2px 8px #0000001a;overflow:visible}.settings-error{display:flex;justify-content:space-between;align-items:center;color:#d32f2f;margin-bottom:20px;padding:12px 14px;background-color:#ffebee;border:1px solid #ef5350;border-radius:6px;font-size:14px;line-height:1.4}.settings-error-close{background:none;border:none;color:#d32f2f;font-size:18px;cursor:pointer;padding:0;margin-left:12px;display:flex;align-items:center;transition:color .2s}.settings-error-close:hover{color:#c62828}.settings-success{color:#2e7d32;margin-bottom:20px;padding:12px 14px;background-color:#e8f5e9;border:1px solid #81c784;border-radius:6px;font-size:14px;line-height:1.4}.settings-section{margin-bottom:32px}.settings-section:last-of-type{margin-bottom:24px}.settings-section-title{font-size:18px;font-weight:600;color:#333;margin:0 0 16px;padding-bottom:12px;border-bottom:2px solid #f0f0f0}.settings-info-group{margin-bottom:16px}.settings-info-group:last-child{margin-bottom:0}.settings-info-value{margin:4px 0 0;padding:12px 14px;background-color:#f5f5f5;border-radius:6px;color:#555;font-size:14px}.settings-info-note{margin-top:12px;font-size:12px;color:#999;font-style:italic}.settings-form-group{margin-bottom:24px}.settings-label{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:8px}.settings-input,.settings-select{width:100%;border:1px solid #ddd;border-radius:6px;padding:12px 14px;font-size:16px;font-family:inherit;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.settings-select{overflow-y:auto;max-height:300px}.settings-input:focus,.settings-select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.settings-input:disabled,.settings-select:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.settings-input::placeholder{color:#999}.settings-field-hint{margin:6px 0 0;font-size:12px;color:#999}.settings-actions{display:flex;gap:12px;margin-top:32px}.settings-button,.settings-button-secondary{flex:1;border:none;border-radius:6px;padding:14px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s,box-shadow .3s}.settings-button{background-color:#4caf50;color:#fff}.settings-button:hover:not(:disabled){background-color:#45a049;box-shadow:0 2px 8px #4caf504d}.settings-button:active:not(:disabled){background-color:#3d8b40}.settings-button-disabled{opacity:.6;cursor:not-allowed}.settings-button-secondary{background-color:#f0f0f0;color:#333;border:1px solid #ddd}.settings-button-secondary:hover:not(:disabled){background-color:#e8e8e8;box-shadow:0 2px 8px #0000001a}.settings-button-secondary:disabled{opacity:.6;cursor:not-allowed}.loading-state{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:400px;gap:16px}.spinner{width:48px;height:48px;border:4px solid #f0f0f0;border-top-color:#4caf50;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:600px){.settings-header{flex-direction:column;align-items:flex-start;gap:16px}.settings-logout-button{width:100%;max-width:200px}.settings-card{padding:20px}.settings-title{font-size:24px}.settings-section-title{font-size:16px}.settings-actions{flex-direction:column}.settings-button,.settings-button-secondary{width:100%}}.calendar-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#333;padding:20px}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;color:#fff}.calendar-title{font-size:32px;font-weight:700;margin:0 0 5px}.calendar-subtitle{margin:0;font-size:14px;opacity:.9}.calendar-header-actions{display:flex;gap:10px}.calendar-back-button,.calendar-logout-button{padding:10px 16px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease}.calendar-back-button:hover,.calendar-logout-button:hover{background:#ffffff4d;border-color:#ffffff80}.calendar-content{background:#fff;border-radius:12px;padding:30px;box-shadow:0 10px 30px #0003}.calendar-controls{display:flex;justify-content:center;align-items:center;gap:20px;margin-bottom:20px}.nav-button{padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.nav-button:hover{background:#764ba2;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.calendar-month{font-size:24px;margin:0;min-width:200px;text-align:center;color:#333}.today-button{display:block;margin:0 auto 20px;padding:10px 20px;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.today-button:hover{background:#764ba2;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.calendar-legend{display:flex;justify-content:center;gap:30px;margin-bottom:20px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:8px;font-size:14px}.legend-color{width:20px;height:20px;border-radius:4px}.legend-color.target-met{background:#10b981}.legend-color.partial{background:#f59e0b}.legend-color.no-entry{background:#e5e7eb}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:20px}.calendar-weekday{text-align:center;font-weight:600;color:#667eea;padding:10px 0;font-size:12px}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .2s ease;position:relative;font-size:14px;font-weight:600;min-height:70px}.calendar-day.target-met{background:#10b981;color:#fff;border-color:#059669}.calendar-day.target-met:hover{transform:translateY(-4px);box-shadow:0 8px 16px #10b9814d}.calendar-day.partial{background:#f59e0b;color:#fff;border-color:#d97706}.calendar-day.partial:hover{transform:translateY(-4px);box-shadow:0 8px 16px #f59e0b4d}.calendar-day.no-entry{background:#e5e7eb;color:#666;border-color:#d1d5db}.calendar-day.no-entry:hover{background:#d1d5db;transform:translateY(-4px)}.calendar-day.other-month{background:#f9fafb;color:#d1d5db;cursor:default}.calendar-day.other-month:hover{transform:none}.calendar-day.future{background:#e5e7eb;color:#999;border-color:#d1d5db;opacity:.5;cursor:default}.calendar-day.future:hover{transform:none}.day-number{font-size:16px;font-weight:700}.day-count{font-size:11px;margin-top:4px;opacity:.9}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#fff}.spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.calendar-form-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.calendar-form-dialog{background:#fff;border-radius:12px;padding:24px;width:90%;max-width:400px;box-shadow:0 20px 60px #0000004d;animation:slideInUp .3s ease}.calendar-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.calendar-form-header h2{margin:0;font-size:20px;color:#333}.calendar-form-close{background:none;border:none;font-size:28px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.calendar-form-close:hover{color:#333}.calendar-form-field{margin-bottom:16px;display:flex;flex-direction:column}.calendar-form-field label{font-size:14px;font-weight:600;margin-bottom:6px;color:#333}.calendar-form-field input{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s}.calendar-form-field input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.calendar-form-field input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.calendar-form-error{background:#fee;color:#c33;padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:16px;border-left:3px solid #c33}.calendar-form-buttons{display:flex;gap:12px;margin-top:24px}.calendar-form-submit,.calendar-form-cancel{flex:1;padding:10px 16px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.calendar-form-submit{background:#667eea;color:#fff}.calendar-form-submit:hover:not(:disabled){background:#764ba2;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.calendar-form-submit:disabled{background:#ccc;cursor:not-allowed}.calendar-form-cancel{background:#f5f5f5;color:#666;border:1px solid #ddd}.calendar-form-cancel:hover{background:#e8e8e8;border-color:#ccc}@keyframes slideInUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.calendar-container{padding:10px}.calendar-content{padding:15px}.calendar-header{flex-direction:column;align-items:flex-start;gap:15px}.calendar-header-actions{width:100%;justify-content:space-between}.calendar-controls{gap:10px}.calendar-month{font-size:18px;min-width:auto}.nav-button{padding:6px 12px;font-size:12px}.calendar-day{min-height:60px;font-size:12px}.day-number{font-size:14px}.day-count{font-size:10px}.calendar-legend{gap:12px}.legend-item{font-size:12px}}.app-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea{font-family:inherit}
