*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #D4511E;--primary-dark: #B8411A;--primary-light: rgba(212, 81, 30, .08);--success: #2D7A4F;--success-light: rgba(45, 122, 79, .08);--warning: #C2780F;--danger: #C53030;--danger-light: rgba(197, 48, 48, .07);--bg: #F4F1EB;--surface: #FFFFFF;--surface-2: #EDE9E1;--border: #DDD9D0;--border-light: #EDE9E1;--text: #1A1714;--text-muted: #7C786F;--text-light: #B8B4AB;--shadow-sm: 0 1px 3px rgba(26,23,20,.06), 0 1px 2px rgba(26,23,20,.04);--shadow: 0 4px 12px rgba(26,23,20,.08), 0 1px 4px rgba(26,23,20,.04);--shadow-lg: 0 16px 48px rgba(26,23,20,.14), 0 4px 12px rgba(26,23,20,.06);--shadow-xl: 0 32px 80px rgba(26,23,20,.18);--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--navbar-h: 60px}html,body{height:100%;font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline;opacity:.85}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit;font-size:1rem}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);background-image:radial-gradient(ellipse 80% 60% at 60% -10%,rgba(212,81,30,.07) 0%,transparent 60%),radial-gradient(ellipse 50% 40% at 0% 100%,rgba(212,81,30,.04) 0%,transparent 55%);padding:1rem}.auth-card{background:var(--surface);border-radius:var(--radius-lg);padding:2.75rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg);border:1px solid var(--border-light);animation:cardEnter .35s ease both}.auth-logo{text-align:center;margin-bottom:2rem}.auth-logo h1{font-family:Fraunces,Georgia,serif;font-size:2rem;font-weight:700;color:var(--text);letter-spacing:-.04em;line-height:1}.auth-logo p{font-size:.875rem;color:var(--text-muted);margin-top:.375rem}.auth-card h2{font-size:1.125rem;font-weight:600;margin-bottom:1.5rem;color:var(--text)}.form-group{margin-bottom:1.125rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}label{display:block;font-size:.6875rem;font-weight:600;margin-bottom:.4rem;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase}.input{width:100%;padding:.625rem .9375rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.9375rem;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #d4511e1a}.input::placeholder{color:var(--text-light)}.input.error{border-color:var(--danger)}select.input{background-image:none}.field-error{font-size:.8125rem;color:var(--danger);margin-top:.25rem}.form-error{background:var(--danger-light);color:var(--danger);border:1px solid rgba(197,48,48,.18);border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.875rem;margin-bottom:1rem}.form-success{background:var(--success-light);color:var(--success);border:1px solid rgba(45,122,79,.18);border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.875rem;margin-bottom:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5625rem 1.25rem;border-radius:var(--radius-sm);font-size:.9375rem;font-weight:500;border:none;transition:background .15s,box-shadow .15s,transform .1s;white-space:nowrap;letter-spacing:-.01em}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-icon{padding:.5rem;border-radius:var(--radius-sm)}.btn-primary{background:var(--primary);color:#fff;font-weight:600;box-shadow:0 1px 3px #d4511e4d,0 4px 12px #d4511e26}.btn-primary:hover{background:var(--primary-dark);box-shadow:0 1px 3px #d4511e59,0 6px 16px #d4511e33}.btn-secondary{background:var(--surface);color:var(--text);border:1.5px solid var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--surface-2);border-color:var(--border)}.btn-danger{background:var(--danger-light);color:var(--danger);border:1px solid rgba(197,48,48,.2)}.btn-danger:hover{background:#c530301f}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.btn-full{width:100%}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding-top:var(--navbar-h)}.page{max-width:1100px;margin:0 auto;padding:2.25rem 1.5rem}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.page-title{font-family:Fraunces,Georgia,serif;font-size:2.125rem;font-weight:700;letter-spacing:-.04em;line-height:1.1;color:var(--text)}.page-subtitle{font-size:.875rem;color:var(--text-muted);margin-top:.375rem}.navbar{position:fixed;top:0;left:0;right:0;height:var(--navbar-h);background:#ffffffe0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.5rem;gap:2rem;z-index:100;box-shadow:0 1px 0 var(--border-light)}.navbar-brand{font-family:Fraunces,Georgia,serif;font-size:1.125rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:.5rem;text-decoration:none;letter-spacing:-.03em}.navbar-brand:hover{opacity:.75;text-decoration:none}.navbar-nav{display:flex;align-items:center;gap:.125rem;flex:1}.nav-link{padding:.4375rem .875rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--text-muted);transition:background .15s,color .15s;display:flex;align-items:center;gap:.375rem}.nav-link:hover{background:var(--surface-2);color:var(--text);text-decoration:none;opacity:1}.nav-link.active{background:var(--primary-light);color:var(--primary)}.navbar-end{display:flex;align-items:center;gap:.625rem;margin-left:auto}.user-badge{font-size:.875rem;color:var(--text-muted);display:flex;align-items:center;gap:.5rem}.avatar{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.notification-btn{position:relative;padding:.5rem;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;transition:border-color .15s,color .15s,box-shadow .15s;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.notification-btn:hover{border-color:var(--primary);color:var(--primary)}.badge{position:absolute;top:-5px;right:-5px;min-width:16px;height:16px;border-radius:99px;background:var(--danger);color:#fff;font-size:.625rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid var(--surface)}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.card-body{padding:1.25rem}.habits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.habit-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow .2s,transform .2s,border-color .2s;animation:cardEnter .28s ease both}.habit-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:#ccc9c0}@keyframes cardEnter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.habit-card-bar{height:3px}.habit-card-body{padding:1.125rem 1.25rem}.habit-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.habit-icon{font-size:1.375rem;line-height:1;flex-shrink:0}.habit-title{font-size:.9375rem;font-weight:600;color:var(--text);flex:1;line-height:1.35}.habit-desc{font-size:.8125rem;color:var(--text-muted);margin-bottom:.75rem;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.5}.habit-meta{display:flex;align-items:center;gap:.625rem;font-size:.75rem;color:var(--text-muted);margin-bottom:.875rem;flex-wrap:wrap}.streak-badge{display:inline-flex;align-items:center;gap:.25rem;background:#fff7ed;color:#c2780f;border:1px solid #FDDCAA;border-radius:99px;padding:.1875rem .625rem;font-size:.75rem;font-weight:600}.streak-milestone{background:#fef3c7;color:#b45309;border-color:#fcd34d}.habit-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.habit-actions{display:flex;align-items:center;gap:.25rem}.complete-btn{display:flex;align-items:center;gap:.375rem;padding:.4375rem .875rem;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s;box-shadow:var(--shadow-sm)}.complete-btn:hover{border-color:var(--success);color:var(--success);background:var(--success-light)}.complete-btn.completed{background:var(--success-light);border-color:#2d7a4f4d;color:var(--success)}.complete-btn.not-due,.complete-btn[disabled]:not(.completed){opacity:.45;cursor:not-allowed;pointer-events:none}.checkmark{display:inline-block;animation:checkEnter .25s cubic-bezier(.34,1.56,.64,1) both}@keyframes checkEnter{0%{opacity:0;transform:scale(0) rotate(-90deg)}to{opacity:1;transform:scale(1) rotate(0)}}.shared-tag{display:inline-flex;align-items:center;gap:.25rem;font-size:.6875rem;color:var(--text-light)}.progress-section{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:1.375rem 1.5rem;margin-bottom:1.75rem;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.progress-ring-wrap{flex-shrink:0}.progress-ring{transform:rotate(-90deg)}.progress-ring-bg{fill:none;stroke:var(--border)}.progress-ring-fill{fill:none;stroke:var(--primary);stroke-linecap:round;transition:stroke-dashoffset .65s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 0 4px rgba(212,81,30,.3))}.progress-info{flex:1;min-width:80px}.progress-label{font-size:.6875rem;color:var(--text-muted);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.07em;font-weight:600}.progress-count{font-family:Fraunces,Georgia,serif;font-size:2.25rem;font-weight:700;color:var(--text);line-height:1;letter-spacing:-.04em}.progress-count span{color:var(--text-muted);font-size:1.125rem;font-weight:400;font-family:DM Sans,sans-serif;letter-spacing:0}.progress-bar-bg{height:4px;background:var(--border);border-radius:99px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--primary);border-radius:99px;transition:width .65s cubic-bezier(.4,0,.2,1)}.schedule-tabs{display:flex;gap:.25rem;background:var(--surface-2);border-radius:var(--radius-sm);padding:.25rem;width:fit-content;border:1px solid var(--border)}.tab-btn{padding:.4375rem 1rem;border-radius:6px;border:none;background:transparent;color:var(--text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s,box-shadow .15s}.tab-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.tab-btn:hover:not(.active){color:var(--text)}.schedule-nav{display:flex;align-items:center;gap:.5rem}.schedule-nav-title{font-size:.9375rem;font-weight:600;min-width:160px;text-align:center;color:var(--text)}.modal-backdrop{position:fixed;inset:0;background:#1a171480;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:200;animation:backdropIn .2s ease both}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}.modal-backdrop.leaving{animation:backdropOut .2s ease both}@keyframes backdropOut{to{opacity:0}}.modal{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-xl);width:100%;max-width:540px;max-height:90vh;overflow-y:auto;animation:modalIn .28s cubic-bezier(.34,1.56,.64,1) both}.modal-backdrop.leaving .modal{animation:modalOut .2s ease both}@keyframes modalIn{0%{opacity:0;transform:scale(.93) translateY(16px)}to{opacity:1;transform:none}}@keyframes modalOut{to{opacity:0;transform:scale(.96) translateY(8px)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal-title{font-size:1rem;font-weight:600;color:var(--text)}.modal-body{padding:1.5rem}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border);background:var(--bg);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.day-timeline{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-sm)}.timeline-row{display:flex;border-bottom:1px solid var(--border);min-height:64px;align-items:stretch}.timeline-row:last-child{border-bottom:none}.time-label{width:60px;flex-shrink:0;font-size:.6875rem;color:var(--text-light);padding:.5rem .5rem 0;font-weight:500;font-variant-numeric:tabular-nums}.timeline-slot{flex:1;padding:.375rem .5rem;display:flex;flex-direction:column;gap:.25rem}.week-grid{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-sm)}.week-header{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border)}.week-day-header{padding:.625rem .5rem;text-align:center;font-size:.6875rem;font-weight:700;color:var(--text-muted);border-right:1px solid var(--border);letter-spacing:.06em;text-transform:uppercase;background:var(--bg)}.week-day-header:last-child{border-right:none}.week-day-header.today{color:var(--primary);background:var(--primary-light)}.week-body{display:grid;grid-template-columns:repeat(7,1fr)}.week-day-col{min-height:120px;padding:.5rem;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:.25rem}.week-day-col:last-child{border-right:none}.week-day-col.today{background:#d4511e06}.month-grid{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-sm)}.month-weekdays{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border);background:var(--bg)}.month-weekday{padding:.5rem;text-align:center;font-size:.625rem;font-weight:700;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}.month-days{display:grid;grid-template-columns:repeat(7,1fr)}.month-day{min-height:80px;padding:.375rem;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}.month-day:nth-child(7n){border-right:none}.month-day-num{font-size:.75rem;font-weight:500;color:var(--text-muted);width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;margin-bottom:.25rem}.month-day.today .month-day-num{background:var(--primary);color:#fff;font-weight:700}.month-day.other-month .month-day-num{color:var(--text-light)}.month-dot-row{display:flex;flex-wrap:wrap;gap:3px;margin-top:2px}.month-dot{width:6px;height:6px;border-radius:50%}.habit-event{border-radius:5px;padding:.2rem .5rem;font-size:.6875rem;font-weight:500;color:#ffffffeb;cursor:pointer;transition:opacity .15s;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;display:flex;align-items:center;gap:.25rem}.habit-event:hover{opacity:.8}.habit-event.done{opacity:.45}.completion-overlay{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;background:#1a171499;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:backdropIn .4s ease both}.completion-overlay.leaving{animation:backdropOut .3s ease both}.completion-card{background:var(--surface);border-radius:20px;border:1px solid var(--border);padding:3rem 2.75rem;text-align:center;max-width:380px;width:100%;box-shadow:var(--shadow-xl);animation:cardPop .5s cubic-bezier(.34,1.56,.64,1) .1s both}@keyframes cardPop{0%{opacity:0;transform:scale(.78)}to{opacity:1;transform:scale(1)}}.completion-shield{font-size:3.75rem;margin-bottom:1.125rem;animation:shieldFloat 2.5s ease-in-out infinite;display:block}@keyframes shieldFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-9px)}}.completion-title{font-family:Fraunces,Georgia,serif;font-size:1.75rem;font-weight:700;margin-bottom:.5rem;letter-spacing:-.035em;color:var(--text)}.completion-sub{font-size:.9375rem;color:var(--text-muted);margin-bottom:2rem}.stars-container{position:relative;height:60px;margin-bottom:1.5rem;overflow:hidden}.star{position:absolute;font-size:1.25rem;animation:starFall 1.5s ease-out both}@keyframes starFall{0%{opacity:0;transform:translateY(-40px) rotate(0)}50%{opacity:1}to{opacity:0;transform:translateY(60px) rotate(360deg)}}.milestone-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.25rem 2rem;text-align:center;max-width:340px;box-shadow:var(--shadow-xl);position:relative;overflow:hidden;animation:modalIn .3s cubic-bezier(.34,1.56,.64,1) both}.milestone-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),#F59E0B)}.milestone-emoji{font-size:3.25rem;margin-bottom:.875rem;display:block}.milestone-title{font-family:Fraunces,Georgia,serif;font-size:1.625rem;font-weight:700;margin-bottom:.375rem;letter-spacing:-.035em;color:var(--text)}.milestone-sub{font-size:.9375rem;color:var(--text-muted);margin-bottom:1.75rem}.color-grid{display:flex;flex-wrap:wrap;gap:.5rem}.color-swatch{width:30px;height:30px;border-radius:50%;cursor:pointer;border:2px solid transparent;outline:2.5px solid transparent;outline-offset:2px;transition:transform .15s,outline-color .15s;box-shadow:var(--shadow-sm)}.color-swatch:hover{transform:scale(1.18)}.color-swatch.selected{outline-color:var(--text);transform:scale(1.12)}.chip-input-wrap{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:.375rem;display:flex;flex-wrap:wrap;gap:.375rem;cursor:text;transition:border-color .15s,box-shadow .15s;min-height:42px;background:var(--surface)}.chip-input-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #d4511e1a}.chip{display:inline-flex;align-items:center;gap:.25rem;background:var(--primary-light);color:var(--primary);border:1px solid rgba(212,81,30,.2);border-radius:99px;padding:.1875rem .625rem .1875rem .75rem;font-size:.8125rem;font-weight:500}.chip-remove{cursor:pointer;font-size:.9375rem;line-height:1;opacity:.55;border:none;background:none;color:inherit;padding:0}.chip-remove:hover{opacity:1}.chip-input-inner{border:none;outline:none;flex:1;min-width:120px;padding:.1875rem .375rem;font-size:.875rem;background:transparent;color:var(--text)}.days-selector{display:flex;gap:.375rem;flex-wrap:wrap}.day-toggle{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:.75rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;box-shadow:var(--shadow-sm)}.day-toggle.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 2px 8px #d4511e59}.empty-state{text-align:center;padding:3.5rem 1.5rem;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.45}.empty-state h3{font-size:1.0625rem;font-weight:600;color:var(--text);margin-bottom:.375rem}.empty-state p{font-size:.9375rem}.notification-panel{position:fixed;top:calc(var(--navbar-h) + 8px);right:1rem;width:328px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:150;overflow:hidden;animation:slideDown .2s ease both}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-panel.leaving{animation:slideUp .15s ease both}@keyframes slideUp{to{opacity:0;transform:translateY(-10px)}}.notification-header{padding:.875rem 1rem;border-bottom:1px solid var(--border);font-weight:600;font-size:.6875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;background:var(--bg)}.notification-item{padding:.9375rem 1rem;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem}.notification-item:last-child{border-bottom:none}.notification-text{font-size:.875rem;color:var(--text);line-height:1.45}.notification-text b{font-weight:600}.notification-actions{display:flex;gap:.5rem}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.mb-4{margin-bottom:1rem}.text-sm{font-size:.875rem}.text-muted{color:var(--text-muted)}.font-semibold{font-weight:600}.text-center{text-align:center}.w-full{width:100%}.habit-event[draggable=true]{cursor:grab;-webkit-user-select:none;user-select:none}.habit-event[draggable=true]:active{cursor:grabbing}.habit-event.dragging{opacity:.3}.timeline-row.drag-over>.timeline-slot{background:var(--primary-light);border-radius:var(--radius-sm);outline:2px dashed rgba(212,81,30,.3);outline-offset:-2px}.week-day-col.drag-over{background:var(--primary-light);outline:2px dashed rgba(212,81,30,.25);outline-offset:-4px}.dnd-hint{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--text-light);margin-bottom:1rem}@media(max-width:640px){.page{padding:1.25rem 1rem}.form-row,.habits-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.auth-card{padding:1.875rem}.navbar{padding:0 1rem;gap:1rem}.page-title{font-size:1.75rem}.user-badge span{display:none}}
