:root{--font-family:'Fredoka',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--primary:#4a90e2;--primary-light:#e6effc;--secondary:#ff9f43;--secondary-light:#fff3e6;--success:#2ecc71;--success-light:#eafaf1;--danger:#ff5252;--danger-light:#ffebee;--flower-active:#ff4b5c;--flower-inactive:#e0e5eb;--dark-text:#2c3e50;--light-text:#7f8c8d;--border-color:#e2e8f0;--app-bg:#ebf3fb;--card-bg:#ffffff;--panel-bg:#f8fafc;--card-radius:24px;--btn-radius:16px;--shadow-sm:0 4px 6px -1px rgba(0, 0, 0, 0.05),0 2px 4px -1px rgba(0, 0, 0, 0.03);--shadow-md:0 10px 15px -3px rgba(74, 144, 226, 0.12),0 4px 6px -2px rgba(74, 144, 226, 0.04);--shadow-lg:0 20px 25px -5px rgba(74, 144, 226, 0.18),0 10px 10px -5px rgba(74, 144, 226, 0.06);--transition-fast:all 0.15s cubic-bezier(0.4, 0, 0.2, 1);--transition-normal:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);--transition-spring:all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275)}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);font-size:14px;background-color:var(--app-bg);color:var(--dark-text);min-height:100vh;display:flex;justify-content:center;align-items:center;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.app-container{width:100vw;height:100vh;background-color:var(--card-bg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;position:relative;overflow:hidden}.app-header{background:linear-gradient(135deg,var(--primary) 0,#357abd 100%);color:#fff;padding:24px 20px 20px;border-bottom-left-radius:30px;border-bottom-right-radius:30px;box-shadow:var(--shadow-md);z-index:10;flex-shrink:0}.user-profile{display:flex;align-items:center;gap:15px;margin-bottom:20px}.avatar-container{width:60px;height:60px;background-color:rgba(255,255,255,.9);border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:32px;box-shadow:var(--shadow-sm);border:3px solid rgba(255,255,255,.4)}.user-info h2{font-size:20px;font-weight:600;margin-bottom:2px}.family-code-badge{font-size:14px;background-color:rgba(255,255,255,.2);padding:3px 10px;border-radius:12px;display:inline-block;backdrop-filter:blur(4px)}.stats-dashboard{background-color:rgba(255,255,255,.95);border-radius:20px;padding:12px 15px;display:flex;justify-content:space-around;align-items:center;box-shadow:var(--shadow-sm);color:var(--dark-text)}.stat-card{text-align:center;flex:1}.stat-value{font-size:22px;font-weight:600;color:var(--flower-active);margin-bottom:2px;display:flex;justify-content:center;align-items:center;gap:4px}.stat-value::before{content:'🌸';font-size:16px}.stat-label{font-size:12px;color:var(--light-text)}.stat-divider{width:1px;height:30px;background-color:var(--border-color)}.app-content{flex:1;overflow-y:auto;padding:16px;background-color:#f7fafc}.tab-panel{display:none;animation:fadeIn .3s ease}.tab-panel.active{display:block}@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.week-picker{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;background-color:var(--card-bg);border-radius:16px;padding:8px 12px;box-shadow:var(--shadow-sm)}.picker-btn{background:0 0;border:none;width:36px;height:36px;border-radius:50%;display:flex;justify-content:center;align-items:center;color:var(--primary);cursor:pointer;transition:var(--transition-fast)}.picker-btn:hover{background-color:var(--primary-light)}.week-info{display:flex;flex-direction:column;align-items:center}.month-year-label{font-size:12px;color:var(--light-text);text-transform:uppercase}.week-number-label{font-size:15px;font-weight:600;color:var(--dark-text)}.calendar-grid-header{display:grid;grid-template-columns:2.2fr repeat(7,1fr);gap:4px;background-color:var(--card-bg);border-radius:16px 16px 0 0;padding:10px 8px;border-bottom:1px solid var(--border-color);text-align:center;box-shadow:0 4px 6px -4px rgba(0,0,0,.05)}.col-habit-title{text-align:left;padding-left:6px;font-size:12px;font-weight:600;color:var(--light-text);display:flex;align-items:center}.col-day{display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;padding:4px 0}.col-day span{font-size:12px;font-weight:600;color:var(--light-text)}.col-day em{font-size:12px;font-style:normal;color:var(--dark-text)}.col-day.today{background-color:var(--primary-light)}.col-day.today span{color:var(--primary)}.col-day.today em{color:var(--primary);font-weight:600}.checkin-container{background-color:var(--card-bg);border-radius:0 0 16px 16px;padding:8px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:4px;margin-bottom:24px}.checkin-row{display:grid;grid-template-columns:2.2fr repeat(7,1fr);gap:4px;padding:12px 0;border-bottom:1px dashed #f1f5f9;align-items:center;transition:var(--transition-fast)}.checkin-row:last-child{border-bottom:none}.habit-name-col{padding-left:6px;font-size:13px;font-weight:600;color:var(--dark-text);line-height:1.3}.flower-btn{background:0 0;border:none;height:38px;display:flex;justify-content:center;align-items:center;cursor:pointer;border-radius:8px;transition:var(--transition-fast);position:relative}.flower-btn:hover{background-color:#f8fafc}.flower-svg{width:26px;height:26px;fill:var(--flower-inactive);transition:var(--transition-spring)}.flower-btn.active .flower-svg{fill:var(--flower-active);filter:drop-shadow(0 2px 4px rgba(255, 75, 92, .4));transform:scale(1.1) rotate(10deg);animation:pop-bounce .45s cubic-bezier(.175,.885,.32,1.5) forwards}@keyframes pop-bounce{0%{transform:scale(.5) rotate(-30deg)}50%{transform:scale(1.4) rotate(15deg)}75%{transform:scale(.95) rotate(-5deg)}100%{transform:scale(1.1) rotate(10deg)}}.particle{position:absolute;pointer-events:none;border-radius:50%;opacity:0;width:4px;height:4px}.section-title-wrapper{margin-bottom:10px}.mt-lg{margin-top:24px}.mt-md{margin-top:16px}.section-title{font-size:16px;font-weight:600;color:var(--dark-text)}.section-desc{font-size:12px;color:var(--light-text)}.habits-list{display:flex;flex-direction:column;gap:8px}.habit-item-card{background-color:var(--card-bg);border-radius:16px;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm);border-left:4px solid var(--primary);transition:var(--transition-fast)}.habit-item-info{display:flex;align-items:center;gap:10px}.drag-handle{color:var(--light-text);cursor:grab;font-size:14px}.habit-item-name{font-size:14px;font-weight:600;color:var(--dark-text)}.remove-btn{background:0 0;border:none;color:var(--danger);font-size:18px;cursor:pointer;width:28px;height:28px;border-radius:50%;display:flex;justify-content:center;align-items:center;transition:var(--transition-fast)}.remove-btn:hover{background-color:var(--danger-light)}.custom-card{background-color:var(--card-bg);border-radius:20px;padding:16px;box-shadow:var(--shadow-sm)}.card-title{font-size:14px;font-weight:600;color:var(--dark-text);margin-bottom:12px}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.form-group label{font-size:12px;font-weight:600;color:var(--light-text)}.form-group.row-group{flex-direction:row;gap:8px}.form-group.row-group input{flex:1}input[type=number],input[type=text]{border:1px solid var(--border-color);background-color:#f8fafc;padding:12px 16px;border-radius:var(--btn-radius);font-family:inherit;font-size:14px;outline:0;transition:var(--transition-fast)}input[type=number]:focus,input[type=text]:focus{border-color:var(--primary);background-color:#fff;box-shadow:0 0 0 3px rgba(74,144,226,.15)}.btn{border:none;font-family:inherit;font-weight:600;font-size:14px;padding:12px 20px;border-radius:var(--btn-radius);cursor:pointer;transition:var(--transition-spring);display:inline-flex;justify-content:center;align-items:center;gap:6px}.btn:active{transform:scale(.95)}.btn-primary{background-color:var(--primary);color:#fff;box-shadow:0 4px 6px rgba(74,144,226,.2)}.btn-primary:hover{background-color:#357abd}.btn-outline{background-color:transparent;border:1.5px solid var(--primary);color:var(--primary)}.btn-outline:hover{background-color:var(--primary-light)}.btn-outline-secondary{background-color:transparent;border:1.5px solid var(--border-color);color:var(--dark-text);font-size:12px;padding:8px 14px}.btn-outline-secondary:hover{background-color:#f1f5f9;border-color:#cbd5e1}.btn-danger{background-color:var(--danger);color:#fff;box-shadow:0 4px 6px rgba(255,82,82,.2)}.btn-danger:hover{background-color:#e33e3e}.btn-round{width:44px;height:44px;border-radius:50%;border:none;background-color:var(--success);color:#fff;font-size:24px;cursor:pointer;display:flex;justify-content:center;align-items:center;box-shadow:0 4px 10px rgba(46,204,113,.3);transition:var(--transition-spring)}.btn-round:hover{transform:scale(1.1) rotate(90deg);background-color:#27ae60}.wishes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.wishes-title-area{display:flex;flex-direction:column}.wishes-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.wish-card{background-color:var(--card-bg);border-radius:20px;padding:16px;box-shadow:var(--shadow-sm);display:flex;gap:14px;align-items:center;position:relative;transition:var(--transition-normal)}.wish-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.wish-icon-box{width:50px;height:50px;background-color:#f1f5f9;border-radius:14px;display:flex;justify-content:center;align-items:center;font-size:28px;flex-shrink:0}.wish-details{flex:1;min-width:0}.wish-title-row{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:4px}.wish-title{font-size:14px;font-weight:600;color:var(--dark-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wish-description{font-size:12px;color:var(--light-text);margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wish-progress-wrapper{display:flex;align-items:center;gap:10px}.wish-progress-bar{flex:1;height:8px;background-color:#f1f5f9;border-radius:4px;overflow:hidden}.wish-progress-fill{height:100%;background:linear-gradient(90deg,#ffc048,#ff9f43);border-radius:4px;width:0%;transition:width .6s cubic-bezier(.4, 0, .2, 1)}.wish-progress-text{font-size:12px;font-weight:600;color:var(--light-text);white-space:nowrap}.redeem-btn{width:42px;height:42px;border-radius:50%;border:none;background-color:var(--flower-inactive);color:#a0aec0;font-size:14px;font-weight:600;cursor:not-allowed;display:flex;justify-content:center;align-items:center;flex-shrink:0;transition:var(--transition-spring)}.wish-card.claimable .redeem-btn{background-color:var(--secondary);color:#fff;cursor:pointer;box-shadow:0 4px 10px rgba(255,159,67,.3)}.wish-card.claimable .redeem-btn:hover{transform:scale(1.1);background-color:#f39c12}.wish-card.claimable .redeem-btn:active{transform:scale(.95)}.wish-card.claimed-card{opacity:.7}.wish-card.claimed-card .wish-progress-fill{background:#cbd5e1}.wish-card.claimed-card .redeem-btn{background-color:var(--success);color:#fff;cursor:default;font-size:12px}.wish-card .delete-wish-btn{position:absolute;top:6px;right:6px;background:0 0;border:none;color:var(--light-text);font-size:14px;cursor:pointer;opacity:0;transition:opacity .2s ease}.wish-card:hover .delete-wish-btn{opacity:1}.card{background-color:var(--card-bg);border-radius:20px;padding:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.settings-card{display:flex;flex-direction:column}.card-title-icon{font-size:15px;font-weight:600;color:var(--dark-text);margin-bottom:12px;display:flex;align-items:center;gap:6px}.settings-intro{font-size:12px;color:var(--light-text);margin-bottom:14px;line-height:1.4}.border-danger{border-color:rgba(255,82,82,.3)}.text-danger{color:var(--danger)!important}.avatar-selector{display:grid;grid-template-columns:repeat(8,1fr);gap:6px;margin-top:4px}.avatar-option{font-size:22px;width:38px;height:38px;display:flex;justify-content:center;align-items:center;cursor:pointer;border-radius:50%;border:2px solid transparent;transition:var(--transition-fast)}.avatar-option:hover{background-color:#f1f5f9}.avatar-option.selected{border-color:var(--primary);background-color:var(--primary-light);transform:scale(1.1)}.emoji-selector{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:4px}.emoji-option{font-size:24px;width:44px;height:44px;display:flex;justify-content:center;align-items:center;cursor:pointer;border-radius:12px;border:2px solid transparent;background-color:#f8fafc;transition:var(--transition-fast)}.emoji-option:hover{background-color:#e2e8f0}.emoji-option.selected{border-color:var(--primary);background-color:var(--primary-light);transform:scale(1.05)}.checkbox-group{flex-direction:row;align-items:center;gap:10px}.toggle-switch{position:relative;display:inline-block;width:46px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#cbd5e1;transition:.4s;border-radius:24px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s cubic-bezier(.175, .885, .32, 1.275);border-radius:50%}input:checked+.slider{background-color:var(--success)}input:focus+.slider{box-shadow:0 0 1px var(--success)}input:checked+.slider:before{transform:translateX(22px)}.toggle-label{font-size:13px;font-weight:600;color:var(--dark-text)}.input-tip{font-size:12px;color:var(--light-text);margin-top:-2px}.sync-actions-group{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px;margin-bottom:8px}.sync-log{font-size:12px;color:var(--light-text);background-color:#f8fafc;padding:8px 12px;border-radius:10px;border-left:3px solid #cbd5e1;word-break:break-all}.backup-actions{display:flex;gap:8px}.backup-actions button{flex:1}.app-navbar{height:64px;background-color:var(--card-bg);border-top:1px solid var(--border-color);display:flex;justify-content:space-around;align-items:center;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -4px 10px rgba(0,0,0,.02);flex-shrink:0;z-index:10}.nav-item{background:0 0;border:none;flex:1;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#94a3b8;cursor:pointer;transition:var(--transition-fast);gap:3px}.nav-icon{font-size:20px;transition:var(--transition-spring)}.nav-label{font-size:12px;font-weight:600}.nav-item.active{color:var(--primary)}.nav-item.active .nav-icon{transform:translateY(-2px) scale(1.15)}.modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:rgba(44,62,80,.5);backdrop-filter:blur(4px);z-index:100;display:flex;justify-content:center;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity .3s ease}.modal-overlay.open{opacity:1;pointer-events:auto}.modal-container{width:100%;background-color:var(--card-bg);border-top-left-radius:30px;border-top-right-radius:30px;padding:24px;box-shadow:0 -10px 25px rgba(0,0,0,.1);transform:translateY(100%);transition:transform .3s cubic-bezier(.175, .885, .32, 1.15)}.modal-overlay.open .modal-container{transform:translateY(0)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h4{font-size:16px;font-weight:600}.modal-close-btn{background:0 0;border:none;font-size:24px;color:var(--light-text);cursor:pointer}.modal-body{margin-bottom:24px;max-height:50vh;overflow-y:auto}.modal-footer{display:flex;gap:12px}.modal-footer button{flex:1}.toast{position:absolute;top:20px;left:50%;transform:translateX(-50%) translateY(-20px);background-color:rgba(44,62,80,.95);color:#fff;padding:10px 20px;border-radius:30px;font-size:13px;font-weight:600;z-index:1000;box-shadow:var(--shadow-md);transition:transform .3s cubic-bezier(.175, .885, .32, 1.275),opacity .3s ease;pointer-events:none;opacity:0;white-space:nowrap;backdrop-filter:blur(4px)}.toast.show{transform:translateX(-50%) translateY(0);opacity:1}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--light-text)}.empty-icon{font-size:48px;margin-bottom:12px}.empty-state p{font-size:13px;margin-bottom:16px;line-height:1.4}.hidden{display:none!important}.hearts-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:1}.floating-heart{position:absolute;bottom:-30px;font-size:20px;opacity:0;animation:floatUp 4s ease-in-out infinite}@keyframes floatUp{0%{transform:translateY(0) scale(.8);opacity:0}20%{opacity:.8}80%{opacity:.8}100%{transform:translateY(-500px) scale(1.2);opacity:0}}.heart-0{left:10%;animation-duration:4.5s;animation-delay:0s;font-size:32px}.heart-1{left:35%;animation-duration:5s;animation-delay:1.2s;font-size:48px}.heart-2{left:55%;animation-duration:4.2s;animation-delay:2.1s;font-size:36px}.heart-3{left:75%;animation-duration:5.5s;animation-delay:.5s;font-size:44px}.heart-4{left:85%;animation-duration:4.8s;animation-delay:3.5s;font-size:28px}.heart-5{left:5%;animation-duration:5.8s;animation-delay:2.8s;font-size:40px}.heart-6{left:25%;animation-duration:4.3s;animation-delay:1.5s;font-size:30px}.heart-7{left:45%;animation-duration:6.1s;animation-delay:.8s;font-size:46px}.heart-8{left:65%;animation-duration:4.7s;animation-delay:3.2s;font-size:24px}.heart-9{left:95%;animation-duration:5.9s;animation-delay:1.9s;font-size:50px}.heart-10{left:20%;animation-duration:5.4s;animation-delay:4.1s;font-size:38px}.heart-11{left:80%;animation-duration:6.8s;animation-delay:.3s;font-size:26px}.clouds-container{position:absolute;top:0;left:0;width:100%;height:120px;pointer-events:none;overflow:hidden;z-index:2}.floating-cloud{position:absolute;opacity:.8;animation:floatCloud linear infinite;filter:drop-shadow(0 2px 4px rgba(255,255,255,.5));transform:scale(1.3,.8)}@keyframes floatCloud{0%{left:100%}100%{left:-30%}}.cloud-0{top:10px;animation-duration:20s;animation-delay:0s;font-size:40px}.cloud-1{top:40px;animation-duration:30s;animation-delay:-10s;font-size:55px;opacity:.6}.cloud-2{top:20px;animation-duration:25s;animation-delay:-15s;font-size:35px;opacity:.9}.cloud-3{top:5px;animation-duration:35s;animation-delay:-5s;font-size:60px;opacity:.5}