*,*:before,*:after{box-sizing:border-box}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--safe-area-right: env(safe-area-inset-right, 0px)}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}html{overflow-x:hidden;-webkit-text-size-adjust:100%}body{margin:0;min-width:320px;min-height:100vh;min-height:100dvh;overflow-x:hidden;padding-top:var(--safe-area-top);padding-bottom:var(--safe-area-bottom);padding-left:var(--safe-area-left);padding-right:var(--safe-area-right);-webkit-tap-highlight-color:transparent}#root{width:100%;max-width:100vw;min-height:100vh;min-height:100dvh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s;min-height:44px;touch-action:manipulation}input,select,textarea{font-size:16px;min-height:44px;touch-action:manipulation}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:#fff9}.autocomplete-container{position:relative;flex:1}.autocomplete-input-wrapper{position:relative;display:flex;align-items:center}.autocomplete-input{width:100%;flex:1}.autocomplete-loading{position:absolute;right:10px;width:14px;height:14px;border:2px solid #646cff;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#1a1a1a;border:1px solid #333;border-radius:4px;box-shadow:0 4px 12px #0000004d;z-index:100;max-height:280px;overflow-y:auto}.autocomplete-suggestion{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;cursor:pointer;border-bottom:1px solid #2a2a2a;min-height:44px;touch-action:manipulation}.autocomplete-suggestion:last-child{border-bottom:none}.autocomplete-suggestion:hover,.autocomplete-suggestion.selected{background:#2a2a2a}.suggestion-main{display:flex;flex-direction:column;gap:2px;overflow:hidden}.suggestion-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-name strong{color:#646cff;font-weight:600}.suggestion-section{font-size:.75em;color:#ffffff80;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-frequency{display:flex;align-items:flex-end;gap:2px;margin-left:8px;flex-shrink:0;height:16px}.signal-bar{width:4px;background:#646cff4d;border-radius:1px}.signal-bar:nth-child(1){height:4px}.signal-bar:nth-child(2){height:8px}.signal-bar:nth-child(3){height:12px}.signal-bar.active{background:#646cff}@media (prefers-color-scheme: light){.autocomplete-dropdown{background:#fff;border-color:#ddd;box-shadow:0 4px 12px #0000001a}.autocomplete-suggestion{border-bottom-color:#eee}.autocomplete-suggestion:hover,.autocomplete-suggestion.selected{background:#f5f5f5}.suggestion-section{color:#00000080}}@media (display-mode: standalone){body{user-select:none;-webkit-user-select:none;overscroll-behavior-y:contain}input,textarea{user-select:text;-webkit-user-select:text}}.lists-page{max-width:1200px;margin:0 auto;padding:2rem}.lists-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.lists-header h1{font-size:1.75rem;color:#ffffffde;margin:0}.create-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#646cff;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .25s}.create-btn:hover{background:#535bf2}.lists-empty{text-align:center;padding:4rem 2rem;color:#fff9}.lists-empty p{margin-bottom:1.5rem;font-size:1.1rem}.lists-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.list-card{background:#1a1a1a;border-radius:12px;padding:1.25rem;cursor:pointer;transition:transform .2s,box-shadow .2s;border:2px solid transparent;position:relative}.list-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.list-card.active{border-color:#646cff}.list-card.dragging{opacity:.5;transform:scale(1.02)}.list-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.list-icon{font-size:1.75rem}.list-name{font-size:1.1rem;font-weight:500;color:#ffffffde;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-active-badge{font-size:.75rem;padding:.25rem .5rem;background:#646cff;color:#fff;border-radius:4px}.list-meta{display:flex;justify-content:space-between;color:#ffffff80;font-size:.85rem;margin-bottom:1rem}.list-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid #333}.list-actions button{flex:1;padding:.5rem;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;transition:background .2s}.list-actions .edit-btn{background:#333;color:#ffffffde}.list-actions .edit-btn:hover{background:#444}.list-actions .activate-btn{background:#2d4a2d;color:#7dff7d}.list-actions .activate-btn:hover{background:#3d5a3d}.list-actions .delete-btn{background:#4a2d2d;color:#ff7d7d}.list-actions .delete-btn:hover{background:#5a3d3d}.list-actions .delete-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#1a1a1a;border-radius:12px;padding:2rem;width:100%;max-width:400px;margin:1rem}.modal h2{margin:0 0 1.5rem;color:#ffffffde}.modal-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group input{padding:.75rem 1rem;border:1px solid #333;border-radius:8px;background:#0a0a0a;color:#ffffffde;font-size:1rem}.form-group select{padding:.75rem 1rem;border:1px solid #333;border-radius:8px;background:#0a0a0a;color:#ffffffde;font-size:1rem;cursor:pointer}.form-group select:focus{outline:none;border-color:#646cff}.icon-picker{display:flex;flex-wrap:wrap;gap:.5rem}.icon-option{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:2px solid #333;border-radius:8px;background:#0a0a0a;font-size:1.5rem;cursor:pointer;transition:border-color .2s}.icon-option:hover{border-color:#555}.icon-option.selected{border-color:#646cff;background:#1a1a2e}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem}.modal-actions button{flex:1;padding:.75rem;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .2s}.modal-actions .cancel-btn{background:#333;color:#ffffffde}.modal-actions .cancel-btn:hover{background:#444}.modal-actions .submit-btn{background:#646cff;color:#fff}.modal-actions .submit-btn:hover{background:#535bf2}.modal-actions .submit-btn:disabled{opacity:.6;cursor:not-allowed}.delete-confirm{text-align:center}.delete-confirm p{color:#ffffffb3;margin-bottom:.5rem}.delete-confirm .warning{color:#ff7d7d;font-size:.9rem;margin-bottom:1.5rem}.delete-confirm .danger-btn{background:#8b3a3a;color:#fff}.delete-confirm .danger-btn:hover{background:#a04545}.loading{text-align:center;padding:2rem;color:#fff9}.error-message{background:#3d1f1f;border:1px solid #5c2d2d;border-radius:8px;padding:.75rem 1rem;color:#ff8080;font-size:.875rem;margin-bottom:1rem}.toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background:#2d4a2d;color:#7dff7d;padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;z-index:1100;animation:fadeInUp .3s ease}.toast.error{background:#4a2d2d;color:#ff7d7d}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%,1rem)}to{opacity:1;transform:translate(-50%)}}.drag-handle{cursor:grab;color:#ffffff4d;padding:.25rem;margin-right:.5rem}.drag-handle:active{cursor:grabbing}@media (max-width: 768px){.lists-page{padding:1rem}.lists-header{flex-direction:column;align-items:stretch;gap:1rem}.lists-header h1{text-align:center;font-size:1.5rem}.create-btn{width:100%;justify-content:center}.lists-grid{grid-template-columns:1fr}}@media (min-width: 1200px){.lists-page{padding:2rem 4rem}.lists-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}}.connection-status{position:fixed;top:0;left:0;right:0;padding:.5rem;text-align:center;font-size:.85rem;z-index:1000;animation:slideDown .3s ease}.connection-status.connecting{background:#1a1a1a;color:#ffffffb3}.connection-status.reconnecting{background:#ffc10733;color:#ffc107}.connection-status.disconnected{background:#f4433633;color:#f44336}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.offline-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 16px;font-size:14px;color:#fff;text-align:center}.offline-banner.offline{background-color:#dc2626}.offline-banner.syncing{background-color:#2563eb}.offline-banner.online{background-color:#059669}.sync-button{padding:4px 12px;border:none;border-radius:4px;background-color:#fff3;color:#fff;font-size:12px;cursor:pointer;transition:background-color .2s}.sync-button:hover:not(:disabled){background-color:#ffffff4d}.sync-button:disabled{opacity:.6;cursor:not-allowed}.last-sync{font-size:12px;opacity:.8}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#1a1a1a;border-bottom:1px solid #333}.app-header h1{margin:0;font-size:1.5rem;color:#ffffffde}.header-nav{display:flex;gap:.75rem}.nav-btn{padding:.5rem 1rem;background:#333;color:#ffffffde;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background .2s}.nav-btn:hover{background:#444}.logout-btn{padding:.5rem 1rem;background:#333;color:#ffffffde;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background .2s}.logout-btn:hover{background:#444}.app-main{flex:1;background:#0a0a0a}@media (max-width: 768px){.app-header{flex-direction:column;padding:.75rem 1rem;gap:.5rem}.app-header h1{font-size:1.25rem}.header-nav{width:100%;justify-content:stretch}.header-nav .nav-btn,.header-nav .logout-btn{flex:1;text-align:center}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.login-card{background:#1a1a1a;border-radius:12px;padding:2rem;width:100%;max-width:400px;box-shadow:0 4px 24px #0000004d}.login-card h1{margin:0 0 .5rem;font-size:2rem;color:#ffffffde}.login-card p{margin:0 0 2rem;color:#fff9}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem;text-align:left}.form-group label{font-size:.875rem;color:#ffffffb3}.form-group input{padding:.75rem 1rem;border:1px solid #333;border-radius:8px;background:#0a0a0a;color:#ffffffde;font-size:1rem;transition:border-color .25s}.form-group input:focus{outline:none;border-color:#646cff}.form-group input::placeholder{color:#fff6}.error-message{background:#3d1f1f;border:1px solid #5c2d2d;border-radius:8px;padding:.75rem 1rem;color:#ff8080;font-size:.875rem}.login-button{padding:.75rem 1.5rem;border:none;border-radius:8px;background:#646cff;color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:background .25s}.login-button:hover:not(:disabled){background:#535bf2}.login-button:disabled{opacity:.6;cursor:not-allowed}.list-detail-page{max-width:1200px;margin:0 auto;padding:2rem}.list-detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.list-title{display:flex;align-items:center;gap:.75rem;flex:1}.list-title-icon{font-size:2rem}.list-title h1{margin:0;font-size:1.75rem;color:#ffffffde}.header-actions{display:flex;gap:.5rem}.template-btn{padding:.5rem 1rem;background:#333;color:#ffffffde;border:1px solid transparent;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background .2s}.template-btn:hover{background:#444;border-color:transparent}.template-btn:focus,.template-btn:focus-visible{outline:none;border-color:transparent}.template-btn.secondary{background:#2d3a4a;color:#7db8ff}.template-btn.secondary:hover{background:#3d4a5a}.add-section-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#646cff;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .25s}.add-section-btn:hover{background:#535bf2}.sections-list{display:flex;flex-direction:column;gap:1rem}.section-card{background:#1a1a1a;border-radius:12px;overflow:hidden}.section-header{display:flex;align-items:center;padding:1rem 1.25rem;gap:.75rem;background:#222}.section-drag-handle{cursor:grab;color:#ffffff4d;font-size:1.25rem}.section-drag-handle:active{cursor:grabbing}.section-collapse-btn{background:none;border:none;color:#fff9;cursor:pointer;padding:.25rem;font-size:1rem;transition:transform .2s}.section-collapse-btn.collapsed{transform:rotate(-90deg)}.section-name{flex:1;font-size:1.1rem;font-weight:500;color:#ffffffde}.section-item-count{font-size:.85rem;color:#ffffff80;background:#333;padding:.25rem .75rem;border-radius:12px}.section-actions{display:flex;gap:.5rem}.section-actions button{padding:.4rem .75rem;border:none;border-radius:6px;cursor:pointer;font-size:.8rem;transition:background .2s}.section-clear-btn{background:#3d3d2d;color:gold}.section-clear-btn:hover{background:#4d4d3d}.section-add-btn{background:#2d3d2d;color:#7dff7d}.section-add-btn:hover{background:#3d4d3d}.section-edit-btn{background:#333;color:#ffffffde}.section-edit-btn:hover{background:#444}.section-delete-btn{background:#4a2d2d;color:#ff7d7d}.section-delete-btn:hover{background:#5a3d3d}.section-content{padding:.5rem 1.25rem 1.25rem}.section-content.collapsed{display:none}.quick-add-bar{display:flex;gap:.5rem;margin-bottom:1.5rem;align-items:flex-start}.quick-add-bar input,.quick-add-bar select{padding:.6rem 1rem;border:1px solid #333;border-radius:6px;background:#0a0a0a;color:#ffffffde;font-size:.95rem}.quick-add-bar input:focus,.quick-add-bar select:focus{outline:none;border-color:#646cff}.quick-add-quantity{width:4.5rem;flex-shrink:0}.quick-add-description{flex:1;min-width:0}.quick-add-section{width:8rem;flex-shrink:0;cursor:pointer}.quick-add-btn{padding:.6rem 1rem;background:#646cff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;flex-shrink:0;font-weight:500}.quick-add-btn:hover{background:#535bf2}.quick-add-btn:disabled{opacity:.5;cursor:not-allowed}.item-row{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#0a0a0a;border-radius:8px;cursor:grab;transition:background .2s,opacity .2s}.item-row:hover{background:#111}.item-row.dragging{opacity:.5;transform:scale(1.02)}.item-row.uncertain{background:#ffd70014;border:1px solid rgba(255,215,0,.2)}.item-row.completed{opacity:.6}.item-drag-handle{color:#ffffff4d;font-size:1rem;cursor:grab}.item-drag-handle:active{cursor:grabbing}.item-checkbox{width:20px;height:20px;cursor:pointer;accent-color:#646cff;flex-shrink:0;margin-right:.75rem}.item-content{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.item-row-main{display:flex;align-items:center}.item-name{color:#ffffffde;word-break:break-word}.item-name.completed{text-decoration:line-through;color:#ffffff80}.item-quantity-inline{color:#ffffff80;font-size:.9em}.item-description{font-size:.85rem;color:#ffffff80;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-actions{display:flex;gap:.25rem;flex-shrink:0}.item-actions button{padding:.25rem .5rem;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;background:transparent;color:#ffffff80;transition:all .2s}.item-actions button:hover{background:#333;color:#ffffffde}.item-uncertain-btn{font-weight:700}.item-uncertain-btn:hover{color:gold!important}.item-edit-btn:hover{color:#646cff}.item-delete-btn:hover{color:#ff7d7d}.completed-section{margin-top:1rem;padding-top:.75rem;border-top:1px solid #333}.completed-section-header{display:flex;align-items:center;gap:.5rem;background:none;border:none;color:#fff9;cursor:pointer;padding:.25rem 0;font-size:.9rem;width:100%}.completed-section-header:hover{color:#fffc}.completed-collapse-btn{font-size:.75rem;transition:transform .2s}.completed-collapse-btn.collapsed{transform:rotate(-90deg)}.completed-items-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.sections-empty{text-align:center;padding:3rem 2rem;color:#ffffff80}.items-empty{text-align:center;padding:1rem;color:#fff6;font-size:.9rem}.section-card.dragging{opacity:.5;transform:scale(1.01)}.apply-template-modal{max-width:500px}.no-templates{color:#fff9;text-align:center;padding:1rem}.template-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.template-option{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#0a0a0a;border:1px solid #333;border-radius:8px;cursor:pointer;transition:all .2s}.template-option:hover{background:#111;border-color:#646cff}.template-option-name{font-weight:500;color:#ffffffde}.template-option-count{font-size:.85rem;color:#ffffff80}.selected-template-name{margin-bottom:1rem;color:#ffffffb3}.select-items-hint{font-size:.9rem;color:#fff9;margin-bottom:.75rem}.template-items-list{max-height:250px;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.template-item-checkbox{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:#0a0a0a;border-radius:6px;cursor:pointer}.template-item-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:#646cff}.template-item-name{flex:1;color:#ffffffde}.template-item-section{font-size:.75rem;padding:.15rem .5rem;background:#333;border-radius:4px;color:#fff9}.modal-description{color:#fff9;margin-bottom:1rem}@media (max-width: 768px){.list-detail-page{padding:1rem}.list-detail-header{flex-wrap:wrap}.header-actions{width:100%;display:flex;flex-wrap:wrap;gap:.5rem}.template-btn,.add-section-btn{flex:1;min-width:120px}.list-title h1{font-size:1.4rem}}.templates-page{max-width:1200px;margin:0 auto;padding:2rem}.templates-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.templates-header h1{font-size:1.75rem;color:#ffffffde;margin:0}.templates-empty{text-align:center;padding:4rem 2rem;color:#fff9}.templates-empty p{margin-bottom:.5rem;font-size:1.1rem}.templates-empty-hint{font-size:.9rem;color:#fff6}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.template-card{background:#1a1a1a;border-radius:12px;padding:1.25rem;cursor:pointer;transition:transform .2s,box-shadow .2s;border:2px solid transparent}.template-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.template-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.template-name{font-size:1.1rem;font-weight:500;color:#ffffffde;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-meta{display:flex;justify-content:space-between;color:#ffffff80;font-size:.85rem;margin-bottom:.75rem}.template-preview{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.preview-item{font-size:.8rem;padding:.25rem .5rem;background:#333;border-radius:4px;color:#ffffffb3}.preview-more{font-size:.8rem;color:#ffffff80;padding:.25rem .5rem}.template-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid #333}.template-actions button{flex:1;padding:.5rem;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;transition:background .2s}.template-actions .edit-btn{background:#333;color:#ffffffde}.template-actions .edit-btn:hover{background:#444}.template-actions .delete-btn{background:#4a2d2d;color:#ff7d7d}.template-actions .delete-btn:hover{background:#5a3d3d}@media (max-width: 768px){.templates-page{padding:1rem}.templates-header{flex-direction:column;align-items:stretch;gap:1rem}.templates-header h1{text-align:center;font-size:1.5rem}.create-btn{width:100%;justify-content:center}.templates-grid{grid-template-columns:1fr}}@media (min-width: 1200px){.templates-page{padding:2rem 4rem}.templates-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}}.template-detail-page{max-width:800px;margin:0 auto;padding:2rem}.template-detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.template-detail-header h1{flex:1;font-size:1.5rem;color:#ffffffde;margin:0}.back-btn{padding:.5rem 1rem;background:#333;color:#ffffffde;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background .2s}.back-btn:hover{background:#444}.edit-name-btn{padding:.5rem 1rem;background:#333;color:#ffffffde;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background .2s}.edit-name-btn:hover{background:#444}.add-item-form{display:flex;gap:.5rem;margin-bottom:1.5rem}.add-item-form input{flex:1;padding:.75rem 1rem;border:1px solid #333;border-radius:8px;background:#0a0a0a;color:#ffffffde;font-size:1rem}.add-item-form input:focus{outline:none;border-color:#646cff}.add-item-btn{padding:.75rem 1.5rem;background:#646cff;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;transition:background .2s}.add-item-btn:hover{background:#535bf2}.items-empty{text-align:center;padding:2rem;color:#ffffff80}.items-list{display:flex;flex-direction:column;gap:.5rem}.template-item-row{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#0a0a0a;border-radius:8px;cursor:grab;transition:background .2s,opacity .2s}.template-item-row:hover{background:#111}.template-item-row.dragging{opacity:.5;transform:scale(1.02)}.template-item-row .item-drag-handle{color:#ffffff4d;font-size:1rem;cursor:grab;flex-shrink:0}.template-item-row .item-drag-handle:active{cursor:grabbing}.template-item-row .item-name{flex:1;color:#ffffffde;min-width:0}.template-item-row .item-quantity{color:#ffffff80;font-size:.9em}.template-item-row .item-section{font-size:.75rem;padding:.15rem .5rem;background:#333;border-radius:4px;color:#fff9;flex-shrink:0}.template-item-row .item-actions{display:flex;gap:.25rem;flex-shrink:0}.template-item-row .item-actions button{padding:.25rem .5rem;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;background:transparent;color:#ffffff80;transition:all .2s}.template-item-row .item-actions button:hover{background:#333;color:#ffffffde}.template-item-row .item-edit-btn:hover{color:#646cff}.template-item-row .item-delete-btn:hover{color:#ff7d7d}@media (max-width: 768px){.template-detail-page{padding:1rem}.template-detail-header{flex-wrap:wrap}.template-detail-header h1{order:1;width:100%;text-align:center;margin-top:.5rem}.back-btn{order:0}.edit-name-btn{order:2;margin-left:auto}}.settings-page{max-width:800px;margin:0 auto;padding:2rem}.settings-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.settings-header h1{margin:0;font-size:1.75rem;color:#ffffffde}.settings-section{margin-bottom:2rem}.settings-section h2{font-size:1.2rem;color:#ffffffb3;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid #333}.settings-card{background:#1a1a1a;border-radius:12px;padding:1.25rem;margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.settings-card-header h3{margin:0 0 .25rem;font-size:1rem;color:#ffffffde}.settings-card-description{margin:0;font-size:.85rem;color:#ffffff80}.settings-action-btn{padding:.6rem 1.25rem;border:none;border-radius:8px;font-size:.9rem;cursor:pointer;transition:background .2s;white-space:nowrap;flex-shrink:0}.settings-action-btn:disabled{opacity:.6;cursor:not-allowed}.export-btn{background:#646cff;color:#fff}.export-btn:hover:not(:disabled){background:#535bf2}.import-btn{background:#333;color:#ffffffde}.import-btn:hover{background:#444}.import-modal,.export-modal{max-width:500px}.export-group{margin-bottom:1rem}.export-group-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.select-toggle-btn{background:none;border:none;color:#646cff;font-size:.8rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:background .2s}.select-toggle-btn:hover{background:#646cff1a}.export-selection-list{display:flex;flex-direction:column;gap:.375rem;max-height:200px;overflow-y:auto}.export-selection-list .checkbox-option{padding:.5rem .75rem}.export-item-icon{flex-shrink:0}.export-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.export-item-count{flex-shrink:0;font-size:.8rem;color:#fff6;margin-left:auto;padding-left:.5rem}.export-empty{text-align:center;color:#ffffff80;padding:2rem 0;margin:0}.import-preview-stats{display:flex;gap:1rem;margin-bottom:1.5rem}.preview-stat{flex:1;text-align:center;background:#0a0a0a;border-radius:8px;padding:1rem .5rem}.stat-count{display:block;font-size:1.5rem;font-weight:600;color:#646cff}.stat-label{display:block;font-size:.8rem;color:#ffffff80;margin-top:.25rem}.import-conflicts{background:#2d2a1f;border:1px solid #5c5328;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.import-conflicts h3{margin:0 0 .5rem;font-size:.9rem;color:#ffd07d}.conflict-group{margin-bottom:.5rem}.conflict-group:last-child{margin-bottom:0}.conflict-label{margin:0 0 .25rem;font-size:.85rem;color:#ffffffb3;font-weight:500}.import-conflicts ul{margin:0;padding-left:1.25rem;font-size:.85rem;color:#fff9}.import-options{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:1rem}.option-group{display:flex;flex-direction:column;gap:.5rem}.option-label{font-size:.875rem;color:#ffffffb3;font-weight:500}.import-mode-options{display:flex;flex-direction:column;gap:.5rem}.radio-option{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;background:#0a0a0a;border-radius:8px;cursor:pointer;transition:background .2s}.radio-option:hover{background:#151515}.radio-option input[type=radio]{margin-top:.15rem;accent-color:#646cff}.radio-label{display:block;font-size:.9rem;color:#ffffffde;font-weight:500}.radio-description{display:block;font-size:.8rem;color:#ffffff80;margin-top:.15rem}.checkbox-options{display:flex;flex-direction:column;gap:.5rem}.checkbox-option{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:#0a0a0a;border-radius:8px;cursor:pointer;font-size:.9rem;color:#ffffffde;transition:background .2s}.checkbox-option:hover{background:#151515}.checkbox-option input[type=checkbox]{accent-color:#646cff}.import-loading{text-align:center;padding:2rem 0}.import-loading h2{margin:0 0 .5rem}.import-loading p{color:#ffffff80}.import-result-stats{margin-bottom:1rem}.import-result-stats p{margin:.25rem 0;color:#7dff7d;font-size:.95rem}.import-skipped{background:#2d2a1f;border:1px solid #5c5328;border-radius:8px;padding:1rem;margin-bottom:1rem;max-height:200px;overflow-y:auto}.import-skipped h3{margin:0 0 .5rem;font-size:.9rem;color:#ffd07d}.import-skipped ul{margin:0;padding-left:1.25rem;font-size:.85rem;color:#fff9}.language-selector{display:flex;flex-wrap:wrap;gap:.5rem;width:100%;margin-top:.75rem}.settings-card:has(.language-selector){flex-direction:column;align-items:stretch}.language-option{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.5rem .75rem;border:1px solid #333;border-radius:8px;background:#0a0a0a;color:#ffffffb3;cursor:pointer;transition:all .2s;min-width:80px;font-size:.85rem}.language-option:hover{border-color:#646cff;background:#646cff1a;color:#ffffffde}.language-option.active{border-color:#646cff;background:#646cff26;color:#646cff;font-weight:500}.language-native-name{font-size:.85rem}.language-code{font-size:.7rem;color:#fff6;text-transform:uppercase}.language-option.active .language-code{color:#646cffb3}@media (max-width: 768px){.settings-page{padding:1rem}.settings-header{flex-direction:column;align-items:stretch;gap:.75rem}.settings-header h1{text-align:center;font-size:1.5rem}.settings-card{flex-direction:column;align-items:stretch}.settings-action-btn{width:100%;text-align:center}.import-preview-stats{flex-direction:column}}.install-banner{position:fixed;bottom:0;left:0;right:0;z-index:1000;padding:12px 16px;padding-bottom:calc(12px + var(--safe-area-bottom, 0px));background:#1a1a2e;border-top:1px solid #646cff;box-shadow:0 -2px 12px #0000004d}.install-banner-content{display:flex;align-items:center;justify-content:space-between;gap:12px;max-width:600px;margin:0 auto}.install-banner-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.install-banner-text strong{font-size:.95rem;color:#fffffff2}.install-banner-text span{font-size:.8rem;color:#fff9;line-height:1.3}.install-banner-actions{display:flex;gap:8px;flex-shrink:0}.install-banner-btn{padding:8px 16px;border-radius:6px;font-size:.85rem;font-weight:500;border:none;cursor:pointer;white-space:nowrap;min-height:44px;touch-action:manipulation}.install-btn{background:#646cff;color:#fff}.install-btn:hover{background:#535bf2}.dismiss-btn{background:transparent;color:#fff9}.dismiss-btn:hover{color:#ffffffe6}@media (max-width: 480px){.install-banner-content{flex-direction:column;align-items:stretch}.install-banner-actions{justify-content:flex-end}}@media (prefers-color-scheme: light){.install-banner{background:#f0f0ff;border-top-color:#646cff;box-shadow:0 -2px 12px #0000001a}.install-banner-text strong{color:#213547}.install-banner-text span{color:#0009}.dismiss-btn{color:#00000080}.dismiss-btn:hover{color:#000c}}
