.login-page,.register-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#0b1220;padding:2rem 1rem}.login-container,.register-container{display:flex;flex-direction:column;align-items:center;width:100%;max-width:440px}.login-brand,.register-brand{text-align:center;margin-bottom:2rem}.brand-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:14px;background:#0f172a;border:1px solid rgba(148,163,184,.14);color:var(--text-primary);margin-bottom:1rem}.brand-icon svg{width:28px;height:28px}.brand-name{color:var(--text-primary);font-size:1.5rem;font-weight:700;letter-spacing:-.03em}.brand-tagline{color:var(--text-secondary);font-size:.9rem;margin-top:.25rem}.login-card,.register-card{width:100%;background:#0f172a;border:1px solid rgba(148,163,184,.14);border-radius:14px;padding:2.5rem 2rem 2rem}.card-header{text-align:center;margin-bottom:1.75rem}.card-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.04em}.card-header p{color:var(--text-secondary);font-size:.875rem;margin-top:.35rem}.alert{display:flex;align-items:flex-start;gap:.625rem;padding:12px 14px;border-radius:12px;font-size:.9rem;margin-bottom:18px}.alert-icon{flex-shrink:0;width:18px;height:18px;margin-top:2px}.alert-error{border:1px solid rgba(239,68,68,.26);background:#ef44441a;color:#fca5a5}.alert-success{border:1px solid rgba(34,197,94,.26);background:#22c55e1a;color:#86efac}.login-form,.register-form{display:grid;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px}.label-row{display:flex;align-items:center;justify-content:space-between}.form-label{font-size:.82rem;font-weight:500;color:var(--text-secondary)}.forgot-link{font-size:.75rem;font-weight:500;color:#2563eb}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:14px;width:18px;height:18px;color:var(--text-muted);pointer-events:none}.form-input{width:100%;padding:12px 13px 12px 2.75rem;font-size:.9375rem;font-family:inherit;color:var(--text-primary);background:#0b1220;border:1px solid rgba(148,163,184,.14);border-radius:12px;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:#2563ebb8;box-shadow:0 0 0 3px #2563eb24}.form-input:disabled{opacity:.55;cursor:not-allowed}.toggle-password{position:absolute;right:12px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-muted)}.toggle-password svg{width:18px;height:18px}.toggle-password:hover{color:var(--text-secondary)}.btn-submit{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:12px 16px;margin-top:8px;font-size:.9375rem;font-weight:600;font-family:inherit;color:#fff;background:#2563eb;border:none;border-radius:12px;cursor:pointer;transition:transform var(--transition-fast),opacity var(--transition-base)}.btn-submit:hover:not(:disabled){transform:translateY(-1px)}.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-loading{opacity:.85}.spinner{display:inline-block;width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite}.check-icon{width:20px;height:20px}.card-footer{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(148,163,184,.14)}.card-footer p{font-size:.8125rem;color:var(--text-secondary)}.signup-link,.login-link{font-weight:600;color:#2563eb}.signup-link:hover,.login-link:hover{color:#3b82f6}.login-footer-text,.register-footer-text{margin-top:2rem;font-size:.75rem;color:var(--text-muted);text-align:center}.dashboard-page{min-height:100vh;background:#0b1220}.dashboard-shell{width:min(1120px,calc(100% - 32px));margin:0 auto;padding:32px 0 48px}.dashboard-navbar{display:flex;align-items:center;min-height:56px;margin-bottom:20px}.dashboard-brand{color:var(--text-primary);font-size:1.1rem;font-weight:700;letter-spacing:-.03em}.dashboard-brand:hover{color:var(--text-primary)}.dashboard-loading{min-height:100vh;display:grid;place-content:center;gap:16px;color:var(--text-secondary);text-align:center}.loading-ring{width:44px;height:44px;border:3px solid rgba(148,163,184,.18);border-top-color:#22c55e;border-radius:50%;margin:0 auto;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-hero{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;padding:0 0 24px;margin-bottom:24px;border-bottom:1px solid rgba(148,163,184,.12)}.hero-copy{max-width:620px}.eyebrow,.panel-kicker{display:inline-block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:#94a3b8}.dashboard-hero h1{margin-top:6px;font-size:clamp(2rem,3vw,2.8rem);line-height:1.08;letter-spacing:-.04em}.dashboard-hero h1 span{color:#f8fafc}.dashboard-hero p{max-width:560px;margin-top:10px;color:var(--text-secondary);font-size:.98rem}.hero-actions{display:grid;gap:12px;min-width:260px}.hero-usercard,.dashboard-panel,.stat-card{border:1px solid rgba(148,163,184,.14);background:#0f172a}.hero-usercard{display:grid;gap:4px;padding:16px;border-radius:14px}.usercard-label{color:var(--text-muted);font-size:.82rem}.ghost-button,.primary-button,.mini-button{border:none;cursor:pointer;transition:transform var(--transition-fast),opacity var(--transition-base),background var(--transition-base)}.ghost-button{padding:11px 16px;border:1px solid rgba(148,163,184,.18);border-radius:12px;background:transparent;color:var(--text-primary)}.primary-button{padding:12px 16px;border-radius:12px;background:#2563eb;color:#fff;font-weight:600}.ghost-button:hover,.primary-button:hover,.mini-button:hover{transform:translateY(-1px)}.ghost-button:disabled,.primary-button:disabled,.mini-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:24px}.stat-card{padding:18px;border-radius:14px}.stat-label{color:var(--text-secondary);font-size:.82rem}.stat-card strong{display:block;margin-top:8px;font-size:1.75rem;letter-spacing:-.04em}.dashboard-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:14px}.dashboard-panel{padding:20px;border-radius:14px}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.panel-header h2{margin-top:2px;font-size:1.25rem;letter-spacing:-.04em}.dashboard-form{display:grid;gap:12px}.dashboard-form label{font-size:.82rem;font-weight:500;color:var(--text-secondary)}.dashboard-form input,.dashboard-form select{width:100%;padding:12px 13px;border:1px solid rgba(148,163,184,.14);border-radius:12px;background:#0b1220;color:var(--text-primary);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.dashboard-form input:focus,.dashboard-form select:focus{border-color:#2563ebb8;box-shadow:0 0 0 3px #2563eb24}.form-split{display:grid;grid-template-columns:1.2fr .8fr;gap:12px}.dashboard-alert{margin-top:14px;padding:12px 14px;border:1px solid rgba(37,99,235,.18);border-radius:12px;background:#2563eb1a;color:#bfdbfe;font-size:.9rem}.dashboard-alert-error{margin-bottom:18px;border-color:#ef444442;background:#ef44441a;color:#fca5a5}.household-ready{display:grid;gap:12px;padding:16px;border:1px solid rgba(34,197,94,.18);border-radius:12px;background:#22c55e12}.status-pill{display:inline-flex;width:fit-content;padding:6px 10px;border-radius:999px;background:#94a3b81f;color:var(--text-primary);font-size:.78rem;font-weight:600;text-transform:capitalize}.status-pill.fresh,.legend-chip.fresh{background:#22c55e24;color:#86efac}.status-pill.expiring-soon,.legend-chip.expiring-soon{background:#f59e0b24;color:#fcd34d}.status-pill.expired,.legend-chip.expired{background:#ef444424;color:#fca5a5}.status-pill.used{background:#38bdf824;color:#7dd3fc}.status-pill.wasted{background:#f472b624;color:#f9a8d4}.inventory-panel{margin-top:2px}.legend-row{display:flex;flex-wrap:wrap;gap:8px}.legend-chip{display:inline-flex;padding:6px 10px;border-radius:999px;font-size:.76rem;font-weight:600}.inventory-list{display:grid;gap:12px}.inventory-card{display:flex;justify-content:space-between;gap:16px;padding:16px;border:1px solid rgba(148,163,184,.12);border-radius:12px;background:#0b1220}.inventory-main{min-width:0}.inventory-title-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.inventory-title-row h3{font-size:1.02rem;font-weight:600;letter-spacing:-.03em}.inventory-meta{display:flex;flex-wrap:wrap;gap:10px 16px;margin-top:8px;color:var(--text-secondary);font-size:.86rem}.meta-chip{display:inline-flex;padding:4px 8px;border-radius:999px;background:#94a3b814}.inventory-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px}.mini-button{padding:9px 12px;border-radius:10px;background:#94a3b814;color:var(--text-primary);font-size:.84rem}.mini-button.warning{background:#f59e0b1a;color:#fcd34d}.mini-button.danger{background:#ef44441a;color:#fca5a5}.empty-state{display:grid;place-items:center;min-height:260px;padding:24px;border:1px dashed rgba(148,163,184,.2);border-radius:12px;background:#0b1220;text-align:center}.empty-state h3{font-size:1.15rem;letter-spacing:-.03em}.empty-state p{margin-top:8px;max-width:520px;color:var(--text-secondary)}@media(max-width:980px){.dashboard-hero,.inventory-card{display:grid}.stats-grid,.dashboard-grid{grid-template-columns:1fr}.inventory-actions{justify-content:flex-start}}@media(max-width:720px){.dashboard-shell{width:min(100% - 20px,1120px);padding:20px 0 32px}.dashboard-panel,.stat-card,.hero-usercard{padding:16px}.form-split{grid-template-columns:1fr}.dashboard-hero h1{font-size:2rem}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-card: rgba(17, 24, 39, .65);--bg-card-border: rgba(99, 102, 241, .15);--accent-primary: #6366f1;--accent-secondary: #818cf8;--accent-glow: rgba(99, 102, 241, .4);--accent-gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a78bfa 100%);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--text-accent: #a5b4fc;--error-bg: rgba(239, 68, 68, .1);--error-border: rgba(239, 68, 68, .3);--error-text: #fca5a5;--success-bg: rgba(34, 197, 94, .1);--success-border: rgba(34, 197, 94, .3);--success-text: #86efac;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-glow: 0 0 40px rgba(99, 102, 241, .15);--shadow-card: 0 25px 60px rgba(0, 0, 0, .4);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{min-height:100vh;width:100%}a{color:var(--accent-secondary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--text-accent)}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}::-webkit-scrollbar{display:none}*{-ms-overflow-style:none;scrollbar-width:none}
