:root{--bg-dark: #2a2a2a;--bg-darker: #1a1a1a;--gold: #D4A574;--gold-hover: #C9A05C;--text-light: #ffffff;--text-gray: #cccccc;font-family:Georgia,Times New Roman,serif;line-height:1.6;font-weight:400;color:var(--text-light);background-color:var(--bg-dark);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:#f5f0e8}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--gold);text-decoration:none;transition:color .3s}a:hover{color:var(--gold-hover)}h1,h2,h3,h4,h5,h6{font-family:Georgia,Times New Roman,serif;font-weight:400}button{border-radius:4px;border:2px solid var(--gold);padding:12px 32px;font-size:.95em;font-weight:600;font-family:Arial,sans-serif;background-color:var(--gold);color:var(--bg-darker);cursor:pointer;transition:all .3s;text-transform:uppercase;letter-spacing:1px}button:hover{background-color:transparent;color:var(--gold)}button:disabled{opacity:.6;cursor:not-allowed}input,textarea,select{font-family:Arial,sans-serif}:root{--sh-header: #B5624A;--sh-header-text:#FFF8F2;--sh-cat: #6B7C45;--sh-cat-text: #F5F0E8;--sh-bg: #F5F0E8;--sh-surface: #FFFFFF;--sh-border: #DDD6C8;--sh-text: #2C2412;--sh-muted: #8B8070;--sh-bought: #A9A090;--sh-accent: #B5624A;--sh-green: #4E7C50;--sh-danger: #C0392B;--sh-radius: 10px;--sh-shadow: 0 2px 8px rgba(0,0,0,.1)}.sh-icon-btn,.sh-drag-handle{box-sizing:border-box;appearance:none;-webkit-appearance:none;font:inherit}.sh-root{flex:1;background:var(--sh-bg);font-family:Segoe UI,system-ui,sans-serif;color:var(--sh-text);display:flex;flex-direction:column}.sh-header{background:var(--sh-header);color:var(--sh-header-text);padding:8px 16px;display:flex;align-items:center;gap:10px;position:sticky;top:0;z-index:100;box-shadow:var(--sh-shadow);min-height:68px}.sh-header h1{flex:1;font-size:1.15rem;font-weight:700;margin:0;letter-spacing:.02em}.sh-header-logo{height:30px;max-height:30px;width:auto;display:block;object-fit:contain;background:#ffffffeb;border-radius:6px;padding:3px 6px}.sh-header-title{font-size:1rem;font-weight:700;color:var(--sh-header-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.sh-header-side{flex:1;display:flex;align-items:center}.sh-header-side--right{justify-content:flex-end}.sh-header-center{display:flex;flex-direction:column;align-items:center;gap:2px;flex-shrink:0}.sh-header-btn{background:#ffffff2e;border:none;border-radius:6px;color:var(--sh-header-text);padding:6px 10px;font-size:.8rem;cursor:pointer;white-space:nowrap;text-decoration:none;display:inline-block}.sh-header-btn:active{opacity:.7}.sh-quick-add{padding:10px 12px;background:var(--sh-surface);border-bottom:1px solid var(--sh-border);display:flex;gap:8px}.sh-quick-add input{flex:1;border:1px solid var(--sh-border);border-radius:8px;padding:9px 12px;font-size:.95rem;background:var(--sh-bg);color:var(--sh-text);outline:none}.sh-quick-add input:focus{border-color:var(--sh-accent)}.sh-quick-add button{background:var(--sh-accent);color:#fff;border:none;border-radius:8px;padding:9px 16px;font-size:.9rem;font-weight:600;cursor:pointer}.sh-quick-add button:active{opacity:.8}.sh-category-header{background:var(--sh-cat);color:var(--sh-cat-text);padding:5px 12px;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between;width:100%;border:none;cursor:pointer;text-align:left;appearance:none;-webkit-appearance:none;font-family:inherit}.sh-category-add{font-size:1rem;font-weight:700;line-height:1;background:#ffffff4d;border-radius:50%;width:20px;height:20px;min-width:20px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:none;letter-spacing:0}.sh-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--sh-surface);border-bottom:1px solid var(--sh-border);transition:background .15s;min-height:0}.sh-item:active{background:#ede8df}.sh-item-check{width:22px;height:22px;min-width:22px;min-height:22px;border-radius:50%;border:2px solid var(--sh-border);background:transparent;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:0;margin:0;box-sizing:border-box;transition:border-color .15s,background .15s;appearance:none;-webkit-appearance:none;outline:none}.sh-item-check.bought{background:var(--sh-green);border-color:var(--sh-green);color:#fff}.sh-item-check svg{width:12px;height:12px;display:block}.sh-item-info{flex:1;min-width:0}.sh-item-name{font-size:.88rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s;line-height:1.3}.sh-item.bought .sh-item-name{color:var(--sh-bought);text-decoration:line-through}.sh-item-qty{font-size:.72rem;color:var(--sh-muted);margin-top:1px;line-height:1.2}.sh-item.bought .sh-item-qty{color:var(--sh-bought)}.sh-item-actions{display:flex;gap:8px;flex-shrink:0}.sh-icon-btn{background:none;border:none;border-radius:6px;padding:5px;cursor:pointer;color:var(--sh-muted);display:flex;align-items:center;justify-content:center}.sh-icon-btn:active{background:var(--sh-border)}.sh-icon-btn.danger:active{color:var(--sh-danger)}.sh-footer{background:var(--sh-surface);border-top:1px solid var(--sh-border);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;position:sticky;bottom:0;font-size:.85rem;color:var(--sh-muted);z-index:10}.sh-footer-clear{background:var(--sh-accent);color:#fff;border:none;border-radius:8px;padding:7px 14px;font-size:.82rem;font-weight:600;cursor:pointer}.sh-footer-clear:disabled{background:var(--sh-border);color:var(--sh-muted);cursor:default}.sh-empty{text-align:center;padding:48px 24px;color:var(--sh-muted)}.sh-empty p{margin:0;font-size:.95rem}.sh-btn-primary{flex:1;background:var(--sh-accent);color:#fff;border:none;border-radius:8px;padding:12px 16px;font-size:.95rem;font-weight:600;cursor:pointer;text-align:center;box-sizing:border-box;display:block}.sh-btn-primary:active{opacity:.8}.sh-btn-secondary{background:var(--sh-border);color:var(--sh-text);border:none;border-radius:8px;padding:12px 16px;font-size:.95rem;cursor:pointer;text-align:center;box-sizing:border-box;display:block}.sh-btn-secondary:active{opacity:.8}.sh-overlay{position:fixed;inset:0;background:#00000073;z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:0}@media(min-width:480px){.sh-overlay{align-items:center}}.sh-modal{background:var(--sh-surface);border-radius:16px 16px 0 0;width:100%;max-width:480px;padding:20px 18px 32px;animation:sh-slide-up .22s ease-out}@media(min-width:480px){.sh-modal{border-radius:16px;padding-bottom:20px}}@keyframes sh-slide-up{0%{transform:translateY(60px);opacity:0}to{transform:none;opacity:1}}.sh-modal h2{margin:0 0 16px;font-size:1rem;color:var(--sh-text)}.sh-field{margin-bottom:12px}.sh-field label{display:block;font-size:.78rem;font-weight:600;color:var(--sh-muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em}.sh-field input,.sh-field select{width:100%;box-sizing:border-box;border:1px solid var(--sh-border);border-radius:8px;padding:10px 12px;font-size:.95rem;background:var(--sh-bg);color:var(--sh-text);outline:none;appearance:none}.sh-field input:focus,.sh-field select:focus{border-color:var(--sh-accent)}.sh-modal-actions{display:flex;gap:8px;margin-top:16px}.sh-login{min-height:100dvh;background:var(--sh-bg);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;gap:0}.sh-login-card{background:var(--sh-surface);border-radius:16px;box-shadow:var(--sh-shadow);padding:32px 24px;width:100%;max-width:360px;text-align:center}.sh-login-logo{height:72px;width:auto;margin:0 auto 16px;display:block}.sh-login-card h1{font-size:1.4rem;color:var(--sh-header);margin:0 0 6px}.sh-login-card p{color:var(--sh-muted);font-size:.9rem;margin:0 0 24px}.sh-google-btn{width:100%;background:var(--sh-surface);border:2px solid var(--sh-border);border-radius:10px;padding:13px;font-size:.95rem;font-weight:600;color:var(--sh-text);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:border-color .15s}.sh-google-btn:hover{border-color:var(--sh-accent)}.sh-error{color:var(--sh-danger);font-size:.82rem;margin-top:10px}.sh-dashboard{min-height:100dvh;background:var(--sh-bg);display:flex;flex-direction:column}.sh-dashboard-content{flex:1;padding:16px 14px;display:flex;flex-direction:column;gap:12px;max-width:900px;margin:0 auto;width:100%;box-sizing:border-box}.sh-section-title{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--sh-muted);margin:4px 0 6px}.sh-list-card{background:var(--sh-surface);border-radius:var(--sh-radius);padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh-shadow);cursor:pointer;transition:transform .12s;border:none;width:100%;text-align:left}.sh-list-card:active{transform:scale(.98)}.sh-list-card-name{font-weight:600;font-size:.98rem;flex:1}.sh-list-card-meta{font-size:.78rem;color:var(--sh-muted);margin-top:2px}.sh-list-card-arrow{color:var(--sh-muted);font-size:1.1rem}.sh-action-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px}.sh-action-card{background:var(--sh-surface);border:2px dashed var(--sh-border);border-radius:var(--sh-radius);padding:18px 12px;text-align:center;cursor:pointer;font-size:.88rem;font-weight:600;color:var(--sh-muted);transition:border-color .15s,color .15s}.sh-action-card:hover{border-color:var(--sh-accent);color:var(--sh-accent)}.sh-help{background:var(--sh-surface);border-radius:var(--sh-radius);padding:12px 14px;display:flex;flex-direction:column;gap:12px}.sh-help-step{display:flex;gap:12px;align-items:flex-start}.sh-help-icon{font-size:1.2rem;flex-shrink:0;margin-top:1px}.sh-help-step strong{display:block;font-size:.85rem;color:var(--sh-text);margin-bottom:2px}.sh-help-step p{margin:0;font-size:.78rem;color:var(--sh-muted);line-height:1.45}.sh-share-code{display:inline-flex;align-items:center;gap:6px;background:var(--sh-bg);border:1px solid var(--sh-border);border-radius:6px;padding:4px 10px;font-size:.8rem;font-family:monospace;font-weight:700;color:var(--sh-muted);cursor:pointer;letter-spacing:.12em}.sh-share-code:active{background:var(--sh-border)}.sh-install-banner{display:flex;align-items:center;gap:10px;background:var(--sh-surface);border:1px solid var(--sh-border);border-left:3px solid var(--sh-accent);border-radius:var(--sh-radius);padding:12px 14px;margin:8px 14px;box-shadow:var(--sh-shadow)}.sh-install-icon{font-size:1.4rem;flex-shrink:0}.sh-install-text{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.sh-install-text strong{font-size:.88rem;font-weight:700;color:var(--sh-text)}.sh-install-text span{font-size:.78rem;color:var(--sh-muted);line-height:1.4}.sh-install-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.sh-install-btn{background:var(--sh-accent);color:#fff;border:none;border-radius:8px;padding:7px 12px;font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap}.sh-install-btn:active{opacity:.8}.sh-install-dismiss{background:none;border:none;color:var(--sh-muted);font-size:1rem;cursor:pointer;padding:4px 6px;line-height:1}.sh-list-content{flex:1;display:flex;flex-direction:column;width:100%;max-width:900px;margin:0 auto;box-sizing:border-box}.sh-list-body{flex:1;overflow-y:auto}.sh-suggestions{position:absolute;left:0;right:0;top:calc(100% + 2px);background:var(--sh-surface);border:1px solid var(--sh-border);border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:300;overflow:hidden}.sh-suggestions-quick{top:calc(100% + -0px);left:0;right:50px}.sh-suggestion-item{display:block;width:100%;text-align:left;padding:9px 13px;font-size:.88rem;background:none;border:none;border-bottom:1px solid var(--sh-border);color:var(--sh-text);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sh-suggestion-item:last-child{border-bottom:none}.sh-suggestion-item:active,.sh-suggestion-item:hover{background:var(--sh-bg)}.sh-drag-handle{display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0;color:var(--sh-border);cursor:grab;touch-action:none;border-radius:3px;transition:color .15s}.sh-drag-handle:active{cursor:grabbing}.sh-item:hover .sh-drag-handle{color:var(--sh-muted)}.sh-item.sh-dragging{opacity:.35}.sh-item.sh-drag-overlay{background:var(--sh-surface);box-shadow:0 8px 24px #0000002e;border-radius:8px;opacity:1;border:1.5px solid var(--sh-accent)}.sh-drop-zone{min-height:8px;transition:background .15s,min-height .15s}.sh-drop-zone.sh-drop-over{background:#b5624a12;min-height:52px}.sh-drop-empty{padding:5px 12px;font-size:.72rem;color:var(--sh-border);font-style:italic;transition:color .15s}.sh-drop-zone.sh-drop-over .sh-drop-empty{color:var(--sh-accent);font-style:normal;font-weight:600}.sh-loading{display:flex;align-items:center;justify-content:center;min-height:100dvh;color:var(--sh-muted);font-size:.95rem}:root{--rn-header: #1C3A2A;--rn-header-text: #E8F5E9;--rn-accent: #2E7D32;--rn-accent-lt: #43A047;--rn-bg: #F4F7F4;--rn-surface: #FFFFFF;--rn-border: #D4E4D4;--rn-text: #1A2E1A;--rn-muted: #6B8F6B;--rn-success: #2E7D32;--rn-warn: #E65100;--rn-danger: #C62828;--rn-radius: 10px;--rn-shadow: 0 2px 8px rgba(0,0,0,.09)}.rn-root{flex:1;background:var(--rn-bg);font-family:Segoe UI,system-ui,sans-serif;color:var(--rn-text);display:flex;flex-direction:column}.rn-app-wrapper{flex:1;display:flex;flex-direction:column;width:100%}.rn-header{background:var(--rn-header);color:var(--rn-header-text);padding:8px 16px;display:flex;align-items:center;position:sticky;top:0;z-index:100;box-shadow:var(--rn-shadow);min-height:68px}.rn-header-side{flex:1;display:flex;align-items:center}.rn-header-side--right{justify-content:flex-end}.rn-header-center{display:flex;flex-direction:column;align-items:center;gap:2px;flex-shrink:0}.rn-header-title{font-size:.95rem;font-weight:700;color:var(--rn-header-text);white-space:nowrap;margin:0}.rn-header-logo{height:28px;width:auto;display:block;object-fit:contain;background:#ffffffe6;border-radius:6px;padding:2px 6px}.rn-header-btn{background:#ffffff26;border:none;border-radius:6px;color:var(--rn-header-text);padding:6px 10px;font-size:.8rem;cursor:pointer;white-space:nowrap;font-family:inherit;appearance:none;-webkit-appearance:none;text-decoration:none;display:inline-block}.rn-header-btn:active{opacity:.7}.rn-loading{flex:1;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--rn-muted);background:var(--rn-bg)}.rn-login{flex:1;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--rn-bg)}.rn-login-card{background:var(--rn-surface);border-radius:var(--rn-radius);padding:32px 24px;width:100%;max-width:360px;box-shadow:var(--rn-shadow);display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.rn-login-logo{height:70px;width:auto;object-fit:contain;align-self:center}.rn-login-card h1{font-size:1.4rem;font-weight:800;color:var(--rn-text);margin:4px 0 0}.rn-login-card p{color:var(--rn-muted);font-size:.9rem;margin:0}.rn-google-btn{display:flex;align-items:center;gap:10px;background:var(--rn-surface);border:2px solid var(--rn-border);border-radius:8px;padding:10px 20px;font-size:.95rem;font-weight:600;cursor:pointer;color:var(--rn-text);margin-top:8px;width:100%;justify-content:center;font-family:inherit}.rn-google-btn:active{background:var(--rn-bg)}.rn-google-btn:disabled{opacity:.6;cursor:default}.rn-error{color:var(--rn-danger);font-size:.82rem;margin:4px 0 0}.rn-dashboard{flex:1;display:flex;flex-direction:column}.rn-dashboard-content{flex:1;padding:16px 14px;display:flex;flex-direction:column;gap:12px;max-width:900px;margin:0 auto;width:100%;box-sizing:border-box}.rn-section-title{font-size:.72rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--rn-muted);margin:4px 0}.rn-group-card{background:var(--rn-surface);border-radius:var(--rn-radius);padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--rn-shadow);cursor:pointer;border:none;width:100%;text-align:left;font-family:inherit;appearance:none;-webkit-appearance:none;transition:transform .12s}.rn-group-card:active{transform:scale(.98)}.rn-group-card-name{font-weight:600;font-size:.98rem;flex:1;color:var(--rn-text)}.rn-group-card-meta{font-size:.78rem;color:var(--rn-muted);margin-top:2px}.rn-group-card-arrow{color:var(--rn-muted);font-size:1.1rem}.rn-action-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px}.rn-action-card{background:var(--rn-surface);border:2px dashed var(--rn-border);border-radius:var(--rn-radius);padding:18px 12px;text-align:center;cursor:pointer;font-size:.88rem;font-weight:600;color:var(--rn-muted);transition:border-color .15s,color .15s;font-family:inherit;appearance:none;-webkit-appearance:none}.rn-action-card:hover{border-color:var(--rn-accent);color:var(--rn-accent)}.rn-field{display:flex;flex-direction:column;gap:4px}.rn-field label{font-size:.78rem;font-weight:600;color:var(--rn-muted);text-transform:uppercase;letter-spacing:.06em}.rn-field input,.rn-field textarea{border:1px solid var(--rn-border);border-radius:8px;padding:9px 12px;font-size:.95rem;background:var(--rn-bg);color:var(--rn-text);outline:none;font-family:inherit;width:100%;box-sizing:border-box}.rn-field input:focus,.rn-field textarea:focus{border-color:var(--rn-accent)}.rn-field textarea{resize:vertical;min-height:60px}.rn-form-panel{background:var(--rn-surface);border-radius:var(--rn-radius);padding:16px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--rn-shadow);border:1px solid var(--rn-border)}.rn-form-panel h3{font-size:.95rem;font-weight:700;margin:0 0 4px}.rn-form-row{display:flex;gap:8px}.rn-form-row .rn-field{flex:1}.rn-form-actions{display:flex;gap:8px;justify-content:flex-end}.rn-btn-primary{background:var(--rn-accent);color:#fff;border:none;border-radius:8px;padding:8px 18px;font-size:.88rem;font-weight:600;cursor:pointer;font-family:inherit}.rn-btn-primary:active{opacity:.8}.rn-btn-primary:disabled{background:var(--rn-border);color:var(--rn-muted);cursor:default}.rn-btn-secondary{background:var(--rn-bg);color:var(--rn-muted);border:1px solid var(--rn-border);border-radius:8px;padding:8px 18px;font-size:.88rem;font-weight:600;cursor:pointer;font-family:inherit}.rn-btn-secondary:active{opacity:.8}.rn-week-view{flex:1;display:flex;flex-direction:column}.rn-week-content{flex:1;display:flex;flex-direction:column;max-width:900px;margin:0 auto;width:100%;box-sizing:border-box;padding:14px;gap:16px}.rn-week-nav{display:flex;align-items:center;justify-content:space-between;background:var(--rn-surface);border-radius:var(--rn-radius);padding:10px 14px;box-shadow:var(--rn-shadow)}.rn-week-nav-btn{background:var(--rn-bg);border:1px solid var(--rn-border);border-radius:6px;width:34px;height:34px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;color:var(--rn-text);font-family:inherit;appearance:none;-webkit-appearance:none;flex-shrink:0}.rn-week-nav-btn:active{background:var(--rn-border)}.rn-week-label{font-size:.85rem;font-weight:600;color:var(--rn-text);text-align:center;flex:1}.rn-week-current-badge{font-size:.7rem;background:var(--rn-accent);color:#fff;border-radius:10px;padding:1px 7px;font-weight:700;display:inline-block;margin-left:6px;vertical-align:middle}.rn-goal-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media(max-width:480px){.rn-goal-cards{grid-template-columns:1fr}}.rn-goal-card{background:var(--rn-surface);border-radius:var(--rn-radius);padding:14px;box-shadow:var(--rn-shadow);display:flex;flex-direction:column;gap:4px;border-left:4px solid var(--rn-accent)}.rn-goal-card-icon{font-size:1.4rem;margin-bottom:2px}.rn-goal-card-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--rn-muted)}.rn-goal-card-value{font-size:1.5rem;font-weight:800;color:var(--rn-accent);line-height:1.1}.rn-goal-card-unit{font-size:.75rem;font-weight:600;color:var(--rn-muted)}.rn-goal-card-desc{font-size:.78rem;color:var(--rn-muted);margin-top:4px;line-height:1.4}.rn-goal-card--empty{border-left-color:var(--rn-border);opacity:.7}.rn-set-goals-btn{background:var(--rn-surface);border:2px dashed var(--rn-border);border-radius:var(--rn-radius);padding:14px;width:100%;text-align:center;cursor:pointer;font-size:.88rem;font-weight:600;color:var(--rn-muted);font-family:inherit;appearance:none;-webkit-appearance:none}.rn-set-goals-btn:active{border-color:var(--rn-accent);color:var(--rn-accent)}.rn-goals-form{background:var(--rn-surface);border-radius:var(--rn-radius);padding:16px;box-shadow:var(--rn-shadow);display:flex;flex-direction:column;gap:14px}.rn-goals-form h3{font-size:.95rem;font-weight:700;margin:0;color:var(--rn-text)}.rn-goals-form-metric{display:flex;flex-direction:column;gap:6px;padding:12px;background:var(--rn-bg);border-radius:8px;border-left:3px solid var(--rn-accent)}.rn-goals-form-metric-title{font-size:.8rem;font-weight:700;color:var(--rn-text);display:flex;align-items:center;gap:6px}.rn-goals-form-row{display:grid;grid-template-columns:100px 1fr;gap:8px}.rn-progress-section{display:flex;flex-direction:column;gap:8px}.rn-member-card{background:var(--rn-surface);border-radius:var(--rn-radius);padding:14px 16px;box-shadow:var(--rn-shadow);display:flex;flex-direction:column;gap:10px}.rn-member-card--me{border:2px solid var(--rn-accent)}.rn-member-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.rn-member-name{font-weight:700;font-size:.95rem;color:var(--rn-text)}.rn-member-badge{font-size:.68rem;background:var(--rn-accent);color:#fff;border-radius:10px;padding:2px 8px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.rn-member-badge--done{background:var(--rn-success)}.rn-member-badge--partial{background:var(--rn-warn)}.rn-member-badge--none{background:var(--rn-muted)}.rn-metrics{display:flex;flex-direction:column;gap:8px}.rn-metric-row{display:flex;flex-direction:column;gap:3px}.rn-metric-label-row{display:flex;align-items:center;justify-content:space-between;gap:6px}.rn-metric-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--rn-muted);display:flex;align-items:center;gap:4px}.rn-metric-value{font-size:.78rem;font-weight:700;color:var(--rn-text)}.rn-metric-value--done{color:var(--rn-success)}.rn-progress-bar{height:6px;background:var(--rn-border);border-radius:3px;overflow:hidden}.rn-progress-fill{height:100%;border-radius:3px;background:var(--rn-accent-lt);transition:width .3s ease}.rn-progress-fill--done{background:var(--rn-success)}.rn-progress-fill--warn{background:var(--rn-warn)}.rn-my-progress{background:var(--rn-surface);border:2px solid var(--rn-accent);border-radius:var(--rn-radius);padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--rn-shadow)}.rn-my-progress h3{font-size:.9rem;font-weight:700;margin:0;color:var(--rn-text)}.rn-my-progress-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media(max-width:400px){.rn-my-progress-grid{grid-template-columns:1fr}}.rn-progress-input-group{display:flex;flex-direction:column;gap:4px}.rn-progress-input-group label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--rn-muted);display:flex;align-items:center;gap:4px}.rn-progress-input-group input{border:1px solid var(--rn-border);border-radius:8px;padding:8px 10px;font-size:1rem;font-weight:700;background:var(--rn-bg);color:var(--rn-text);outline:none;font-family:inherit;width:100%;box-sizing:border-box;text-align:center}.rn-progress-input-group input:focus{border-color:var(--rn-accent)}.rn-progress-unit{font-size:.7rem;color:var(--rn-muted);text-align:center;margin-top:1px}.rn-carried-badge{font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:#2e7d321f;color:var(--rn-accent);border:1px solid var(--rn-accent);border-radius:10px;padding:2px 8px;white-space:nowrap}.rn-goals-form-carry-note{font-size:.78rem;color:var(--rn-muted);background:#2e7d3212;border-left:3px solid var(--rn-accent);border-radius:0 6px 6px 0;padding:8px 12px;margin:0;line-height:1.5}.rn-no-goals{text-align:center;padding:32px 24px;color:var(--rn-muted);background:var(--rn-surface);border-radius:var(--rn-radius);box-shadow:var(--rn-shadow)}.rn-no-goals p{font-size:.9rem;margin-bottom:12px}.rn-share-code{display:inline-flex;align-items:center;gap:6px;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);border-radius:6px;padding:4px 10px;font-size:.78rem;font-family:monospace;font-weight:700;color:var(--rn-header-text);cursor:pointer;letter-spacing:.12em;appearance:none;-webkit-appearance:none}.rn-share-code:active{background:#ffffff38}:root{--cl-header: #2D4A3E;--cl-header-text: #E8F5E9;--cl-accent: #388E3C;--cl-accent-lt: #66BB6A;--cl-bg: #F7FAF7;--cl-surface: #FFFFFF;--cl-border: #D6E8D6;--cl-text: #1A2E1A;--cl-muted: #6B8F6B;--cl-success: #2E7D32;--cl-warn: #F57F17;--cl-danger: #C62828;--cl-radius: 14px;--cl-shadow: 0 2px 10px rgba(0,0,0,.08)}.cl-root{flex:1;background:var(--cl-bg);font-family:Segoe UI,system-ui,sans-serif;color:var(--cl-text);display:flex;flex-direction:column}.cl-app-wrapper{flex:1;display:flex;flex-direction:column;width:100%}.cl-loading{flex:1;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--cl-muted);background:var(--cl-bg)}.cl-header{background:var(--cl-header);color:var(--cl-header-text);padding:8px 16px;display:flex;align-items:center;position:sticky;top:0;z-index:100;box-shadow:var(--cl-shadow);min-height:68px}.cl-header-side{flex:1;display:flex;align-items:center}.cl-header-side--right{justify-content:flex-end}.cl-header-center{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:2px}.cl-header-title{font-size:.95rem;font-weight:700;color:var(--cl-header-text);white-space:nowrap;margin:0}.cl-header-btn{background:#ffffff26;border:none;border-radius:6px;color:var(--cl-header-text);padding:6px 10px;font-size:.8rem;cursor:pointer;white-space:nowrap;font-family:inherit;appearance:none;-webkit-appearance:none;text-decoration:none;display:inline-block}.cl-header-btn:active{opacity:.7}.cl-header-logo{height:28px;width:auto;object-fit:contain;background:#ffffffe6;border-radius:6px;padding:2px 6px}.cl-share-code{display:inline-flex;align-items:center;gap:5px;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);border-radius:6px;padding:4px 10px;font-size:.78rem;font-family:monospace;font-weight:700;color:var(--cl-header-text);cursor:pointer;letter-spacing:.12em;appearance:none;-webkit-appearance:none}.cl-share-code:active{background:#ffffff38}.cl-login{flex:1;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--cl-bg)}.cl-login-card{background:var(--cl-surface);border-radius:var(--cl-radius);padding:32px 24px;width:100%;max-width:360px;box-shadow:var(--cl-shadow);display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.cl-login-logo{height:70px;width:auto;object-fit:contain}.cl-login-card h1{font-size:1.4rem;font-weight:800;color:var(--cl-text);margin:4px 0 0}.cl-login-card p{color:var(--cl-muted);font-size:.9rem;margin:0}.cl-google-btn{display:flex;align-items:center;gap:10px;background:var(--cl-surface);border:2px solid var(--cl-border);border-radius:8px;padding:10px 20px;font-size:.95rem;font-weight:600;cursor:pointer;color:var(--cl-text);margin-top:8px;width:100%;justify-content:center;font-family:inherit}.cl-google-btn:active{background:var(--cl-bg)}.cl-google-btn:disabled{opacity:.6;cursor:default}.cl-error{color:var(--cl-danger);font-size:.82rem;margin:4px 0 0}.cl-dashboard{flex:1;display:flex;flex-direction:column}.cl-dashboard-content{flex:1;padding:16px 14px;display:flex;flex-direction:column;gap:12px;max-width:900px;margin:0 auto;width:100%;box-sizing:border-box}.cl-section-title{font-size:.72rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--cl-muted);margin:4px 0}.cl-house-card{background:var(--cl-surface);border-radius:var(--cl-radius);padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--cl-shadow);cursor:pointer;border:none;width:100%;text-align:left;font-family:inherit;appearance:none;-webkit-appearance:none;transition:transform .12s}.cl-house-card:active{transform:scale(.98)}.cl-house-card-icon{font-size:1.6rem;flex-shrink:0}.cl-house-card-name{font-weight:600;font-size:.98rem;flex:1;color:var(--cl-text)}.cl-house-card-meta{font-size:.78rem;color:var(--cl-muted);margin-top:2px}.cl-house-card-arrow{color:var(--cl-muted);font-size:1.1rem}.cl-action-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px}.cl-action-card{background:var(--cl-surface);border:2px dashed var(--cl-border);border-radius:var(--cl-radius);padding:18px 12px;text-align:center;cursor:pointer;font-size:.88rem;font-weight:600;color:var(--cl-muted);font-family:inherit;appearance:none;-webkit-appearance:none;transition:border-color .15s,color .15s}.cl-action-card:hover{border-color:var(--cl-accent);color:var(--cl-accent)}.cl-field{display:flex;flex-direction:column;gap:4px}.cl-field label{font-size:.78rem;font-weight:600;color:var(--cl-muted);text-transform:uppercase;letter-spacing:.06em}.cl-field input,.cl-field select,.cl-field textarea{border:1px solid var(--cl-border);border-radius:8px;padding:9px 12px;font-size:.95rem;background:var(--cl-bg);color:var(--cl-text);outline:none;font-family:inherit;width:100%;box-sizing:border-box}.cl-field input:focus,.cl-field select:focus{border-color:var(--cl-accent)}.cl-form-panel{background:var(--cl-surface);border-radius:var(--cl-radius);padding:16px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--cl-shadow);border:1px solid var(--cl-border)}.cl-form-panel h3{font-size:.95rem;font-weight:700;margin:0 0 4px}.cl-form-row{display:flex;gap:8px}.cl-form-row .cl-field{flex:1}.cl-form-actions{display:flex;gap:8px;justify-content:flex-end}.cl-btn-primary{background:var(--cl-accent);color:#fff;border:none;border-radius:8px;padding:9px 20px;font-size:.88rem;font-weight:600;cursor:pointer;font-family:inherit}.cl-btn-primary:active{opacity:.8}.cl-btn-primary:disabled{background:var(--cl-border);color:var(--cl-muted);cursor:default}.cl-btn-secondary{background:var(--cl-bg);color:var(--cl-muted);border:1px solid var(--cl-border);border-radius:8px;padding:9px 20px;font-size:.88rem;font-weight:600;cursor:pointer;font-family:inherit}.cl-btn-secondary:active{opacity:.8}.cl-btn-danger{background:#ffebee;color:var(--cl-danger);border:1px solid #FFCDD2;border-radius:8px;padding:9px 20px;font-size:.88rem;font-weight:600;cursor:pointer;font-family:inherit}.cl-btn-danger:active{opacity:.8}.cl-house-view{flex:1;display:flex;flex-direction:column}.cl-house-content{flex:1;padding:16px 14px 80px;display:flex;flex-direction:column;gap:14px;max-width:900px;margin:0 auto;width:100%;box-sizing:border-box}.cl-summary-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:var(--cl-surface);border-radius:10px;padding:10px 14px;box-shadow:var(--cl-shadow);font-size:.8rem}.cl-streak-widget{display:flex;align-items:center;gap:4px;flex-shrink:0}.cl-streak-flame{line-height:1;transition:font-size .6s ease,opacity .6s ease;display:inline-block}.cl-streak-flame--out{filter:grayscale(1)}.cl-streak-count{font-size:1.15rem;font-weight:900;color:var(--cl-text);line-height:1;transition:color .4s}.cl-streak-count--dim{color:var(--cl-muted)}.cl-streak-label{font-size:.7rem;color:var(--cl-muted);font-weight:600;margin-left:1px}.cl-streak-divider{width:1px;height:20px;background:var(--cl-border);margin:0 4px;flex-shrink:0}.cl-summary-pill{display:inline-flex;align-items:center;gap:4px;border-radius:20px;padding:3px 10px;font-weight:600;font-size:.74rem}.cl-summary-pill--ok{background:#e8f5e9;color:#2e7d32}.cl-summary-pill--warn{background:#fff8e1;color:#e65100}.cl-summary-pill--crit{background:#ffebee;color:#c62828}.cl-rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}@media(max-width:360px){.cl-rooms-grid{grid-template-columns:repeat(2,1fr)}}.cl-room-card{background:var(--cl-surface);border-radius:var(--cl-radius);padding:16px 12px 12px;box-shadow:var(--cl-shadow);display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;border:2px solid transparent;width:100%;font-family:inherit;appearance:none;-webkit-appearance:none;transition:transform .12s,box-shadow .12s,background .3s,border-color .3s;position:relative;overflow:hidden}.cl-room-card:active{transform:scale(.97)}.cl-room-card--thriving{border-color:#c8e6c9;background:linear-gradient(160deg,#fff 60%,#f1f8f1);box-shadow:0 2px 12px #2e7d321a}.cl-room-card--good{border-color:#dcedc8;background:#fafffe}.cl-room-card--attention{border-color:#ffe082;background:linear-gradient(160deg,#fff 40%,#fffde7);box-shadow:0 2px 10px #f57f171a}.cl-room-card--critical{border-color:#ffab91;background:linear-gradient(160deg,#fff 30%,#fbe9e7);box-shadow:0 2px 14px #e64a1924;animation:cl-pulse-critical 2.4s ease-in-out infinite}.cl-room-card--overdue{border-color:#ef9a9a;background:linear-gradient(160deg,#fff5f5,#ffebee);box-shadow:0 2px 16px #c628282e;animation:cl-shake-overdue 3.5s ease-in-out infinite}@keyframes cl-pulse-critical{0%,to{box-shadow:0 2px 14px #e64a1924}50%{box-shadow:0 4px 20px #e64a1952}}@keyframes cl-shake-overdue{0%,85%,to{transform:translate(0)}88%{transform:translate(-3px)}91%{transform:translate(3px)}94%{transform:translate(-2px)}97%{transform:translate(2px)}}.cl-circle-wrap{position:relative;width:80px;height:80px;flex-shrink:0}.cl-circle-svg{width:80px;height:80px;transform:rotate(-90deg)}.cl-circle-track{fill:none;stroke:var(--cl-border);stroke-width:6}.cl-circle-fill{fill:none;stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset .6s ease,stroke .6s ease}.cl-circle-emoji{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;line-height:1}.cl-room-card--overdue .cl-circle-emoji{animation:cl-emoji-pulse 1.6s ease-in-out infinite}.cl-room-card--critical .cl-circle-emoji{animation:cl-emoji-pulse 2.4s ease-in-out infinite}@keyframes cl-emoji-pulse{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.65;transform:translate(-50%,-50%) scale(.88)}}.cl-room-name{font-size:.85rem;font-weight:700;color:var(--cl-text);text-align:center;line-height:1.2}.cl-room-status-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:2px 8px;border-radius:10px}.cl-room-status-label--thriving{background:#e8f5e9;color:#2e7d32}.cl-room-status-label--good{background:#f1f8e9;color:#558b2f}.cl-room-status-label--attention{background:#fff8e1;color:#f57f17}.cl-room-status-label--critical{background:#fbe9e7;color:#e64a19}.cl-room-status-label--overdue{background:#ffebee;color:#b71c1c}.cl-room-days-label{font-size:.7rem;color:var(--cl-muted);text-align:center}.cl-fab{position:fixed;bottom:24px;right:20px;width:56px;height:56px;border-radius:28px;background:var(--cl-accent);color:#fff;font-size:1.6rem;border:none;box-shadow:0 4px 14px #388e3c66;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:50;font-family:inherit;transition:transform .15s}.cl-fab:active{transform:scale(.93)}.cl-modal-overlay{position:fixed;inset:0;background:#0006;z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:0}@media(min-width:500px){.cl-modal-overlay{align-items:center;padding:20px}}.cl-modal{background:var(--cl-surface);border-radius:20px 20px 0 0;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;padding:20px 20px 32px;display:flex;flex-direction:column;gap:14px}@media(min-width:500px){.cl-modal{border-radius:20px;max-height:80vh}}.cl-modal-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.cl-modal-title{font-size:1.1rem;font-weight:800;color:var(--cl-text);display:flex;align-items:center;gap:8px}.cl-modal-close{width:32px;height:32px;border-radius:16px;border:none;background:var(--cl-bg);color:var(--cl-muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:inherit;flex-shrink:0}.cl-room-detail-status{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px;padding:12px 0}.cl-room-detail-circle-wrap{position:relative;width:100px;height:100px}.cl-room-detail-circle-wrap .cl-circle-svg{width:100px;height:100px}.cl-room-detail-circle-wrap .cl-circle-emoji{font-size:2rem}.cl-room-detail-pct{font-size:1.8rem;font-weight:900;color:var(--cl-text);line-height:1}.cl-room-detail-sublabel{font-size:.8rem;color:var(--cl-muted);text-align:center}.cl-clean-note-input{width:100%;box-sizing:border-box;border:1px solid var(--cl-border);border-radius:8px;padding:9px 12px;font-size:.88rem;background:var(--cl-bg);color:var(--cl-text);outline:none;font-family:inherit;resize:vertical;min-height:52px}.cl-clean-note-input:focus{border-color:var(--cl-accent)}.cl-clean-note-input::placeholder{color:var(--cl-muted)}.cl-clean-btn{background:var(--cl-accent);color:#fff;border:none;border-radius:12px;padding:14px 24px;font-size:1rem;font-weight:700;cursor:pointer;width:100%;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s}.cl-clean-btn:active{background:var(--cl-accent-lt)}.cl-clean-btn:disabled{background:var(--cl-border);color:var(--cl-muted);cursor:default}.cl-log-list{display:flex;flex-direction:column;gap:6px}.cl-log-item{display:flex;flex-direction:column;gap:4px;padding:8px 12px;background:var(--cl-bg);border-radius:8px;font-size:.82rem;color:var(--cl-text)}.cl-log-main{display:flex;align-items:center;justify-content:space-between}.cl-log-who{font-weight:600}.cl-log-when{color:var(--cl-muted)}.cl-log-note{font-size:.8rem;color:var(--cl-muted);margin:0;padding-left:4px;border-left:2px solid var(--cl-border);font-style:italic;line-height:1.4}.cl-log-empty{font-size:.82rem;color:var(--cl-muted);text-align:center;padding:8px 0}.cl-interval-chips{display:flex;flex-wrap:wrap;gap:6px}.cl-interval-chip{background:var(--cl-bg);border:1px solid var(--cl-border);border-radius:20px;padding:5px 12px;font-size:.8rem;font-weight:600;cursor:pointer;color:var(--cl-text);font-family:inherit;appearance:none;-webkit-appearance:none}.cl-interval-chip--active{background:var(--cl-accent);border-color:var(--cl-accent);color:#fff}.cl-icon-grid{display:flex;flex-wrap:wrap;gap:6px}.cl-icon-btn{width:40px;height:40px;border-radius:8px;border:2px solid var(--cl-border);background:var(--cl-bg);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:inherit}.cl-icon-btn--active{border-color:var(--cl-accent);background:#e8f5e9}.cl-empty-rooms{text-align:center;padding:40px 24px;color:var(--cl-muted)}.cl-empty-rooms-icon{font-size:3rem;margin-bottom:8px}.cl-empty-rooms p{font-size:.9rem;margin:0 0 16px}.cl-divider{height:1px;background:var(--cl-border);margin:4px 0}.app{min-height:100vh;background-color:var(--bg-dark);display:flex;flex-direction:column}
