@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.header{position:sticky;top:0;z-index:90;padding:14px var(--space-lg);display:flex;align-items:center;background:var(--color-bg);border-bottom:1px solid transparent;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.header--scrolled{border-color:#3d7a5e1a;box-shadow:0 1px 12px #2d5a4612}.header-logo-btn{display:flex;align-items:center;gap:10px;background:none;padding:0;cursor:pointer;border-radius:var(--radius-sm);transition:opacity var(--transition-fast)}.header-logo-btn:hover{opacity:.75}.header-logo{display:flex;align-items:center;color:var(--color-primary);flex-shrink:0}.header-leaf{display:block}.header-title{margin:0;font-size:1.2rem;font-weight:700;color:var(--color-primary);letter-spacing:-.025em}.deed-card{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md);background:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-card);position:relative;overflow:hidden;transition:box-shadow var(--transition-base),transform var(--transition-base)}.deed-card:hover{box-shadow:var(--shadow-lift);transform:translateY(-1px)}.deed-card-bar{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent, var(--color-primary));border-radius:var(--radius-md) 0 0 var(--radius-md)}.deed-card-emoji{font-size:1.4rem;flex-shrink:0;line-height:1.4;margin-left:4px}.deed-card-body{flex:1;min-width:0}.deed-card-title{margin:0 0 var(--space-xs) 0;font-size:.95rem;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deed-card-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin:0 0 var(--space-xs) 0;font-size:.875rem;color:var(--accent, var(--color-primary));font-weight:500}.deed-card-recurring-badge{font-size:.75rem;font-weight:500;color:var(--color-text-muted);background:var(--color-surface);padding:2px 8px;border-radius:20px}.deed-card-note{margin:0 0 var(--space-xs) 0;font-size:.82rem;color:var(--color-text-muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deed-card-date{display:block;font-size:.8rem;color:var(--color-text-subtle);margin-top:2px}.deed-card-actions{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-xs);flex-shrink:0}.deed-card-action{font-size:.8rem;font-weight:500;background:none;padding:4px 8px;border-radius:var(--radius-xs);color:var(--color-text-muted);transition:color var(--transition-fast),background var(--transition-fast)}.deed-card-action:hover{background:#0000000d;color:var(--color-text)}.deed-card-action--danger{color:var(--color-error)}.deed-card-action--danger:hover{background:#b54a4a14;color:var(--color-error)}.deed-card-action--muted{opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast),background var(--transition-fast)}.deed-card:hover .deed-card-action--muted{opacity:1}.home{padding-bottom:var(--space-xl)}.home-greeting{font-size:1.1rem;color:var(--color-text-muted);margin:0 0 var(--space-lg) 0;font-weight:400}.home-greeting-name{color:var(--color-text);font-weight:600}.hero{background:var(--color-primary);background-image:radial-gradient(ellipse at 90% 15%,rgba(255,255,255,.12) 0%,transparent 60%),linear-gradient(145deg,#3d7a5e,#2e5e47);color:var(--color-white);border-radius:var(--radius-xl);padding:var(--space-lg) var(--space-lg) var(--space-xl);margin-bottom:var(--space-xl);box-shadow:var(--shadow-float);position:relative;overflow:hidden}.hero:after{content:"";position:absolute;bottom:-18px;right:-18px;width:100px;height:100px;border-radius:50%;background:#ffffff0d;pointer-events:none}.hero-eyebrow{margin:0 0 var(--space-lg) 0;font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;opacity:.7}.hero-stats{display:flex;align-items:center;gap:0}.hero-stat{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center}.hero-stat-value{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}.hero-stat-label{font-size:.75rem;font-weight:500;opacity:.75;margin-top:4px;text-transform:uppercase;letter-spacing:.04em}.hero-divider{width:1px;height:40px;background:#fff3;flex-shrink:0}.hero-empty-hint{margin:var(--space-lg) 0 0 0;text-align:center;font-size:.9rem;opacity:.75}.recent-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-md)}.recent-title{margin:0;font-size:1rem;font-weight:700;color:var(--color-text);letter-spacing:-.01em}.recent-view-all{background:none;color:var(--color-primary);font-size:.85rem;font-weight:500;padding:0;transition:opacity var(--transition-fast)}.recent-view-all:hover{opacity:.75}.recent-empty{text-align:center;padding:var(--space-xl) var(--space-lg);background:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-card);color:var(--color-text-muted)}.recent-empty p{margin:0 0 var(--space-xs) 0;font-weight:500}.recent-empty-hint{font-size:.9rem;opacity:.8}.recent-list{display:flex;flex-direction:column;gap:var(--space-sm)}.journal{padding-bottom:var(--space-xl)}.journal-filters{display:flex;gap:var(--space-sm);margin-bottom:var(--space-xl);overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none;-webkit-mask-image:linear-gradient(to right,black 80%,transparent 100%);mask-image:linear-gradient(to right,black 80%,transparent 100%)}.journal-filters::-webkit-scrollbar{display:none}.journal-tab{display:flex;align-items:center;gap:5px;padding:7px 14px;border-radius:40px;font-size:.85rem;font-weight:500;color:var(--color-text-muted);background:var(--color-white);box-shadow:var(--shadow-card);white-space:nowrap;flex-shrink:0;transition:color var(--transition-base),background var(--transition-base),box-shadow var(--transition-base)}.journal-tab:hover{color:var(--color-text)}.journal-tab.active{background:var(--color-primary);color:var(--color-white);box-shadow:0 3px 12px #3d7a5e40}.journal-tab-emoji{font-size:1rem;line-height:1}.journal-month{margin-bottom:var(--space-xl)}.journal-month-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.journal-month-title{margin:0;font-size:.8rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-muted)}.journal-month-count{font-size:.75rem;font-weight:600;color:var(--color-white);background:var(--color-accent);padding:1px 7px;border-radius:20px;line-height:1.6}.journal-month-list{display:flex;flex-direction:column;gap:var(--space-sm)}.journal-empty{text-align:center;padding:var(--space-2xl) var(--space-lg);background:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.journal-empty-icon{font-size:2.5rem;margin-bottom:var(--space-md)}.journal-empty-title{margin:0 0 var(--space-sm) 0;font-size:1rem;font-weight:600;color:var(--color-text)}.journal-empty-hint{margin:0;font-size:.9rem;color:var(--color-text-muted);line-height:1.5}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#141e1973;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:backdrop-in .2s ease}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}@media (min-width: 640px){.modal-backdrop{align-items:center;padding:var(--space-lg)}}.modal-sheet{background:var(--color-bg);width:100%;max-height:92vh;overflow-y:auto;border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:0 -8px 40px #00000026;animation:sheet-up .3s cubic-bezier(.32,.72,0,1)}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media (min-width: 640px){.modal-sheet{max-width:440px;border-radius:var(--radius-xl);max-height:88vh;animation:modal-in .25s cubic-bezier(.32,.72,0,1)}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}}.modal-steps{display:flex;justify-content:center;gap:6px;padding:14px 0 0}.modal-step-dot{width:6px;height:6px;border-radius:50%;background:#3d7a5e33;transition:background var(--transition-base),width var(--transition-base)}.modal-step-dot.active{background:var(--color-primary);width:18px;border-radius:3px}.modal-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:1px solid rgba(61,122,94,.08);min-height:60px}.modal-title{flex:1;margin:0;font-size:1.15rem;font-weight:700;color:var(--color-text);display:flex;align-items:center;gap:8px;letter-spacing:-.02em}.modal-title-emoji{font-size:1.2rem}.modal-back{background:none;color:var(--color-text-muted);font-size:1.3rem;padding:0 var(--space-sm) 0 0;line-height:1;transition:color var(--transition-fast)}.modal-back:hover{color:var(--color-text)}.modal-close{width:32px;height:32px;border-radius:50%;background:var(--color-surface);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-left:auto;transition:background var(--transition-fast),color var(--transition-fast)}.modal-close:hover{background:#00000014;color:var(--color-text)}.modal-categories{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm);padding:var(--space-lg)}.category-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-md);background:var(--cat-bg, rgba(61,122,94,.08));color:var(--cat-color, var(--color-primary));border-radius:var(--radius-md);border:2px solid transparent;transition:border-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-fast)}.category-btn:hover{border-color:var(--cat-color, var(--color-primary));box-shadow:0 4px 16px #00000014;transform:translateY(-1px)}.category-btn:active{transform:scale(.97)}.category-emoji{font-size:2rem;line-height:1}.category-label{font-size:.85rem;font-weight:600;color:var(--color-text);text-align:center}.modal-form{padding:var(--space-md) var(--space-lg) var(--space-xl)}.field{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-md)}.field-label{font-size:.85rem;font-weight:600;color:var(--color-text)}.field-label-opt{font-weight:400;color:var(--color-text-muted)}.field-hint{font-size:.8rem;color:var(--color-text-muted);line-height:1.4}.modal-form input,.modal-form select,.modal-form textarea{width:100%;min-width:0;padding:11px var(--space-md);border:1.5px solid rgba(61,122,94,.18);border-radius:var(--radius-sm);background:var(--color-white);color:var(--color-text);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.modal-form input:focus,.modal-form select:focus,.modal-form textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3d7a5e1f}.modal-form textarea{resize:vertical;min-height:68px}.field-row{display:flex;gap:var(--space-sm)}.field-row input{flex:1;min-width:0}.field-row select{width:90px;flex-shrink:0}.modal-save{width:100%;padding:14px var(--space-lg);margin-top:var(--space-md);background:var(--color-primary);color:var(--color-white);font-size:1rem;font-weight:600;border-radius:var(--radius-md);transition:opacity var(--transition-base),transform var(--transition-fast);letter-spacing:-.01em}.modal-save:hover:not(:disabled){opacity:.92;transform:translateY(-1px)}.modal-save:active:not(:disabled){transform:scale(.98)}.modal-save:disabled{opacity:.45;cursor:not-allowed}.modal-confirmation{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl) var(--space-lg);gap:var(--space-md);min-height:200px}.confirmation-check{animation:check-in .4s cubic-bezier(.34,1.56,.64,1)}@keyframes check-in{0%{transform:scale(0) rotate(-20deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.check-path{stroke-dasharray:30;stroke-dashoffset:30;animation:draw-check .35s ease .25s forwards}@keyframes draw-check{to{stroke-dashoffset:0}}.modal-confirmation-title{margin:0;font-size:1.25rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.modal-confirmation-sub{margin:0;font-size:.95rem;color:var(--color-text-muted)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;max-width:640px;margin:0 auto;display:flex;background:#ffffffeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(61,122,94,.1);padding-top:var(--space-sm);padding-bottom:max(var(--space-sm),env(safe-area-inset-bottom));z-index:50}@media (min-width: 640px){.bottom-nav{border-radius:var(--radius-lg) var(--radius-lg) 0 0}}@media (min-width: 768px){.bottom-nav{max-width:720px;left:50%;transform:translate(-50%)}}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:var(--space-xs) var(--space-sm);font-size:.75rem;font-weight:500;color:var(--color-text-muted);background:none;position:relative;transition:color var(--transition-base)}.bottom-nav-item:hover{color:var(--color-text)}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-dot{position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--color-primary);animation:dot-pop .2s ease}@keyframes dot-pop{0%{transform:translate(-50%) scale(0);opacity:0}to{transform:translate(-50%) scale(1);opacity:1}}.recurring-prompt{display:flex;align-items:flex-start;gap:var(--space-md);background:var(--color-white);border:1.5px solid var(--color-accent);border-left:4px solid var(--color-accent);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-lg);box-shadow:0 2px 12px #c8a96e1f;animation:prompt-in .3s ease}@keyframes prompt-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.recurring-prompt-icon{font-size:1.2rem;color:var(--color-accent);flex-shrink:0;line-height:1.4}.recurring-prompt-body{flex:1}.recurring-prompt-text{margin:0 0 var(--space-sm) 0;font-size:.9rem;color:var(--color-text);line-height:1.4}.recurring-prompt-more{font-size:.82rem;color:var(--color-text-muted);margin-left:4px}.recurring-prompt-actions{display:flex;align-items:center;gap:var(--space-md)}.recurring-prompt-btn{background:var(--color-accent);color:var(--color-white);padding:7px 16px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;transition:opacity var(--transition-fast),transform var(--transition-fast)}.recurring-prompt-btn:hover{opacity:.9;transform:translateY(-1px)}.recurring-prompt-dismiss{background:none;color:var(--color-text-muted);font-size:.82rem;padding:0;transition:color var(--transition-fast)}.recurring-prompt-dismiss:hover{color:var(--color-text)}.auth-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#141e1885;backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);z-index:600;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);animation:auth-fade-in .2s ease}@keyframes auth-fade-in{0%{opacity:0}to{opacity:1}}.auth-modal{background:var(--color-bg);border-radius:var(--radius-xl);padding:var(--space-xl) var(--space-xl) var(--space-lg);width:100%;max-width:400px;box-shadow:0 28px 80px #00000038;position:relative;animation:auth-modal-in .28s cubic-bezier(.34,1.25,.64,1)}@keyframes auth-modal-in{0%{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.auth-modal-close{position:absolute;top:var(--space-md);right:var(--space-md);width:30px;height:30px;border-radius:50%;background:var(--color-surface);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.auth-modal-close:hover{background:#00000014;color:var(--color-text)}.auth-modal-logo{width:52px;height:52px;border-radius:var(--radius-md);background:var(--color-primary);color:var(--color-white);display:flex;align-items:center;justify-content:center;margin:0 0 var(--space-md) 0}.auth-tabs{display:flex;gap:2px;background:var(--color-surface);border-radius:var(--radius-sm);padding:3px;margin-bottom:var(--space-lg)}.auth-tab{flex:1;padding:8px;font-size:.875rem;font-weight:600;border-radius:calc(var(--radius-sm) - 2px);background:none;color:var(--color-text-muted);transition:background var(--transition-base),color var(--transition-base)}.auth-tab.active{background:var(--color-white);color:var(--color-text);box-shadow:0 1px 4px #00000014}.auth-title{margin:0 0 var(--space-xs) 0;font-size:1.35rem;font-weight:800;letter-spacing:-.03em;color:var(--color-text)}.auth-sub{margin:0 0 var(--space-lg) 0;font-size:.875rem;color:var(--color-text-muted);line-height:1.5}.auth-google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:11px var(--space-lg);background:var(--color-white);border:1.5px solid rgba(0,0,0,.12);border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;color:var(--color-text);transition:background var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast);margin-bottom:var(--space-md)}.auth-google-btn:hover:not(:disabled){background:var(--color-surface);border-color:#0003;transform:translateY(-1px)}.auth-google-btn:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);color:var(--color-text-subtle);font-size:.8rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#00000014}.auth-field{display:flex;flex-direction:column;gap:5px;margin-bottom:var(--space-md)}.auth-field label{font-size:.82rem;font-weight:600;color:var(--color-text);display:flex;align-items:center;gap:var(--space-sm)}.auth-field-hint{font-weight:400;color:var(--color-text-muted)}.auth-field input{padding:11px var(--space-md);border:1.5px solid rgba(61,122,94,.18);border-radius:var(--radius-sm);background:var(--color-white);color:var(--color-text);font-size:1rem;width:100%;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.auth-field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3d7a5e1f}.auth-forgot{display:block;background:none;color:var(--color-primary);font-size:.8rem;margin:-8px 0 var(--space-md) auto;padding:0;text-align:right;transition:opacity var(--transition-fast)}.auth-forgot:hover{opacity:.7}.auth-error{background:#b54a4a14;border:1px solid rgba(181,74,74,.2);border-radius:var(--radius-xs);color:var(--color-error);font-size:.85rem;padding:var(--space-sm) var(--space-md);margin:0 0 var(--space-md) 0;line-height:1.4}.auth-success{background:#3d7a5e14;border:1px solid rgba(61,122,94,.2);border-radius:var(--radius-sm);color:var(--color-primary);font-size:.9rem;padding:var(--space-md);margin-bottom:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);line-height:1.5}.auth-btn-primary{width:100%;padding:13px var(--space-lg);background:var(--color-primary);color:var(--color-white);font-size:.95rem;font-weight:700;border-radius:var(--radius-md);transition:background var(--transition-base),transform var(--transition-fast),opacity var(--transition-fast);margin-bottom:var(--space-sm);letter-spacing:-.01em}.auth-btn-primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px)}.auth-btn-primary:disabled{opacity:.5;cursor:not-allowed}.auth-link{display:block;background:none;color:var(--color-primary);font-size:.85rem;font-weight:500;padding:var(--space-xs) 0;text-align:center;transition:opacity var(--transition-fast)}.auth-link:hover{opacity:.7}.auth-privacy{margin:var(--space-md) 0 0;font-size:.75rem;color:var(--color-text-subtle);text-align:center;line-height:1.4}.lp{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);overflow-x:hidden}.lp-section-inner,.lp-nav-inner,.lp-hero-inner,.lp-impact-inner,.lp-philosophy-inner,.lp-quote-inner,.lp-cta-inner,.lp-footer-inner{max-width:1080px;margin:0 auto;padding:0 var(--space-lg)}.lp-section-eyebrow{font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);margin:0 0 var(--space-sm) 0}.lp-section-title{margin:0 0 var(--space-xl) 0;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;letter-spacing:-.03em;color:var(--color-text)}.lp-logo{display:flex;align-items:center;gap:8px;font-size:1.1rem;font-weight:700;color:var(--color-primary);letter-spacing:-.02em}.lp-logo-leaf{color:var(--color-primary)}.lp-nav{position:sticky;top:0;z-index:100;background:#faf7f2e0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(61,122,94,.1)}.lp-nav-inner{display:flex;align-items:center;justify-content:space-between;padding-top:16px;padding-bottom:16px}.lp-nav-login{background:var(--color-primary);color:var(--color-white);font-size:.875rem;font-weight:600;padding:9px 20px;border-radius:40px;transition:background var(--transition-base),transform var(--transition-fast)}.lp-nav-login:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.lp-btn-primary{display:inline-flex;align-items:center;background:var(--color-primary);color:var(--color-white);font-size:1rem;font-weight:600;padding:14px 28px;border-radius:40px;border:none;cursor:pointer;transition:background var(--transition-base),transform var(--transition-fast),box-shadow var(--transition-base);box-shadow:0 4px 20px #3d7a5e47;white-space:nowrap}.lp-btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 8px 28px #3d7a5e59}.lp-btn-primary--large{font-size:1.1rem;padding:18px 36px}.lp-btn-ghost{display:inline-flex;align-items:center;color:var(--color-primary);font-size:.95rem;font-weight:500;padding:14px 20px;border-radius:40px;background:none;text-decoration:none;transition:background var(--transition-fast)}.lp-btn-ghost:hover{background:#3d7a5e12}.lp-hero{position:relative;padding:clamp(60px,10vw,120px) 0 clamp(60px,10vw,100px);overflow:hidden}.lp-hero-inner{position:relative;z-index:1;max-width:720px}.lp-hero-eyebrow{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);margin:0 0 var(--space-md) 0}.lp-hero-headline{font-size:clamp(2.2rem,5.5vw,4rem);font-weight:800;letter-spacing:-.04em;line-height:1.12;margin:0 0 var(--space-lg) 0;color:var(--color-text)}.lp-hero-accent{color:var(--color-primary);position:relative}.lp-hero-sub{font-size:clamp(1rem,2vw,1.2rem);color:var(--color-text-muted);line-height:1.65;max-width:540px;margin:0 0 var(--space-xl) 0}.lp-hero-ctas{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center}.lp-hero-orb{position:absolute;border-radius:50%;pointer-events:none}.lp-hero-orb--1{width:500px;height:500px;right:-120px;top:-80px;background:radial-gradient(circle,rgba(61,122,94,.12) 0%,transparent 70%)}.lp-hero-orb--2{width:300px;height:300px;right:80px;bottom:-60px;background:radial-gradient(circle,rgba(200,169,110,.1) 0%,transparent 70%)}.lp-impact{background:var(--color-primary);background-image:linear-gradient(135deg,#3d7a5e,#2e5e47);color:var(--color-white);padding:clamp(40px,7vw,80px) 0}.lp-impact-inner{text-align:center}.lp-impact-label{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.65;margin:0 0 var(--space-lg) 0}.lp-impact-stats{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}.lp-impact-stat{flex:1;min-width:160px;display:flex;flex-direction:column;align-items:center;padding:var(--space-md)}.lp-impact-value{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;letter-spacing:-.03em;line-height:1.1}.lp-impact-desc{font-size:.8rem;font-weight:500;opacity:.7;margin-top:6px;text-transform:uppercase;letter-spacing:.06em}.lp-impact-divider{width:1px;height:50px;background:#fff3;flex-shrink:0}.lp-impact-note{font-size:.82rem;opacity:.55;margin:var(--space-lg) 0 0 0;font-style:italic}.lp-steps{padding:clamp(60px,10vw,100px) 0;background:var(--color-white)}.lp-steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-xl)}.lp-step{position:relative}.lp-step-icon{width:56px;height:56px;border-radius:var(--radius-md);background:#3d7a5e14;color:var(--color-primary);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-md)}.lp-step-n{display:block;font-size:.72rem;font-weight:800;letter-spacing:.12em;color:var(--color-accent);text-transform:uppercase;margin-bottom:6px}.lp-step-title{font-size:1.2rem;font-weight:700;letter-spacing:-.02em;margin:0 0 var(--space-sm) 0;color:var(--color-text)}.lp-step-desc{font-size:.95rem;color:var(--color-text-muted);line-height:1.6;margin:0}.lp-philosophy{padding:clamp(60px,10vw,100px) 0;background:var(--color-bg)}.lp-philosophy-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}@media (max-width: 768px){.lp-philosophy-inner{grid-template-columns:1fr}}.lp-philosophy-title{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;letter-spacing:-.04em;line-height:1.15;margin:0 0 var(--space-lg) 0;color:var(--color-text)}.lp-philosophy-body{font-size:1rem;color:var(--color-text-muted);line-height:1.7;margin:0 0 var(--space-lg) 0}.lp-philosophy-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-sm)}.lp-philosophy-list li{font-size:.92rem;color:var(--color-text);line-height:1.5}.lp-philosophy-card{background:var(--color-primary);background-image:linear-gradient(145deg,#3d7a5e,#2e5e47);border-radius:var(--radius-xl);padding:var(--space-lg);box-shadow:0 20px 60px #3d7a5e4d;transform:rotate(1.5deg);transition:transform var(--transition-slow)}.lp-philosophy-card:hover{transform:rotate(0)}.lp-philosophy-card-inner{background:#ffffff0f;border-radius:var(--radius-lg);padding:var(--space-lg)}.lp-philosophy-card-eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff9;margin:0 0 var(--space-md) 0}.lp-philosophy-card-stats{display:flex;align-items:center;gap:0;margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid rgba(255,255,255,.15)}.lp-philosophy-card-stats>div:not(.lp-philosophy-card-div){flex:1;text-align:center;display:flex;flex-direction:column}.lp-philosophy-card-val{font-size:1.2rem;font-weight:700;color:#fff;letter-spacing:-.02em}.lp-philosophy-card-lbl{font-size:.68rem;color:#ffffff8c;text-transform:uppercase;letter-spacing:.06em;margin-top:3px}.lp-philosophy-card-div{width:1px;height:36px;background:#fff3}.lp-philosophy-card-deeds{display:flex;flex-direction:column;gap:var(--space-sm)}.lp-philosophy-card-deed{display:flex;align-items:center;gap:var(--space-sm);background:#ffffff14;border-radius:var(--radius-sm);padding:10px var(--space-md)}.lp-philosophy-card-deed span{font-size:1.2rem;flex-shrink:0}.lp-philosophy-card-deed div p{margin:0;line-height:1.3}.lp-philosophy-card-deed div p:first-child{font-size:.85rem;font-weight:600;color:#ffffffeb}.lp-philosophy-card-deed div p:last-child{font-size:.74rem;color:#ffffff80}.lp-cats{padding:clamp(60px,10vw,100px) 0;background:var(--color-white)}.lp-cats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-md)}.lp-cat{padding:var(--space-lg);border-radius:var(--radius-lg);background:var(--cat-bg, rgba(61,122,94,.07));border:1.5px solid transparent;transition:border-color var(--transition-base),transform var(--transition-base),box-shadow var(--transition-base);cursor:default}.lp-cat:hover{border-color:var(--cat-color);transform:translateY(-3px);box-shadow:0 8px 24px #00000012}.lp-cat-emoji{display:block;font-size:2rem;margin-bottom:var(--space-sm)}.lp-cat-label{font-size:.95rem;font-weight:700;color:var(--cat-color);margin:0 0 var(--space-xs) 0}.lp-cat-desc{font-size:.82rem;color:var(--color-text-muted);line-height:1.5;margin:0}.lp-quote{padding:clamp(60px,10vw,100px) 0;background:var(--color-surface, #F3EEE6)}.lp-quote-inner{text-align:center;max-width:680px}.lp-quote-mark{color:var(--color-primary);margin-bottom:var(--space-lg);display:block;margin-left:auto;margin-right:auto}.lp-quote-text{font-size:clamp(1.3rem,3vw,1.9rem);font-weight:600;letter-spacing:-.025em;line-height:1.45;color:var(--color-text);margin:0 0 var(--space-lg) 0;font-style:italic}.lp-quote-attr{font-size:.85rem;color:var(--color-text-muted);margin:0}.lp-cta{padding:clamp(80px,12vw,140px) 0;background:var(--color-bg);text-align:center}.lp-cta-title{font-size:clamp(1.8rem,4vw,3rem);font-weight:800;letter-spacing:-.04em;line-height:1.15;margin:0 0 var(--space-md) 0;color:var(--color-text)}.lp-cta-sub{font-size:1.05rem;color:var(--color-text-muted);margin:0 0 var(--space-xl) 0}.lp-cta-note{margin:var(--space-md) 0 0 0;font-size:.82rem;color:var(--color-text-subtle)}.lp-footer{background:var(--color-primary);color:#ffffffb3;padding:var(--space-xl) 0}.lp-footer-inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.lp-footer-logo{color:#ffffffe6}.lp-footer-tagline{margin:0;font-size:.9rem;opacity:.7}.lp-footer-copy{margin:0;font-size:.78rem;opacity:.5}.lp-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#141e1880;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:500;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);animation:lp-backdrop-in .2s ease}@keyframes lp-backdrop-in{0%{opacity:0}to{opacity:1}}.lp-modal{background:var(--color-bg);border-radius:var(--radius-xl);padding:var(--space-xl);width:100%;max-width:420px;box-shadow:0 24px 80px #0000002e;position:relative;animation:lp-modal-in .3s cubic-bezier(.34,1.3,.64,1);text-align:center}@keyframes lp-modal-in{0%{opacity:0;transform:scale(.9) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}.lp-modal-close{position:absolute;top:var(--space-md);right:var(--space-md);width:32px;height:32px;border-radius:50%;background:var(--color-surface);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.lp-modal-close:hover{background:#00000014;color:var(--color-text)}.lp-modal-logo{width:64px;height:64px;border-radius:var(--radius-lg);background:#3d7a5e1a;color:var(--color-primary);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md)}.lp-modal-title{font-size:1.5rem;font-weight:800;letter-spacing:-.03em;color:var(--color-text);margin:0 0 var(--space-sm) 0}.lp-modal-sub{font-size:.9rem;color:var(--color-text-muted);margin:0 0 var(--space-lg) 0;line-height:1.5}.lp-modal-field{display:flex;flex-direction:column;gap:var(--space-xs);text-align:left;margin-bottom:var(--space-md)}.lp-modal-field span{font-size:.85rem;font-weight:600;color:var(--color-text)}.lp-modal-field input{padding:13px var(--space-md);border:1.5px solid rgba(61,122,94,.2);border-radius:var(--radius-sm);background:var(--color-white);color:var(--color-text);font-size:1rem;width:100%;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.lp-modal-field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3d7a5e1f}.lp-modal-field input.error{border-color:var(--color-error)}.lp-modal-error{font-size:.8rem!important;font-weight:400!important;color:var(--color-error)!important}.lp-modal-enter{width:100%;padding:14px var(--space-lg);background:var(--color-primary);color:var(--color-white);font-size:1rem;font-weight:700;border-radius:var(--radius-md);border:none;cursor:pointer;transition:background var(--transition-base),transform var(--transition-fast);margin-bottom:var(--space-md)}.lp-modal-enter:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.lp-modal-privacy{font-size:.78rem;color:var(--color-text-muted);margin:0}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;animation:pulse-opacity 1.2s ease-in-out infinite}@keyframes pulse-opacity{0%,to{opacity:.3}50%{opacity:1}}.app{min-height:100vh;min-height:100dvh;max-width:640px;margin:0 auto;position:relative}@media (min-width: 768px){.app{max-width:720px;box-shadow:0 0 60px #2d5a461a}}.main{padding:var(--space-md) var(--space-md);padding-top:var(--space-md)}.fab{position:fixed;bottom:calc(62px + var(--space-md));right:var(--space-lg);width:54px;height:54px;border-radius:50%;background:var(--color-primary);color:var(--color-white);font-size:26px;font-weight:300;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-float);z-index:100;transition:transform var(--transition-base),box-shadow var(--transition-base),background var(--transition-base)}.fab:hover{transform:scale(1.08) rotate(45deg);background:var(--color-primary-dark);box-shadow:0 8px 32px #2d5a464d}.fab:active{transform:scale(.95) rotate(45deg)}@media (min-width: 768px){.fab{bottom:var(--space-lg);right:max(var(--space-lg),calc(50vw - 360px + var(--space-lg)))}}:root{--color-bg: #FAF7F2;--color-surface: #F3EEE6;--color-primary: #3D7A5E;--color-primary-dark: #2E5E47;--color-accent: #C8A96E;--color-accent-light: rgba(200, 169, 110, .14);--color-text: #2C2C2C;--color-text-muted: #6B6B6B;--color-text-subtle: #9A9A9A;--color-white: #ffffff;--color-error: #b54a4a;--cat-donation: #3D7A5E;--cat-volunteering: #4A7FA5;--cat-kindness: #B87058;--cat-environmental: #5A9A70;--cat-other: #C8A96E;--shadow-card: 0 2px 14px rgba(45, 90, 70, .08);--shadow-lift: 0 6px 24px rgba(45, 90, 70, .14);--shadow-float: 0 8px 28px rgba(45, 90, 70, .22);--radius-xs: 6px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-xl: 24px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 36px;--space-2xl: 48px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--transition-fast: .15s ease;--transition-base: .22s ease;--transition-slow: .35s ease}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{margin:0;font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);min-height:100vh;min-height:100dvh;line-height:1.5}#root{min-height:100vh;min-height:100dvh;padding-bottom:88px}@media (min-width: 768px){#root{padding-bottom:104px}}button{font-family:inherit;cursor:pointer;border:none}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-xs)}input,select,textarea{font-family:inherit;font-size:1rem}a{color:var(--color-primary);text-decoration:none}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#3d7a5e33;border-radius:2px}
