.topBar{background:#363636;padding:15px 5px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center;position:fixed;top:0;left:0;right:0;z-index:1000}.logoutButton{background:none;border:none;font-size:24px;cursor:pointer;padding:5px;display:flex;align-items:center;transition:transform .2s}.logoutButton:hover{transform:scale(1.1)}.logoutIcon{filter:invert(1)}.title{margin:0;color:#fff;cursor:pointer;transition:opacity .2s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.title:hover{opacity:.8}.home-container{display:flex;flex-direction:column;min-height:100vh;width:100%;padding-top:100px;box-sizing:border-box;overflow-x:hidden;background:#f5f5f5}.home-main{flex:1;padding:40px;overflow:auto;width:100%;box-sizing:border-box}.pages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;max-width:1200px;margin:0 auto;width:100%}.page-card{background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;align-items:center;gap:15px;min-height:200px}.page-card:hover{transform:translateY(-5px);box-shadow:0 4px 16px #00000026}.page-icon{font-size:64px}.page-name{margin:0;color:#333}.page-description{margin:0;color:#666;text-align:center}.add-user-btn{padding:10px 20px;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:16px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:30px;border-radius:8px;min-width:400px;box-shadow:0 2px 10px #0000001a}.modal-content h2{margin-top:0;margin-bottom:20px}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500}.form-group input{width:100%;padding:8px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box}.modal-buttons{display:flex;gap:10px;margin-top:20px}.btn-add,.btn-cancel{flex:1;padding:10px;border:none;border-radius:4px;cursor:pointer;font-size:14px}@media (max-width: 768px){.home-container{padding-top:90px}.home-main{padding:20px}.pages-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px}.page-card{padding:25px;min-height:180px}.page-icon{font-size:56px}}@media (max-width: 480px){.home-container{padding-top:80px}.home-main{padding:15px}.pages-grid{grid-template-columns:1fr;gap:12px}.page-card{padding:20px;min-height:150px;gap:12px}.page-icon{font-size:48px}.page-name{font-size:18px}.page-description{font-size:14px}}.container{display:flex;justify-content:center;align-items:center;height:100vh;background-color:#f5f5f5}.form{padding:20px;border-radius:8px;background-color:#fff;box-shadow:0 2px 8px #0003;width:300px}.inputGroup{margin-bottom:15px;display:flex;flex-direction:column}.input{padding:8px;font-size:16px;border-radius:4px;border:1px solid #ccc;margin-top:5px}.button{width:100%;padding:10px;font-size:16px;border-radius:4px;border:none;background-color:#007bff;color:#fff;cursor:pointer}.error{color:red;margin-bottom:10px}.shopping-container{display:flex;flex-direction:column;min-height:100vh;width:100%;padding-top:100px;box-sizing:border-box;overflow-x:hidden;background:#f5f5f5}.shopping-main{flex:1;padding:40px;width:100%;box-sizing:border-box}.add-item-form{display:flex;gap:10px;margin-bottom:20px;align-items:flex-start;background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #0000001a}.add-item-form input{flex:1;padding:.875rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s;min-width:0;width:100%;box-sizing:border-box}.add-item-form input:focus{outline:none;border-color:#667eea}.add-item-form input:disabled{background-color:#f5f5f5;cursor:not-allowed}.add-item-form button{padding:.875rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;white-space:nowrap;flex-shrink:0}.add-item-form button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.add-item-form button:disabled{opacity:.6;cursor:not-allowed}.shopping-list{background:#fff;border-radius:12px;padding:.75rem;box-shadow:0 4px 12px #0000001a;margin-bottom:1rem}.shopping-list>p{text-align:center;color:#666;font-size:1.1rem;margin:2rem 0}.shopping-list ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}.shopping-list li{display:flex;justify-content:space-between;align-items:center;padding:.5rem .65rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;gap:.6rem;transition:all .2s ease;-webkit-user-select:none;user-select:none;min-height:32px;border:2px solid transparent}.shopping-list li:hover{background-color:#f9f9f9}.shopping-list li.purchased .item-content{opacity:.25}.shopping-list li.selected{background:#e3f2fd;border-color:#2196f3;cursor:pointer}.item-content{display:flex;align-items:center;gap:.4rem;flex:1;min-width:0}.user-icon-small,.user-icon-placeholder-small{width:22px;height:22px;border-radius:50%;flex-shrink:0}.user-icon-small{object-fit:cover}.user-icon-placeholder-small{display:flex;align-items:center;justify-content:center;font-size:.85rem;background:#f0f0f0}.item-name{flex:1;min-width:0;word-break:break-word;font-size:.95rem;transition:text-decoration .2s}.item-actions{display:flex;gap:.4rem;align-items:center}.icon-button{width:30px;height:30px;border:none;border-radius:50%;cursor:pointer;font-size:1.05rem;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.icon-button:hover{transform:scale(1.1)}.icon-button:active{transform:scale(.95)}.check-button{background-color:#e8f5e9;color:#4caf50}.check-button:hover{background-color:#c8e6c9}.check-button.checked{background-color:#4caf50;color:#fff}.delete-controls{display:flex;gap:1rem;justify-content:center;background:#fff;padding:1rem 1.5rem;border-radius:12px;box-shadow:0 4px 12px #0000001a}.btn-delete-mode,.btn-delete-selected,.btn-cancel-delete{padding:.875rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.btn-delete-mode{background:#ffebee;color:#f44336}.btn-delete-mode:hover{background:#ffcdd2}.btn-delete-selected{background:#f44336;color:#fff}.btn-delete-selected:hover:not(:disabled){background:#d32f2f}.btn-delete-selected:disabled{opacity:.5;cursor:not-allowed}.btn-cancel-delete{background:#e0e0e0;color:#333}.btn-cancel-delete:hover{background:#bdbdbd}.shopping-main .error{background:#dc26261a;color:#dc2626;border:1px solid rgba(220,38,38,.3);text-align:center;padding:2rem;font-size:1.1rem;border-radius:12px}.input-wrapper{position:relative;flex:1;min-width:0}.input-wrapper input{width:100%;box-sizing:border-box}.suggestions-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #e0e0e0;border-top:none;border-radius:0 0 8px 8px;max-height:200px;overflow-y:auto;z-index:1000;list-style:none;padding:0;margin:0;box-shadow:0 4px 12px #00000026}.suggestions-dropdown li{padding:.875rem 1rem;cursor:pointer;transition:background-color .15s;border-bottom:1px solid #f0f0f0;font-size:1rem}.suggestions-dropdown li:last-child{border-bottom:none}.suggestions-dropdown li:hover,.suggestions-dropdown li.selected{background-color:#f5f5f5}@media (max-width: 768px){.shopping-container{padding-top:90px}.shopping-main{padding:20px}.add-item-form{flex-direction:row;padding:1rem;gap:.75rem}.add-item-form button{width:auto;padding:.875rem 1.5rem}.shopping-list{padding:.6rem}.shopping-list ul{gap:.3rem}.shopping-list li{padding:.5rem .6rem;gap:.5rem;min-height:30px;border:2px solid transparent}.item-name{font-size:.9rem}.icon-button{width:34px;height:34px;font-size:1.15rem}.delete-controls{padding:.75rem 1rem;gap:.5rem}.btn-delete-mode,.btn-delete-selected,.btn-cancel-delete{flex:1;padding:.75rem 1rem;font-size:.95rem}}@media (max-width: 480px){.shopping-container{padding-top:80px}.shopping-main{padding:10px}.add-item-form{padding:.875rem;flex-direction:row;gap:.5rem}.add-item-form input,.add-item-form button{font-size:.95rem}.add-item-form button{padding:.875rem 1.25rem;width:auto}.shopping-list li{padding:.6rem .7rem;gap:.65rem;min-height:40px;border:2px solid transparent}.shopping-list ul{gap:.4rem}.icon-button{width:38px;height:38px;font-size:1.25rem}.item-actions{gap:1rem}.delete-controls{flex-direction:column;padding:.75rem}.btn-delete-mode,.btn-delete-selected,.btn-cancel-delete{width:100%}}.toast{padding:1rem 1.5rem;border-radius:8px;margin-top:1rem;font-weight:500;animation:slideIn .3s ease-out}.toast.success{background-color:#4caf50;color:#fff}.toast.error{background-color:#f44336;color:#fff}.toast.info{background-color:#2196f3;color:#fff}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.computer-main{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 60px);padding:20px;box-sizing:border-box}.computer-content{width:100%;max-width:600px;padding:20px}.computer-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:20px}.computer-button{padding:16px 24px;font-size:16px;font-weight:600;border:none;border-radius:8px;background-color:#007bff;color:#fff;cursor:pointer;transition:all .3s ease;min-height:56px;touch-action:manipulation;display:flex;align-items:center;justify-content:center;gap:8px;position:relative;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.computer-button:hover:not(:disabled){background-color:#0056b3;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.computer-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #0003}.computer-button:disabled{opacity:.6;cursor:not-allowed}.computer-button.loading{background-color:#0056b3}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.computer-message{position:fixed;bottom:20px;left:50%;transform:translate(-50%);padding:16px 24px;border-radius:8px;text-align:center;font-weight:500;min-width:300px;max-width:90%;box-shadow:0 4px 12px #0000004d;z-index:1000;animation:slideUp .3s ease}.computer-message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.computer-message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}@media (max-width: 768px){.computer-main,.computer-content{padding:16px}.computer-buttons{grid-template-columns:repeat(2,1fr);gap:12px}.computer-button{font-size:15px;padding:14px 20px}}@media (max-width: 480px){.computer-main{padding:12px;min-height:calc(100vh - 50px)}.computer-content{padding:12px}.computer-buttons{grid-template-columns:1fr;gap:12px}.computer-button{font-size:16px;padding:16px;min-height:60px;width:100%}.spinner{width:14px;height:14px}.computer-message{bottom:16px;padding:14px 20px;font-size:14px;min-width:auto;width:calc(100% - 32px);max-width:none}}@media (min-width: 1200px){.computer-buttons{grid-template-columns:repeat(2,1fr);max-width:500px;margin-left:auto;margin-right:auto}}.admin-container{display:flex;flex-direction:column;min-height:100vh;width:100%;max-width:100%;padding-top:100px;overflow-x:hidden;box-sizing:border-box;background:#f5f5f5}.admin-main{flex:1;padding:1rem;width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.admin-content{max-width:1200px;width:100%;margin:0 auto;padding:2rem 1rem;box-sizing:border-box}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.section-header h2{margin:0}.add-user-btn{padding:.75rem 1.5rem;font-size:1rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s ease;width:auto;white-space:nowrap}.add-user-btn:hover{background-color:#0056b3}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;padding:1rem;z-index:1000;overflow-y:auto;overflow-x:hidden;box-sizing:border-box}.modal-content{background:#fff;padding:2rem;border-radius:8px;width:100%;max-width:500px;box-shadow:0 4px 6px #0000001a;max-height:90vh;overflow-y:auto;overflow-x:hidden;box-sizing:border-box;margin:auto}.modal-content h2{margin-top:0;margin-bottom:1.5rem;font-size:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-group input{width:100%;padding:.75rem;font-size:1rem;border:1px solid #ddd;border-radius:4px;box-sizing:border-box;max-width:100%}.form-group input:focus{outline:none;border-color:#007bff}.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;background:#fff;cursor:pointer;box-sizing:border-box;max-width:100%}.form-group select:focus{outline:none;border-color:#007bff}.modal-buttons{display:flex;gap:1rem;flex-wrap:wrap}.modal-buttons button{flex:1;min-width:120px;padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:4px;cursor:pointer;transition:all .3s ease}.btn-add{background-color:#28a745;color:#fff}.btn-add:hover{background-color:#218838}.btn-cancel{background-color:#6c757d;color:#fff}.btn-cancel:hover{background-color:#5a6268}.users-list{margin-top:2rem;width:100%;max-width:100%;overflow-x:hidden}.users-list h2{margin-bottom:1rem}.users-table{width:100%;max-width:100%;border-collapse:collapse;background:transparent;border-radius:8px;overflow:hidden;box-shadow:none;table-layout:fixed}.users-table thead{background:transparent}.users-table th,.users-table td{padding:1rem;text-align:left;border-bottom:1px solid #e0e0e0}.users-table th{font-weight:600;color:#333}.users-table td{color:#666;user-select:none;-webkit-user-select:none}.users-table tbody tr:hover{background:#ffffff80}.btn-edit{padding:.5rem 1rem;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.btn-edit:hover{background:#0056b3}.user-icon-small{width:32px;height:32px;border-radius:50%;object-fit:cover;display:block;margin:0 auto}.user-icon-placeholder{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;border-radius:50%;background:#f0f0f0;margin:0 auto}.modal-icon-preview{display:flex;justify-content:center;margin-bottom:1rem}.user-icon-large{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid #ddd}.user-icon-placeholder-large{display:flex;align-items:center;justify-content:center;font-size:2.5rem;background:#f0f0f0}.file-input{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;cursor:pointer;box-sizing:border-box;max-width:100%}.file-input::-webkit-file-upload-button{padding:.5rem 1rem;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;margin-right:1rem}.file-input::-webkit-file-upload-button:hover{background:#0056b3}.users-table th:first-child,.users-table td:first-child{width:60px;text-align:center;vertical-align:middle}.btn-change-password{width:100%;padding:.75rem;background:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem}.btn-change-password:hover{background:#5a6268}.action-buttons{display:flex;gap:.5rem}.btn-delete{padding:.5rem 1rem;background:#dc3545;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.btn-delete:hover{background:#c82333}@media (max-width: 768px){.admin-container{padding-top:90px}.admin-content{padding:1.5rem .75rem}.modal-content{padding:1.5rem;max-height:92vh}.modal-content h2{font-size:1.25rem}.add-user-btn{width:100%;max-width:none}.section-header{flex-direction:column;align-items:flex-start}.users-table th,.users-table td{padding:.75rem .5rem;font-size:.9rem}.action-buttons{flex-direction:column;gap:.25rem}.btn-edit,.btn-delete{width:100%;padding:.4rem .75rem;font-size:.85rem}}@media (max-width: 480px){.admin-container{padding-top:80px;overflow-x:hidden;max-width:100vw}.admin-main{padding:.5rem;overflow-x:hidden;max-width:100%}.admin-content{padding:1rem .5rem;overflow-x:hidden;max-width:100%}.modal-overlay{padding:0;align-items:center;overflow-x:hidden}.modal-content{padding:.75rem;width:100vw;max-width:100vw;max-height:100vh;margin:0;border-radius:0;overflow-x:hidden}.modal-content h2{font-size:1rem;margin-bottom:.75rem}.modal-buttons{flex-direction:column;gap:.5rem;margin-top:.75rem}.modal-buttons button{width:100%;padding:.65rem}.form-group{margin-bottom:.75rem}.form-group label{font-size:.85rem;margin-bottom:.3rem}.form-group input,.form-group select{font-size:16px;padding:.6rem;width:100%;max-width:100%;box-sizing:border-box}.user-icon-large{width:50px;height:50px}.user-icon-placeholder-large{font-size:1.75rem}.modal-icon-preview{margin-bottom:.5rem}.btn-change-password{padding:.6rem;font-size:.9rem}.file-input{padding:.3rem;font-size:.85rem;width:100%;max-width:100%;box-sizing:border-box}.file-input::-webkit-file-upload-button{padding:.4rem .6rem;font-size:.8rem;margin-right:.5rem}.users-list{overflow-x:hidden;max-width:100%}.users-table{font-size:.85rem;overflow-x:hidden;max-width:100%;table-layout:auto}.users-table th,.users-table td{padding:.5rem .25rem}.users-table th:first-child,.users-table td:first-child{width:40px}.user-icon-small{width:24px;height:24px}.user-icon-placeholder{width:24px;height:24px;font-size:1rem}.action-buttons{flex-direction:row;gap:.5rem;width:100%;max-width:100%;box-sizing:border-box}.btn-edit,.btn-delete{flex:1;padding:.5rem .75rem;font-size:.85rem;box-sizing:border-box}.users-table thead{display:none}.users-table,.users-table tbody,.users-table tr,.users-table td{display:block;width:100%;max-width:100%}.users-table tr{margin-bottom:1rem;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;box-sizing:border-box;background:#fff}.users-table td{text-align:left;padding:.75rem;border-bottom:1px solid #f0f0f0;position:relative;word-break:break-word;overflow-wrap:break-word;box-sizing:border-box}.users-table td:last-child{border-bottom:none}.users-table td:first-child{display:inline-block;text-align:left;padding:.75rem;background:transparent;width:auto;vertical-align:middle;border-bottom:none}.users-table td:nth-child(2){display:inline-block;vertical-align:middle;width:auto;padding:.75rem .75rem .75rem .5rem;border-bottom:1px solid #f0f0f0}.users-table td:nth-child(2):before{content:""}.users-table td:nth-child(3){padding:.75rem}.users-table td:nth-child(3):before{content:"Role: ";font-weight:600;color:#333}.users-table td:nth-child(4){padding:.5rem .75rem}.add-user-btn{font-size:.95rem;padding:.65rem 1.25rem}}@media (max-width: 360px){.modal-overlay{padding:0}.modal-content{padding:.5rem;width:100vw;max-width:100vw;max-height:100vh;border-radius:0}.modal-content h2{font-size:.95rem;margin-bottom:.5rem}.form-group{margin-bottom:.6rem}.form-group label{font-size:.8rem;margin-bottom:.25rem}.form-group input,.form-group select,.btn-change-password{padding:.5rem;font-size:16px;width:100%;max-width:100%}.user-icon-large{width:45px;height:45px}.user-icon-placeholder-large{font-size:1.5rem}.file-input{padding:.25rem;font-size:.8rem;width:100%;max-width:100%}.file-input::-webkit-file-upload-button{padding:.35rem .5rem;font-size:.75rem}.modal-buttons{gap:.4rem;margin-top:.5rem}.modal-buttons button{padding:.55rem .75rem;font-size:.85rem}.btn-edit,.btn-delete{font-size:.8rem;padding:.45rem .6rem}.action-buttons{gap:.4rem}}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-tap-highlight-color:transparent}@media (max-width: 768px){*{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}input,textarea{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}img,a{-webkit-touch-callout:none}}
