@import "https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800;900&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;0,9..40,800;1,9..40,400&display=swap";@keyframes slide-in-left{0%{opacity:0;transform:translate(28px)}to{opacity:1;transform:translate(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(-28px)}to{opacity:1;transform:translate(0)}}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}:root{--bg:#fafaf8;--bg-soft:#f5f2ec;--bg-muted:#ede8df;--surface:#fff;--dark:#3d1f14;--dark-2:#4a2518;--dark-3:#5a3020;--accent:#7a3b2a;--accent-2:#5c2a1a;--accent-light:#f5ead8;--accent-glow:#7a3b2a26;--sand:#edd9b5;--sand-light:#fbf5e8;--terra:#9a5e3a;--terra-light:#f5ead8;--text:#1c0f05;--text-2:#4a3020;--text-muted:#8a6a50;--text-light:#c4a882;--border:#3d1f141a;--border-soft:#3d1f140f;--success:#2d7a4f;--warning:#c4832a;--error:#c43a2a;--cat-health:#2d7a4f;--cat-work:#b87333;--cat-relation:#c4632a;--cat-finance:#8a6a50;--cat-leisure:#4a8a6a;--cat-self:#7a5a8a;--sidebar-w:260px;--font:"DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-display:"Sora", -apple-system, BlinkMacSystemFont, sans-serif;--r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:20px;--r-2xl:28px;--r-3xl:36px;--r-full:9999px;--shadow-sm:0 1px 3px #1c0f050f, 0 1px 2px #1c0f050a;--shadow-md:0 4px 16px #1c0f0514, 0 2px 6px #1c0f050d;--shadow-lg:0 10px 32px #1c0f051c, 0 4px 12px #1c0f0512;--shadow-xl:0 20px 60px #1c0f0526, 0 8px 20px #1c0f0514;--t:.18s cubic-bezier(.4,0,.2,1);--t-slow:.32s cubic-bezier(.4,0,.2,1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font);background:var(--bg-soft);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}img,svg{max-width:100%;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit}a{color:inherit;text-decoration:none}ul,ol{list-style:none}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--dark);z-index:100;border-right:1px solid #ffffff08;flex-direction:column;min-height:100vh;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}.sidebar:before{content:"";pointer-events:none;background:radial-gradient(at 40% 0,#edd9b514 0%,#0000 65%);height:300px;position:absolute;top:0;left:0;right:0}.sidebar-logo{z-index:1;border-bottom:1px solid #ffffff0a;padding:32px 24px 24px;position:relative}.sidebar-logo-icon{border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:14px;display:flex;overflow:hidden}.sidebar-logo-icon img{object-fit:cover;border-radius:10px;width:44px;height:44px;display:block}.sidebar-brand-name{color:var(--sand);letter-spacing:-.02em;font-size:17px;font-weight:800;line-height:1.1;font-family:var(--font-display)}.sidebar-brand-sub{color:#ffffff38;letter-spacing:.14em;text-transform:uppercase;margin-top:3px;font-size:9.5px;font-weight:500}.sidebar-nav{z-index:1;flex-direction:column;flex:1;gap:2px;padding:16px 12px;display:flex;position:relative}.sidebar-section-label{color:#ffffff2e;letter-spacing:.16em;text-transform:uppercase;padding:16px 12px 6px;font-size:9px;font-weight:700}.sidebar-item{border-radius:var(--r-lg);color:#ffffff6b;transition:all var(--t);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:11px;width:100%;padding:11px 14px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex}.sidebar-item:hover{color:#ffffffd9;background:#ffffff0f}.sidebar-item.active{color:#fff;background:#edd9b51c;border:1px solid #edd9b52e}.sidebar-item svg{opacity:.7;flex-shrink:0;width:16px;height:16px}.sidebar-item.active svg{opacity:1;color:var(--sand)}.sidebar-watermark{pointer-events:none;z-index:0;opacity:1;position:absolute;bottom:72px;right:-16px}.sidebar-footer{z-index:1;border-top:1px solid #ffffff0a;padding:12px;position:relative}.sidebar-user{border-radius:var(--r-lg);cursor:pointer;transition:background var(--t);align-items:center;gap:10px;padding:10px 12px;display:flex}.sidebar-user:hover{background:#ffffff0d}.sidebar-avatar{border-radius:var(--r-full);background:var(--sand);width:34px;height:34px;color:var(--dark);flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.sidebar-user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-role{color:#ffffff40;font-size:10px}.main{margin-left:var(--sidebar-w);background:var(--bg-soft);flex:1;min-height:100vh}.topbar{-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-soft);z-index:50;background:#fafaf8eb;justify-content:space-between;align-items:center;height:64px;padding:0 40px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-page-title{color:var(--text);letter-spacing:-.02em;font-size:15px;font-weight:700}.topbar-greeting{color:var(--text-muted);font-size:13px}.topbar-right{align-items:center;gap:8px;display:flex}.topbar-btn{border-radius:var(--r-full);cursor:pointer;width:36px;height:36px;transition:all var(--t);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:relative}.topbar-btn:hover{background:var(--bg-muted)}.topbar-btn svg{width:17px;height:17px;color:var(--text-2)}.topbar-badge{background:var(--terra);border-radius:var(--r-full);border:2px solid var(--bg);width:7px;height:7px;position:absolute;top:6px;right:6px}.new-task-btn{border-radius:var(--r-full);background:var(--dark);color:var(--sand);font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--t);letter-spacing:-.01em;border:none;align-items:center;gap:7px;padding:9px 18px;display:flex}.new-task-btn:hover{background:var(--dark-2);transform:translateY(-1px);box-shadow:0 4px 16px #3d1f1440}.new-task-btn svg{width:15px;height:15px}.page{width:100%;padding:40px 44px;position:relative}.page-header{justify-content:space-between;align-items:flex-start;margin-bottom:36px;display:flex}.page:before{content:"";top:0;left:var(--sidebar-w);pointer-events:none;z-index:0;background-image:radial-gradient(circle,#3d1f1412 1px,#0000 1px);background-size:24px 24px;position:fixed;bottom:0;right:0}.page>*{z-index:1;position:relative}.page-title{color:var(--text);letter-spacing:-.06em;font-size:44px;font-weight:800;line-height:1;font-family:var(--font-display)}.page-subtitle{color:var(--text-muted);letter-spacing:-.01em;margin-top:8px;font-size:14px;font-weight:400}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--surface);border-radius:var(--r-xl);border:1px solid var(--border-soft);box-shadow:var(--shadow-sm);transition:all var(--t);flex-direction:column;gap:14px;padding:22px 24px;display:flex;position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-header{justify-content:space-between;align-items:center;display:flex}.stat-icon{border-radius:var(--r-md);justify-content:center;align-items:center;width:38px;height:38px;display:flex}.stat-icon svg{width:18px;height:18px}.stat-icon.brown,.stat-icon.violet{background:var(--accent-light);color:var(--accent)}.stat-icon.rose{background:var(--terra-light);color:var(--terra)}.stat-icon.green{color:var(--success);background:#2d7a4f1a}.stat-icon.amber{background:var(--sand-light);color:var(--warning)}.stat-icon.dark{color:var(--dark);background:#1c0f0512}.stat-label{color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;font-size:10px;font-weight:700}.stat-value{color:var(--text);letter-spacing:-.05em;font-size:36px;font-weight:800;line-height:1;font-family:var(--font-display)}.stat-meta{color:var(--text-muted);font-size:12px}.dash-grid{grid-template-columns:1fr 360px;gap:24px;display:grid}.dash-col{flex-direction:column;gap:24px;display:flex}.card{background:var(--surface);border-radius:var(--r-xl);border:1px solid var(--border-soft);box-shadow:var(--shadow-sm);overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.card-body{padding:24px}.card-body-sm{padding:18px}.card-body-lg{padding:32px}.card-gradient{background:linear-gradient(135deg, var(--dark) 0%, var(--dark-3) 100%);border:none;position:relative;overflow:hidden}.card-gradient:before{content:"";pointer-events:none;background:radial-gradient(at 80% 20%,#b8733338 0%,#0000 60%),radial-gradient(at 20% 80%,#c4632a24 0%,#0000 50%);position:absolute;inset:0}.section-hd{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.section-title{color:var(--text);letter-spacing:-.02em;font-size:16px;font-weight:700;font-family:var(--font-display)}.section-link{color:var(--accent);cursor:pointer;transition:opacity var(--t);align-items:center;gap:4px;font-size:12.5px;font-weight:600;display:flex}.section-link:hover{opacity:.65}.cal-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.cal-month{color:var(--text);letter-spacing:-.02em;font-size:15px;font-weight:700;font-family:var(--font-display)}.cal-nav{gap:4px;display:flex}.cal-nav-btn{border-radius:var(--r-full);background:var(--bg-muted);cursor:pointer;width:30px;height:30px;transition:all var(--t);border:none;justify-content:center;align-items:center;display:flex}.cal-nav-btn:hover{background:var(--accent-light);color:var(--accent)}.cal-nav-btn svg{width:13px;height:13px;color:var(--text-2)}.cal-grid{grid-template-columns:repeat(7,1fr);gap:2px;width:100%;display:grid}.cal-dow{text-align:center;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;padding:6px 0 10px;font-size:9.5px;font-weight:700}.cal-day{border-radius:var(--r-md);cursor:pointer;height:38px;min-height:38px;transition:all var(--t);flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex;position:relative}.cal-day:hover{background:var(--bg-muted)}.cal-day.empty{cursor:default}.cal-day.empty:hover{background:0 0}.cal-day.other .day-num{color:var(--text-light)}.cal-day.today{background:var(--dark)}.cal-day.today .day-num{color:#fff;font-weight:700}.cal-day.selected{background:var(--accent)}.cal-day.selected .day-num{color:#fff;font-weight:700}.day-num{color:var(--text);-webkit-user-select:none;user-select:none;font-size:12.5px;font-weight:500;line-height:1}.day-dot{border-radius:var(--r-full);background:var(--accent);width:4px;height:4px}.cal-day.today .day-dot,.cal-day.selected .day-dot{background:#ffffffa6}.task-list{flex-direction:column;gap:8px;display:flex}.task-item{background:var(--bg);border:1px solid var(--border-soft);border-radius:var(--r-lg);cursor:pointer;transition:all var(--t);align-items:flex-start;gap:13px;padding:14px 18px;display:flex}.task-item:hover{border-color:#7a3b2a40;box-shadow:0 2px 12px #7a3b2a12}.task-check{border-radius:var(--r-full);border:1.5px solid var(--text-light);cursor:pointer;width:20px;height:20px;transition:all var(--t);flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;display:flex}.task-check:hover{border-color:var(--accent)}.task-check.done{background:var(--dark);border-color:var(--dark)}.task-check.done:after{content:"";border-bottom:2px solid #fff;border-left:2px solid #fff;width:8px;height:5px;display:block;transform:rotate(-45deg)translateY(-1px)}.task-body{flex:1;min-width:0}.task-name{color:var(--text);font-size:14px;font-weight:500;line-height:1.4}.task-name.done{color:var(--text-muted);text-decoration:line-through}.task-meta{flex-wrap:wrap;align-items:center;gap:6px;margin-top:5px;display:flex}.task-time{color:var(--text-muted);background:var(--bg-muted);border-radius:var(--r-full);padding:2px 8px;font-size:11px}.task-tag{border-radius:var(--r-full);letter-spacing:.05em;text-transform:uppercase;background:var(--bg-muted);color:var(--text-2);padding:2px 8px;font-size:10px;font-weight:700}.task-why{color:var(--text-muted);margin-top:4px;font-size:12px;font-style:italic;line-height:1.4}.planner-item{background:var(--surface);border-left:3px solid var(--accent);border-radius:0 var(--r-lg) var(--r-lg) 0;transition:all .22s;animation:.22s both planner-in}.planner-item:hover{background:var(--bg-soft);border-left-color:var(--dark)}.done-item{opacity:.5;border-left-color:var(--border);animation:.28s both planner-done}.done-item:hover{opacity:.65}@keyframes planner-in{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}@keyframes planner-done{0%{opacity:1}to{opacity:.5}}.pillars-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.pillar-card-img{background-position:50%;background-size:cover;transition:transform .5s;position:absolute;inset:0}.pillar-card:hover .pillar-card-img{transform:scale(1.06)}.pillar-card-overlay{background:linear-gradient(#0000 0%,#1c0f0540 45%,#1c0f05e6 100%);position:absolute;inset:0}.pillar-card-body{padding:16px;position:absolute;bottom:0;left:0;right:0}.pillar-card-name{color:#fff;font-size:14px;font-weight:700;font-family:var(--font-display);margin-bottom:4px}.pillar-card-meta{justify-content:space-between;align-items:center;display:flex}.pillar-card-count{color:#ffffff8c;font-size:11px}.pillar-card-pct{color:var(--sand);font-size:11px;font-weight:700}.progress-bar{background:var(--bg-muted);border-radius:var(--r-full);height:4px;overflow:hidden}.progress-fill{border-radius:var(--r-full);background:var(--accent);height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.progress-fill.success{background:var(--success)}.progress-fill.dark{background:var(--dark)}.btn{border-radius:var(--r-full);font-size:13.5px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--t);letter-spacing:-.01em;white-space:nowrap;border:none;align-items:center;gap:8px;padding:11px 22px;display:inline-flex}.btn-primary{background:var(--dark);color:var(--sand)}.btn-primary:hover{background:var(--dark-2);transform:translateY(-1px);box-shadow:0 4px 16px #3d1f1438}.btn-secondary{background:var(--bg-muted);color:var(--text)}.btn-secondary:hover{background:var(--bg-soft);border:1px solid var(--border)}.btn-outline{color:var(--text);border:1.5px solid var(--border);background:0 0}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-sm{padding:8px 16px;font-size:12.5px}.btn-lg{padding:14px 28px;font-size:15px}.btn svg{width:15px;height:15px}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-2);letter-spacing:.06em;text-transform:uppercase;font-size:11.5px;font-weight:700}.form-input{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-lg);width:100%;color:var(--text);transition:border-color var(--t), box-shadow var(--t);font-size:14px;font-family:var(--font);outline:none;padding:12px 16px}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-input::placeholder{color:var(--text-light)}.form-textarea{resize:vertical;min-height:96px}.form-select{appearance:none;cursor:pointer}.form-hint{color:var(--text-muted);font-size:11.5px}.dropdown-menu{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);z-index:200;min-width:180px;padding:6px;animation:.14s fade-up;position:absolute;top:calc(100% + 6px);right:0}.dropdown-item{border-radius:var(--r-lg);color:var(--text);cursor:pointer;transition:background var(--t);align-items:center;gap:10px;padding:10px 14px;font-size:13.5px;font-weight:500;display:flex}.dropdown-item:hover{background:var(--bg-soft)}.dropdown-item.danger{color:var(--error)}.dropdown-item.danger:hover{background:#c43a2a0f}.dropdown-item svg{width:15px;height:15px;color:var(--text-muted);flex-shrink:0}.dropdown-divider{background:var(--border-soft);height:1px;margin:4px 0}.modal-overlay{z-index:500;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#1c0f0573;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--r-2xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;animation:.2s fade-up;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;padding:28px 28px 0;display:flex}.modal-title{color:var(--text);letter-spacing:-.03em;font-size:20px;font-weight:800;font-family:var(--font-display)}.modal-close{border-radius:var(--r-full);background:var(--bg-muted);cursor:pointer;width:32px;height:32px;transition:all var(--t);border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-soft)}.modal-close svg{width:14px;height:14px;color:var(--text-2)}.modal-body{padding:24px 28px 28px}.badge{border-radius:var(--r-full);letter-spacing:.06em;text-transform:uppercase;align-items:center;gap:4px;padding:3px 10px;font-size:10px;font-weight:700;display:inline-flex}.badge-brown{background:var(--accent-light);color:var(--accent)}.badge-terra{background:var(--terra-light);color:var(--terra)}.badge-green{color:var(--success);background:#2d7a4f1a}.badge-amber{background:var(--sand-light);color:var(--warning)}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:48px 24px;display:flex}.empty-icon{border-radius:var(--r-xl);background:var(--accent-light);justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:4px;display:flex}.empty-icon svg{width:22px;height:22px;color:var(--accent)}.empty-title{color:var(--text);font-size:15px;font-weight:700;font-family:var(--font-display)}.empty-desc{color:var(--text-muted);max-width:260px;font-size:13px;line-height:1.55}.divider{background:var(--border-soft);height:1px;margin:20px 0}.login-shell{background:var(--bg);grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.login-left{background:var(--dark);flex-direction:column;justify-content:space-between;padding:56px;display:flex;position:relative;overflow:hidden}.login-left:before{content:"";pointer-events:none;background:radial-gradient(at 30% 20%,#b8733340 0%,#0000 55%),radial-gradient(at 80% 80%,#c4632a2e 0%,#0000 50%);position:absolute;inset:0}.login-left-content{z-index:1;position:relative}.login-logo-mark{border-radius:12px;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:40px;display:flex;overflow:hidden}.login-logo-mark img{object-fit:cover;border-radius:12px;width:52px;height:52px;display:block}.login-headline{color:#fff;letter-spacing:-.05em;font-size:44px;font-weight:800;line-height:1.05;font-family:var(--font-display);margin-bottom:18px}.login-headline span{color:var(--sand)}.login-desc{color:#ffffff73;max-width:340px;font-size:14.5px;line-height:1.7}.login-features{z-index:1;flex-direction:column;gap:12px;display:flex;position:relative}.login-feature{align-items:center;gap:12px;display:flex}.login-feature-dot{border-radius:var(--r-full);background:#b8733333;border:1px solid #b873334d;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.login-feature-dot:after{content:"";border-left:1.5px solid var(--sand);border-bottom:1.5px solid var(--sand);width:7px;height:5px;display:block;transform:rotate(-45deg)translateY(-1px)}.login-feature-text{color:#ffffff8c;font-size:13px;font-weight:400}.login-right{background:var(--bg);justify-content:center;align-items:center;padding:56px;display:flex}.login-box{width:100%;max-width:400px}.login-box-title{color:var(--text);letter-spacing:-.05em;font-size:30px;font-weight:800;font-family:var(--font-display);margin-bottom:6px}.login-box-sub{color:var(--text-muted);margin-bottom:32px;font-size:14px}.login-tabs{background:var(--bg-soft);border-radius:var(--r-full);margin-bottom:24px;padding:4px;display:flex}.login-tab{border-radius:var(--r-full);text-align:center;cursor:pointer;transition:all var(--t);color:var(--text-muted);font-size:13px;font-weight:600;font-family:var(--font);background:0 0;border:none;flex:1;padding:9px}.login-tab.active{background:var(--dark);color:#fff;box-shadow:var(--shadow-sm)}.login-form{flex-direction:column;gap:14px;display:flex}.login-divider{align-items:center;gap:10px;margin:4px 0;display:flex}.login-divider-line{background:#1c0f0512;flex:1;height:1px}.login-divider-text{color:var(--text-muted);font-size:11.5px;font-weight:500}.onboarding-shell{background:var(--dark);justify-content:center;align-items:center;min-height:100vh;padding:32px;display:flex;position:relative;overflow:hidden}.onboarding-shell:before{content:"";pointer-events:none;background:radial-gradient(at 50% 0,#b8733338 0%,#0000 60%),radial-gradient(at 100% 100%,#c4632a26 0%,#0000 50%);position:absolute;inset:0}.onboarding-card{background:var(--surface);border-radius:var(--r-3xl);width:100%;max-width:520px;box-shadow:var(--shadow-xl);z-index:1;padding:56px;position:relative}.onboarding-dots{gap:6px;margin-bottom:36px;display:flex}.onboarding-dot{border-radius:var(--r-full);background:var(--bg-muted);height:3px;transition:all var(--t);flex:1}.onboarding-dot.active{background:var(--accent)}.onboarding-icon{border-radius:var(--r-xl);background:var(--accent-light);justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:24px;display:flex}.onboarding-icon svg{width:24px;height:24px;color:var(--accent)}.onboarding-title{color:var(--text);letter-spacing:-.04em;font-size:26px;font-weight:800;line-height:1.15;font-family:var(--font-display);margin-bottom:12px}.onboarding-text{color:var(--text-muted);margin-bottom:36px;font-size:14.5px;line-height:1.65}.checkin-shell{background:var(--bg-soft);justify-content:center;align-items:center;min-height:100vh;padding:32px;display:flex}.checkin-card{background:var(--surface);border-radius:var(--r-3xl);width:100%;max-width:560px;box-shadow:var(--shadow-xl);padding:56px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#1c0f051a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#1c0f0533}.today-strip{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);margin-bottom:28px;padding:20px 24px}.hide-mobile{display:inline}.show-mobile{display:none}@media (width<=1200px){.stats-grid,.pillars-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.sidebar{transform:translate(-100%)}.main{margin-left:0}.dash-grid,.login-shell{grid-template-columns:1fr}.login-left{display:none}html,body{overscroll-behavior:none;background:var(--bg-soft)}}@media (width<=600px){.stats-grid{grid-template-columns:repeat(2,1fr)}.pillars-grid{grid-template-columns:1fr}.page{padding:20px 16px}.page-title,.stat-value{font-size:28px}.hide-mobile{display:none}.show-mobile{display:inline}html{height:100%;overflow:hidden}body{background:var(--bg-soft);height:100%;overflow:hidden}.app-shell{-webkit-overflow-scrolling:touch;background:var(--bg-soft);position:fixed;inset:0;overflow:hidden auto}.main{background:var(--bg-soft);min-height:100%}}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.flex-1{flex:1}.min-w-0{min-width:0}.w-full{width:100%}.text-center{text-align:center}.font-bold{font-weight:700}.text-sm{font-size:13px}.text-xs{font-size:11px}.text-muted{color:var(--text-muted)}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.home-page{padding:32px 44px 60px;position:relative;overflow:hidden}.home-watermark{bottom:-60px;right:calc(var(--sidebar-w) - 120px);font-family:var(--font-display);color:#3d1f1406;pointer-events:none;z-index:0;-webkit-user-select:none;user-select:none;letter-spacing:-.08em;font-size:520px;font-weight:900;line-height:1;position:fixed;transform:translate(50%)}.home-header{z-index:1;justify-content:space-between;align-items:center;margin-bottom:32px;display:flex;position:relative}.home-header-left{align-items:center;gap:16px;display:flex}.home-logo{object-fit:cover;border-radius:10px;flex-shrink:0;width:44px;height:44px;display:block}.home-greeting{color:var(--text-muted);margin-bottom:1px;font-size:13px;font-weight:400}.home-name{font-family:var(--font-display);color:var(--text);letter-spacing:-.04em;font-size:26px;font-weight:800;line-height:1}.home-header-right{align-items:center;gap:12px;display:flex}.home-date-pill{border-radius:var(--r-full);background:var(--surface);border:1px solid var(--border-soft);color:var(--text-muted);box-shadow:var(--shadow-sm);align-items:center;gap:6px;padding:7px 14px;font-size:12px;font-weight:500;display:flex}.home-avatar{object-fit:cover;cursor:pointer;border:2px solid var(--border-soft);width:40px;height:40px;transition:all var(--t);border-radius:50%;flex-shrink:0}.home-avatar:hover{border-color:var(--accent);transform:scale(1.05)}.home-avatar-initials{background:var(--dark);color:var(--sand);font-size:15px;font-weight:700;font-family:var(--font-display);justify-content:center;align-items:center;display:flex}.planner-hero{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-2xl);box-shadow:var(--shadow-md);z-index:1;margin-bottom:24px;padding:28px 32px;position:relative;overflow:hidden}.planner-hero-bg-dots{pointer-events:none;border-radius:inherit;background-image:radial-gradient(circle,#3d1f140f 1.2px,#0000 1.2px);background-size:20px 20px;position:absolute;inset:0}.planner-hero-header{z-index:1;justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex;position:relative}.planner-hero-label{color:var(--accent);letter-spacing:.14em;text-transform:uppercase;margin-bottom:4px;font-size:10px;font-weight:700}.planner-hero-date{font-family:var(--font-display);color:var(--text);letter-spacing:-.04em;text-transform:capitalize;font-size:22px;font-weight:800;line-height:1.1}.planner-hero-progress-wrap{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.planner-hero-progress-ring{width:52px;height:52px;position:relative}.planner-hero-progress-ring svg{display:block}.planner-hero-pct{color:var(--text);font-size:11px;font-weight:800;font-family:var(--font-display);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.planner-checklist{z-index:1;flex-direction:column;gap:0;display:flex;position:relative}.planner-task-row{border-bottom:1px solid var(--border-soft);cursor:pointer;transition:all var(--t);align-items:center;gap:14px;padding:13px 0;display:flex}.planner-task-row:last-child{border-bottom:none}.planner-task-row:hover{border-radius:var(--r-md);background:#3d1f1405;margin:0 -8px;padding-left:8px;padding-right:8px}.planner-check-btn{border:1.5px solid var(--text-light);cursor:pointer;width:28px;height:28px;transition:all var(--t);color:var(--text-light);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.planner-check-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.planner-check-done{border-color:var(--success);color:var(--success);background:#2d7a4f14}.planner-task-info{flex:1;min-width:0}.planner-task-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14.5px;font-weight:500;line-height:1.3;overflow:hidden}.planner-task-meta{align-items:center;gap:8px;margin-top:3px;display:flex}.planner-task-time{color:var(--text-muted);background:var(--bg-soft);border-radius:var(--r-full);padding:2px 8px;font-size:11px}.planner-task-cat{font-size:11px;font-weight:600}.planner-done-section{border-top:1px dashed var(--border);margin-top:8px;padding-top:8px}.planner-done-label{color:var(--text-light);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;font-size:10px;font-weight:700}.planner-task-done{opacity:.55}.planner-add-row{color:var(--text-muted);cursor:pointer;transition:color var(--t);text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;margin-top:4px;padding:12px 0;font-size:13px;font-weight:500;display:flex}.planner-add-row:hover{color:var(--accent)}.planner-empty{color:var(--text-muted);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:32px 0;font-size:13.5px;display:flex}.planner-add-btn{border-radius:var(--r-full);background:var(--dark);color:var(--sand);cursor:pointer;transition:all var(--t);border:none;padding:9px 22px;font-family:inherit;font-size:13px;font-weight:600}.planner-add-btn:hover{background:var(--dark-2);transform:translateY(-1px)}.home-bottom-grid{z-index:1;grid-template-columns:1fr 1fr 1fr;gap:20px;margin-bottom:28px;display:grid;position:relative}.home-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);padding:20px 22px}.home-card-label{color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;align-items:center;gap:7px;margin-bottom:14px;font-size:10px;font-weight:700;display:flex}.home-note-textarea{resize:vertical;width:100%;min-height:100px;font-family:var(--font);color:var(--text);placeholder-color:var(--text-light);background:0 0;border:none;outline:none;font-size:13.5px;line-height:1.6}.home-note-textarea::placeholder{color:var(--text-light)}.mini-cal-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.mini-cal-month{color:var(--text);letter-spacing:-.01em;font-size:12.5px;font-weight:700}.mini-cal-nav{background:var(--bg-soft);cursor:pointer;width:24px;height:24px;transition:all var(--t);color:var(--text-2);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.mini-cal-nav:hover{background:var(--accent-light);color:var(--accent)}.mini-cal-grid{grid-template-columns:repeat(7,1fr);gap:1px;display:grid}.mini-cal-weekday{text-align:center;color:var(--text-light);letter-spacing:.06em;text-transform:uppercase;padding:4px 0 6px;font-size:8.5px;font-weight:700}.mini-cal-day{height:26px;color:var(--text-2);cursor:pointer;transition:all var(--t);border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:1px;font-size:11px;font-weight:400;display:flex;position:relative}.mini-cal-day:hover{background:var(--bg-soft)}.mini-cal-day.today{background:var(--dark);color:#fff;font-weight:700}.mini-cal-day.has-tasks{color:var(--accent);font-weight:600}.mini-cal-day.today.has-tasks{color:var(--sand)}.mini-cal-dot{background:var(--accent);border-radius:50%;width:3px;height:3px;position:absolute;bottom:2px}.mini-cal-day.today .mini-cal-dot{background:var(--sand)}.gcal-connect-area{flex-direction:column;align-items:center;gap:10px;padding:8px 0;display:flex}.gcal-icon{border-radius:var(--r-lg);background:var(--accent-light);justify-content:center;align-items:center;width:52px;height:52px;display:flex}.gcal-text{color:var(--text-muted);text-align:center;font-size:12.5px}.gcal-btn{border-radius:var(--r-full);background:var(--dark);color:var(--sand);cursor:pointer;transition:all var(--t);white-space:nowrap;border:none;padding:9px 18px;font-family:inherit;font-size:12px;font-weight:600}.gcal-btn:hover{background:var(--dark-2);transform:translateY(-1px)}.home-section-title{font-family:var(--font-display);color:var(--text);letter-spacing:-.02em;z-index:1;align-items:center;gap:8px;margin-bottom:16px;font-size:16px;font-weight:700;display:flex;position:relative}.pillars-grid{z-index:1;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px;display:grid;position:relative}.pillar-card{border-radius:var(--r-xl);aspect-ratio:4/3;cursor:pointer;transition:transform var(--t-slow), box-shadow var(--t-slow);position:relative;overflow:hidden}.pillar-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)scale(1.01)}.pillar-img{object-fit:cover;width:100%;height:100%;transition:transform .5s;position:absolute;inset:0}.pillar-card:hover .pillar-img{transform:scale(1.06)}.pillar-overlay{background:linear-gradient(#0000 0%,#1c0f0533 45%,#1c0f05e0 100%);position:absolute;inset:0}.pillar-content{padding:14px 16px;position:absolute;bottom:0;left:0;right:0}.pillar-name{color:#fff;font-size:13px;font-weight:700;font-family:var(--font-display);margin-bottom:2px}.pillar-count{color:#ffffff80;font-size:11px}.pillar-edit-btn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;opacity:0;width:28px;height:28px;transition:all var(--t);color:#fff;background:#ffffff26;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:10px;right:10px}.pillar-card:hover .pillar-edit-btn{opacity:1}.home-checkin-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-xl);cursor:pointer;transition:all var(--t);box-shadow:var(--shadow-sm);z-index:1;justify-content:space-between;align-items:center;padding:20px 24px;display:flex;position:relative}.home-checkin-card:hover{box-shadow:var(--shadow-md);border-color:#7a3b2a33;transform:translateY(-1px)}.home-checkin-left{flex-direction:column;display:flex}.home-checkin-right{color:var(--accent);align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}@media (width<=1100px){.home-bottom-grid{grid-template-columns:1fr 1fr}.home-gcal-card{grid-column:1/-1}}@media (width<=900px){.home-page{padding:20px 16px 80px}.home-bottom-grid{grid-template-columns:1fr}.home-gcal-card{grid-column:auto}.pillars-grid{grid-template-columns:repeat(2,1fr)}.home-watermark{font-size:280px;bottom:-30px}}@media (width<=600px){.home-name{font-size:20px}.planner-hero{padding:20px 18px}.planner-hero-date{font-size:17px}.pillars-grid{grid-template-columns:1fr 1fr}}.birthdays-page{padding:40px 44px}.birthday-list{flex-direction:column;gap:12px;margin-top:24px;display:flex}.birthday-item{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-xl);transition:all var(--t);cursor:pointer;align-items:center;gap:16px;padding:16px 20px;display:flex}.birthday-item:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.birthday-avatar{background:var(--accent-light);width:44px;height:44px;color:var(--accent);font-size:16px;font-weight:700;font-family:var(--font-display);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.birthday-info{flex:1;min-width:0}.birthday-name{color:var(--text);font-size:14.5px;font-weight:600}.birthday-date{color:var(--text-muted);margin-top:2px;font-size:12px}.birthday-days{border-radius:var(--r-full);background:var(--accent-light);color:var(--accent);padding:4px 12px;font-size:11px;font-weight:700}.birthday-days.today-bday{background:var(--dark);color:var(--sand)}.birthday-add-btn{border-radius:var(--r-full);background:var(--dark);color:var(--sand);cursor:pointer;transition:all var(--t);border:none;align-items:center;gap:8px;padding:12px 20px;font-family:inherit;font-size:13px;font-weight:600;display:flex}.birthday-add-btn:hover{background:var(--dark-2);transform:translateY(-1px)}.music-page{padding:40px 44px}.music-player-card{background:var(--dark);border-radius:var(--r-2xl);margin-bottom:24px;padding:32px;position:relative;overflow:hidden}.music-player-card:before{content:"";pointer-events:none;background:radial-gradient(at 80% 20%,#edd9b51f 0%,#0000 60%);position:absolute;inset:0}.music-player-title{font-family:var(--font-display);color:var(--sand);margin-bottom:6px;font-size:20px;font-weight:800}.music-player-sub{color:#fff6;margin-bottom:24px;font-size:13px}.music-controls{align-items:center;gap:16px;display:flex}.music-ctrl-btn{cursor:pointer;width:44px;height:44px;transition:all var(--t);color:#ffffffb3;background:#ffffff1a;border:1px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;display:flex}.music-ctrl-btn:hover{color:#fff;background:#ffffff2e}.music-ctrl-btn.play{background:var(--sand);width:52px;height:52px;color:var(--dark);border:none}.music-ctrl-btn.play:hover{background:#fff;transform:scale(1.06)}.music-progress{cursor:pointer;background:#ffffff26;border-radius:2px;flex:1;height:3px}.music-progress-fill{background:var(--sand);border-radius:2px;width:35%;height:100%;transition:width .1s}.whatsapp-page{padding:40px 44px}.whatsapp-hero{border-radius:var(--r-2xl);background:linear-gradient(135deg,#128c7e 0%,#075e54 100%);align-items:center;gap:32px;margin-bottom:24px;padding:40px;display:flex;position:relative;overflow:hidden}.whatsapp-hero:before{content:"";pointer-events:none;background:radial-gradient(at 90% 10%,#ffffff1a 0%,#0000 60%);position:absolute;inset:0}.whatsapp-icon-wrap{border-radius:var(--r-xl);background:#ffffff26;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;display:flex}.whatsapp-hero-text h2{font-family:var(--font-display);color:#fff;letter-spacing:-.04em;margin-bottom:8px;font-size:24px;font-weight:800}.whatsapp-hero-text p{color:#ffffffb3;font-size:14px;line-height:1.6}.whatsapp-connect-btn{border-radius:var(--r-full);color:#128c7e;cursor:pointer;transition:all var(--t);background:#fff;border:none;align-items:center;gap:8px;margin-top:20px;padding:13px 28px;font-family:inherit;font-size:14px;font-weight:700;display:inline-flex}.whatsapp-connect-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.whatsapp-features{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.whatsapp-feature-card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-xl);padding:20px}.whatsapp-feature-icon{border-radius:var(--r-md);color:#128c7e;background:#128c7e1a;justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:12px;display:flex}.whatsapp-feature-title{color:var(--text);margin-bottom:6px;font-size:14px;font-weight:700}.whatsapp-feature-desc{color:var(--text-muted);font-size:12.5px;line-height:1.5}@media (width<=900px){.birthdays-page,.music-page,.whatsapp-page{padding:20px 16px 80px}.whatsapp-hero{flex-direction:column;gap:20px;padding:28px 20px}.whatsapp-features{grid-template-columns:1fr}}
