@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600&family=DM+Serif+Display&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cream: #faf8f4;--sand: #f0ede6;--border: #e4e0d8;--text: #1a1815;--muted: #7a7570;--accent: #2d6a4f;--accent-light: #d8f3dc;--accent-dark: #1b4332;--danger: #c0392b;--warning: #e67e22;--radius: 12px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 4px 12px rgba(0,0,0,.05)}body{font-family:DM Sans,sans-serif;background:var(--cream);color:var(--text);min-height:100vh;font-size:15px;line-height:1.6}.topbar{background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:2rem;padding:0 2rem;height:60px;position:sticky;top:0;z-index:100}.topbar-brand{font-family:"DM Serif Display",serif;font-size:1.2rem;color:var(--accent-dark);white-space:nowrap;letter-spacing:-.01em}.topbar-nav{display:flex;gap:.25rem;flex:1}.nav-btn{background:none;border:none;padding:.4rem .9rem;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.875rem;color:var(--muted);transition:all .15s}.nav-btn:hover{background:var(--sand);color:var(--text)}.nav-btn.active{background:var(--accent-light);color:var(--accent-dark);font-weight:500}.topbar-right{display:flex;align-items:center;gap:.75rem}.btn-new{background:var(--accent);color:#fff;border:none;padding:.45rem 1rem;border-radius:8px;font-family:inherit;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s;white-space:nowrap}.btn-new:hover{background:var(--accent-dark)}.user-menu{position:relative}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;border:none;cursor:pointer;transition:opacity .15s}.user-avatar:hover{opacity:.85}.family-dropdown{position:absolute;right:0;top:calc(100% + 8px);background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);width:240px;overflow:hidden;z-index:200}.family-header{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:.75rem 1rem .5rem}.family-member{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem}.member-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-light);color:var(--accent-dark);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;flex-shrink:0}.member-email{font-size:.85rem;color:var(--text)}.member-tag{font-size:.75rem;color:var(--muted)}.family-divider{height:1px;background:var(--border);margin:.25rem 0}.family-signout{display:block;width:100%;text-align:left;background:none;border:none;padding:.65rem 1rem;font-family:inherit;font-size:.875rem;color:var(--danger);cursor:pointer}.family-signout:hover{background:#fff0f0}.main-content{max-width:760px;margin:0 auto;padding:2rem 1.5rem}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.75rem}.page h2{font-family:"DM Serif Display",serif;font-size:1.75rem;color:var(--text);font-weight:400}.page-sub{color:var(--muted);font-size:.875rem;margin-top:2px}.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.form-card{margin-bottom:1.5rem}.form-card h3{font-size:1rem;font-weight:600;margin-bottom:1rem}.timeline{display:flex;flex-direction:column;gap:0}.timeline-group{margin-bottom:1.75rem}.timeline-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:.75rem;display:flex;align-items:center;gap:.75rem}.timeline-label:after{content:"";flex:1;height:1px;background:var(--border)}.timeline-cards{display:flex;flex-direction:column;gap:.75rem}.timeline-card{display:flex;flex-direction:column;gap:.6rem}.card-top{display:flex;align-items:center;justify-content:space-between}.card-type-badge{font-size:.75rem;font-weight:500;color:var(--muted)}.status-badge{font-size:.72rem;font-weight:600;padding:.2rem .6rem;border-radius:100px;text-transform:capitalize}.card-title{font-weight:600;font-size:1rem}.card-sub{font-size:.85rem;color:var(--muted)}.card-notes{font-size:.85rem;color:var(--muted);font-style:italic}.card-actions{display:flex;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border);flex-wrap:wrap}.grocery-items{list-style:disc;padding-left:1.25rem;font-size:.9rem;color:var(--text);display:flex;flex-direction:column;gap:.2rem;margin-top:.25rem}.past-section{margin-top:2rem}.btn-past{font-size:.85rem;color:var(--muted)}.past-label{color:var(--muted);opacity:.7}.muted-text{font-size:.875rem;color:var(--muted)}.grid-form{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.field{display:flex;flex-direction:column;gap:.35rem}.field.full{grid-column:1 / -1}.field-row{display:flex;gap:.75rem}.field-row .field{flex:1}.field-hint{font-size:.78rem;color:var(--warning)}.form-actions{display:flex;gap:.75rem}label{font-size:.78rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}input,select,textarea{font-family:inherit;font-size:.925rem;padding:.55rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--cream);color:var(--text);transition:border-color .15s;width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);background:#fff}textarea{resize:vertical}.btn-primary{background:var(--accent);color:#fff;border:none;padding:.6rem 1.25rem;border-radius:8px;font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s,transform .1s}.btn-primary:hover{background:var(--accent-dark)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background:none;border:1px solid var(--border);padding:.4rem .85rem;border-radius:8px;font-family:inherit;font-size:.825rem;cursor:pointer;transition:all .15s;color:var(--muted)}.btn-ghost:hover{background:var(--sand);color:var(--text)}.btn-ghost.btn-danger{color:var(--danger);border-color:#f5c6c6}.btn-ghost.btn-danger:hover{background:#fff0f0}.btn-ghost.btn-success{color:var(--accent-dark);border-color:#b7e4c7}.btn-ghost.btn-success:hover{background:var(--accent-light)}.btn-ghost.btn-warning{color:var(--warning);border-color:#fdeac7}.btn-ghost.btn-warning:hover{background:#fff8ee}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:500;padding:1rem}.modal-box{background:#fff;border-radius:16px;width:100%;max-width:460px;box-shadow:0 8px 40px #0000002e;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem 0}.modal-header h3{font-size:1.1rem;font-weight:600}.modal-close{background:none;border:none;font-size:1rem;color:var(--muted);cursor:pointer;padding:.25rem;line-height:1}.modal-close:hover{color:var(--text)}.type-tabs{display:flex;gap:.5rem;padding:1rem 1.5rem 0}.type-tab{flex:1;background:var(--sand);border:1px solid var(--border);border-radius:8px;padding:.5rem;font-family:inherit;font-size:.85rem;cursor:pointer;color:var(--muted);transition:all .15s}.type-tab.active{background:var(--accent-light);border-color:#b7e4c7;color:var(--accent-dark);font-weight:500}.modal-form{padding:1rem 1.5rem;display:flex;flex-direction:column;gap:.85rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border)}.provider-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.provider-card{display:flex;flex-direction:column;gap:.75rem}.provider-top{display:flex;align-items:center;gap:.75rem}.provider-avatar{width:44px;height:44px;border-radius:50%;background:var(--sand);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:600;color:var(--muted);flex-shrink:0}.provider-name{font-weight:600;font-size:.975rem}.role-badge{display:inline-block;font-size:.75rem;font-weight:500;padding:.15rem .55rem;border-radius:100px;margin-top:3px}.provider-details{display:flex;flex-direction:column;gap:.3rem}.detail-row{font-size:.85rem;color:var(--muted)}.detail-row.notes{font-style:italic}.provider-actions{display:flex;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border);margin-top:auto}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--cream);padding:1.5rem}.login-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:2.5rem;width:100%;max-width:380px;box-shadow:var(--shadow)}.login-header{text-align:center;margin-bottom:2rem}.login-logo{font-size:2.5rem;margin-bottom:.75rem}.login-header h1{font-family:"DM Serif Display",serif;font-size:1.75rem;font-weight:400}.login-header p{color:var(--muted);font-size:.9rem;margin-top:.25rem}.login-form{display:flex;flex-direction:column;gap:1rem}.loading{text-align:center;color:var(--muted);padding:3rem}.empty-state{text-align:center;padding:3rem;color:var(--muted)}.empty-icon{font-size:2.5rem;margin-bottom:.75rem}.error-msg{background:#fff0f0;border:1px solid #f5c6c6;color:var(--danger);padding:.6rem .85rem;border-radius:8px;font-size:.875rem}.info-banner{background:#fffbeb;border:1px solid #fde68a;color:#92400e;padding:.75rem 1rem;border-radius:8px;font-size:.875rem;margin-bottom:1.25rem}.splash{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--muted)}@media (max-width: 600px){.grid-form{grid-template-columns:1fr}.topbar-nav{display:none}.main-content{padding:1.25rem 1rem}.field-row{flex-direction:column}}.card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.5rem;border-top:1px solid var(--border);gap:.5rem}.card-actions{display:flex;gap:.5rem;flex-wrap:wrap;flex:1}.owner-tag{display:flex;align-items:center;gap:.35rem;flex-shrink:0;margin-left:auto}.owner-initial{width:22px;height:22px;border-radius:50%;background:var(--accent-light);color:var(--accent-dark);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600}.owner-name{font-size:.78rem;color:var(--muted);font-weight:500}
