@import"https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box;font-family:"Baloo 2",Comic Sans MS,cursive,Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif!important}html,body,#root{height:100%;font-family:"Baloo 2",Comic Sans MS,cursive,Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif!important}body{margin:0;font-family:"Baloo 2",Comic Sans MS,cursive,Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif!important}.auth-bg{min-height:100%;display:grid;place-items:center;background:radial-gradient(1200px 600px at 50% 120%,rgba(145,208,255,.25),transparent 60%),linear-gradient(180deg,#dff4ff,#bfe7ff,#cfeeff 60%,#eaf6ff);padding:32px 16px}.auth-bg:after{content:"";position:fixed;inset:0;background:radial-gradient(800px 800px at 50% 85%,rgba(255,255,255,.5) 0 2px,transparent 3px) 0 0/1200px 600px,radial-gradient(1000px 1000px at 50% 100%,rgba(255,255,255,.5) 0 2px,transparent 3px) 0 0/1400px 700px;pointer-events:none;opacity:.45}.glass{width:100%;max-width:420px;border-radius:20px;background:linear-gradient(180deg,#ffffffbf,#ffffffa6);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.8);box-shadow:0 20px 40px #00385e1a,0 2px #ffffffe6 inset,0 -1px #0000000a inset;padding:28px}.badge{width:62px;height:62px;display:grid;place-items:center;margin:-52px auto 6px;border-radius:18px}.badge-logo{width:48px;height:auto;max-width:100%;display:block}.auth-title{text-align:center;margin:8px 0 2px;font-weight:700;font-size:22px;color:#0f172a}.auth-sub{text-align:center;margin:0 0 16px;font-size:13px;color:#6b7280}.field{display:flex;align-items:center;gap:10px;background:#f3f7fb;border:1px solid #e6eef5;padding:10px 12px;border-radius:12px;transition:border-color .15s ease,box-shadow .15s ease}.field:focus-within{border-color:#8ad0ee;box-shadow:0 0 0 4px #6ac0ea59}.field input{width:100%;border:0;outline:0;background:transparent;color:#0f172a;font-size:14px}.icon{width:18px;height:18px;opacity:.75}.row{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#6b7280}.link{color:#0f172a;text-decoration:none;font-weight:600}.link:hover{text-decoration:underline}.btn{width:100%;border:0;border-radius:12px;cursor:pointer;color:#fff;font-weight:600;background:linear-gradient(180deg,#2b2d31,#111112);padding:12px 14px;box-shadow:0 6px 18px #11111240;transition:transform .04s ease,filter .15s ease}.btn:hover{filter:brightness(1.05)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.6;cursor:not-allowed}.divider{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;color:#9aa4b2;font-size:12px;margin:12px 0}.divider:before,.divider:after{content:"";height:1px;background:#e8edf3}.sso-row{display:flex;gap:10px;justify-content:center}.sso{display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid #e5ebf2;background:#fff;border-radius:12px;padding:10px 14px;min-width:110px;cursor:pointer;transition:box-shadow .15s ease,transform .04s ease}.sso:hover{box-shadow:0 6px 18px #0000000f}.sso:active{transform:translateY(1px)}.error{color:#b91c1c;font-size:12px;margin-top:8px;text-align:center}.app-header{background:linear-gradient(180deg,#ffffffe0,#ffffffb3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.8);box-shadow:0 6px 18px #02161f0f}.logout{background:#111;color:#fff;border:0;border-radius:10px;padding:8px 12px;cursor:pointer}.logout:hover{filter:brightness(1.05)}.week-wrap{display:flex;flex-direction:column;gap:10px;width:100%}.week-top{display:flex;align-items:center;gap:10px;width:100%}.week-top .spacer{flex:1}.month-input{max-width:200px;font-size:12px;padding:8px 10px;border-radius:12px;border:1px solid #e5e7eb;background:#fff;box-shadow:0 2px 6px #0000000a}.today-btn{background:none;border:none;color:#10b981;font-weight:700;cursor:pointer;font-size:12px;padding:6px 10px;border-radius:10px;transition:background .15s ease}.today-btn:hover{background:#10b98114}.week-row{position:relative;width:100%}.week-core{min-width:0;padding:0 56px;display:flex;flex-direction:column;gap:8px}.week-label{text-align:center;font-size:12px;color:#6b7280}.week-days{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;min-width:0}.day-chip{min-width:0;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 6px;border-radius:12px;background:#f6f7f9;border:1px solid #e5e7eb;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease}.day-chip:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000000f;background:#fff}.day-chip.selected{background:#fff;border-color:#10b981;box-shadow:0 0 0 2px #10b98129 inset}.day-chip .dow{font-size:10px;color:#6b7280;line-height:1}.day-chip .daynum{font-size:14px;font-weight:800;line-height:1.1}.arrow-btn{position:absolute;top:calc(50% + 14px);transform:translateY(-50%);width:38px;height:38px;border-radius:9999px;display:grid;place-items:center;border:none;background:#f3f4f6;color:#111827;cursor:pointer;box-shadow:0 2px 6px #0000000f,0 0 0 1px #e5e7eb inset;transition:transform .12s ease,background .12s ease;font-size:18px;line-height:1;z-index:1}.arrow-btn:hover{transform:translateY(-50%) scale(1.05)}.arrow-btn.mint{background:#10b981;color:#fff;box-shadow:0 2px 8px #10b98159}.arrow-btn.mint:hover{background:#059669}.arrow-btn.prev{left:8px}.arrow-btn.next{right:8px}@media (max-width: 420px){.month-input{max-width:150px;padding:6px 8px}.week-core{padding:0 48px}.arrow-btn{width:34px;height:34px;font-size:16px}.week-days{gap:6px}}.task-item-container{position:relative;margin-bottom:0;overflow:hidden;border-radius:12px;width:100%;min-height:80px}.task-actions{position:absolute;inset:0;display:flex;z-index:1;border-radius:12px;overflow:hidden}.action-edit{flex:1;background:linear-gradient(135deg,#10b981,#059669);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:600;gap:4px}.action-delete{flex:1;background:linear-gradient(135deg,#ef4444,#dc2626);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:600;gap:4px}.task-item{position:relative;background:#fff;border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #00000014;border:1px solid rgba(0,0,0,.06);transition:all .3s ease;z-index:2;cursor:grab;-webkit-user-select:none;user-select:none}.task-item.dragging{cursor:grabbing;box-shadow:0 4px 16px #00000026;transform:scale(1.02)}.task-item:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-1px)}.task-item:active{cursor:grabbing}.task-item.completed{background:#f8fafc;opacity:.8;cursor:default}.task-item.completed:hover{transform:none;box-shadow:0 2px 8px #00000014}.task-item.completing{animation:completeTask .3s ease-in-out}@keyframes completeTask{0%{transform:scale(1)}30%{transform:scale(1.05)}50%{transform:scale(1.05);box-shadow:0 8px 32px #10b9814d}to{transform:scale(1)}}.task-checkbox-container{position:relative;display:flex;align-items:center;justify-content:center}.task-checkbox{width:20px;height:20px;border-radius:6px;border:2px solid #d1d5db;background:#fff;cursor:pointer;transition:all .3s ease;appearance:none;margin:0;position:relative}.task-checkbox:checked{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;animation:checkboxPop .15s ease}@keyframes checkboxPop{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.checkbox-animation{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.checkmark{width:14px;height:14px;fill:#fff;opacity:0;transform:scale(0);transition:all .3s ease}.task-checkbox:checked+.checkbox-animation .checkmark{opacity:1;transform:scale(1);animation:checkmarkDraw .15s ease .05s both}@keyframes checkmarkDraw{0%{stroke-dasharray:0 50;stroke-dashoffset:0}to{stroke-dasharray:50 0;stroke-dashoffset:0}}.task-content{flex:1;min-width:0;text-align:center}.task-header{display:flex;align-items:center;justify-content:center;margin-bottom:2px}.task-name{font-weight:600;font-size:18px;color:#1f2937;transition:all .3s ease}.item-type-indicator{font-size:14px;margin-right:8px;opacity:.7}.habit-indicator{color:#8b5cf6}.task-item.completed .task-name{color:#9ca3af;text-decoration:line-through;text-decoration-color:#9ca3af;text-decoration-thickness:2px;animation:strikethrough .3s ease}@keyframes strikethrough{0%{text-decoration:none}to{text-decoration:line-through}}.task-right-section{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:60px}.time-badge{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap}.task-description{font-size:14px;color:#6b7280;margin-top:4px;line-height:1.4}.task-item.completed .task-description{color:#9ca3af}.color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;box-shadow:0 2px 4px #0003}.completion-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden;border-radius:12px}.particle{position:absolute;width:6px;height:6px;background:#10b981;border-radius:50%;animation:particleFloat .4s ease-out forwards}.particle-0{top:20%;left:20%;animation-delay:0s}.particle-1{top:30%;left:80%;animation-delay:.1s}.particle-2{top:60%;left:15%;animation-delay:.2s}.particle-3{top:70%;left:85%;animation-delay:.1s}.particle-4{top:40%;left:50%;animation-delay:.05s}.particle-5{top:80%;left:60%;animation-delay:.15s}@keyframes particleFloat{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(0) translateY(-30px)}}.swipe-hint{position:absolute;top:50%;transform:translateY(-50%);background:#000c;color:#fff;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600;z-index:10;animation:fadeInOut .3s ease}.swipe-hint.edit{left:16px}.swipe-hint.delete{right:16px}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-50%) scale(.9)}to{opacity:1;transform:translateY(-50%) scale(1)}}@media (max-width: 640px){.task-item{padding:12px}.task-name{font-size:16px}.task-description{font-size:13px}.task-right-section{min-width:50px}}[data-theme=dark] .task-item{background:linear-gradient(145deg,#2d3748,#1a202c);border:1px solid rgba(75,85,99,.5);box-shadow:0 4px 16px #0000004d}[data-theme=dark] .task-item:hover{background:linear-gradient(145deg,#374151,#1f2937);border-color:#10b98199;box-shadow:0 6px 20px #0006}[data-theme=dark] .task-item.completed{background:linear-gradient(145deg,#1f2937,#111827);opacity:.8}[data-theme=dark] .task-name{color:#f9fafb}[data-theme=dark] .task-item.completed .task-name{color:#6b7280}[data-theme=dark] .task-description{color:#d1d5db}[data-theme=dark] .task-item.completed .task-description{color:#6b7280}[data-theme=dark] .task-checkbox{border-color:#6b7280;background:linear-gradient(145deg,#374151cc,#1f2937e6)}[data-theme=dark] .task-checkbox:checked{background:#10b981;border-color:#10b981}[data-theme=dark] .task-metadata-item{color:#9ca3af}[data-theme=dark] .task-time-badge{background:linear-gradient(145deg,#10b98133,#0596691a);border:1px solid rgba(16,185,129,.3);color:#10b981;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@media (prefers-color-scheme: dark){[data-theme=auto] .task-item{background:linear-gradient(145deg,#2d3748,#1a202c);border:1px solid rgba(75,85,99,.5);box-shadow:0 4px 16px #0000004d}[data-theme=auto] .task-item:hover{background:linear-gradient(145deg,#374151,#1f2937);border-color:#10b98199;box-shadow:0 6px 20px #0006}[data-theme=auto] .task-item.completed{background:linear-gradient(145deg,#1f2937,#111827);opacity:.8}[data-theme=auto] .task-name{color:#f9fafb}[data-theme=auto] .task-item.completed .task-name{color:#6b7280}[data-theme=auto] .task-description{color:#d1d5db}[data-theme=auto] .task-item.completed .task-description{color:#6b7280}[data-theme=auto] .task-checkbox{border-color:#6b7280;background:linear-gradient(145deg,#374151cc,#1f2937e6)}[data-theme=auto] .task-checkbox:checked{background:#10b981;border-color:#10b981}[data-theme=auto] .task-metadata-item{color:#9ca3af}[data-theme=auto] .task-time-badge{background:linear-gradient(145deg,#10b98133,#0596691a);border:1px solid rgba(16,185,129,.3);color:#10b981;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}.stat-circle{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;transition:all .2s ease;width:100%;min-height:160px}.stat-circle:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001f}.stat-circle-content{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.circle-container{position:relative;width:100px;height:100px;flex-shrink:0}.progress-ring{width:100px;height:100px}.progress-circle{transition:stroke-dashoffset .6s ease}.circle-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;z-index:1}.circle-icon{font-size:18px;margin-bottom:2px;line-height:1}.circle-stats{font-size:16px;font-weight:600;color:#374151;line-height:1;margin:0}.stat-circle-title{font-size:14px;font-weight:500;color:#6b7280;text-align:center;line-height:1.2;margin-top:12px}[data-theme=dark] .stat-circle{background:linear-gradient(145deg,#374151,#2d3748);border:1px solid rgba(75,85,99,.4);box-shadow:0 8px 32px #0000004d,0 1px #ffffff0d inset}[data-theme=dark] .stat-circle:hover{box-shadow:0 12px 40px #0006,0 1px #ffffff1a inset;border-color:#10b98166}[data-theme=dark] .circle-stats,[data-theme=dark] .stat-circle-title{color:#9ca3af}[data-theme=dark] .progress-ring circle:first-child{stroke:#4b5563}@media (prefers-color-scheme: dark){[data-theme=auto] .stat-circle{background:linear-gradient(145deg,#374151,#2d3748);border:1px solid rgba(75,85,99,.4);box-shadow:0 8px 32px #0000004d,0 1px #ffffff0d inset}[data-theme=auto] .stat-circle:hover{box-shadow:0 12px 40px #0006,0 1px #ffffff1a inset;border-color:#10b98166}[data-theme=auto] .circle-stats,[data-theme=auto] .stat-circle-title{color:#9ca3af}[data-theme=auto] .progress-ring circle:first-child{stroke:#4b5563}}@media (max-width: 480px){.stat-circle{padding:12px}.circle-stats{font-size:12px}.circle-icon{font-size:14px}}.confetti-container{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:9999;overflow:hidden}.confetti-piece{position:absolute;width:8px;height:8px;top:-10px;animation:confetti-fall linear forwards;opacity:.8}.confetti-piece:nth-child(odd){width:6px;height:12px;border-radius:2px}.confetti-piece:nth-child(2n){width:10px;height:6px;border-radius:50%}@keyframes confetti-fall{0%{transform:translateY(-10px) rotate(0);opacity:1}10%{opacity:.9}90%{opacity:.7}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.celebration-message{position:absolute;top:20%;left:50%;transform:translate(-50%);font-size:24px;font-weight:700;color:#10b981;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.1);animation:celebration-bounce .6s ease-out;background:#ffffffe6;padding:16px 24px;border-radius:12px;box-shadow:0 4px 20px #0000001a}@keyframes celebration-bounce{0%{transform:translate(-50%) scale(.5);opacity:0}50%{transform:translate(-50%) scale(1.1)}to{transform:translate(-50%) scale(1);opacity:1}}.confetti-piece:nth-child(3n){animation-duration:2.5s!important}.confetti-piece:nth-child(4n){animation-duration:3.5s!important}.confetti-piece:nth-child(5n){animation-duration:4s!important}@media (max-width: 480px){.celebration-message{font-size:20px;padding:12px 20px;top:15%}}.view-toggle{display:flex;background:#f8fafc;border-radius:12px;padding:4px;gap:2px;border:1px solid #e2e8f0;margin:16px 0;width:fit-content}.view-toggle-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;background:transparent;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500;color:#64748b;min-width:80px;justify-content:center}.view-toggle-btn:hover{background:#e2e8f0;color:#475569}.view-toggle-btn.active{background:#fff;color:#0f172a;box-shadow:0 1px 3px #0000001a}.view-toggle-icon{font-size:16px}.view-toggle-label{font-size:13px;font-weight:500}[data-theme=dark] .view-toggle{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(75,85,99,.4);box-shadow:0 4px 16px #0000004d,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .view-toggle-btn{color:#9ca3af}[data-theme=dark] .view-toggle-btn:hover{background:linear-gradient(145deg,#374151cc,#1f293799);color:#d1d5db}[data-theme=dark] .view-toggle-btn.active{background:linear-gradient(145deg,#10b981,#059669);color:#fff;box-shadow:0 4px 12px #10b9814d,0 1px #fff3 inset}@media (prefers-color-scheme: dark){[data-theme=auto] .view-toggle{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(75,85,99,.4);box-shadow:0 4px 16px #0000004d,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .view-toggle-btn{color:#9ca3af}[data-theme=auto] .view-toggle-btn:hover{background:linear-gradient(145deg,#374151cc,#1f293799);color:#d1d5db}[data-theme=auto] .view-toggle-btn.active{background:linear-gradient(145deg,#10b981,#059669);color:#fff;box-shadow:0 4px 12px #10b9814d,0 1px #fff3 inset}}@media (max-width: 480px){.view-toggle-btn{min-width:60px;padding:8px 10px}.view-toggle-label{display:none}.view-toggle-icon{font-size:18px}}.list-view{margin-top:12px}.list-view-columns{display:grid;grid-template-columns:1fr 1fr;gap:20px}.list-view-column{display:flex;flex-direction:column}.column-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding:8px 12px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.column-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:#0f172a}.column-content{display:flex;flex-direction:column;gap:8px}.empty-column{display:flex;align-items:center;justify-content:center;padding:24px 12px;border:2px dashed #e2e8f0;border-radius:8px;background:#fafafa}.empty-column-text{font-size:13px;color:#94a3b8;font-style:italic}[data-theme=dark] .column-header{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(75,85,99,.4);box-shadow:0 4px 16px #0000004d,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .column-count{background:linear-gradient(145deg,#374151cc,#1f293799);border:1px solid rgba(75,85,99,.4);color:#d1d5db;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .empty-column{background:linear-gradient(145deg,#1f29374d,#11182780);border:2px dashed rgba(75,85,99,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .empty-column-text{color:#6b7280}@media (prefers-color-scheme: dark){[data-theme=auto] .column-header{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(75,85,99,.4);box-shadow:0 4px 16px #0000004d,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .column-title{color:#f9fafb}[data-theme=auto] .column-count{background:linear-gradient(145deg,#374151cc,#1f293799);border:1px solid rgba(75,85,99,.4);color:#d1d5db;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .empty-column{background:linear-gradient(145deg,#1f29374d,#11182780);border:2px dashed rgba(75,85,99,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .empty-column-text{color:#6b7280}}@media (max-width: 768px){.list-view-columns{grid-template-columns:1fr;gap:16px}.column-header{padding:10px 14px}.column-title{font-size:15px}.column-icon{font-size:18px}}@media (max-width: 480px){.list-view-columns{gap:12px}.column-header{padding:8px 12px}}.timeline-view{margin-top:12px}.timeline-container{display:flex;flex-direction:column;gap:2px;max-height:600px;overflow-y:auto;padding-right:8px;scrollbar-width:thin;scrollbar-color:#cbd5e1 #f1f5f9}.timeline-container::-webkit-scrollbar{width:6px}.timeline-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.timeline-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.timeline-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.timeline-hour{display:grid;grid-template-columns:80px 1fr;align-items:flex-start;gap:16px;padding:8px 0;border-bottom:1px solid #f1f5f9}.timeline-hour:last-child{border-bottom:none}.timeline-hour-label{display:flex;align-items:center;justify-content:flex-end;padding-top:4px;position:sticky;top:0;background:#fff;z-index:1}.hour-main{font-size:12px;font-weight:600;color:#64748b;text-align:right}.timeline-hour-content{min-height:32px;display:flex;align-items:center}.timeline-items{display:flex;flex-direction:column;gap:6px;width:100%}.timeline-empty-slot{display:flex;align-items:center;justify-content:center;height:32px;border:1px dashed #e2e8f0;border-radius:6px;background:#fafafa}.empty-slot-text{color:#cbd5e1;font-size:14px}.timeline-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;border-left:4px solid var(--item-color);transition:all .2s ease}.timeline-item:hover{background:#f8fafc;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.timeline-item.completed{opacity:.7;background:#f8fafc}.timeline-item.completed .timeline-item-name{text-decoration:line-through;color:#64748b}.timeline-item.habit{border-left-style:dashed}.timeline-item-checkbox{display:flex;align-items:center}.timeline-checkbox{width:16px;height:16px;border-radius:4px;border:2px solid var(--item-color);background:#fff;cursor:pointer;appearance:none;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.timeline-checkbox:checked{background:var(--item-color);border-color:var(--item-color)}.timeline-checkbox:checked:after{content:"✓";color:#fff;font-size:10px;font-weight:700}.timeline-item-content{flex:1;display:flex;align-items:center;justify-content:space-between}.timeline-item-name{font-size:14px;font-weight:500;color:#0f172a;display:flex;align-items:center;gap:6px}.timeline-habit-icon{font-size:12px;opacity:.7}.timeline-item-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s ease}.timeline-item:hover .timeline-item-actions{opacity:1}.timeline-action-btn{background:none;border:none;padding:4px;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s ease}.timeline-action-btn:hover{background:#e2e8f0}.unscheduled-section{border-top:2px solid #e2e8f0;margin-top:12px;padding-top:16px}.unscheduled-section .hour-main{color:#f59e0b;font-weight:700}[data-theme=dark] .timeline-container::-webkit-scrollbar-track{background:#111827cc}[data-theme=dark] .timeline-container::-webkit-scrollbar-thumb{background:#4b5563cc}[data-theme=dark] .timeline-container::-webkit-scrollbar-thumb:hover{background:#6b7280e6}[data-theme=dark] .timeline-hour{border-bottom:1px solid rgba(75,85,99,.3)}[data-theme=dark] .timeline-hour-label{background:transparent}[data-theme=dark] .hour-main{color:#9ca3af}[data-theme=dark] .timeline-empty-slot{background:linear-gradient(145deg,#1f29374d,#11182780);border:1px dashed rgba(75,85,99,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .empty-slot-text{color:#6b7280}[data-theme=dark] .timeline-item{background:linear-gradient(145deg,#2d374899,#1a202ccc);border:1px solid rgba(75,85,99,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .timeline-item:hover{background:linear-gradient(145deg,#374151b3,#1f2937e6);border-color:#10b9814d;box-shadow:0 4px 12px #0000004d}[data-theme=dark] .timeline-item.completed{background:linear-gradient(145deg,#1f293780,#111827b3)}[data-theme=dark] .timeline-item.completed .timeline-item-name{color:#6b7280}[data-theme=dark] .timeline-checkbox{background:linear-gradient(145deg,#374151cc,#1f2937e6);border-color:var(--item-color)}[data-theme=dark] .timeline-item-name{color:#f9fafb}[data-theme=dark] .timeline-action-btn:hover{background:linear-gradient(145deg,#374151cc,#1f293799)}[data-theme=dark] .unscheduled-section{border-top:2px solid rgba(75,85,99,.4)}[data-theme=dark] .unscheduled-section .hour-main{color:#f59e0b}@media (prefers-color-scheme: dark){[data-theme=auto] .timeline-container::-webkit-scrollbar-track{background:#111827cc}[data-theme=auto] .timeline-container::-webkit-scrollbar-thumb{background:#4b5563cc}[data-theme=auto] .timeline-container::-webkit-scrollbar-thumb:hover{background:#6b7280e6}[data-theme=auto] .timeline-hour{border-bottom:1px solid rgba(75,85,99,.3)}[data-theme=auto] .timeline-hour-label{background:transparent}[data-theme=auto] .hour-main{color:#9ca3af}[data-theme=auto] .timeline-empty-slot{background:linear-gradient(145deg,#1f29374d,#11182780);border:1px dashed rgba(75,85,99,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .empty-slot-text{color:#6b7280}[data-theme=auto] .timeline-item{background:linear-gradient(145deg,#2d374899,#1a202ccc);border:1px solid rgba(75,85,99,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .timeline-item:hover{background:linear-gradient(145deg,#374151b3,#1f2937e6);border-color:#10b9814d;box-shadow:0 4px 12px #0000004d}[data-theme=auto] .timeline-item.completed{background:linear-gradient(145deg,#1f293780,#111827b3)}[data-theme=auto] .timeline-item.completed .timeline-item-name{color:#6b7280}[data-theme=auto] .timeline-checkbox{background:linear-gradient(145deg,#374151cc,#1f2937e6);border-color:var(--item-color)}[data-theme=auto] .timeline-item-name{color:#f9fafb}[data-theme=auto] .timeline-action-btn:hover{background:linear-gradient(145deg,#374151cc,#1f293799)}[data-theme=auto] .unscheduled-section{border-top:2px solid rgba(75,85,99,.4)}[data-theme=auto] .unscheduled-section .hour-main{color:#f59e0b}}@media (max-width: 768px){.timeline-hour{grid-template-columns:60px 1fr;gap:12px}.hour-main{font-size:11px}.timeline-item{padding:10px}.timeline-item-name{font-size:13px}}@media (max-width: 480px){.timeline-hour{grid-template-columns:50px 1fr;gap:8px}.timeline-item{padding:8px}.timeline-item-actions{opacity:1}}.calendar-view{margin-top:12px}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding:0 8px}.calendar-nav-btn{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:#64748b;transition:all .2s ease}.calendar-nav-btn:hover{background:#e2e8f0;color:#0f172a}.calendar-title{font-size:18px;font-weight:600;color:#0f172a}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#e2e8f0;border-radius:8px;overflow:hidden;border:1px solid #e2e8f0}.calendar-day-header{background:#f8fafc;padding:8px 4px;text-align:center;font-size:12px;font-weight:600;color:#64748b}.calendar-day{background:#fff;min-height:60px;padding:4px;display:flex;flex-direction:column;cursor:pointer;transition:all .2s ease;position:relative}.calendar-day:hover{background:#f8fafc}.calendar-day.today{background:#dbeafe}.calendar-day.today:hover{background:#bfdbfe}.calendar-day.selected{background:#3b82f6;color:#fff}.calendar-day.selected:hover{background:#2563eb}.calendar-day.selected .calendar-day-number{color:#fff}.calendar-day.other-month{background:#f9fafb;color:#d1d5db;cursor:default}.calendar-day.other-month:hover{background:#f9fafb}.calendar-day.has-items{border:1px solid #e5e7eb}.calendar-day-number{font-size:13px;font-weight:500;color:#0f172a;margin-bottom:2px;align-self:flex-start}.calendar-day-indicators{display:flex;flex-wrap:wrap;gap:2px;margin-bottom:2px;flex:1}.calendar-indicator{width:6px;height:6px;border-radius:50%;border:1px solid;transition:all .2s ease}.calendar-indicator.task,.calendar-indicator.habit{border-radius:50%}.calendar-indicator.completed{transform:scale(1.1)}.calendar-indicator-more{font-size:8px;font-weight:600;color:#64748b;line-height:6px;padding-left:1px}.calendar-completion-bar{height:2px;border-radius:1px;margin-top:auto;transition:width .3s ease}.calendar-completion-star{position:absolute;top:2px;right:2px;font-size:12px;line-height:1;z-index:2;filter:drop-shadow(0 1px 1px rgba(0,0,0,.2))}.calendar-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.loading-dot{width:4px;height:4px;background:#94a3b8;border-radius:50%;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.calendar-legend{display:flex;justify-content:center;gap:16px;margin-top:12px;padding:8px}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#64748b}.legend-indicator{width:8px;height:8px;border:1px solid #94a3b8;background:#94a3b8}.legend-indicator.task,.legend-indicator.habit{border-radius:50%}.legend-completion-bar{width:12px;height:3px;background:#f59e0b;border-radius:1px}.legend-star{font-size:12px;line-height:1}[data-theme=dark] .calendar-nav-btn{background:linear-gradient(145deg,#374151cc,#1f2937e6);border:1px solid rgba(75,85,99,.4);color:#f9fafb;box-shadow:0 2px 8px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .calendar-nav-btn:hover{background:linear-gradient(145deg,#4b5563e6,#374151cc);border-color:#10b98166;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}[data-theme=dark] .calendar-title{color:#f9fafb}[data-theme=dark] .calendar-grid{background:#4b556366;border:1px solid rgba(75,85,99,.4)}[data-theme=dark] .calendar-day-header{background:linear-gradient(145deg,#1f2937cc,#111827e6);color:#9ca3af}[data-theme=dark] .calendar-day{background:linear-gradient(145deg,#2d374899,#1a202ccc);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .calendar-day:hover{background:linear-gradient(145deg,#374151b3,#1f2937e6)}[data-theme=dark] .calendar-day.today{background:linear-gradient(145deg,#10b98133,#0596691a);border:1px solid rgba(16,185,129,.3)}[data-theme=dark] .calendar-day.today:hover{background:linear-gradient(145deg,#10b9814d,#05966933)}[data-theme=dark] .calendar-day.selected{background:linear-gradient(145deg,#10b981,#059669);color:#fff}[data-theme=dark] .calendar-day.selected:hover{background:linear-gradient(145deg,#059669,#047857)}[data-theme=dark] .calendar-day.other-month{background:#11182780;color:#4b5563}[data-theme=dark] .calendar-day.other-month:hover{background:#11182799}[data-theme=dark] .calendar-day.has-items{border:1px solid rgba(75,85,99,.6)}[data-theme=dark] .calendar-day-number{color:#f9fafb}[data-theme=dark] .calendar-day.other-month .calendar-day-number{color:#4b5563}[data-theme=dark] .calendar-indicator-more{color:#9ca3af}[data-theme=dark] .loading-dot{background:#6b7280}[data-theme=dark] .legend-item{color:#9ca3af}[data-theme=dark] .legend-indicator{border-color:#6b7280;background:#6b7280}@media (prefers-color-scheme: dark){[data-theme=auto] .calendar-nav-btn{background:linear-gradient(145deg,#374151cc,#1f2937e6);border:1px solid rgba(75,85,99,.4);color:#f9fafb;box-shadow:0 2px 8px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .calendar-nav-btn:hover{background:linear-gradient(145deg,#4b5563e6,#374151cc);border-color:#10b98166;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}[data-theme=auto] .calendar-title{color:#f9fafb}[data-theme=auto] .calendar-grid{background:#4b556366;border:1px solid rgba(75,85,99,.4)}[data-theme=auto] .calendar-day-header{background:linear-gradient(145deg,#1f2937cc,#111827e6);color:#9ca3af}[data-theme=auto] .calendar-day{background:linear-gradient(145deg,#2d374899,#1a202ccc);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .calendar-day:hover{background:linear-gradient(145deg,#374151b3,#1f2937e6)}[data-theme=auto] .calendar-day.today{background:linear-gradient(145deg,#10b98133,#0596691a);border:1px solid rgba(16,185,129,.3)}[data-theme=auto] .calendar-day.today:hover{background:linear-gradient(145deg,#10b9814d,#05966933)}[data-theme=auto] .calendar-day.selected{background:linear-gradient(145deg,#10b981,#059669);color:#fff}[data-theme=auto] .calendar-day.selected:hover{background:linear-gradient(145deg,#059669,#047857)}[data-theme=auto] .calendar-day.other-month{background:#11182780;color:#4b5563}[data-theme=auto] .calendar-day.other-month:hover{background:#11182799}[data-theme=auto] .calendar-day.has-items{border:1px solid rgba(75,85,99,.6)}[data-theme=auto] .calendar-day-number{color:#f9fafb}[data-theme=auto] .calendar-day.other-month .calendar-day-number{color:#4b5563}[data-theme=auto] .calendar-indicator-more{color:#9ca3af}[data-theme=auto] .loading-dot{background:#6b7280}[data-theme=auto] .legend-item{color:#9ca3af}[data-theme=auto] .legend-indicator{border-color:#6b7280;background:#6b7280}}@media (max-width: 768px){.calendar-grid{gap:0}.calendar-day{min-height:50px;padding:3px}.calendar-day-number{font-size:12px}.calendar-indicator{width:5px;height:5px}.calendar-title{font-size:16px}.calendar-nav-btn{width:32px;height:32px;font-size:14px}}@media (max-width: 480px){.calendar-day{min-height:40px;padding:2px}.calendar-day-number{font-size:11px}.calendar-indicator{width:4px;height:4px}.calendar-completion-star{font-size:10px;top:1px;right:1px}.calendar-legend{gap:12px}.legend-item{font-size:11px}}.date-popup-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.date-popup{background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000026;max-width:700px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.date-popup-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e2e8f0;background:#f8fafc}.date-popup-title{margin:0;font-size:18px;font-weight:600;color:#0f172a}.date-popup-close{background:none;border:none;font-size:18px;color:#64748b;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.date-popup-close:hover{background:#e2e8f0;color:#0f172a}.date-popup-content{padding:24px;overflow-y:auto;flex:1}.date-popup-columns{display:grid;grid-template-columns:1fr 1fr;gap:24px}.date-popup-column{display:flex;flex-direction:column}.date-popup-column-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;padding:12px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.column-icon{font-size:16px}.column-title{font-weight:600;font-size:14px;color:#0f172a;flex:1}.column-count{background:#e2e8f0;color:#64748b;font-size:12px;font-weight:600;padding:4px 8px;border-radius:12px;min-width:20px;text-align:center}.date-popup-column-content{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:#cbd5e1 #f1f5f9}.date-popup-column-content::-webkit-scrollbar{width:4px}.date-popup-column-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:2px}.date-popup-column-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.popup-item{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;transition:all .2s ease;border-left-width:4px}.popup-item:hover{background:#f8fafc;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.popup-item.completed{opacity:.7;background:#f8fafc}.popup-item.completed .popup-item-name{text-decoration:line-through;color:#64748b}.popup-item-checkbox{display:flex;align-items:center}.popup-checkbox{width:18px;height:18px;border-radius:4px;border:2px solid #d1d5db;background:#fff;cursor:pointer;appearance:none;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.popup-checkbox:checked{background:#10b981;border-color:#10b981}.popup-checkbox:checked:after{content:"✓";color:#fff;font-size:12px;font-weight:700}.popup-item-content{flex:1;display:flex;flex-direction:column;gap:4px}.popup-item-name{font-size:14px;font-weight:500;color:#0f172a;display:flex;align-items:center;gap:6px}.popup-habit-icon{font-size:12px;opacity:.7}.popup-item-description{font-size:12px;color:#64748b;line-height:1.4}.popup-item-time{font-size:11px;color:#8b5cf6;font-weight:500;display:flex;align-items:center;gap:4px}.popup-item-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s ease}.popup-item:hover .popup-item-actions{opacity:1}.popup-action-btn{background:none;border:none;padding:6px;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s ease;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.popup-action-btn:hover{background:#e2e8f0}.popup-action-btn.delete:hover{background:#fee2e2}.date-popup-empty{display:flex;align-items:center;justify-content:center;padding:32px 16px;color:#94a3b8;font-size:14px;font-style:italic;border:2px dashed #e2e8f0;border-radius:8px;background:#fafafa}@media (max-width: 768px){.date-popup{margin:10px;max-height:90vh}.date-popup-columns{grid-template-columns:1fr;gap:16px}.date-popup-content{padding:16px}.date-popup-header{padding:16px 20px}.date-popup-title{font-size:16px}}[data-theme=dark] .date-popup-overlay{background:#000000b3}[data-theme=dark] .date-popup{background:linear-gradient(145deg,#1f2937f2,#111827fa);border:1px solid rgba(75,85,99,.4);box-shadow:0 25px 50px #00000080,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}[data-theme=dark] .date-popup-header{background:linear-gradient(145deg,#2d3748cc,#1a202ce6);border-bottom:1px solid rgba(75,85,99,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .date-popup-title{color:#f9fafb}[data-theme=dark] .date-popup-close{color:#9ca3af}[data-theme=dark] .date-popup-close:hover{background:linear-gradient(145deg,#374151cc,#1f293799);color:#f9fafb}[data-theme=dark] .date-popup-column-header{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(75,85,99,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .column-title{color:#f9fafb}[data-theme=dark] .column-count{background:linear-gradient(145deg,#374151cc,#1f293799);color:#d1d5db;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .date-popup-column-content::-webkit-scrollbar-track{background:#111827cc}[data-theme=dark] .date-popup-column-content::-webkit-scrollbar-thumb{background:#4b5563cc}[data-theme=dark] .popup-item{background:linear-gradient(145deg,#2d374899,#1a202ccc);border:1px solid rgba(75,85,99,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .popup-item:hover{background:linear-gradient(145deg,#374151b3,#1f2937e6);border-color:#10b9814d;box-shadow:0 4px 12px #0000004d}[data-theme=dark] .popup-item.completed{background:linear-gradient(145deg,#1f293780,#111827b3)}[data-theme=dark] .popup-item.completed .popup-item-name{color:#6b7280}[data-theme=dark] .popup-checkbox{background:linear-gradient(145deg,#374151cc,#1f2937e6);border-color:#6b7280}[data-theme=dark] .popup-checkbox:checked{background:#10b981;border-color:#10b981}[data-theme=dark] .popup-item-name{color:#f9fafb}[data-theme=dark] .popup-item-description{color:#9ca3af}[data-theme=dark] .popup-item-time{color:#a78bfa}[data-theme=dark] .popup-action-btn:hover{background:linear-gradient(145deg,#374151cc,#1f293799)}[data-theme=dark] .popup-action-btn.delete:hover{background:linear-gradient(145deg,#dc262633,#b91c1c1a)}[data-theme=dark] .date-popup-empty{background:linear-gradient(145deg,#1f29374d,#11182780);border:2px dashed rgba(75,85,99,.4);color:#6b7280;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@media (prefers-color-scheme: dark){[data-theme=auto] .date-popup-overlay{background:#000000b3}[data-theme=auto] .date-popup{background:linear-gradient(145deg,#1f2937f2,#111827fa);border:1px solid rgba(75,85,99,.4);box-shadow:0 25px 50px #00000080,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}[data-theme=auto] .date-popup-header{background:linear-gradient(145deg,#2d3748cc,#1a202ce6);border-bottom:1px solid rgba(75,85,99,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .date-popup-title{color:#f9fafb}[data-theme=auto] .date-popup-close{color:#9ca3af}[data-theme=auto] .date-popup-close:hover{background:linear-gradient(145deg,#374151cc,#1f293799);color:#f9fafb}[data-theme=auto] .date-popup-column-header{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(75,85,99,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .column-title{color:#f9fafb}[data-theme=auto] .column-count{background:linear-gradient(145deg,#374151cc,#1f293799);color:#d1d5db;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .date-popup-column-content::-webkit-scrollbar-track{background:#111827cc}[data-theme=auto] .date-popup-column-content::-webkit-scrollbar-thumb{background:#4b5563cc}[data-theme=auto] .popup-item{background:linear-gradient(145deg,#2d374899,#1a202ccc);border:1px solid rgba(75,85,99,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .popup-item:hover{background:linear-gradient(145deg,#374151b3,#1f2937e6);border-color:#10b9814d;box-shadow:0 4px 12px #0000004d}[data-theme=auto] .popup-item.completed{background:linear-gradient(145deg,#1f293780,#111827b3)}[data-theme=auto] .popup-item.completed .popup-item-name{color:#6b7280}[data-theme=auto] .popup-checkbox{background:linear-gradient(145deg,#374151cc,#1f2937e6);border-color:#6b7280}[data-theme=auto] .popup-checkbox:checked{background:#10b981;border-color:#10b981}[data-theme=auto] .popup-item-name{color:#f9fafb}[data-theme=auto] .popup-item-description{color:#9ca3af}[data-theme=auto] .popup-item-time{color:#a78bfa}[data-theme=auto] .popup-action-btn:hover{background:linear-gradient(145deg,#374151cc,#1f293799)}[data-theme=auto] .popup-action-btn.delete:hover{background:linear-gradient(145deg,#dc262633,#b91c1c1a)}[data-theme=auto] .date-popup-empty{background:linear-gradient(145deg,#1f29374d,#11182780);border:2px dashed rgba(75,85,99,.4);color:#6b7280;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}@media (max-width: 480px){.date-popup-overlay,.popup-item{padding:10px}.popup-item-actions{opacity:1}.date-popup-column-content{max-height:300px}}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.type-selector{background:#fff;border-radius:16px;padding:24px;width:100%;max-width:400px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.type-selector h3{margin:0 0 20px;font-size:20px;font-weight:700;color:#111827;text-align:center}.type-buttons{display:grid;gap:12px}.type-button{display:flex;flex-direction:column;align-items:center;padding:20px;border:2px solid #e5e7eb;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s ease;text-align:center}.type-button:hover{border-color:#10b981;background:#f0fdfa;transform:translateY(-2px);box-shadow:0 4px 12px #10b98126}.type-button .type-icon{font-size:32px;margin-bottom:8px}.type-button .type-title{font-size:20px;font-weight:700;color:#111827;margin-bottom:4px}.type-button .type-desc{font-size:14px;color:#6b7280}.add-item-popup{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040}.popup-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.popup-header h2{margin:0;font-size:20px;font-weight:700;color:#111827}.close-btn{width:32px;height:32px;border:none;background:none;font-size:24px;color:#6b7280;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-btn:hover{background:#e5e7eb;color:#374151}.popup-content{flex:1;overflow-y:auto;padding:24px}.popup-actions{display:flex;gap:20px;padding:28px 48px 40px;border-top:1px solid #e5e7eb;background:#f9fafb;border-bottom-left-radius:16px;border-bottom-right-radius:16px;margin:0 8px 8px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:600;font-size:14px;color:#374151}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease;background:#fff}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.form-group input.error,.form-group textarea.error,.form-group select.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef444433,0 0 8px #ef44444d;animation:errorGlow .3s ease-in-out}@keyframes errorGlow{0%{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 4px #ef444433,0 0 12px #ef444466}to{box-shadow:0 0 0 3px #ef444433,0 0 8px #ef44444d}}.error-text{display:block;font-size:12px;color:#ef4444;margin-top:4px}.form-help-text{font-size:12px;color:#6b7280;margin-top:4px;margin-bottom:8px;font-style:italic}.type-toggle{display:flex;background:#f3f4f6;border-radius:8px;padding:4px}.toggle-btn{flex:1;padding:8px 12px;border:none;background:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;color:#6b7280}.toggle-btn.active{background:#fff;color:#10b981;box-shadow:0 1px 3px #0000001a}.type-context{margin-top:12px;padding:12px;background:#f8fafc;border-radius:8px;border-left:3px solid #10b981}.type-context p{margin:0;font-size:12px;line-height:1.4;color:#475569}.type-context p+p{margin-top:6px}.type-context strong{color:#1e293b;font-weight:600}.color-picker{display:flex;flex-wrap:wrap;gap:8px}.color-option{width:40px;height:40px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .2s ease;position:relative}.color-option:hover{transform:scale(1.1);box-shadow:0 4px 8px #00000026}.color-option.selected{border-color:#374151;transform:scale(1.1)}.color-option.selected:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;font-size:16px;text-shadow:0 1px 2px rgba(0,0,0,.5)}.custom-color-container{position:relative}.custom-color-btn{width:40px!important;height:40px!important;border-radius:8px;cursor:pointer;transition:all .2s ease;position:relative;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0}.custom-color-btn::-webkit-color-swatch-wrapper{padding:0;border:none;border-radius:8px}.custom-color-btn::-webkit-color-swatch{border:none;border-radius:8px}.custom-color-btn::-moz-color-swatch{border:none;border-radius:8px}.custom-color-btn:hover{transform:scale(1.1);box-shadow:0 4px 8px #00000026}.custom-color-btn.selected{border-color:#374151!important;transform:scale(1.1)}.custom-color-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;font-size:16px;text-shadow:0 1px 2px rgba(0,0,0,.8);pointer-events:none}.checkbox-group{display:flex;align-items:center}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500;color:#374151}.checkbox-label input[type=checkbox]{width:auto;margin:0;accent-color:#10b981}.days-selector{display:flex;flex-wrap:wrap;gap:6px}.day-btn{padding:8px 12px;border:1px solid #d1d5db;background:#fff;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;color:#374151;min-width:44px}.day-btn:hover{border-color:#10b981;background:#f0fdfa}.day-btn.selected{background:#10b981;border-color:#10b981;color:#fff}.habit-days-selector{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-top:8px}.habit-days-selector.error{animation:errorGlow .3s ease-in-out}.habit-days-selector.error .habit-day-btn{border-color:#ef4444;box-shadow:0 0 0 2px #ef444433}.habit-day-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;aspect-ratio:1;min-height:64px;border:2px solid #e5e7eb;border-radius:16px;background:#fff;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);padding:8px;font-size:12px;font-weight:600;color:#6b7280;position:relative;overflow:hidden}.habit-day-btn .day-short{display:block}.habit-day-btn .day-full{display:none}.habit-day-btn:hover{transform:translateY(-2px) scale(1.02);border-color:#10b981;color:#059669;background:linear-gradient(135deg,#f0fdfa,#ecfdf5);box-shadow:0 8px 25px #10b98126}.habit-day-btn.selected{background:linear-gradient(135deg,#10b981,#059669);border-color:#047857;color:#fff;box-shadow:0 4px 15px #10b98166;transform:scale(1.05)}.habit-day-btn.selected:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 8px 25px #10b98180}.btn-primary,.btn-secondary{flex:1;padding:12px 24px;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;border:none}.reminders-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:20px;margin:16px 0}.reminder-header{margin-bottom:16px}.toggle-switch-container{display:flex;align-items:center;justify-content:space-between;padding:12px 0}.reminder-toggle-text{font-size:16px;font-weight:600;color:#374151}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e0;transition:all .3s ease;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;top:3px;background-color:#fff;transition:all .3s ease;border-radius:50%;box-shadow:0 2px 4px #0003;transform:translate(0)}.toggle-switch input:checked+.toggle-slider{background-color:#10b981!important}.toggle-switch input:checked+.toggle-slider:before{transform:translate(25px)!important}.toggle-switch input:not(:checked)+.toggle-slider:before{transform:translate(0)!important}.toggle-switch:hover .toggle-slider{box-shadow:0 0 8px #10b9814d}.reminder-options-container{margin-top:20px;display:flex;flex-direction:column;gap:20px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.reminder-times-section{display:flex;flex-direction:column;gap:12px}.reminder-section-label{font-size:14px;font-weight:600;color:#4b5563;margin-bottom:8px}.reminder-times-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.reminder-time-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 12px;border:2px solid #e5e7eb;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s ease;min-height:80px;gap:6px}.reminder-time-btn:hover{border-color:#10b981;background:#f0fdfa;transform:translateY(-2px);box-shadow:0 4px 12px #10b98126}.reminder-time-btn.selected{border-color:#10b981;background:#10b981;color:#fff;transform:translateY(-2px);box-shadow:0 6px 16px #10b98140}.reminder-icon{font-size:20px;margin-bottom:4px}.reminder-label{font-size:13px;font-weight:600;text-align:center;line-height:1.2}.custom-reminder-section{margin-top:12px;padding:16px;background:#f0fdfa;border:1px solid #a7f3d0;border-radius:8px;animation:slideIn .3s ease-out}.custom-reminder-inputs{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.custom-time-input{width:80px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;text-align:center;background:#fff}.custom-time-input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.custom-unit-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.custom-unit-select:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.custom-before-text{font-size:14px;color:#6b7280;font-weight:500}@media (max-width: 640px){.modal-overlay{padding:10px}.add-item-popup{max-height:95vh}.form-row{grid-template-columns:1fr;gap:12px}.color-picker{gap:6px}.color-option{width:36px;height:36px}.custom-color-btn{width:36px!important;height:36px!important}.popup-actions{flex-direction:column;padding:24px 40px 32px;margin:0 4px 4px}.btn-primary,.btn-secondary{flex:none}.habit-days-selector{grid-template-columns:repeat(7,1fr);gap:6px}.habit-day-btn{min-height:56px;padding:6px;font-size:11px}.habit-day-btn .day-short{display:none}.habit-day-btn .day-full{display:block;font-size:10px}.reminder-times-grid{grid-template-columns:1fr}.custom-reminder-inputs{justify-content:flex-start}}[data-theme=dark] .type-selector{background:#1f2937;color:#f9fafb}[data-theme=dark] .type-selector h3{color:#f9fafb}[data-theme=dark] .type-button{background:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=dark] .type-button:hover{border-color:#10b981;background:#064e3b}[data-theme=dark] .type-button span:nth-child(2){color:#f9fafb}[data-theme=dark] .type-button .type-desc{color:#9ca3af}[data-theme=dark] .add-item-popup{background:#1f2937;color:#f9fafb}[data-theme=dark] .popup-header{background:#111827;border-bottom-color:#374151}[data-theme=dark] .popup-header h2{color:#f9fafb}[data-theme=dark] .close-btn{color:#9ca3af}[data-theme=dark] .close-btn:hover{background:#374151;color:#f9fafb}[data-theme=dark] .popup-actions{background:#111827;border-top-color:#374151}[data-theme=dark] .form-group label{color:#d1d5db}[data-theme=dark] .form-group input,[data-theme=dark] .form-group textarea,[data-theme=dark] .form-group select{background:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=dark] .form-group input:focus,[data-theme=dark] .form-group textarea:focus,[data-theme=dark] .form-group select:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}[data-theme=dark] .form-group input.error,[data-theme=dark] .form-group textarea.error,[data-theme=dark] .form-group select.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}[data-theme=dark] .form-help-text{color:#9ca3af}[data-theme=dark] .type-toggle{background:#374151}[data-theme=dark] .toggle-btn{color:#9ca3af}[data-theme=dark] .toggle-btn.active{background:#1f2937;color:#10b981;box-shadow:0 1px 3px #0000004d}[data-theme=dark] .checkbox-label input[type=checkbox]{accent-color:#10b981}[data-theme=dark] .day-btn{background:#374151;border-color:#4b5563;color:#d1d5db}[data-theme=dark] .day-btn:hover{border-color:#10b981;background:#064e3b}[data-theme=dark] .day-btn.selected{background:#10b981;border-color:#10b981;color:#fff}[data-theme=dark] .habit-day-btn{background:#374151;border-color:#4b5563;color:#9ca3af}[data-theme=dark] .habit-day-btn:hover{border-color:#10b981;background:#064e3b}[data-theme=dark] .habit-day-btn.selected{background:#10b981;border-color:#10b981;color:#fff}[data-theme=dark] .habit-day-indicator{background:#374151;border-color:#4b5563;color:#9ca3af}[data-theme=dark] .reminders-section{background:#2d3748;border-color:#4a5568}[data-theme=dark] .reminder-toggle-text{color:#f7fafc}[data-theme=dark] .reminder-section-label{color:#e2e8f0}[data-theme=dark] .reminder-time-btn{background:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=dark] .reminder-time-btn:hover{border-color:#10b981;background:#064e3b}[data-theme=dark] .reminder-time-btn.selected{background:#10b981;border-color:#10b981;color:#fff}[data-theme=dark] .custom-reminder-section{background:#064e3b;border-color:#10b981}[data-theme=dark] .custom-time-input,[data-theme=dark] .custom-unit-select{background:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=dark] .custom-time-input:focus,[data-theme=dark] .custom-unit-select:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}[data-theme=dark] .custom-before-text{color:#d1d5db}@media (prefers-color-scheme: dark){[data-theme=auto] .type-selector{background:#1f2937;color:#f9fafb}[data-theme=auto] .type-selector h3{color:#f9fafb}[data-theme=auto] .type-button{background:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=auto] .type-button:hover{border-color:#10b981;background:#064e3b}[data-theme=auto] .type-button span:nth-child(2){color:#f9fafb}[data-theme=auto] .type-button .type-desc{color:#9ca3af}[data-theme=auto] .add-item-popup{background:#1f2937;color:#f9fafb}[data-theme=auto] .popup-header{background:#111827;border-bottom-color:#374151}[data-theme=auto] .popup-header h2{color:#f9fafb}[data-theme=auto] .close-btn{color:#9ca3af}[data-theme=auto] .close-btn:hover{background:#374151;color:#f9fafb}[data-theme=auto] .popup-actions{background:#111827;border-top-color:#374151}[data-theme=auto] .form-group label{color:#d1d5db}[data-theme=auto] .form-group input,[data-theme=auto] .form-group textarea,[data-theme=auto] .form-group select{background:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=auto] .form-group input:focus,[data-theme=auto] .form-group textarea:focus,[data-theme=auto] .form-group select:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}[data-theme=auto] .form-group input.error,[data-theme=auto] .form-group textarea.error,[data-theme=auto] .form-group select.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}[data-theme=auto] .form-help-text{color:#9ca3af}[data-theme=auto] .type-toggle{background:#374151}[data-theme=auto] .toggle-btn{color:#9ca3af}[data-theme=auto] .toggle-btn.active{background:#1f2937;color:#10b981;box-shadow:0 1px 3px #0000004d}[data-theme=auto] .checkbox-label{color:#d1d5db}[data-theme=auto] .checkbox-label input[type=checkbox]{accent-color:#10b981}[data-theme=auto] .day-btn{background:#374151;border-color:#4b5563;color:#d1d5db}[data-theme=auto] .day-btn:hover{border-color:#10b981;background:#064e3b}[data-theme=auto] .day-btn.selected{background:#10b981;border-color:#10b981;color:#fff}[data-theme=auto] .habit-day-btn{background:#374151;border-color:#4b5563;color:#9ca3af}[data-theme=auto] .habit-day-btn:hover{border-color:#10b981;background:#064e3b}[data-theme=auto] .habit-day-btn.selected{background:#10b981;border-color:#10b981;color:#fff}[data-theme=auto] .habit-day-indicator{background:#374151;border-color:#4b5563;color:#9ca3af}[data-theme=auto] .reminders-section{background:#2d3748;border-color:#4a5568}[data-theme=auto] .reminder-toggle-text{color:#f7fafc}[data-theme=auto] .reminder-section-label{color:#e2e8f0}[data-theme=auto] .reminder-time-btn{background:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=auto] .reminder-time-btn:hover{border-color:#10b981;background:#064e3b}[data-theme=auto] .reminder-time-btn.selected{background:#10b981;border-color:#10b981;color:#fff}[data-theme=auto] .custom-reminder-section{background:#064e3b;border-color:#10b981}[data-theme=auto] .custom-time-input,[data-theme=auto] .custom-unit-select{background:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=auto] .custom-time-input:focus,[data-theme=auto] .custom-unit-select:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}[data-theme=auto] .custom-before-text{color:#d1d5db}}.home-container{padding:20px;max-width:800px;margin:0 auto}.task-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}.home-header{margin-bottom:24px}.home-title{font-size:24px;font-weight:700;color:#111827;margin-bottom:8px}.home-subtitle{font-size:16px;color:#6b7280;margin-bottom:16px}.home-content{display:flex;flex-direction:column;gap:24px}.task{background:#fafafa;border-radius:8px;margin-bottom:8px;padding:14px;transition:all .2s ease;border-left:4px solid transparent}.task:hover{background:#f5f5f5;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.task:last-child{margin-bottom:0}.item-type-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;font-size:12px;background:#10b9811a;border:1px solid rgba(16,185,129,.2)}.item-type-badge[data-type=habit]{background:#8b5cf61a;border-color:#8b5cf633}.frequency-badge{display:inline-block;background:#e0f2fe;color:#0369a1;font-size:11px;font-weight:500;padding:2px 6px;border-radius:4px;margin-left:8px}.meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.time-badge{background:#10b9811a;color:#059669;font-size:11px;font-weight:600;padding:3px 8px;border-radius:12px;border:1px solid rgba(16,185,129,.2)}.dot{width:12px;height:12px;border-radius:50%;border:2px solid white;box-shadow:0 0 0 1px #0000001a;flex-shrink:0}.habit-days-display{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}.habit-day-indicator{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:20px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;font-size:10px;font-weight:600;color:#6b7280;padding:0 4px}.task[style*=border-left] .habit-day-indicator{background:#fff3;border-color:#ffffff4d;color:#374151}.empty{text-align:center;padding:40px 20px;color:#9ca3af}.empty-title{font-size:18px;font-weight:600;color:#374151;margin-bottom:8px}.empty-description{font-size:14px;color:#6b7280;margin-bottom:16px}.empty-action{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#10b981;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.empty-action:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b98140}.home-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{padding:20px;border-radius:12px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;text-align:center}.stat-value{font-size:28px;font-weight:700;color:#10b981;margin-bottom:4px}.stat-label{font-size:14px;font-weight:500;color:#64748b}@media (max-width: 768px){.home-container{padding:16px}.home-stats{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:16px}.stat-value{font-size:24px}.stat-circles-container{grid-template-columns:1fr 1fr;gap:12px}.stat-circle{min-height:140px;padding:20px}}.stat-circles-container{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0 8px;width:100%}.home-container .view-toggle{margin-left:0;margin-top:0;margin-bottom:16px;align-self:flex-start}.skeleton.stat-circle{height:160px;border-radius:12px}.assistant-container{height:calc(100vh - 100px);display:flex;flex-direction:column;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.assistant-warning{padding:20px;display:flex;justify-content:center;background:transparent;border:none}.warning-content{background:linear-gradient(135deg,#fef3cd,#fde68a);border:1px solid #f59e0b;border-radius:20px;padding:18px 24px;box-shadow:0 8px 25px #f59e0b33;max-width:700px;width:100%;display:flex;align-items:center;justify-content:center;gap:12px;text-align:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s ease}.warning-icon{font-size:20px;flex-shrink:0;margin-top:2px}.warning-text{font-size:14px;line-height:1.5;color:#92400e}.warning-text strong{color:#78350f}.assistant-header{padding:16px 20px;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;gap:12px}.assistant-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px}.assistant-info h2{font-size:18px;font-weight:600;color:#111827;margin:0 0 2px}.assistant-info p{font-size:14px;color:#6b7280;margin:0}.chat-container{flex:1;display:flex;flex-direction:column;max-width:800px;margin:0 auto;width:100%;position:relative;padding:0 20px}.chat-container:before{content:"";position:absolute;top:0;left:0;right:0;height:20px;background:transparent;pointer-events:none;z-index:1}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#10b981,#059669);border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#059669,#047857)}.message{display:flex;gap:12px;max-width:80%;animation:messageSlideIn .3s ease-out}.message.user{align-self:flex-end;flex-direction:row-reverse}.message.assistant{align-self:flex-start}.message-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;box-shadow:0 2px 8px #0000001a}.message.user .message-avatar{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.message.assistant .message-avatar{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:6px}.buddi-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.user-avatar{font-size:16px}.message-content{background:#fff;border:1px solid #e5e7eb;border-radius:18px;padding:14px 18px;box-shadow:0 2px 8px #00000014;position:relative}.message.user .message-content{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#10b981}.message.assistant .message-content{background:#fff;border:1px solid #e2e8f0}.message.assistant .message-content:before{content:"";position:absolute;left:-8px;top:12px;width:0;height:0;border-style:solid;border-width:8px 8px 8px 0;border-color:transparent white transparent transparent}.message.user .message-content:before{content:"";position:absolute;right:-8px;top:12px;width:0;height:0;border-style:solid;border-width:8px 0 8px 8px;border-color:transparent transparent transparent #10b981}.message-content:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001f}.assistant-container{color:#111827}[data-theme=dark] .assistant-container{color:#f9fafb}.message-text{font-size:14px;line-height:1.5;margin:0}.message-time{font-size:12px;color:#6b7280;margin-top:4px;text-align:right}.message.user .message-time{color:#fffc}.chat-input-container{padding:20px;background:linear-gradient(135deg,#fff,#f8fafc);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid #e5e7eb;border-radius:24px 24px 0 0}.chat-input-form{display:flex;gap:12px;max-width:800px;margin:0 auto;background:#fffc;border-radius:32px;padding:8px;box-shadow:0 4px 20px #00000014;border:1px solid rgba(226,232,240,.6)}.chat-input{flex:1;padding:16px 20px;border:none;border-radius:24px;font-size:15px;resize:none;outline:none;transition:all .2s ease;background:transparent;box-shadow:none}.chat-input:focus{background:#ffffffe6}.chat-input-form:focus-within{border-color:#10b981;box-shadow:0 0 0 4px #10b9811a,0 8px 25px #00000026;transform:translateY(-2px)}.chat-input::placeholder{color:#9ca3af;font-style:italic}.chat-send-btn{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0;font-size:18px;font-weight:700;box-shadow:0 4px 12px #10b9814d}.chat-send-btn:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);transform:scale(1.05);box-shadow:0 6px 16px #10b98166}.chat-send-btn:active{transform:scale(.95)}.chat-send-btn:disabled{background:#d1d5db;cursor:not-allowed;transform:none;box-shadow:none}.typing-indicator{display:flex;gap:12px;align-self:flex-start;max-width:80%}.typing-content{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:12px 16px;display:flex;align-items:center;gap:8px}.typing-dots{display:flex;gap:4px}.typing-dot{width:8px;height:8px;background:#9ca3af;border-radius:50%;animation:typing 1.4s infinite ease-in-out}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-10px)}}.chat-suggestions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;justify-content:center}.suggestion-chip{padding:10px 16px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e2e8f0;border-radius:20px;font-size:13px;font-weight:500;color:#475569;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 2px 4px #0000000d}.suggestion-chip:hover{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#10b981;transform:translateY(-2px);box-shadow:0 4px 12px #10b98140}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.empty-icon{font-size:48px;color:#10b981;margin-bottom:16px}.empty-title{font-size:20px;font-weight:600;color:#111827;margin-bottom:8px}.empty-description{font-size:14px;color:#6b7280;margin-bottom:20px;max-width:400px}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.message.loading .message-content{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:shimmer 2s infinite}[data-theme=dark] .assistant-container{background:linear-gradient(135deg,#1a202c,#2d3748)}[data-theme=dark] .warning-content{background:linear-gradient(145deg,#d9770626,#f59e0b1a);border:1px solid rgba(217,119,6,.3);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #d977061a}.warning-content:hover{transform:translateY(-2px);box-shadow:0 12px 35px #f59e0b40}[data-theme=dark] .warning-content:hover{box-shadow:0 12px 35px #d9770626}[data-theme=dark] .warning-text{color:#fbbf24}[data-theme=dark] .warning-text strong{color:#f59e0b}[data-theme=dark] .chat-container:before{background:transparent}[data-theme=dark] .message-content:hover{transform:translateY(-1px);box-shadow:0 8px 32px #0006,0 1px #ffffff26 inset}[data-theme=dark] .message.user .message-content:hover{box-shadow:0 8px 32px #10b98166,0 1px #ffffff40 inset}[data-theme=dark] .chat-messages::-webkit-scrollbar-track{background:#374151}[data-theme=dark] .message-content,[data-theme=dark] .message.assistant .message-content{background:linear-gradient(145deg,#374151e6,#1f2937cc);border:1px solid rgba(75,85,99,.4);color:#f9fafb;box-shadow:0 8px 32px #0000004d,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .message.user .message-content{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#059669;box-shadow:0 8px 32px #10b9814d,0 1px #fff3 inset}[data-theme=dark] .message.assistant .message-content:before{border-color:transparent rgba(55,65,81,.9) transparent transparent}[data-theme=dark] .message-time{color:#9ca3af}[data-theme=dark] .message.user .message-time{color:#fffc}[data-theme=dark] .chat-input-container{background:linear-gradient(145deg,#1f2937e6,#111827cc);border-top:1px solid rgba(75,85,99,.4);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=dark] .chat-input-form{background:linear-gradient(145deg,#374151cc,#1f2937e6);border:1px solid rgba(75,85,99,.4);box-shadow:0 8px 32px #0000004d,0 1px #ffffff1a inset}[data-theme=dark] .chat-input{background:transparent;border:none;color:#f9fafb;box-shadow:none}[data-theme=dark] .chat-input:focus{background:#37415180}[data-theme=dark] .chat-input-form:focus-within{border-color:#10b981;box-shadow:0 0 0 4px #10b9811a,0 12px 35px #0006;transform:translateY(-2px)}[data-theme=dark] .chat-input::placeholder{color:#9ca3af}[data-theme=dark] .suggestion-chip{background:linear-gradient(145deg,#374151cc,#1f2937e6);border:2px solid rgba(75,85,99,.4);color:#d1d5db;box-shadow:0 4px 16px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .suggestion-chip:hover{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#10b981;box-shadow:0 8px 25px #10b98166}[data-theme=dark] .typing-content{background:linear-gradient(145deg,#374151e6,#1f2937cc);border:1px solid rgba(75,85,99,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .typing-dot{background:#9ca3af}[data-theme=dark] .empty-description{color:#9ca3af}[data-theme=dark] .message.loading .message-content{background:linear-gradient(90deg,#37415180 25%,#4b5563b3,#37415180 75%);background-size:200% 100%;animation:shimmerDark 2s infinite}@keyframes shimmerDark{0%{background-position:-200% 0}to{background-position:200% 0}}@media (max-width: 768px){.assistant-warning{padding:16px}.warning-content{flex-direction:column;gap:8px;border-radius:16px;padding:14px 18px;align-items:flex-start;text-align:left}.warning-text{font-size:13px}.chat-messages{padding:12px}.message{max-width:85%}.message-avatar{width:32px;height:32px}.buddi-avatar{width:20px;height:20px}.chat-input-container{padding:12px}.chat-input{padding:14px 18px;font-size:14px}.chat-send-btn{width:48px;height:48px;font-size:16px}.chat-suggestions{justify-content:flex-start;gap:8px}.suggestion-chip{font-size:12px;padding:8px 12px}}.stats-container{padding:16px;max-width:1200px;margin:0 auto;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:100vh}.stats-hero{background:linear-gradient(135deg,#10b981,#059669);border-radius:20px;padding:24px;margin-bottom:20px;color:#fff;position:relative;overflow:hidden;box-shadow:0 8px 24px #10b9814d}.stats-hero:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.1'%3E%3Ccircle cx='30' cy='30' r='4'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") repeat;opacity:.3}.hero-content{position:relative;z-index:1;text-align:center}.hero-title{font-size:24px;font-weight:800;margin:0 0 8px;background:linear-gradient(45deg,#fff,#f0fdfa);background-clip:text;-webkit-background-clip:text;text-shadow:0 2px 4px rgba(0,0,0,.2)}.hero-message{font-size:16px;margin:0 0 16px;opacity:.95;font-weight:500}.hero-decoration{position:absolute;top:16px;right:16px;z-index:1}.celebration-emoji{font-size:28px;animation:bounce 2s infinite}.time-selector{display:flex;gap:8px;justify-content:center}.time-option{padding:8px 16px;border:2px solid rgba(255,255,255,.3);background:#ffffff1a;border-radius:12px;font-size:12px;font-weight:600;cursor:pointer;transition:all .3s ease;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.time-option:hover{border-color:#ffffff80;background:#fff3}.time-option.active{background:#ffffffe6;border-color:#ffffffe6;color:#059669}.stats-overview{display:flex;gap:12px;margin-bottom:20px;padding:0 4px}.stat-item{flex:1;background:#fff;border-radius:16px;padding:16px 12px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 16px #00000014;border:1px solid #f1f5f9;transition:all .3s ease}.stat-item:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.stat-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d}.stat-content{flex:1;min-width:0}.stat-value{font-size:20px;font-weight:800;color:#111827;line-height:1;margin-bottom:2px}.stat-label{font-size:11px;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.insights-section{background:#fff;border-radius:20px;padding:20px;box-shadow:0 4px 20px #00000014;border:1px solid #f1f5f9}.section-title{font-size:16px;font-weight:700;color:#111827;margin-bottom:16px;text-align:center}.chart-container{margin-bottom:24px}.chart-bars{display:flex;align-items:end;justify-content:space-around;height:120px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;padding:12px;gap:4px}.chart-bar-wrapper{display:flex;flex-direction:column;align-items:center;flex:1;max-width:60px}.chart-bar{width:100%;min-height:6px;background:linear-gradient(135deg,#10b981,#059669);border-radius:6px 6px 3px 3px;position:relative;transition:all .3s ease;box-shadow:0 2px 8px #10b9814d;display:flex;align-items:end;justify-content:center;padding-bottom:2px;animation:barGrowUp .8s ease-out}.chart-bar:hover{background:linear-gradient(135deg,#059669,#047857);transform:scaleY(1.05);box-shadow:0 4px 12px #10b98166}.bar-value{color:#fff;font-size:9px;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.3)}.bar-label{margin-top:8px;font-size:10px;color:#6b7280;font-weight:600;text-align:center}.badges-compact{border-top:1px solid #f1f5f9;padding-top:20px}.badges-row{display:flex;justify-content:space-around;gap:8px;flex-wrap:wrap}.badge-compact{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;transition:all .3s ease;cursor:pointer;position:relative}.badge-compact.unlocked{background:linear-gradient(135deg,#fef3c7,#fcd34d);border:2px solid #f59e0b;box-shadow:0 4px 12px #f59e0b4d;animation:badgeGlow 2s ease-in-out infinite alternate}.badge-compact.locked{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e5e7eb;opacity:.4;filter:grayscale(100%)}.badge-compact:hover{transform:translateY(-2px) scale(1.1)}.badge-compact.unlocked:hover{box-shadow:0 6px 16px #f59e0b66}.badge-item{display:flex;flex-direction:column;align-items:center;padding:24px;border-radius:20px;text-align:center;transition:all .3s ease;position:relative;overflow:hidden}.badge-item.unlocked{background:linear-gradient(135deg,#fef3c7,#fcd34d);border:2px solid #f59e0b;box-shadow:0 8px 25px #f59e0b4d;animation:badgeGlow 2s ease-in-out infinite alternate}.badge-item.locked{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #e5e7eb;opacity:.6}.badge-item:hover{transform:translateY(-4px) scale(1.05)}.badge-item.unlocked:hover{box-shadow:0 12px 35px #f59e0b66}.badge-icon-large{font-size:48px;margin-bottom:12px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.badge-item.locked .badge-icon-large{filter:grayscale(100%) opacity(.5)}.badge-name{font-size:14px;font-weight:700;color:#111827;margin-bottom:4px}.badge-item.locked .badge-name{color:#9ca3af}.badge-desc{font-size:12px;color:#6b7280;line-height:1.3}.badge-item.locked .badge-desc{color:#d1d5db}.motivation-footer{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:24px;padding:32px;text-align:center;color:#fff;position:relative;overflow:hidden;box-shadow:0 8px 32px #6366f14d}.motivation-footer:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.1'%3E%3Cpath d='M20 20c0 11.046-8.954 20-20 20v20h40V20H20z'/%3E%3C/g%3E%3C/svg%3E") repeat;opacity:.1}.motivation-quote{font-size:18px;font-style:italic;line-height:1.6;position:relative;z-index:1}.quote-author{display:block;margin-top:12px;font-size:14px;opacity:.9;font-weight:600}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glow{0%{box-shadow:0 8px 20px #10b9814d}to{box-shadow:0 8px 30px #10b98199}}@keyframes flicker{0%{transform:scale(1);opacity:1}to{transform:scale(1.1);opacity:.8}}@keyframes twinkle{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}}@keyframes badgeGlow{0%{box-shadow:0 8px 25px #f59e0b4d}to{box-shadow:0 8px 35px #f59e0b80}}[data-theme=dark] .stats-container{background:linear-gradient(135deg,#1a202c,#2d3748);color:#f9fafb}[data-theme=dark] .stats-hero{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 20px 50px #05966966}[data-theme=dark] .hero-title{background:linear-gradient(45deg,#fff,#f0fdfa);background-clip:text;-webkit-background-clip:text}[data-theme=dark] .achievement-card{background:linear-gradient(145deg,#374151e6,#1f2937cc);border:1px solid rgba(75,85,99,.4);box-shadow:0 8px 32px #0000004d,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .achievement-card:hover{box-shadow:0 20px 60px #0006,0 1px #ffffff26 inset}[data-theme=dark] .achievement-title{color:#f9fafb}[data-theme=dark] .achievement-label{color:#9ca3af}[data-theme=dark] .stats-overview .stat-item{background:linear-gradient(145deg,#374151e6,#1f2937cc);border:1px solid rgba(75,85,99,.4);box-shadow:0 4px 16px #0000004d,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .stat-value{color:#f9fafb}[data-theme=dark] .stat-label{color:#9ca3af}[data-theme=dark] .bar-value{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.7)}[data-theme=dark] .chart-bar{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b98166;border:1px solid rgba(255,255,255,.05)}[data-theme=dark] .stat-icon{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b98166;border:1px solid rgba(255,255,255,.1)}[data-theme=dark] .stat-item:hover{box-shadow:0 8px 24px #0006,0 1px #ffffff26 inset;background:linear-gradient(145deg,#374151,#1f2937e6)}[data-theme=dark] .badge-compact.unlocked{animation:darkBadgeGlow 2s ease-in-out infinite alternate}@keyframes darkBadgeGlow{0%{box-shadow:0 4px 12px #f59e0b66}to{box-shadow:0 6px 20px #f59e0b99}}[data-theme=dark] .chart-container{position:relative}[data-theme=dark] .chart-container:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent,rgba(16,185,129,.03),transparent);border-radius:12px;pointer-events:none}[data-theme=dark] .badge-compact[title]:hover:after{content:attr(title);position:absolute;bottom:-40px;left:50%;transform:translate(-50%);background:#000000e6;color:#fff;padding:6px 10px;border-radius:6px;font-size:11px;font-weight:500;white-space:nowrap;z-index:1000;border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 12px #0000004d}[data-theme=dark] .insights-section:before{content:"";position:absolute;top:-1px;left:20px;right:20px;height:1px;background:linear-gradient(90deg,transparent,rgba(16,185,129,.3),transparent)}[data-theme=dark] .time-option{background:linear-gradient(145deg,#374151cc,#1f2937e6);border:2px solid rgba(75,85,99,.4);color:#d1d5db;box-shadow:0 4px 16px #0003}[data-theme=dark] .time-option:hover{border-color:#10b981;background:linear-gradient(145deg,#10b9811a,#0596691a);box-shadow:0 8px 20px #10b98133}[data-theme=dark] .time-option.active{background:linear-gradient(135deg,#10b981,#059669);border-color:#059669;color:#fff}[data-theme=dark] .insights-section{background:linear-gradient(145deg,#374151e6,#1f2937cc);border:1px solid rgba(75,85,99,.4);box-shadow:0 4px 20px #0006,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .chart-bars{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(55,65,81,.5)}[data-theme=dark] .bar-label{color:#9ca3af}[data-theme=dark] .chart-bar:hover{background:linear-gradient(135deg,#059669,#10b981);box-shadow:0 4px 16px #10b98180}[data-theme=dark] .badges-compact{border-top:1px solid rgba(75,85,99,.4)}[data-theme=dark] .badge-compact.unlocked{background:linear-gradient(135deg,#fef3c7e6,#fcd34dcc);border:2px solid #f59e0b;box-shadow:0 4px 12px #f59e0b66}[data-theme=dark] .badge-compact.unlocked:hover{box-shadow:0 6px 16px #f59e0b80;background:linear-gradient(135deg,#fef3c7,#fcd34de6)}[data-theme=dark] .badge-compact.locked{background:linear-gradient(145deg,#37415199,#1f2937b3);border:2px solid rgba(75,85,99,.5);opacity:.3}[data-theme=dark] .badge-compact.locked:hover{background:linear-gradient(145deg,#374151b3,#1f2937cc);opacity:.4}[data-theme=dark] .motivation-footer{background:linear-gradient(135deg,#6366f1e6,#8b5cf6cc);box-shadow:0 8px 32px #6366f166}*{transition:transform .2s ease,box-shadow .2s ease}.stats-container::-webkit-scrollbar{width:6px}.stats-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.stats-container::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#10b981,#059669);border-radius:3px}[data-theme=dark] .stats-container::-webkit-scrollbar-track{background:#374151}.badge-item.unlocked:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity .3s ease}.badge-item.unlocked:hover:before{opacity:1}.chart-bar{animation:barGrowUp .8s ease-out}@keyframes barGrowUp{0%{height:0;opacity:0}to{opacity:1}}.chart-bar-wrapper:nth-child(1) .chart-bar{animation-delay:.1s}.chart-bar-wrapper:nth-child(2) .chart-bar{animation-delay:.2s}.chart-bar-wrapper:nth-child(3) .chart-bar{animation-delay:.3s}.chart-bar-wrapper:nth-child(4) .chart-bar{animation-delay:.4s}.chart-bar-wrapper:nth-child(5) .chart-bar{animation-delay:.5s}.chart-bar-wrapper:nth-child(6) .chart-bar{animation-delay:.6s}.chart-bar-wrapper:nth-child(7) .chart-bar{animation-delay:.7s}@media (max-width: 768px){.stats-container{padding:12px}.stats-hero{padding:20px;margin-bottom:16px}.hero-title{font-size:20px}.hero-message{font-size:14px;margin-bottom:12px}.celebration-emoji{font-size:24px;top:12px;right:12px}.stats-overview{flex-direction:column;gap:8px}.stat-item{padding:12px}.stat-icon{width:36px;height:36px;font-size:16px}.stat-value{font-size:18px}.insights-section{padding:16px}.section-title{font-size:14px;margin-bottom:12px}.chart-bars{height:100px;padding:8px}.bar-value{font-size:8px}.bar-label{font-size:9px;margin-top:6px}.badges-compact{padding-top:16px}.badge-compact{width:36px;height:36px;font-size:16px}.time-option{padding:6px 12px;font-size:11px}}@media (max-width: 480px){.stats-container{padding:8px}.stats-hero{padding:16px}.hero-title{font-size:18px}.hero-message{font-size:13px}.stat-item{padding:10px}.stat-value{font-size:16px}.stat-label{font-size:10px}.insights-section{padding:12px}.badge-compact{width:32px;height:32px;font-size:14px}.badges-row{gap:6px}}.password-popup-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.password-popup{background:#fff;border-radius:14px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 6px 18px #02161f0a;border:1px solid #e2e8f0;animation:slideUp .3s cubic-bezier(.4,0,.2,1);margin:20px}.popup-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 0;border-bottom:1px solid #f1f5f9;margin-bottom:24px}.popup-title{font-size:20px;font-weight:700;color:#0f172a;margin:0;display:flex;align-items:center;gap:12px}.popup-icon{font-size:24px}.popup-close{width:36px;height:36px;border:none;background:#f1f5f9;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;color:#64748b;transition:all .2s ease}.popup-close:hover{background:#e2e8f0;color:#475569;transform:scale(1.05)}.popup-close:disabled{opacity:.5;cursor:not-allowed;transform:none}.popup-form{padding:0 24px}.form-group{margin-bottom:20px}.form-label{display:block;font-weight:600;color:#1e293b;margin-bottom:8px;font-size:14px}.password-input-wrapper{position:relative;display:flex;align-items:center}.form-input{width:100%;padding:12px 48px 12px 16px;border:1px solid #e2e8f0;border-radius:12px;font-size:16px;transition:all .2s ease;background:#fff;color:#0f172a;box-sizing:border-box;box-shadow:0 1px 3px #0000001a}.form-input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.form-input.error{border-color:#ef4444}.form-input.error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;color:#64748b;font-size:16px;transition:all .2s ease;z-index:1}.password-toggle:hover{color:#374151;transform:translateY(-50%) scale(1.1)}.password-toggle:disabled{opacity:.5;cursor:not-allowed;transform:translateY(-50%) scale(1)}.validation-check{position:absolute;right:48px;top:50%;transform:translateY(-50%);color:#10b981;font-weight:700}.password-strength{margin-top:8px;display:flex;align-items:center;gap:12px}.strength-bar{flex:1;height:4px;background:#e5e7eb;border-radius:2px;overflow:hidden}.strength-fill{height:100%;transition:all .3s ease;border-radius:2px}.strength-text{font-size:12px;font-weight:600;min-width:60px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#6b7280}.checkbox-label input[type=checkbox]{width:16px;height:16px;border-radius:4px;border:2px solid #d1d5db;background:#fff;cursor:pointer}.checkbox-label input[type=checkbox]:checked{background:#3b82f6;border-color:#3b82f6}.checkbox-text{-webkit-user-select:none;user-select:none}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;font-size:14px;display:flex;align-items:center;gap:8px;margin-bottom:20px}.error-icon{font-size:16px}.popup-actions{display:flex;gap:16px;padding:24px 0 0;margin-top:20px}.btn-secondary{flex:1;padding:16px 32px;border:1px solid #cbd5e1;background:none;color:#475569;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:14px}.btn-secondary:hover:not(:disabled){border-color:#94a3b8;color:#374151;transform:translateY(-1px)}.btn-primary{flex:2;padding:16px 32px;border:1px solid #10b981;background:none;color:#10b981;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:14px;display:flex;align-items:center;justify-content:center;gap:8px}.btn-primary:hover:not(:disabled){color:#059669;border-color:#059669;transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.password-tips{padding:12px 24px 14px;background:#f8fafc;border-top:1px solid #f1f5f9;margin-top:16px}.password-tips h4{margin:0 0 4px;font-size:11px;font-weight:600;color:#475569;text-align:center}.password-tips ul{margin:0;padding:0;list-style:none;color:#64748b;font-size:10px;line-height:1.2;text-align:center}.password-tips li{margin-bottom:1px}[data-theme=dark] .password-popup{background:linear-gradient(145deg,#1f2937,#1a202c);border:1px solid rgba(75,85,99,.3);box-shadow:0 8px 32px #0000004d,0 1px #ffffff0d inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .popup-title{color:#f9fafb}[data-theme=dark] .popup-close{background:#374151;color:#9ca3af}[data-theme=dark] .popup-close:hover{background:#4b5563;color:#f3f4f6}[data-theme=dark] .form-label{color:#e5e7eb}[data-theme=dark] .form-input{background:#374151;border-color:#4b5563;color:#f9fafb;box-shadow:inset 0 1px 3px #0003}[data-theme=dark] .form-input:focus{border-color:#34d399;box-shadow:0 0 0 3px #34d3991a}[data-theme=dark] .form-input::placeholder{color:#9ca3af}[data-theme=dark] .strength-bar{background:#4b5563}[data-theme=dark] .checkbox-label{color:#d1d5db}[data-theme=dark] .checkbox-label input[type=checkbox]{background:#374151;border-color:#6b7280}[data-theme=dark] .error-message{background:#dc26261a;border-color:#dc26264d;color:#fca5a5}[data-theme=dark] .popup-header{border-bottom-color:#374151}[data-theme=dark] .popup-actions{border-top-color:#374151}[data-theme=dark] .password-toggle{color:#9ca3af}[data-theme=dark] .password-toggle:hover{color:#d1d5db}[data-theme=dark] .btn-secondary{background:none;border-color:#4b5563;color:#e5e7eb}[data-theme=dark] .btn-secondary:hover:not(:disabled){border-color:#6b7280;color:#f3f4f6}[data-theme=dark] .btn-primary{background:none;border-color:#34d399;color:#34d399}[data-theme=dark] .btn-primary:hover:not(:disabled){border-color:#6ee7b7;color:#6ee7b7}[data-theme=dark] .password-tips{background:#111827;border-top-color:#374151}[data-theme=dark] .password-tips h4{color:#d1d5db}[data-theme=dark] .password-tips ul{color:#9ca3af}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 640px){.password-popup{margin:10px;max-height:95vh}.popup-actions{flex-direction:column}.btn-primary{flex:none}}.account-container{padding:24px;max-width:900px;margin:0 auto;min-height:100vh}.account-header{text-align:center;margin-bottom:40px}.account-title{font-size:32px;font-weight:800;color:#0f172a;margin-bottom:8px;background:linear-gradient(135deg,#10b981,#059669);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.account-subtitle{font-size:16px;color:#64748b;margin:0}.success-message{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:1px solid #10b981;color:#065f46;padding:16px 20px;border-radius:14px;font-weight:600;display:flex;align-items:center;gap:12px;margin-bottom:24px;animation:slideDown .3s ease-out;box-shadow:0 6px 18px #02161f0a}.success-icon{font-size:18px}.account-tabs{display:flex;background:#fff;border-radius:14px;padding:8px;margin-bottom:32px;box-shadow:0 6px 18px #02161f0a;border:1px solid #e5e7eb;gap:4px}.account-tab{flex:1;display:flex;align-items:center;justify-content:center;padding:16px 20px;border:none;background:transparent;color:#64748b;font-weight:600;font-size:14px;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.account-tab:hover{color:#374151;background:#f1f5f9}.account-tab.active{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 6px 18px #10b98140;transform:translateY(-1px)}.account-content{display:flex;flex-direction:column;gap:24px}.account-section{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:24px;box-shadow:0 6px 18px #02161f0a;transition:all .3s ease}.account-section:hover{box-shadow:0 8px 32px #02161f14;transform:translateY(-1px)}.section-title{font-size:18px;font-weight:700;color:#0f172a;margin-bottom:20px;display:flex;align-items:center;gap:12px}.section-icon{font-size:24px}.profile-info{margin-top:8px}.profile-avatar{display:flex;align-items:center;gap:20px}.avatar-circle{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:800;color:#fff;box-shadow:0 6px 18px #10b98140}.avatar-info{flex:1}.user-name{margin:0 0 4px;font-size:24px;font-weight:700;color:#0f172a}.user-email{margin:0 0 8px;font-size:16px;color:#64748b}.join-date{margin:0;font-size:14px;color:#94a3b8}.security-options{display:flex;flex-direction:column;gap:16px}.security-item{display:flex;justify-content:space-between;align-items:center;padding:20px;border:1px solid #f1f5f9;border-radius:14px;transition:all .2s ease;background:#fafafa}.security-item:hover{border-color:#e2e8f0;background:#f8fafc;box-shadow:0 2px 8px #02161f0a}.security-info h4{margin:0 0 4px;font-size:16px;font-weight:600;color:#1e293b}.security-info p{margin:0;font-size:14px;color:#64748b}.preference-group{display:flex;flex-direction:column;gap:20px}.preference-item{display:flex;flex-direction:column;gap:8px}.preference-label{display:flex;flex-direction:column;gap:8px;font-weight:600;color:#1e293b;font-size:14px}.preference-select{padding:12px 16px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;color:#0f172a;font-size:14px;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.preference-select:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.preference-description{margin:4px 0 0;font-size:13px;color:#64748b;font-weight:400}.account-container .toggle-label{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:600;color:#1e293b;font-size:14px;-webkit-user-select:none;user-select:none}.account-container .toggle-label input[type=checkbox]{display:none!important;visibility:hidden}.account-container .toggle-slider{width:48px;height:28px;background:#cbd5e1;border-radius:14px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;cursor:pointer;box-shadow:inset 0 2px 4px #0000000f}.account-container .toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:24px;height:24px;background:#fff;border-radius:50%;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #00000026}.account-container .toggle-label:hover .toggle-slider{background:#94a3b8}.account-container .toggle-label input[type=checkbox]:checked+.toggle-slider{background:#10b981!important;box-shadow:0 6px 18px #10b98140}.account-container .toggle-label:hover input[type=checkbox]:checked+.toggle-slider{background:#059669!important}.account-container .toggle-label input[type=checkbox]:checked+.toggle-slider:before{transform:translate(20px)}.theme-selection h4{margin:0 0 20px;font-size:16px;font-weight:600;color:#374151}.theme-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px}.theme-option{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;border:2px solid #e5e7eb;border-radius:16px;cursor:pointer;transition:all .3s ease;text-align:center}.theme-option:hover{border-color:#10b981;box-shadow:0 4px 12px #10b98126;transform:translateY(-2px)}.theme-option.active{border-color:#10b981;background:linear-gradient(135deg,#10b98114,#0596690d);box-shadow:0 8px 24px #10b98133}.theme-option input[type=radio]{display:none}.theme-preview{width:60px;height:40px;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb;display:flex;flex-direction:column}.preview-header{height:12px;width:100%}.preview-content{flex:1;width:100%}.light-preview .preview-header{background:#f3f4f6}.light-preview .preview-content{background:#fff}.dark-preview .preview-header{background:#374151}.dark-preview .preview-content{background:#1f2937}.auto-preview .preview-header{background:linear-gradient(90deg,#f3f4f6 50%,#374151 50%)}.auto-preview .preview-content{background:linear-gradient(90deg,#fff 50%,#1f2937 50%)}.theme-name{font-size:13px;font-weight:600;color:#374151}.btn-outline{padding:10px 20px;border:1px solid #10b981;background:transparent;color:#10b981;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:14px}.btn-outline:hover{background:#10b981;color:#fff;transform:translateY(-1px);box-shadow:0 6px 18px #10b98140}.btn-danger{padding:12px 24px;border:1px solid #ef4444;background:#ef4444;color:#fff;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:14px;box-shadow:0 2px 8px #ef444426}.btn-danger:hover{background:#dc2626;border-color:#dc2626;transform:translateY(-1px);box-shadow:0 6px 18px #ef444440}.danger-zone{border-color:#fecaca;background:linear-gradient(135deg,#fef2f2,#fff)}.danger-actions{display:flex;justify-content:flex-start}.accessibility-note{padding:20px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:12px;color:#0369a1;font-size:14px;line-height:1.6;margin:0}[data-theme=dark] .account-title{color:#f9fafb;background:linear-gradient(135deg,#34d399,#10b981);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}[data-theme=dark] .account-subtitle{color:#cbd5e1}[data-theme=dark] .success-message{background:linear-gradient(135deg,#10b98133,#0596691a);border-color:#10b98166;color:#6ee7b7}[data-theme=dark] .account-tabs{background:#1f2937;border-color:#374151}[data-theme=dark] .account-tab{color:#9ca3af}[data-theme=dark] .account-tab:hover{color:#f3f4f6;background:#374151}[data-theme=dark] .account-tab.active{background:linear-gradient(135deg,#10b981,#059669);color:#fff}[data-theme=dark] .account-section{background:#1f2937;border-color:#374151}[data-theme=dark] .section-title,[data-theme=dark] .user-name{color:#f9fafb}[data-theme=dark] .user-email{color:#d1d5db}[data-theme=dark] .join-date{color:#9ca3af}[data-theme=dark] .security-item{border-color:#374151;background:transparent}[data-theme=dark] .security-item:hover{border-color:#4b5563;background:#111827}[data-theme=dark] .security-info h4{color:#f3f4f6}[data-theme=dark] .security-info p{color:#d1d5db}[data-theme=dark] .preference-label{color:#f3f4f6}[data-theme=dark] .preference-select{background:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=dark] .preference-select:focus{border-color:#34d399;box-shadow:0 0 0 3px #34d3991a}[data-theme=dark] .preference-description{color:#9ca3af}[data-theme=dark] .account-container .toggle-label{color:#f3f4f6}[data-theme=dark] .account-container .toggle-slider{background:#4b5563!important}[data-theme=dark] .account-container .toggle-label:hover .toggle-slider{background:#6b7280!important}[data-theme=dark] .account-container .toggle-label input[type=checkbox]:checked+.toggle-slider{background:#10b981!important}[data-theme=dark] .account-container .toggle-label:hover input[type=checkbox]:checked+.toggle-slider{background:#059669!important}[data-theme=dark] .theme-selection h4{color:#f3f4f6}[data-theme=dark] .theme-option{border-color:#4b5563;background:transparent}[data-theme=dark] .theme-option:hover{border-color:#34d399;box-shadow:0 4px 12px #34d39926}[data-theme=dark] .theme-option.active{border-color:#34d399;background:linear-gradient(135deg,#34d3991a,#10b9810d);box-shadow:0 8px 24px #34d39933}[data-theme=dark] .theme-preview{border-color:#4b5563}[data-theme=dark] .theme-name{color:#f3f4f6}[data-theme=dark] .btn-outline{border-color:#34d399;color:#34d399}[data-theme=dark] .btn-outline:hover{background:#34d399;color:#111827}[data-theme=dark] .danger-zone{border-color:#ef44444d;background:linear-gradient(135deg,#ef44440d,#1f2937cc)}[data-theme=dark] .accessibility-note{background:linear-gradient(135deg,#10b9811a,#0596690d);border-color:#10b9814d;color:#6ee7b7}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.account-container{padding:16px}.account-title{font-size:28px}.account-tabs{flex-direction:column;gap:0}.account-tab{justify-content:flex-start;padding:12px 16px}.profile-avatar{flex-direction:column;text-align:center;gap:16px}.security-item{flex-direction:column;align-items:flex-start;gap:12px}.theme-options{grid-template-columns:1fr}.danger-actions,.btn-danger{width:100%}}@media (max-width: 480px){.account-section{padding:20px}.section-title{font-size:18px}}.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);display:flex;align-items:center;justify-content:center;color:#fff;font-size:32px;font-weight:700;position:relative;overflow:hidden}.avatar-upload-btn{position:absolute;bottom:0;right:0;width:24px;height:24px;border-radius:50%;background:#374151;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px}.profile-info h3{font-size:20px;font-weight:600;color:#111827;margin-bottom:4px}.profile-info p{font-size:14px;color:#6b7280;margin:0}.profile-fields{display:flex;flex-direction:column;gap:16px}.field-group{display:flex;flex-direction:column;gap:6px}.field-label{font-size:14px;font-weight:500;color:#374151}.field-input{padding:12px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease}.field-input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.settings-list{display:flex;flex-direction:column;gap:16px}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:16px;border:1px solid #e5e7eb;border-radius:12px;background:#fafafa;transition:all .2s ease}.setting-item:hover{background:#f5f5f5;border-color:#d1d5db}.setting-info{flex:1}.setting-title{font-size:14px;font-weight:500;color:#374151;margin-bottom:2px}.setting-description{font-size:12px;color:#6b7280}.setting-control{flex-shrink:0}.toggle-switch{position:relative;width:48px;height:28px;background:#e5e7eb;border-radius:14px;cursor:pointer;transition:background-color .2s ease}.toggle-switch.active{background:#10b981}.toggle-slider{position:absolute;top:2px;left:2px;width:24px;height:24px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 3px #0003}.toggle-switch.active .toggle-slider{transform:translate(20px)}.theme-selector{display:flex;gap:8px}.theme-option{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;background:#fff}.theme-option:hover{border-color:#10b981;background:#f0fdfa}.theme-option.active{background:#10b981;border-color:#10b981;color:#fff}.action-buttons{display:flex;flex-direction:column;gap:12px}.action-btn{padding:12px 16px;border-radius:8px;font-weight:500;font-size:14px;cursor:pointer;transition:all .2s ease;border:none;display:flex;align-items:center;gap:8px}.btn-primary{background:#10b981;color:#fff}.btn-primary:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b98140}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover{background:#e5e7eb;border-color:#9ca3af}.btn-danger{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.btn-danger:hover{background:#fecaca;border-color:#f87171}.stats-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px;margin-top:16px}.stat-item{text-align:center;padding:16px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.stat-value{font-size:24px;font-weight:700;color:#10b981;margin-bottom:4px}.stat-label{font-size:12px;font-weight:500;color:#64748b}@media (max-width: 768px){.account-container{padding:16px}.account-section{padding:20px}.profile-avatar-container{flex-direction:column;text-align:center;gap:12px}.setting-item{flex-direction:column;align-items:flex-start;gap:12px}.setting-control{align-self:flex-end}.stats-summary{grid-template-columns:repeat(2,1fr);gap:12px}}#root{max-width:100%;margin:0 auto;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px;box-shadow:0 6px 18px #02161f0a}.grid{display:grid;gap:14px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.muted{color:#6b7280;font-size:12px}.section-title{font-size:16px;font-weight:700;color:#0f172a;margin-bottom:12px}.section-header{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.swipe-key{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#6b7280;font-weight:500;padding:8px 12px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.key-item{display:flex;align-items:center;gap:4px}[data-theme=dark] .swipe-key{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(75,85,99,.4);color:#9ca3af;box-shadow:0 4px 16px #0000004d,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@media (prefers-color-scheme: dark){[data-theme=auto] .swipe-key{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(75,85,99,.4);color:#9ca3af;box-shadow:0 4px 16px #0000004d,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}@media (max-width: 640px){.swipe-key{flex-direction:column;gap:4px;text-align:center}}.task{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #f3f4f6}.task:last-child{border-bottom:none}.meta{font-size:12px;color:#6b7280;margin-top:2px}.h-scroll{display:flex;gap:8px;padding:4px;overflow-x:auto;scroll-snap-type:x proximity}.pill{scroll-snap-align:start;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 10px;border-radius:999px;background:#f3f7fb;border:1px solid #e6eef5;font-size:12px;color:#0f172a;cursor:pointer}.pill.active{border-color:#8ad0ee;box-shadow:0 0 0 2px #6ac0ea40}.tabbar{position:sticky;bottom:0;z-index:10;display:grid;grid-template-columns:repeat(3,1fr);background:#fff;border-top:1px solid #e5e7eb;box-shadow:0 -4px 20px #00000014}.tabbar .tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:20px 12px;font-size:16px;color:#64748b;text-decoration:none;font-weight:600;letter-spacing:.5px;transition:all .3s ease;position:relative}.tabbar .tab:hover{color:#374151;transform:translateY(-1px)}.tabbar .tab.active{color:#10b981;font-weight:700;text-shadow:0 1px 2px rgba(16,185,129,.2)}.tabbar .tab.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:40px;height:3px;background:linear-gradient(90deg,#10b981,#34d399);border-radius:0 0 2px 2px}.fab{position:fixed;right:20px;bottom:80px;width:56px;height:56px;border-radius:50%;background-color:#10b981;border:none;color:#fff;font-size:24px;cursor:pointer;box-shadow:0 4px 12px #00000026;transition:all .2s ease;z-index:100}.fab:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003;background-color:#059669}.tile{position:relative;border-radius:16px;padding:14px;background:linear-gradient(180deg,#ffffffeb,#ffffffdb);border:1px solid rgba(255,255,255,.9);box-shadow:0 10px 24px #0000000f,0 1px #ffffffe6 inset}.tile.mint{background:#e9fbf3;border-color:#d6f7ea}.tile.dark{color:#fff;background:#111;border-color:#111;box-shadow:none}.daybar{display:grid;gap:6px}.monthbar{display:flex;justify-content:space-between;align-items:center;padding:2px 4px;position:sticky;top:0;z-index:2}.monthbar strong{font-size:14px}.monthbar .jumper select{appearance:auto;font-size:12px;padding:6px 8px;border-radius:10px;border:1px solid #e6eef5;background:#fff;margin-left:6px}.daystrip{scroll-snap-type:x proximity;padding-bottom:6px;cursor:grab;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.daystrip::-webkit-scrollbar{display:none}.daystrip{scrollbar-width:none}.daystrip.dragging,.daystrip:active{cursor:grabbing}.daystrip .day{scroll-snap-align:center;min-width:60px}.side-menu{transition:right .3s ease}.side-menu-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.side-menu-item:hover{background-color:#f9fafb;border-radius:4px;margin:0 -8px;padding-left:8px!important;padding-right:8px!important}.hamburger-btn:hover{background-color:#f3f4f6!important;border-radius:4px}[data-theme=dark] .hamburger-btn:hover{background:linear-gradient(145deg,#374151e6,#1f2937cc)!important;box-shadow:0 2px 8px #0000004d!important;border:1px solid rgba(75,85,99,.4)!important;border-radius:8px!important}@media (max-width: 480px){.side-menu{width:280px!important;right:-280px!important}.side-menu.open{right:0!important}}.tab-buttons{display:flex;gap:8px;margin-bottom:16px}[data-theme=dark]{color-scheme:dark}[data-theme=dark] body{background-color:#1a202c;color:#f9fafb}[data-theme=dark] .card{background:linear-gradient(145deg,#1f2937,#1a202c);border:1px solid rgba(75,85,99,.3);color:#f9fafb;box-shadow:0 8px 32px #0000004d,0 1px #ffffff0d inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .field{background-color:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=dark] .btn{background-color:#10b981;color:#fff}[data-theme=dark] .side-menu{background-color:#1f2937!important;color:#f9fafb}[data-theme=dark] .side-menu-item{color:#d1d5db!important}[data-theme=dark] .side-menu-item:hover{background-color:#374151!important}[data-theme=dark] .app-header{background:#252e3a!important;border-bottom:1px solid #374151;-webkit-backdrop-filter:none;backdrop-filter:none}[data-theme=dark] .tabbar{background-color:#252e3a;border-top:1px solid #374151;box-shadow:0 -4px 20px #00000040}[data-theme=dark] .tab{color:#9ca3af}[data-theme=dark] .tab:hover{color:#d1d5db}[data-theme=dark] .tab.active{color:#34d399;text-shadow:0 1px 2px rgba(52,211,153,.3)}[data-theme=dark] .tab.active:before{background:linear-gradient(90deg,#34d399,#6ee7b7)}[data-theme=dark] .tile{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(75,85,99,.3);box-shadow:0 8px 32px #0006,0 1px #ffffff1a inset,0 0 0 1px #ffffff0d inset;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#f9fafb;transition:all .3s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .tile:hover{transform:translateY(-2px);box-shadow:0 12px 40px #00000080,0 1px #ffffff26 inset,0 0 0 1px #10b98133 inset;border-color:#10b98166}[data-theme=dark] .tile.mint{background:linear-gradient(145deg,#10b98126,#0596691a);border-color:#10b9814d;box-shadow:0 8px 32px #10b9811a,0 1px #10b98133 inset}[data-theme=dark] .tile.mint:hover{border-color:#10b98180;box-shadow:0 12px 40px #10b98133,0 1px #10b9814d inset}[data-theme=dark] .tile-k{color:#9ca3af}[data-theme=dark] .tile-v{color:#f9fafb}[data-theme=dark] .pill{background:linear-gradient(145deg,#374151cc,#1f293799);border:1px solid rgba(75,85,99,.4);color:#d1d5db;box-shadow:0 2px 8px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .pill:hover{background:linear-gradient(145deg,#4b5563e6,#374151b3);border-color:#10b98166;transform:translateY(-1px)}[data-theme=dark] .pill.active{background:linear-gradient(145deg,#10b981,#059669);border-color:#059669;color:#fff;box-shadow:0 4px 12px #10b9814d}[data-theme=dark] .day-chip{background:linear-gradient(145deg,#374151cc,#1f2937e6);border:1px solid rgba(75,85,99,.4);color:#d1d5db;box-shadow:0 4px 16px #0000004d,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .day-chip:hover{background:linear-gradient(145deg,#4b5563e6,#374151cc);border-color:#10b98166;transform:translateY(-2px);box-shadow:0 6px 20px #0006,0 1px #ffffff26 inset}[data-theme=dark] .day-chip.selected{background:linear-gradient(145deg,#10b981,#059669);border-color:#059669;color:#fff;transform:translateY(-2px) scale(1.02);box-shadow:0 8px 25px #10b98166,0 1px #fff3 inset}[data-theme=dark] .day-chip .dow,[data-theme=dark] .day-chip .daynum{color:#fff}[data-theme=dark] .month-input{background:linear-gradient(145deg,#374151cc,#1f2937e6);border:1px solid rgba(75,85,99,.4);color:#f9fafb;box-shadow:0 2px 8px #0003 inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .month-input:focus{border-color:#10b98180;box-shadow:0 0 0 3px #10b9811a,0 2px 8px #0003 inset}[data-theme=dark] .week-label{color:#9ca3af;font-weight:500}[data-theme=dark] .arrow-btn{background:linear-gradient(145deg,#374151cc,#1f2937e6);color:#f9fafb;border:1px solid rgba(75,85,99,.4);box-shadow:0 2px 8px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .2s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .arrow-btn:hover{background:linear-gradient(145deg,#4b5563e6,#374151cc);border-color:#10b98166;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}[data-theme=dark] .arrow-btn.mint{background:linear-gradient(145deg,#10b981,#059669);color:#fff;border-color:#059669;box-shadow:0 4px 12px #10b9814d}[data-theme=dark] .arrow-btn.mint:hover{background:linear-gradient(145deg,#059669,#047857);border-color:#047857;transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}[data-theme=dark] .section-title{color:#f9fafb}[data-theme=dark] .task{background:linear-gradient(145deg,#2d374899,#1a202ccc);border:1px solid rgba(75,85,99,.3);border-radius:12px;margin-bottom:8px;padding:14px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 16px #0003;transition:all .2s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .task:hover{background:linear-gradient(145deg,#374151b3,#1f2937e6);border-color:#10b9814d;transform:translateY(-1px);box-shadow:0 6px 20px #0000004d}[data-theme=dark] .meta,[data-theme=dark] .empty{color:#9ca3af}[data-theme=dark] .empty-title{color:#f9fafb}[data-theme=dark] .time-badge{background:linear-gradient(145deg,#10b98133,#0596691a);border:1px solid rgba(16,185,129,.3);color:#10b981;box-shadow:0 2px 8px #10b9811a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-weight:600}[data-theme=dark] .monthbar{background:#111827cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:12px;margin-bottom:8px;padding:8px 12px;border:1px solid rgba(75,85,99,.2)}[data-theme=dark] .monthbar strong{color:#f9fafb;font-weight:600}[data-theme=dark] .monthbar .jumper select{background:linear-gradient(145deg,#374151cc,#1f2937e6);border:1px solid rgba(75,85,99,.4);color:#f9fafb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px}[data-theme=dark] .daystrip{background:#1118274d;border-radius:12px;padding:8px 4px 12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .modal-overlay{background:#000000b3}[data-theme=dark] .skeleton{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(75,85,99,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=dark] .skeleton:after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}[data-theme=dark] .item-type-badge{background:#10b98133;border-color:#10b9814d;color:#10b981}[data-theme=dark] .item-type-badge[data-type=habit]{background:#8b5cf633;border-color:#8b5cf64d;color:#a78bfa}[data-theme=dark] .frequency-badge{background:#0ea5e933;color:#38bdf8}@media (prefers-color-scheme: dark){[data-theme=auto]{color-scheme:dark}[data-theme=auto] body{background-color:#1a202c;color:#f9fafb}[data-theme=auto] .card{background:linear-gradient(145deg,#1f2937,#1a202c);border:1px solid rgba(75,85,99,.3);color:#f9fafb;box-shadow:0 8px 32px #0000004d,0 1px #ffffff0d inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .field{background-color:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=auto] .btn{background-color:#10b981;color:#fff}[data-theme=auto] .side-menu{background-color:#1f2937!important;color:#f9fafb}[data-theme=auto] .side-menu-item{color:#d1d5db!important}[data-theme=auto] .side-menu-item:hover{background-color:#374151!important}[data-theme=auto] .app-header{background:#252e3a!important;border-bottom:1px solid #374151;-webkit-backdrop-filter:none;backdrop-filter:none}[data-theme=auto] .tabbar{background-color:#252e3a;border-top:1px solid #374151;box-shadow:0 -4px 20px #00000040}[data-theme=auto] .tab{color:#9ca3af}[data-theme=auto] .tab:hover{color:#d1d5db}[data-theme=auto] .tab.active{color:#34d399;text-shadow:0 1px 2px rgba(52,211,153,.3)}[data-theme=auto] .tab.active:before{background:linear-gradient(90deg,#34d399,#6ee7b7)}[data-theme=auto] .tile{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(75,85,99,.3);box-shadow:0 8px 32px #0006,0 1px #ffffff1a inset,0 0 0 1px #ffffff0d inset;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#f9fafb;transition:all .3s cubic-bezier(.4,0,.2,1)}[data-theme=auto] .tile:hover{transform:translateY(-2px);box-shadow:0 12px 40px #00000080,0 1px #ffffff26 inset,0 0 0 1px #10b98133 inset;border-color:#10b98166}[data-theme=auto] .tile.mint{background:linear-gradient(145deg,#10b98126,#0596691a);border-color:#10b9814d;box-shadow:0 8px 32px #10b9811a,0 1px #10b98133 inset}[data-theme=auto] .tile.mint:hover{border-color:#10b98180;box-shadow:0 12px 40px #10b98133,0 1px #10b9814d inset}[data-theme=auto] .tile-k{color:#9ca3af}[data-theme=auto] .tile-v{color:#f9fafb}[data-theme=auto] .pill{background:linear-gradient(145deg,#374151cc,#1f293799);border:1px solid rgba(75,85,99,.4);color:#d1d5db;box-shadow:0 2px 8px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .pill:hover{background:linear-gradient(145deg,#4b5563e6,#374151b3);border-color:#10b98166;transform:translateY(-1px)}[data-theme=auto] .pill.active{background:linear-gradient(145deg,#10b981,#059669);border-color:#059669;color:#fff;box-shadow:0 4px 12px #10b9814d}[data-theme=auto] .day-chip{background:linear-gradient(145deg,#374151cc,#1f2937e6);border:1px solid rgba(75,85,99,.4);color:#d1d5db;box-shadow:0 4px 16px #0000004d,0 1px #ffffff1a inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s cubic-bezier(.4,0,.2,1)}[data-theme=auto] .day-chip:hover{background:linear-gradient(145deg,#4b5563e6,#374151cc);border-color:#10b98166;transform:translateY(-2px);box-shadow:0 6px 20px #0006,0 1px #ffffff26 inset}[data-theme=auto] .day-chip.selected{background:linear-gradient(145deg,#10b981,#059669);border-color:#059669;color:#fff;transform:translateY(-2px) scale(1.02);box-shadow:0 8px 25px #10b98166,0 1px #fff3 inset}[data-theme=auto] .day-chip .dow,[data-theme=auto] .day-chip .daynum{color:#9ca3af}[data-theme=auto] .month-input{background:linear-gradient(145deg,#374151cc,#1f2937e6);border:1px solid rgba(75,85,99,.4);color:#f9fafb;box-shadow:0 2px 8px #0003 inset;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .month-input:focus{border-color:#10b98180;box-shadow:0 0 0 3px #10b9811a,0 2px 8px #0003 inset}[data-theme=auto] .week-label{color:#9ca3af;font-weight:500}[data-theme=auto] .arrow-btn{background:linear-gradient(145deg,#374151cc,#1f2937e6);color:#f9fafb;border:1px solid rgba(75,85,99,.4);box-shadow:0 2px 8px #0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .2s cubic-bezier(.4,0,.2,1)}[data-theme=auto] .arrow-btn:hover{background:linear-gradient(145deg,#4b5563e6,#374151cc);border-color:#10b98166;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}[data-theme=auto] .arrow-btn.mint{background:linear-gradient(145deg,#10b981,#059669);color:#fff;border-color:#059669;box-shadow:0 4px 12px #10b9814d}[data-theme=auto] .arrow-btn.mint:hover{background:linear-gradient(145deg,#059669,#047857);border-color:#047857;transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}[data-theme=auto] .section-title{color:#f9fafb}[data-theme=auto] .task{background:linear-gradient(145deg,#2d374899,#1a202ccc);border:1px solid rgba(75,85,99,.3);border-radius:12px;margin-bottom:8px;padding:14px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 16px #0003;transition:all .2s cubic-bezier(.4,0,.2,1)}[data-theme=auto] .task:hover{background:linear-gradient(145deg,#374151b3,#1f2937e6);border-color:#10b9814d;transform:translateY(-1px);box-shadow:0 6px 20px #0000004d}[data-theme=auto] .meta,[data-theme=auto] .empty{color:#9ca3af}[data-theme=auto] .empty-title{color:#f9fafb}[data-theme=auto] .time-badge{background:linear-gradient(145deg,#10b98133,#0596691a);border:1px solid rgba(16,185,129,.3);color:#10b981;box-shadow:0 2px 8px #10b9811a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-weight:600}[data-theme=auto] .skeleton{background:linear-gradient(145deg,#1f2937cc,#111827e6);border:1px solid rgba(75,85,99,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=auto] .skeleton:after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}[data-theme=auto] .monthbar{background:#111827cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:12px;margin-bottom:8px;padding:8px 12px;border:1px solid rgba(75,85,99,.2)}[data-theme=auto] .monthbar strong{color:#f9fafb;font-weight:600}[data-theme=auto] .monthbar .jumper select{background:linear-gradient(145deg,#374151cc,#1f2937e6);border:1px solid rgba(75,85,99,.4);color:#f9fafb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px}[data-theme=auto] .daystrip{background:#1118274d;border-radius:12px;padding:8px 4px 12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}
