@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Fraunces:wght@700;900&display=swap";:root{--bg:#faf8f5;--surface:#fff;--surface2:#f4f1ec;--border:#e8e2d9;--text:#1a1510;--text2:#6b5f52;--text3:#a89880;--accent:#d97706;--accent-light:#fef3c7;--accent-dark:#b45309;--green:#16a34a;--green-light:#dcfce7;--blue:#2563eb;--blue-light:#dbeafe;--red:#dc2626;--red-light:#fee2e2;--shadow:0 2px 8px #00000014;--shadow-lg:0 8px 32px #0000001f;--radius:12px;--radius-sm:8px}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);height:100%;color:var(--text);font-family:Nunito,sans-serif;font-size:15px}#root{height:100%}.splash{background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:24px;height:100vh;display:flex}.splash-logo{color:var(--accent);align-items:center;gap:12px;font-family:Fraunces,serif;font-size:2rem;font-weight:900;display:flex}.splash-icon{font-size:2.5rem}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-bg{background:linear-gradient(135deg,#fef9f0 0%,#fdf4e3 50%,#f9ede0 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--surface);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--border);border-radius:20px;padding:40px 36px}.login-brand{text-align:center;margin-bottom:32px}.login-icon{margin-bottom:8px;font-size:3rem;display:block}.login-brand h1{color:var(--accent);margin-bottom:6px;font-family:Fraunces,serif;font-size:2.2rem;font-weight:900}.login-brand p{color:var(--text2);font-size:.95rem}.login-form{flex-direction:column;gap:16px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--text2);text-transform:uppercase;letter-spacing:.04em;font-size:.85rem;font-weight:700}.field input,.field select{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);padding:11px 14px;font-family:inherit;font-size:1rem;transition:border-color .2s}.field input:focus,.field select:focus{border-color:var(--accent);outline:none}.field input:disabled{opacity:.6;cursor:not-allowed}.field input[type=range]{accent-color:var(--accent);padding:4px 0}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:13px;font-family:inherit;font-size:1rem;font-weight:800;transition:background .2s,transform .1s;display:flex}.btn-primary:hover:not(:disabled){background:var(--accent-dark)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.login-toggle{color:var(--accent);cursor:pointer;text-align:center;background:0 0;border:none;margin-top:8px;font-family:inherit;font-size:.9rem}.login-toggle:hover{text-decoration:underline}.alert{border-radius:var(--radius-sm);padding:10px 14px;font-size:.9rem;font-weight:600}.alert-error{background:var(--red-light);color:var(--red)}.alert-success{background:var(--green-light);color:var(--green)}.setup-bg{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.setup-card{background:var(--surface);width:100%;max-width:440px;box-shadow:var(--shadow-lg);border:1px solid var(--border);border-radius:20px;padding:40px 36px}.setup-choices{flex-direction:column;gap:14px;margin-top:8px;display:flex}.choice-btn{border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;text-align:left;flex-direction:column;gap:4px;padding:20px;transition:all .2s;display:flex}.choice-btn:hover{border-color:var(--accent);background:var(--accent-light)}.choice-icon{margin-bottom:4px;font-size:1.5rem}.choice-btn strong{color:var(--text);font-size:1.05rem}.choice-btn small{color:var(--text2);font-size:.85rem}.shell{background:var(--bg);flex-direction:column;max-width:600px;height:100vh;margin:0 auto;display:flex}.topbar{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.topbar-brand{align-items:center;gap:8px;display:flex}.topbar-icon{font-size:1.4rem}.topbar-name{color:var(--accent);font-family:Fraunces,serif;font-size:1.3rem;font-weight:900}.topbar-group{align-items:center;gap:10px;display:flex}.topbar-family{color:var(--text2);background:var(--surface2);border-radius:20px;padding:4px 10px;font-size:.8rem;font-weight:700}.topbar-avatar{object-fit:cover;border:2px solid var(--accent);border-radius:50%;width:32px;height:32px}.shell-main{flex:1;padding-bottom:80px;overflow-y:auto}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);z-index:10;width:100%;max-width:600px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -2px 16px #00000014}.nav-btn{cursor:pointer;color:var(--text3);background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:3px;padding:10px 4px;font-family:inherit;transition:color .2s;display:flex}.nav-btn.active{color:var(--accent)}.nav-icon{display:flex;position:relative}.badge{background:var(--red);color:#fff;text-align:center;border-radius:10px;min-width:16px;padding:1px 5px;font-size:.65rem;font-weight:800;position:absolute;top:-6px;right:-8px}.nav-label{font-size:.72rem;font-weight:700}.page{padding:20px}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.page-header h2{color:var(--text);font-family:Fraunces,serif;font-size:1.6rem;font-weight:900}.btn-sm{border:1.5px solid var(--accent);border-radius:var(--radius-sm);color:var(--accent);cursor:pointer;background:#fff;align-items:center;gap:5px;padding:8px 14px;font-family:inherit;font-size:.85rem;font-weight:700;transition:all .15s;display:flex}.btn-sm:hover{background:var(--accent);color:#fff}.btn-sm:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:var(--red);border-color:var(--red);color:#fff}.dashboard-layout{gap:0;min-height:60vh;display:flex}.rooms-panel{background:var(--surface2);border-right:1px solid var(--border);border-radius:var(--radius) 0 0 var(--radius);flex-shrink:0;width:130px;padding:12px}.panel-label{color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;padding:0 4px;font-size:.7rem;font-weight:800}.room-chip{border-radius:var(--radius-sm);cursor:pointer;color:var(--text2);justify-content:space-between;align-items:center;margin-bottom:4px;padding:9px 10px;font-size:.88rem;font-weight:600;transition:all .15s;display:flex}.room-chip:hover{background:var(--accent-light);color:var(--accent)}.room-chip.active{background:var(--accent);color:#fff}.empty-hint{color:var(--text3);padding:8px 4px;font-size:.8rem}.items-panel{flex:1;min-width:0;padding:16px}.items-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.items-header h3{color:var(--text);font-family:Fraunces,serif;font-size:1.2rem;font-weight:700}.items-actions{gap:8px;display:flex}.items-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;display:grid}.item-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;display:flex;overflow:hidden}.item-img{object-fit:cover;width:100%;height:90px}.item-img-placeholder{background:var(--surface2);justify-content:center;align-items:center;height:90px;font-size:2rem;display:flex}.item-info{padding:8px 10px 4px}.item-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;font-weight:700;display:block;overflow:hidden}.item-actions{align-items:center;gap:6px;padding:6px 8px 10px;display:flex}.btn-request{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:5px;padding:6px 8px;font-family:inherit;font-size:.75rem;font-weight:700;transition:background .15s;display:flex}.btn-request:hover:not(:disabled){background:var(--accent-dark)}.btn-request:disabled{opacity:.6;cursor:not-allowed}.btn-icon-danger{border:1.5px solid var(--border);cursor:pointer;color:var(--text3);background:0 0;border-radius:6px;align-items:center;padding:6px;transition:all .15s;display:flex}.btn-icon-danger:hover{border-color:var(--red);color:var(--red)}.request-list{flex-direction:column;gap:12px;display:flex}.request-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);align-items:flex-start;gap:12px;padding:14px;display:flex}.inbox-card.status-claimed{border-left:3px solid var(--blue)}.inbox-card.status-fulfilled{border-left:3px solid var(--green)}.inbox-card.status-open{border-left:3px solid var(--accent)}.req-img{object-fit:cover;border-radius:8px;flex-shrink:0;width:60px;height:60px}.req-body{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.req-title{color:var(--text);font-size:1rem;font-weight:800}.req-meta{color:var(--text2);font-size:.82rem}.req-status{font-size:.82rem;font-weight:700}.req-sender{color:var(--text3);align-items:center;gap:6px;margin-top:4px;font-size:.82rem;display:flex}.req-claimed{color:var(--blue);margin-top:4px;font-size:.82rem;font-weight:600}.req-actions{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.tiny-avatar{object-fit:cover;border-radius:50%;width:22px;height:22px}.tiny-avatar-placeholder{background:var(--surface2);border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;display:flex}.btn-claim{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:6px;align-items:center;gap:5px;padding:7px 12px;font-family:inherit;font-size:.82rem;font-weight:700;display:flex}.btn-fulfill{background:var(--green);color:#fff;cursor:pointer;border:none;border-radius:6px;align-items:center;gap:5px;padding:7px 12px;font-family:inherit;font-size:.82rem;font-weight:700;display:flex}.filter-tabs{gap:6px;margin-bottom:16px;padding-bottom:4px;display:flex;overflow-x:auto}.filter-tab{border:1.5px solid var(--border);cursor:pointer;color:var(--text2);white-space:nowrap;background:0 0;border-radius:20px;padding:6px 14px;font-family:inherit;font-size:.82rem;font-weight:700;transition:all .15s}.filter-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.account-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:20px}.account-section h3{color:var(--text);margin-bottom:16px;font-family:Fraunces,serif;font-size:1.1rem;font-weight:700}.avatar-area{align-items:center;gap:14px;margin-bottom:16px;display:flex}.profile-avatar{object-fit:cover;border:3px solid var(--accent);border-radius:50%;width:64px;height:64px}.profile-avatar-placeholder{background:var(--surface2);border:3px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:2rem;display:flex}.group-info{flex-direction:column;gap:10px;display:flex}.group-name{color:var(--text);font-size:1.2rem;font-weight:800}.invite-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.invite-label{color:var(--text2);font-size:.85rem;font-weight:600}.invite-code{color:var(--accent);letter-spacing:.1em;background:var(--accent-light);border-radius:6px;padding:4px 10px;font-size:1.1rem;font-weight:900}.btn-copy{border:1.5px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:5px;padding:6px 12px;font-family:inherit;font-size:.82rem;font-weight:700;display:flex}.member-list{flex-direction:column;gap:10px;display:flex}.member-row{background:var(--surface2);border-radius:8px;align-items:center;gap:10px;padding:10px;display:flex}.member-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.member-name{color:var(--text);font-size:.9rem;font-weight:700}.member-status{color:var(--text3);font-size:.75rem}.status-pending{color:var(--accent)}.status-approved{color:var(--green)}.btn-approve{background:var(--green);color:#fff;cursor:pointer;border:none;border-radius:6px;align-items:center;gap:4px;padding:6px 10px;font-family:inherit;font-size:.8rem;font-weight:700;display:flex}.btn-danger-outline{border:2px solid var(--red);color:var(--red);border-radius:var(--radius);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:8px;width:100%;margin-bottom:10px;padding:11px 16px;font-family:inherit;font-size:.95rem;font-weight:700;transition:all .15s;display:flex}.btn-danger-outline:hover{background:var(--red);color:#fff}.modal-overlay{z-index:100;background:#0006;justify-content:center;align-items:flex-end;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:20px 20px 0 0;flex-direction:column;gap:16px;width:100%;max-width:600px;max-height:85vh;padding:28px 24px 40px;animation:.2s slideUp;display:flex;overflow-y:auto}.modal-tall{max-height:92vh}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;display:flex}.modal-header h3{color:var(--text);font-family:Fraunces,serif;font-size:1.2rem;font-weight:700}.modal-close{cursor:pointer;color:var(--text3);background:0 0;border:none;padding:4px;display:flex}.img-preview{object-fit:cover;border-radius:8px;width:100%;max-height:150px;margin-bottom:8px}.empty-state{text-align:center;color:var(--text3);padding:40px 20px}.empty-state span{margin-bottom:10px;font-size:2.5rem;display:block}.empty-state p{font-size:.95rem}.loading-hint{text-align:center;color:var(--text3);padding:20px;font-size:.9rem}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}@media (width<=480px){.rooms-panel{width:110px}.login-card,.setup-card{padding:28px 20px}.items-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}}
