*,*:before,*:after{box-sizing:border-box}html{scroll-padding-bottom:5rem}#root{width:100%}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;font-weight:400;--primary: #2563eb;--primary-light: #dbeafe;--primary-glow: rgba(37, 99, 235, .12);--bg-color: #f0f4f8;--text-main: #0f172a;--text-muted: #64748b;--card-bg: rgba(255, 255, 255, .85);--card-border: rgba(0, 0, 0, .08);color-scheme:light;color:var(--text-main);background-color:var(--bg-color);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;align-items:center;justify-content:center;min-width:320px;min-height:100vh;position:relative;overflow-x:hidden;background-image:radial-gradient(circle at 15% 50%,rgba(37,99,235,.07),transparent 30%),radial-gradient(circle at 85% 20%,rgba(99,179,237,.1),transparent 30%)}body:before{content:"";position:absolute;top:0;left:0;width:100vw;height:100vh;background:radial-gradient(ellipse at 60% 0%,rgba(37,99,235,.08),transparent 60%);z-index:-1;pointer-events:none}h1{font-size:4rem;line-height:1.1;font-weight:800;letter-spacing:-1.5px;background:linear-gradient(to right,#0f172a,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.2em}h2{font-size:1.5rem;font-weight:600;margin-top:0;margin-bottom:1.5rem;color:var(--text-main);border-bottom:1px solid var(--card-border);padding-bottom:.75rem}.navbar{position:fixed;top:0;left:0;right:0;height:56px;display:flex;align-items:center;padding:0 1.5rem;gap:1.5rem;background:#ffffffe6;border-bottom:1px solid rgba(0,0,0,.07);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:1000}.navbar-brand{font-size:1.1rem;font-weight:800;letter-spacing:-.5px;background:linear-gradient(to right,#0f172a,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;-webkit-user-select:none;user-select:none;flex-shrink:0}.navbar-links{display:flex;align-items:center;gap:.25rem;flex:1}.nav-link{display:flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:8px;font-size:.9rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:color .2s,background .2s;white-space:nowrap}.nav-link:hover{color:var(--text-main);background:#0000000d}.nav-link.active{color:var(--primary);background:var(--primary-light)}.nav-logout{background:none;border:none;cursor:pointer;font-family:inherit;margin-left:auto}.mobile-nav-link.nav-logout{width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:inherit;color:#ef4444}.mobile-nav-link.nav-logout:hover{background:#ef444414;color:#ef4444}.nav-logout:hover{color:#ef4444!important;background:#ef444414!important}.hamburger{display:none;background:none;border:none;color:var(--text-main);cursor:pointer;padding:.4rem;border-radius:8px;margin-left:auto;transition:background .2s}.hamburger:hover{background:#0000000d}.navbar-page-title{display:none;position:absolute;left:50%;transform:translate(-50%);font-size:1rem;font-weight:700;letter-spacing:-.3px;color:var(--text-main);white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none}.mobile-menu{display:none;position:absolute;top:56px;left:0;right:0;background:#fffffffa;border-bottom:1px solid rgba(0,0,0,.07);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);flex-direction:column;padding:.75rem;gap:.25rem;opacity:0;transform:translateY(-8px);transition:opacity .2s,transform .2s;pointer-events:none}.mobile-menu.open{opacity:1;transform:translateY(0);pointer-events:all}.mobile-nav-link{display:flex;align-items:center;gap:.6rem;padding:.75rem 1rem;border-radius:10px;font-size:1rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:color .15s,background .15s}.mobile-nav-link:hover{color:var(--text-main);background:#0000000a}.mobile-nav-link.active{color:var(--primary);background:var(--primary-light)}@media(max-width:640px){.navbar-links{display:none}.hamburger{display:flex;align-items:center;justify-content:center}.mobile-menu{display:flex}.navbar-page-title{display:block}}.shopping-list-container{width:100%;margin-top:0;display:flex;flex-direction:column;gap:1rem}.shopping-list{display:flex;flex-direction:column;gap:.5rem;min-height:50px}.shopping-item{display:flex;align-items:center;padding:.75rem 1rem;background:#ffffffb3;border:1px solid rgba(0,0,0,.06);border-radius:10px;gap:.75rem;transition:background .15s,border-color .15s}.shopping-item:hover{background:#fff;border-color:#2563eb26}.shopping-item.is-dragging{background:#2563eb14;border-color:#2563eb40;box-shadow:0 6px 20px #2563eb1f;z-index:10}.shopping-item.is-completed{opacity:.5}.shopping-item.is-completed .item-title{text-decoration:line-through;color:var(--text-muted)}.drag-handle{cursor:grab;color:var(--text-muted);opacity:.35;display:flex;align-items:center;justify-content:center;padding:.6rem;margin:-.35rem -.5rem -.35rem -.85rem;transition:opacity .2s}.drag-handle:hover,.shopping-item:hover .drag-handle{opacity:.8}.drag-handle:active{cursor:grabbing}.toggle-button{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#94a3b8;transition:color .2s,transform .1s}.toggle-button:hover{color:var(--primary)}.toggle-button:active{transform:scale(.9)}.check-icon{color:#16a34a}.item-content{flex:1;display:flex;flex-direction:column;gap:.1rem;min-width:0}.item-title{font-size:1rem;text-align:left;color:var(--text-main);transition:color .2s;word-break:break-word;overflow-wrap:anywhere;white-space:normal}.item-countdown{display:flex;align-items:center;gap:.25rem;font-size:.7rem;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.2px}.delete-button{background:none;border:none;padding:.25rem;cursor:pointer;color:#94a3b8;opacity:0;transition:opacity .2s,color .2s;display:flex;align-items:center;justify-content:center}.shopping-item:hover .delete-button{opacity:.6}.delete-button:hover{opacity:1!important;color:#dc2626}.add-item-form{display:flex;align-items:center;gap:.75rem}.add-item-form:focus-within{border-color:#2563eb66;box-shadow:0 0 0 3px #2563eb1a}.add-button{background:none;border:none;padding:0;cursor:pointer;color:#94a3b8;display:flex;align-items:center;justify-content:center;transition:color .2s}.add-button:not(:disabled):hover{color:var(--primary)}.add-button:disabled{opacity:.4;cursor:not-allowed}.add-input{flex:1;background:transparent;border:none;color:var(--text-main);font-size:1rem;padding:.5rem 0;outline:none;min-width:0;word-break:break-word;overflow-wrap:anywhere}.add-input::placeholder{color:#94a3b8}.loading,.error{padding:2rem;text-align:center;color:var(--text-muted)}.error{color:#dc2626}.sort-button{background:none;border:none;padding:.25rem;cursor:pointer;color:#94a3b8;display:flex;align-items:center;justify-content:center;transition:color .2s,transform .2s;flex-shrink:0}.sort-button:hover:not(:disabled){color:#7c3aed;transform:scale(1.15)}.shuffle-button:hover:not(:disabled){color:#ea580c;transform:scale(1.15)}.sort-button:disabled{cursor:not-allowed}@keyframes sparkle-spin{0%{transform:rotate(0) scale(1);opacity:1}50%{transform:rotate(180deg) scale(1.25);opacity:.7}to{transform:rotate(360deg) scale(1);opacity:1}}.sort-button--sorting{color:#7c3aed!important;animation:sparkle-spin 1s linear infinite}@keyframes sort-shimmer{0%{opacity:1}50%{opacity:.4}to{opacity:1}}.shopping-list--sorting .shopping-item{animation:sort-shimmer 1.2s ease-in-out infinite;pointer-events:none}.shopping-list--sorting .shopping-item:nth-child(2){animation-delay:.1s}.shopping-list--sorting .shopping-item:nth-child(3){animation-delay:.2s}.shopping-list--sorting .shopping-item:nth-child(4){animation-delay:.3s}.shopping-list--sorting .shopping-item:nth-child(5){animation-delay:.4s}.shopping-list--sorting .shopping-item:nth-child(6){animation-delay:.5s}@keyframes comment-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.sort-comment{display:flex;align-items:flex-start;gap:.5rem;padding:.65rem .85rem;background:#7c3aed14;border:1px solid rgba(124,58,237,.2);border-radius:10px;animation:comment-fade-in .25s ease-out;font-size:.85rem;color:#5b21b6;line-height:1.4}.sort-comment__icon{flex-shrink:0;font-size:.9rem;margin-top:1px}.sort-comment__text{flex:1}.sort-comment__dismiss{background:none;border:none;cursor:pointer;color:#7c3aed;font-size:1.1rem;line-height:1;padding:0 0 0 .25rem;opacity:.6;transition:opacity .15s;flex-shrink:0}.sort-comment__dismiss:hover{opacity:1}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.login-card{background:#fff;border:1px solid var(--card-border);border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:380px;box-shadow:0 1px 8px #0000000f,0 4px 24px #0000000a}.login-logo{font-size:1.1rem;font-weight:800;letter-spacing:-.5px;background:linear-gradient(to right,#0f172a,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.25rem;-webkit-user-select:none;user-select:none}.login-title{font-size:1.5rem;font-weight:700;letter-spacing:-.5px;color:var(--text-main);margin:0 0 1.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--card-border)}.login-form{display:flex;flex-direction:column;gap:1.1rem}.login-field{display:flex;flex-direction:column;gap:.35rem}.login-field label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.login-field input{padding:.6rem .85rem;border-radius:8px;border:1px solid var(--card-border);background:var(--bg-color);color:var(--text-main);font-size:.975rem;font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s}.login-field input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.login-error{color:#dc2626;font-size:.875rem;margin:0;padding:.5rem .75rem;background:#dc26260f;border-radius:8px;border-left:3px solid #dc2626}.login-btn{padding:.65rem;border-radius:8px;border:none;background:var(--primary);color:#fff;font-size:.975rem;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .2s,transform .15s;margin-top:.25rem}.login-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.auth-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-muted);font-size:1rem}.main-content{min-height:calc(100vh - 56px);padding-top:56px;display:flex;align-items:flex-start;justify-content:center;padding-bottom:5rem}.app{max-width:900px;width:90%;margin:0 auto;display:flex;flex-direction:column;align-items:stretch;padding-top:2.5rem}.page{width:100%;display:flex;flex-direction:column;gap:1.5rem}.page-title{font-size:1.5rem;font-weight:700;letter-spacing:-.5px;color:var(--text-main);margin:0}.card{margin-top:1rem;padding:2rem;width:100%;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:16px;box-shadow:0 1px 8px #0000000f,0 4px 24px #0000000a;text-align:left}.card p{margin:1rem 0;font-size:1.05rem;color:var(--text-muted);display:flex;flex-direction:column;gap:.25rem}.card p strong{color:var(--text-main);font-size:.85rem;text-transform:uppercase;letter-spacing:1px}.status-indicator{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:8px;background-color:#10b981;box-shadow:0 0 10px #10b981}@media(max-width:640px){.app{padding-top:.5rem}.page-title{display:none}.add-item-form{left:0;right:0;width:100%;border-radius:0;border-left:none;border-right:none;border-bottom:none}}.add-item-form{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:90%;max-width:900px;border-top:1px solid rgba(0,0,0,.1);border-bottom:none;border-radius:12px 12px 0 0;background:#fffffff7;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:.75rem 1rem;box-shadow:0 -2px 12px #00000012;z-index:100}
