.login-container{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4a5568,#2d3748);padding:20px;overflow-y:auto}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px #00000026;width:100%;max-width:450px;border:1px solid #e2e8f0}.login-header{background:linear-gradient(135deg,#4a5568,#2d3748);color:#fff;padding:40px 30px;text-align:center;border-bottom:1px solid #e2e8f0}.login-header h1{font-size:2.5em;margin-bottom:10px;color:#fff}.login-header p{font-size:1.1em;color:#e2e8f0}.login-form{padding:40px 30px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#2d3748}.form-group input{width:100%;padding:12px;border:2px solid #cbd5e0;border-radius:6px;font-size:1em;background-color:#fff;color:#2d3748;transition:all .3s}.form-group input:focus{outline:none;border-color:#718096;background-color:#f7fafc}.form-group input::placeholder{color:#a0aec0}.error-message{background:#fed7d7;color:#c53030;padding:12px;border-radius:6px;margin-bottom:20px;border:1px solid #fc8181}.submit-btn{width:100%;padding:14px;background:linear-gradient(135deg,#4a5568,#2d3748);color:#fff;border:none;border-radius:6px;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 6px #2d374833}.submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#2d3748,#1a202c);transform:translateY(-2px);box-shadow:0 6px 12px #2d37484d}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.divider{text-align:center;margin:25px 0;position:relative}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:45%;height:1px;background:#cbd5e0}.divider:before{left:0}.divider:after{right:0}.divider span{background:#fff;padding:0 10px;color:#718096;font-size:.9em}.google-btn{width:100%;padding:14px;background:#fff;color:#2d3748;border:2px solid #cbd5e0;border-radius:6px;font-size:1em;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:10px}.google-btn:hover{background:#f7fafc;border-color:#718096}@media (max-width: 480px){.login-header h1{font-size:2em}.login-form{padding:30px 20px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:20px 25px;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;color:#2d3748;font-size:1.5em}.close-btn{background:none;border:none;font-size:2em;color:#718096;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-btn:hover{background:#f7fafc;color:#2d3748}.modal-body{padding:25px}.recurring-toggle{margin-bottom:25px;padding:15px;background:#f7fafc;border-radius:8px;border:2px solid #cbd5e0}.recurring-toggle label{display:flex;align-items:center;cursor:pointer;font-weight:600;color:#2d3748}.recurring-toggle input[type=checkbox]{width:20px;height:20px;margin-right:12px;cursor:pointer}.toggle-label{font-size:1.1em}.recurring-settings{animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;color:#2d3748;margin-bottom:8px}.form-group select,.form-group input[type=number],.form-group input[type=date]{width:100%;padding:10px;border:1px solid #cbd5e0;border-radius:6px;font-size:1em;color:#2d3748;background:#fff;transition:all .2s}.form-group select:focus,.form-group input:focus{outline:none;border-color:#4a5568;box-shadow:0 0 0 3px #4a55681a}.interval-input{display:flex;align-items:center;gap:10px}.interval-input input{width:80px}.interval-label{color:#718096;font-weight:500}.radio-group{display:flex;flex-direction:column;gap:12px}.radio-option{display:flex;align-items:center;gap:8px;padding:10px;background:#f7fafc;border-radius:6px;cursor:pointer;transition:all .2s}.radio-option:hover{background:#edf2f7}.radio-option input[type=radio]{width:18px;height:18px;cursor:pointer}.inline-date-input,.inline-number-input{padding:6px 10px!important;width:auto!important;flex:1;max-width:200px}.inline-number-input{max-width:80px}.inline-date-input:disabled,.inline-number-input:disabled{background:#e2e8f0;cursor:not-allowed}.preview-box{margin-top:20px;padding:15px;background:#fff5e6;border-left:4px solid #f59e0b;border-radius:4px;color:#92400e}.preview-box strong{display:block;margin-bottom:5px;color:#78350f}.modal-footer{padding:20px 25px;border-top:2px solid #e2e8f0;display:flex;justify-content:flex-end;gap:10px}.btn-primary,.btn-secondary{padding:10px 25px;border:none;border-radius:6px;font-size:1em;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#4a5568,#2d3748);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#2d3748,#1a202c);transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.btn-secondary{background:#fff;color:#2d3748;border:2px solid #cbd5e0}.btn-secondary:hover{background:#f7fafc;border-color:#a0aec0}@media (max-width: 768px){.modal-content{width:95%;margin:20px}.modal-header h2{font-size:1.2em}.radio-option{flex-wrap:wrap}.inline-date-input{max-width:100%}}.weekday-selector{display:flex;gap:8px;flex-wrap:wrap}.weekday-btn{padding:8px 12px;border:2px solid #cbd5e0;background:#fff;border-radius:6px;cursor:pointer;font-weight:600;color:#4a5568;transition:all .2s;min-width:45px}.weekday-btn:hover{border-color:#4a5568;background:#f7fafc}.weekday-btn.active{background:#4a5568;color:#fff;border-color:#4a5568}.planner-container{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#f5f7fa;display:flex;flex-direction:column;overflow:hidden}.planner-header{background:linear-gradient(135deg,#4a5568,#2d3748);color:#fff;padding:12px 24px;border-bottom:1px solid #cbd5e0;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.planner-header h1{font-size:1.4em;margin-bottom:2px;color:#fff}.planner-header p{font-size:.85em;color:#e2e8f0}.logout-btn{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.3);padding:6px 18px;border-radius:6px;font-size:.9em;font-weight:600;cursor:pointer;transition:all .3s}.logout-btn:hover{background:#fff3;border-color:#ffffff80}.tabs{display:flex;background:#fff;border-bottom:2px solid #e2e8f0;flex-shrink:0;box-shadow:0 2px 4px #0000000d}.tab{padding:10px 20px;cursor:pointer;border:none;background:none;font-size:.95em;font-weight:600;color:#718096;transition:all .3s;border-bottom:3px solid transparent}.tab:hover{color:#2d3748;background:#f7fafc}.tab.active{color:#2d3748;border-bottom-color:#4a5568;background:#f7fafc}.content{flex:1;background:#fff;padding:20px 24px;overflow-y:auto}.section-title{font-size:1.25em;color:#1a202c;margin:12px 0 10px;padding-bottom:6px;border-bottom:2px solid #cbd5e0}.focus-box{background:#f7fafc;border-left:4px solid #4a5568;padding:12px 16px;margin:12px 0;border-radius:4px;box-shadow:0 1px 3px #0000000d}.focus-box h3{color:#2d3748;margin-bottom:10px;font-size:1.1em}.focus-item{display:flex;align-items:center;margin:6px 0}.focus-item strong{margin-right:8px;min-width:18px;color:#4a5568;font-size:.95em}.focus-item input[type=text]{flex:1;padding:8px;background:#fff;border:1px solid #cbd5e0;border-radius:4px;color:#2d3748;font-size:.95em}.focus-item input[type=text]:focus{border-color:#718096;background:#fff;box-shadow:0 0 0 3px #4a55681a}table{width:100%;border-collapse:collapse;margin-top:12px;font-size:.9em;background:#fff;box-shadow:0 1px 3px #0000000d;border-radius:8px;overflow:hidden}th{background:#f7fafc;padding:8px 10px;text-align:left;font-weight:600;color:#2d3748;border:1px solid #e2e8f0;font-size:.9em}td{padding:6px 10px;border:1px solid #e2e8f0;background:#fff;color:#2d3748}input,select,textarea{width:100%;padding:5px;border:1px solid #cbd5e0;border-radius:4px;font-size:.875em;font-family:inherit;background:#fff;color:#2d3748}input:focus,select:focus,textarea:focus{outline:none;border-color:#718096;background:#f7fafc}input::placeholder,textarea::placeholder{color:#a0aec0}textarea{resize:vertical;min-height:50px}input[type=checkbox]{width:auto;cursor:pointer;accent-color:#4a5568}input[type=date]{cursor:pointer}.matrix{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-top:20px}.matrix-quadrant{border:2px solid #e2e8f0;border-radius:8px;padding:15px;min-height:200px;background:#f7fafc;box-shadow:0 1px 3px #0000000d}.matrix-quadrant h4{margin-bottom:10px;padding-bottom:8px;border-bottom:2px solid;color:#2d3748}.matrix-quadrant p{color:#718096}.matrix-quadrant ul{list-style:none;padding:0}.matrix-quadrant li{padding:8px;margin:5px 0;background:#fff;border-radius:4px;color:#2d3748;border-left:3px solid;box-shadow:0 1px 2px #0000000d;cursor:move;transition:all .2s;-webkit-user-select:none;user-select:none}.matrix-quadrant li:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.matrix-quadrant li.dragging{opacity:.5;cursor:grabbing}.matrix-quadrant.drag-over{background:#e2e8f0;border-color:#4a5568;border-width:3px}.q1 h4{color:#2d3748;border-color:#4a5568}.q1 li{border-color:#4a5568}.q2 h4{color:#2d3748;border-color:#718096}.q2 li{border-color:#718096}.q3 h4{color:#2d3748;border-color:#a0aec0}.q3 li{border-color:#a0aec0}.q4 h4{color:#2d3748;border-color:#cbd5e0}.q4 li{border-color:#cbd5e0}.download-btn{background:linear-gradient(135deg,#4a5568,#2d3748);color:#fff;padding:10px 24px;border:none;border-radius:6px;font-size:.95em;font-weight:600;cursor:pointer;margin:12px 0;transition:all .3s;box-shadow:0 2px 4px #0000001a}.download-btn:hover{background:linear-gradient(135deg,#2d3748,#1a202c);transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.reflection-box{background:#fefcfb;border-left:4px solid #f59e0b;padding:12px 16px;margin:16px 0;border-radius:4px;box-shadow:0 1px 3px #0000000d}.reflection-box h3{color:#92400e;margin-bottom:12px;display:flex;align-items:center;gap:10px;font-size:1.1em;cursor:pointer;-webkit-user-select:none;user-select:none}.reflection-box h3:hover{opacity:.8}.reflection-content.expanded{max-height:2000px;transition:max-height .5s ease-in}.reflection-field{margin-bottom:12px}.reflection-field label{display:block;font-weight:600;color:#2d3748;margin-bottom:6px;font-size:.95em}.reflection-field textarea{min-height:70px}.rating-group{display:flex;gap:20px;margin-top:12px}.rating-item{flex:1}.rating-item label{display:block;font-weight:600;color:#2d3748;margin-bottom:8px;font-size:.95em}.star-rating{display:flex;gap:4px}.star{font-size:1.5em;cursor:pointer;color:#cbd5e0;transition:color .2s}.star.filled{color:#f59e0b}.star:hover{color:#fbbf24}@media (max-width: 768px){.planner-header{flex-direction:column;text-align:center;padding:15px 20px}.planner-header h1{font-size:1.5em}.logout-btn{margin-top:10px}.tabs{overflow-x:auto}.tab{padding:12px 15px;font-size:.9em}.content{padding:20px 15px}.matrix{grid-template-columns:1fr}table{font-size:.85em}th,td{padding:8px 6px}}.template-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.template-item{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;transition:all .2s}.template-item:hover{background:#edf2f7;border-color:#cbd5e0;box-shadow:0 2px 4px #0000000d}.template-info{flex:1}.template-info h4{margin:0 0 5px;color:#2d3748;font-size:1.1em}.template-actions{display:flex;gap:8px}.reflection-content{max-height:0;overflow:hidden;transition:max-height .3s ease-out}.reflection-content.expanded{max-height:2000px}.reflection-box h3{cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;align-items:center}.reflection-box h3:hover{color:#1a202c}tr.recurring-parent{background:#f0f9ff}tr.recurring-instance{background:#fafafa}.App{width:100vw;height:100vh;background-color:#f5f7fa;color:#2c3e50}.card{padding:2em;margin:1em;background-color:#fff;border-radius:8px;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d}.info{margin-top:2em;padding:1em;background-color:#f7fafc;border-radius:8px;color:#4a5568;border:1px solid #cbd5e0}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#2c3e50;background-color:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:#f5f7fa}h1{font-size:3.2em;line-height:1.1;color:#1a202c}button{border-radius:8px;border:1px solid #cbd5e0;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#fff;color:#2d3748;cursor:pointer;transition:all .25s}button:hover{border-color:#a0aec0;background-color:#f7fafc}button:focus,button:focus-visible{outline:2px solid #718096;outline-offset:2px}input,select,textarea{color:#2d3748;background-color:#fff;border:1px solid #cbd5e0}input:focus,select:focus,textarea:focus{outline:none;border-color:#718096;background-color:#fff}
