*{box-sizing:border-box}:root{font-family:Noto Sans JP,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:#4a4a4a;background-color:#f8f6f4;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;-webkit-tap-highlight-color:transparent;touch-action:manipulation}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:500}button{font-family:inherit;cursor:pointer}a{color:#8b7a6b;text-decoration:none}a:hover{text-decoration:underline}.toast{position:fixed;top:16px;left:50%;transform:translate(-50%);background-color:#fff;border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:280px;max-width:90%;z-index:2000;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translate(-50%) translateY(-100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.toast-success{border-left:4px solid #A8B5A0}.toast-error{border-left:4px solid #C97D7D}.toast-info{border-left:4px solid #8B7A6B}.toast-message{flex:1;font-size:14px;color:#4a4a4a;line-height:1.5}.toast-close{background:none;border:none;color:#8a8a8a;font-size:20px;line-height:1;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .2s}.toast-close:hover{opacity:1}.toast-close:active{opacity:.5}.app{min-height:100vh;background-color:#f8f6f4}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px}.loading-spinner-container.small{padding:20px;gap:8px}.loading-spinner-container.large{padding:60px;gap:24px}.spinner{width:40px;height:40px;border:4px solid #E0E0E0;border-top:4px solid #8B7A6B;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner-container.small .spinner{width:24px;height:24px;border-width:3px}.loading-spinner-container.large .spinner{width:56px;height:56px;border-width:5px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-message{margin:0;font-size:16px;color:#8a8a8a;text-align:center}.loading-spinner-container.small .loading-message{font-size:14px}.loading-spinner-container.large .loading-message{font-size:18px}.error-message{background-color:#c97d7d;color:#fff;padding:12px 16px;border-radius:8px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.error-text{flex:1;font-size:14px;line-height:1.5}.error-dismiss{background:none;border:none;color:#fff;font-size:24px;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:.8;transition:opacity .2s}.error-dismiss:hover{opacity:1}.error-dismiss:active{opacity:.6}.confirm-dialog-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:16px}.confirm-dialog-content{background-color:#fff;border-radius:12px;padding:24px;max-width:320px;width:100%;box-shadow:0 4px 16px #0000004d}.confirm-dialog-title{margin:0 0 16px;font-size:18px;font-weight:500;color:#4a4a4a}.confirm-dialog-message{margin:0 0 24px;font-size:14px;line-height:1.6;color:#4a4a4a;word-break:break-word;overflow-wrap:break-word}.confirm-dialog-buttons{display:flex;gap:12px;justify-content:flex-end}.confirm-dialog-button{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s,transform .2s;min-width:80px}.confirm-dialog-button:active{transform:scale(.98)}.confirm-dialog-button-cancel{background-color:#fff;color:#4a4a4a;border:1px solid #E0E0E0}.confirm-dialog-button-cancel:active{background-color:#f8f6f4}.confirm-dialog-button-confirm{background-color:#8b7a6b;color:#fff}.confirm-dialog-button-confirm:active{background-color:#7a6b5d}.confirm-dialog-button-danger{background-color:#c97d7d}.confirm-dialog-button-danger:active{background-color:#b86d6d}.shopping-list-page{display:flex;flex-direction:column;min-height:100vh;background-color:#f8f6f4;padding-top:72px}.page-header{position:fixed;top:0;left:0;right:0;z-index:100;background-color:#fff;padding:12px 16px;border-bottom:1px solid #E0E0E0;display:flex;align-items:center;justify-content:space-between;gap:8px}.page-header h1{margin:0;font-size:20px;font-weight:500;color:#4a4a4a;flex:1}.toggle-completed-button{background-color:#f8f6f4;border:1px solid #E0E0E0;border-radius:16px;padding:6px 12px;font-size:12px;font-weight:500;color:#8b7a6b;cursor:pointer;transition:background-color .2s,border-color .2s;white-space:nowrap}.toggle-completed-button:active{background-color:#e0e0e0;border-color:#8b7a6b}.icon-button{background:none;border:none;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;border-radius:8px;transition:background-color .2s,opacity .2s;color:#c97d7d}.icon-button svg{width:24px;height:24px}.icon-button:hover{background-color:#c97d7d1a}.icon-button:active{background-color:#c97d7d33;opacity:.8}.page-content{flex:1;padding:16px 16px 80px;overflow-y:auto;-webkit-overflow-scrolling:touch}.empty-state{text-align:center;padding:60px 20px;color:#8a8a8a}.empty-state-hint{font-size:14px;margin-top:8px}.items-container{display:flex;flex-direction:column;gap:16px}.category-section{display:flex;flex-direction:column;gap:8px}.category-title{font-size:15px;font-weight:500;color:#8b7a6b;margin:0;padding:0 4px}.items-list{display:flex;flex-direction:column;gap:4px}.item-card{background-color:#fff;border-radius:8px;padding:8px 12px;box-shadow:0 1px 4px #00000014;display:flex;align-items:center;gap:8px;transition:transform .2s,box-shadow .2s}.item-card.completed{opacity:.6}.item-checkbox{display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0}.item-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#A8B5A0;flex-shrink:0}.item-name{flex:1;font-size:15px;color:#4a4a4a;line-height:1.4;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 0}.item-card.completed .item-name{text-decoration:line-through;color:#8a8a8a}.fab{position:fixed;bottom:80px;right:16px;width:56px;height:56px;border-radius:50%;background-color:#8b7a6b;color:#fff;border:none;font-size:28px;font-weight:300;cursor:pointer;box-shadow:0 4px 12px #8b7a6b66;z-index:99;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}.fab:active{transform:scale(.95);box-shadow:0 2px 6px #8b7a6b4d}.form-field input,.form-field select{padding:12px 16px;border:1px solid #E0E0E0;border-radius:8px;font-size:16px;font-family:inherit;color:#4a4a4a;background-color:#fff;transition:border-color .2s}.form-field input:focus,.form-field select:focus{outline:none;border-color:#8b7a6b}.category-management-page{display:flex;flex-direction:column;min-height:100vh;background-color:#f8f6f4}.categories-container{display:flex;flex-direction:column;gap:12px}.category-card{background-color:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014;display:flex;align-items:center;justify-content:space-between;gap:12px}.category-name{flex:1;font-size:16px;color:#4a4a4a}.edit-button{padding:8px 16px;border:1px solid #8B7A6B;border-radius:8px;background-color:#fff;color:#8b7a6b;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.edit-button:active{background-color:#f8f6f4}.add-category-card{background-color:#fff;border:2px dashed #E0E0E0;border-radius:12px;padding:16px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:border-color .2s,background-color .2s;color:#8b7a6b;font-size:16px;font-weight:500}.add-category-card:active{border-color:#8b7a6b;background-color:#f8f6f4}.add-icon{font-size:24px;font-weight:300;line-height:1}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-content{background-color:#fff;border-radius:12px;padding:24px;max-width:400px;width:100%;box-shadow:0 4px 16px #0003}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-header h2{margin:0;font-size:20px;font-weight:500;color:#4a4a4a;flex:1}.delete-icon-button{background:none;border:none;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;border-radius:8px;transition:background-color .2s,opacity .2s;color:#c97d7d}.delete-icon-button svg{width:24px;height:24px}.delete-icon-button:hover{background-color:#c97d7d1a}.delete-icon-button:active:not(:disabled){background-color:#c97d7d33;opacity:.8}.delete-icon-button:disabled{opacity:.5;cursor:not-allowed}.modal-content form{display:flex;flex-direction:column;gap:20px}.form-field input{padding:12px 16px;border:1px solid #E0E0E0;border-radius:8px;font-size:16px;font-family:inherit;color:#4a4a4a;background-color:#fff;transition:border-color .2s}.form-field input::placeholder{color:#8a8a8a}.modal-buttons{display:flex;gap:12px;margin-top:8px}.modal-buttons button{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:opacity .2s,transform .2s}.modal-buttons button:disabled{opacity:.5;cursor:not-allowed}.modal-buttons button:active:not(:disabled){transform:scale(.98)}.button-primary{background-color:#8b7a6b;color:#fff}.button-primary:active:not(:disabled){background-color:#7a6b5d}.button-secondary{background-color:#fff;color:#8b7a6b;border:1px solid #8B7A6B}.button-secondary:active:not(:disabled){background-color:#f8f6f4}.button-danger{background-color:#c97d7d;color:#fff}.button-danger:active:not(:disabled){background-color:#b86d6d}.share-management-page{display:flex;flex-direction:column;min-height:100vh;background-color:#f8f6f4}.loading{text-align:center;padding:40px;color:#8a8a8a}.invite-code-card{background-color:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.invite-code-text{flex:1;font-size:18px;font-weight:500;color:#8b7a6b;font-family:Courier New,monospace;letter-spacing:2px}.copy-button{padding:8px 16px;border:1px solid #8B7A6B;border-radius:8px;background-color:#fff;color:#8b7a6b;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.copy-button:active:not(:disabled){background-color:#f8f6f4}.copy-button:disabled{opacity:.5;cursor:not-allowed}.regenerate-button{width:100%;padding:12px 16px;border:1px solid #8B7A6B;border-radius:8px;background-color:#fff;color:#8b7a6b;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.regenerate-button:active:not(:disabled){background-color:#f8f6f4}.regenerate-button:disabled{opacity:.5;cursor:not-allowed}.members-container{display:flex;flex-direction:column;gap:8px}.member-card{background-color:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014;display:flex;align-items:center;justify-content:space-between;gap:12px}.member-name{flex:1;font-size:16px;color:#4a4a4a}.member-badge{padding:4px 12px;border-radius:12px;background-color:#a8b5a0;color:#fff;font-size:12px;font-weight:500}.join-other-group-button{width:100%;padding:12px 16px;border:none;border-radius:8px;background-color:#8b7a6b;color:#fff;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.join-other-group-button:active{background-color:#7a6b5d}.leave-button{width:100%;padding:12px 16px;border:none;border-radius:8px;background-color:#c97d7d;color:#fff;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.leave-button:active:not(:disabled){background-color:#b86d6d}.leave-button:disabled{opacity:.5;cursor:not-allowed}.settings-page{display:flex;flex-direction:column;min-height:100vh;background-color:#f8f6f4}.section{margin-bottom:32px}.section-title{font-size:16px;font-weight:500;color:#4a4a4a;margin:0 0 12px;padding:0 4px}.setting-item{background-color:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014;display:flex;align-items:center;justify-content:space-between;gap:12px}.setting-label{flex:1;font-size:16px;color:#4a4a4a}.toggle-switch{position:relative;display:inline-block;width:48px;height:28px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#e0e0e0;transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:#a8b5a0}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.setting-link{width:100%;background-color:#fff;border:none;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;transition:background-color .2s;font-size:16px;color:#4a4a4a;text-align:left}.setting-link:active{background-color:#f8f6f4}.setting-link .arrow{color:#8a8a8a;font-size:20px}.group-join-page{display:flex;flex-direction:column;min-height:100vh;background-color:#f8f6f4}.page-header{background-color:#fff;padding:16px;border-bottom:1px solid #E0E0E0;display:flex;align-items:center;gap:12px}.back-button{background:none;border:none;font-size:24px;color:#4a4a4a;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.back-button:active{opacity:.6}.page-header h1{margin:0;font-size:20px;font-weight:500;color:#4a4a4a}.page-content{flex:1;padding:16px 16px 80px;overflow-y:auto}.error-message{background-color:#c97d7d;color:#fff;padding:12px 16px;border-radius:8px;margin-bottom:16px}.join-form{display:flex;flex-direction:column;gap:24px}.form-field{display:flex;flex-direction:column;gap:8px}.form-field label{font-size:14px;font-weight:500;color:#4a4a4a}.form-field input{padding:12px 16px;border:1px solid #E0E0E0;border-radius:8px;font-size:18px;font-family:Courier New,monospace;letter-spacing:2px;color:#4a4a4a;background-color:#fff;transition:border-color .2s;text-align:center}.form-field input:focus{outline:none;border-color:#8b7a6b}.form-field input::placeholder{color:#8a8a8a;letter-spacing:0}.form-hint{font-size:12px;color:#8a8a8a;margin:0;padding:0 4px}.join-button{width:100%;padding:16px;border:none;border-radius:8px;background-color:#8b7a6b;color:#fff;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s,transform .2s}.join-button:active:not(:disabled){background-color:#7a6b5d;transform:scale(.98)}.join-button:disabled{opacity:.5;cursor:not-allowed}.page-footer{position:fixed;bottom:0;left:0;right:0;background-color:#fff;border-top:1px solid #E0E0E0;padding:12px 16px;display:flex;justify-content:space-around;gap:12px;box-shadow:0 -2px 8px #00000014;z-index:100}.footer-button{flex:1;height:48px;border:none;border-radius:8px;background-color:#f8f6f4;color:#4a4a4a;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;gap:4px}.footer-button svg{width:24px;height:24px}.footer-button:active{background-color:#e0e0e0}.footer-button.active{background-color:#8b7a6b;color:#fff}.footer-button.active:active{background-color:#7a6b5d}
