*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#3b82f6;--color-primary-dark:#2563eb;--color-primary-light:#eff6ff;--color-danger:#ef4444;--color-danger-light:#fef2f2;--color-success:#22c55e;--color-text:#1e293b;--color-text-muted:#64748b;--color-border:#e2e8f0;--color-bg:#f8fafc;--color-surface:#fff;--radius:.75rem;--radius-sm:.375rem;--shadow-sm:0 1px 3px #00000014;--shadow:0 4px 12px #0000001a;color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;font-size:16px}body{min-height:100dvh;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}#root{min-height:100dvh}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;text-decoration:none;transition:background-color .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:#fff;width:100%}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn-ghost{color:var(--color-text-muted);background:0 0;padding:.5rem .75rem}.btn-ghost:hover{background-color:var(--color-border);color:var(--color-text)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-outline{border:1.5px solid var(--color-border);color:var(--color-text);background:0 0}.btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary)}.app-layout{flex-direction:column;min-height:100dvh;display:flex}.app-header{z-index:100;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;height:3.5rem;padding:0 1.25rem;display:flex;position:sticky;top:0}.app-logo{color:var(--color-primary);letter-spacing:-.02em;font-size:1.125rem;font-weight:700;text-decoration:none}.app-nav{align-items:center;gap:.5rem;display:flex}.search-wrap{flex:1;max-width:20rem;margin:0 .75rem;position:relative}.search-input-wrap{background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:2rem;align-items:center;gap:.4rem;padding:0 .75rem;transition:border-color .15s;display:flex}.search-input-wrap:focus-within{border-color:var(--color-primary);background:var(--color-surface)}.search-icon{flex-shrink:0;font-size:.85rem}.search-input{width:100%;color:var(--color-text);background:0 0;border:none;padding:.45rem 0;font-size:.875rem}.search-input:focus{outline:none}.search-input::-webkit-search-cancel-button{display:none}.search-clear{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;flex-shrink:0;padding:.2rem;font-size:.75rem}.search-results{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);z-index:150;max-height:16rem;position:absolute;top:calc(100% + .5rem);left:0;right:0;overflow-y:auto}.search-empty{color:var(--color-text-muted);text-align:center;padding:1rem;font-size:.875rem}.search-result-item{border:none;border-bottom:1px solid var(--color-border);cursor:pointer;text-align:left;background:0 0;flex-direction:column;align-items:flex-start;gap:.15rem;width:100%;padding:.75rem 1rem;transition:background-color .1s;display:flex}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background-color:var(--color-primary-light)}.search-item-name{color:var(--color-text);font-size:.9rem;font-weight:600}.search-item-box{color:var(--color-primary);font-size:.775rem;font-weight:500}.app-main{flex:1;width:100%;max-width:48rem;margin:0 auto;padding:1.5rem 1.25rem}.auth-container{background-color:var(--color-bg);justify-content:center;align-items:center;min-height:100dvh;padding:1.5rem;display:flex}.auth-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:22rem;padding:2rem}.auth-title{color:var(--color-primary);text-align:center;margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.auth-subtitle{color:var(--color-text-muted);text-align:center;margin-bottom:1.5rem;font-size:.9rem}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-link{text-align:center;color:var(--color-text-muted);margin-top:1.25rem;font-size:.875rem}.auth-link a{color:var(--color-primary);font-weight:500;text-decoration:none}.auth-link a:hover{text-decoration:underline}.form-group{flex-direction:column;gap:.375rem;display:flex}.form-group label{color:var(--color-text);font-size:.875rem;font-weight:500}.form-group input,.form-group textarea,.form-group select{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);background:var(--color-surface);width:100%;padding:.625rem .875rem;font-size:.9375rem;transition:border-color .15s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--color-primary);outline:none}.form-group textarea{resize:vertical;min-height:5rem}.error-message{color:var(--color-danger);background-color:var(--color-danger-light);border-radius:var(--radius-sm);padding:.625rem .875rem;font-size:.875rem}.loading-screen{justify-content:center;align-items:center;min-height:100dvh;display:flex}.loading-spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:2.5rem;height:2.5rem;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn-google{background:var(--color-surface);border:1.5px solid var(--color-border);color:var(--color-text);gap:.625rem;width:100%;font-weight:500}.btn-google:hover:not(:disabled){background-color:var(--color-bg);border-color:#aaa}.auth-divider{color:var(--color-text-muted);align-items:center;gap:.75rem;margin:1rem 0;font-size:.8rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.page{padding:.5rem 0}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.page-header h2{font-size:1.25rem;font-weight:600}.btn-new{padding:.5rem 1rem;font-size:.9rem;width:auto!important}.box-list{flex-direction:column;gap:.75rem;display:flex}.box-card{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius);align-items:center;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.box-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.box-card-link{color:inherit;flex:1;align-items:center;gap:1rem;min-width:0;padding:1rem .75rem 1rem 1rem;text-decoration:none;display:flex}.box-number{color:var(--color-primary);background:var(--color-primary-light);white-space:nowrap;border-radius:.25rem;padding:.25rem .5rem;font-size:.8rem;font-weight:700}.box-info{flex:1;min-width:0}.box-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.9375rem;font-weight:600;overflow:hidden}.box-count{color:var(--color-text-muted);font-size:.8rem}.box-arrow{color:var(--color-border);font-size:1.25rem}.box-actions{border-left:1px solid var(--color-border);gap:.25rem;padding:0 .5rem;display:flex}.btn-icon{cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:.5rem;font-size:1rem;line-height:1;transition:background-color .15s}.btn-icon:hover{background-color:var(--color-bg)}.btn-icon-danger:hover{background-color:var(--color-danger-light)}.empty-state{text-align:center;color:var(--color-text-muted);padding:3rem 1rem}.empty-icon{margin-bottom:.75rem;font-size:3rem}.empty-title{color:var(--color-text);margin-bottom:.375rem;font-size:1rem;font-weight:600}.empty-subtitle{font-size:.875rem}.breadcrumb{flex-direction:column;gap:.125rem;min-width:0;display:flex}.breadcrumb-link{color:var(--color-text-muted);font-size:.8rem;text-decoration:none}.breadcrumb-link:hover{color:var(--color-primary)}.breadcrumb h2{white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;display:flex;overflow:hidden}.box-number-sm{color:var(--color-primary);background:var(--color-primary-light);border-radius:.25rem;flex-shrink:0;padding:.2rem .4rem;font-size:.75rem;font-weight:700}.item-list{flex-direction:column;gap:.625rem;display:flex}.item-card{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius);align-items:center;gap:.875rem;padding:.75rem;transition:border-color .15s;display:flex;overflow:hidden}.item-card:hover{border-color:var(--color-primary)}.item-photo-wrap{border-radius:var(--radius-sm);background:var(--color-bg);flex-shrink:0;width:3.5rem;height:3.5rem;overflow:hidden}.item-photo{object-fit:cover;width:100%;height:100%}.item-info{flex:1;min-width:0}.item-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin:0 0 .2rem;font-size:.9375rem;font-weight:600;overflow:hidden}.item-description{color:var(--color-text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.8rem;display:-webkit-box;overflow:hidden}.photo-picker{gap:.75rem;display:flex}.photo-btn{border:1.5px dashed var(--color-border);border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-muted);text-align:center;flex:1;justify-content:center;align-items:center;gap:.375rem;padding:.75rem;font-size:.875rem;font-weight:500;transition:border-color .15s,color .15s;display:flex}.photo-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.photo-preview-wrap{border-radius:var(--radius-sm);display:inline-block;position:relative;overflow:hidden}.photo-preview{object-fit:cover;border-radius:var(--radius-sm);width:100%;max-height:12rem;display:block}.photo-remove{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;font-size:.75rem;display:flex;position:absolute;top:.375rem;right:.375rem}.modal-card-lg{max-width:26rem}.modal-overlay{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:1rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:22rem;padding:1.5rem;animation:.15s slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(.5rem)}to{opacity:1;transform:translateY(0)}}.modal-title{color:var(--color-text);margin-bottom:1.25rem;font-size:1rem;font-weight:600}.confirm-message{color:var(--color-text);margin-bottom:1.25rem;font-size:.9rem;line-height:1.5}.btn-nav{padding:.4rem .6rem;font-size:1rem}.members-list{flex-direction:column;gap:.625rem;margin-bottom:2rem;display:flex}.member-card{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius);align-items:center;gap:.875rem;padding:.875rem 1rem;display:flex}.member-avatar{background:var(--color-primary-light);width:2.25rem;height:2.25rem;color:var(--color-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.member-info{flex:1;min-width:0}.member-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.member-email{color:var(--color-text-muted);font-size:.775rem}.member-badge{border-radius:2rem;flex-shrink:0;padding:.2rem .5rem;font-size:.7rem;font-weight:600}.badge-admin{background:var(--color-primary-light);color:var(--color-primary)}.badge-member{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.invite-section{border-top:1px solid var(--color-border);padding-top:1.5rem}.invite-section h3{margin-bottom:.375rem;font-size:1rem;font-weight:600}.invite-hint{color:var(--color-text-muted);font-size:.85rem}.invite-code-wrap{flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:.875rem;display:flex}.invite-code{letter-spacing:.2em;color:var(--color-primary);background:var(--color-primary-light);border-radius:var(--radius-sm);padding:.5rem 1rem;font-family:monospace;font-size:1.5rem;font-weight:700}.confirm-actions{justify-content:flex-end;gap:.75rem;display:flex}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--color-primary:#60a5fa;--color-primary-dark:#3b82f6;--color-primary-light:#172554;--color-danger:#f87171;--color-danger-light:#450a0a;--color-success:#4ade80;--color-text:#f1f5f9;--color-text-muted:#94a3b8;--color-border:#334155;--color-bg:#0f172a;--color-surface:#1e293b;--shadow-sm:0 1px 3px #0000004d;--shadow:0 4px 12px #0006}}[data-theme=dark]{--color-primary:#60a5fa;--color-primary-dark:#3b82f6;--color-primary-light:#172554;--color-danger:#f87171;--color-danger-light:#450a0a;--color-success:#4ade80;--color-text:#f1f5f9;--color-text-muted:#94a3b8;--color-border:#334155;--color-bg:#0f172a;--color-surface:#1e293b;--shadow-sm:0 1px 3px #0000004d;--shadow:0 4px 12px #0006}.nav-avatar{object-fit:cover;border:2px solid #0000;border-radius:50%;width:2rem;height:2rem;transition:border-color .15s;display:block}.nav-avatar-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.2rem;transition:opacity .15s;display:flex}.nav-avatar-btn:hover{opacity:.8}.nav-avatar-fallback{background:var(--color-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:.75rem;font-weight:700;display:flex}.settings-overlay{z-index:300;background:#00000073;animation:.15s fadeIn;position:fixed;inset:0}.settings-panel{background:var(--color-surface);flex-direction:column;width:min(22rem,100vw);animation:.2s slideInRight;display:flex;position:absolute;top:0;bottom:0;right:0;overflow-y:auto;box-shadow:-4px 0 24px #00000026}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.settings-header{border-bottom:1px solid var(--color-border);background:var(--color-surface);z-index:1;justify-content:space-between;align-items:center;padding:1.25rem 1.25rem 1rem;display:flex;position:sticky;top:0}.settings-header h2{color:var(--color-text);font-size:1rem;font-weight:600}.settings-close{cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm);background:0 0;border:none;padding:.3rem;font-size:1.1rem;line-height:1;transition:background-color .15s,color .15s}.settings-close:hover{color:var(--color-text);background:var(--color-bg)}.settings-body{flex-direction:column;flex:1;gap:1.5rem;padding:1.25rem;display:flex}.settings-section{flex-direction:column;gap:.625rem;display:flex}.settings-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);font-size:.7rem;font-weight:600}.settings-user{background:var(--color-bg);border-radius:var(--radius);align-items:center;gap:.875rem;padding:.875rem;display:flex}.settings-avatar-lg{object-fit:cover;border-radius:50%;flex-shrink:0;width:3rem;height:3rem}.settings-avatar-lg-fallback{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:3rem;height:3rem;font-size:1.25rem;font-weight:700;display:flex}.settings-user-info{min-width:0}.settings-user-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin:0 0 .15rem;font-size:.9375rem;font-weight:600;overflow:hidden}.settings-user-email{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.8rem;overflow:hidden}.settings-stat-row{background:var(--color-bg);border-radius:var(--radius-sm);align-items:center;gap:.625rem;padding:.625rem .75rem;font-size:.875rem;display:flex}.settings-stat-icon{flex-shrink:0;font-size:1rem}.settings-stat-label{color:var(--color-text-muted);flex:1;font-size:.8rem}.settings-stat-value{color:var(--color-text);text-align:right;font-size:.85rem;font-weight:600}.theme-toggle{background:var(--color-bg);border-radius:var(--radius-sm);border:1.5px solid var(--color-border);display:flex;overflow:hidden}.theme-btn{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:.2rem;padding:.5rem .25rem;font-size:.78rem;line-height:1.2;transition:background-color .15s,color .15s;display:flex}.theme-btn span{font-size:1rem}.theme-btn.active{background:var(--color-primary);color:#fff}.theme-btn:not(.active):hover{background:var(--color-border);color:var(--color-text)}.settings-logout{margin-top:auto}
