@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Poppins:wght@400;500;600;700&display=swap";:root{font-family:Inter,Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;--primary-green: #4CAF50;--primary-green-dark: #45a049;--primary-green-light: #81C784;--accent-orange: #FF9800;--accent-orange-dark: #F57C00;--accent-red: #F44336;--warm-yellow: #FFC107;--warm-beige: #FFF8E1;--fresh-mint: #C8E6C9;--earth-brown: #8D6E63;--text-dark: #2E7D32;--text-light: #666;--bg-light: #F5F5F5;--bg-white: #FFFFFF;--border-light: #E0E0E0;--shadow: rgba(0, 0, 0, .1);--shadow-hover: rgba(0, 0, 0, .15);color-scheme:light;color:#333;background-color:var(--bg-light);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);background-attachment:fixed}h1,h2,h3,h4,h5,h6{color:var(--text-dark);margin:.5em 0;font-family:Poppins,Inter,sans-serif;font-weight:600;letter-spacing:-.02em}h1{font-size:1.75em;font-weight:700;background:linear-gradient(135deg,var(--primary-green) 0%,var(--accent-orange) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2;font-family:Poppins,Inter,sans-serif}h2{font-size:1.5em;font-weight:600;line-height:1.3;font-family:Poppins,Inter,sans-serif}h3{font-size:1.25em;font-weight:600;font-family:Poppins,Inter,sans-serif}@media (min-width: 768px){h1{font-size:2.5em}h2{font-size:2em}}button{border-radius:12px;border:none;padding:14px 20px;font-size:1em;font-weight:600;font-family:Inter,Poppins,sans-serif;background:linear-gradient(135deg,var(--primary-green) 0%,var(--primary-green-dark) 100%);color:#fff;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px var(--shadow);min-height:44px;touch-action:manipulation;letter-spacing:.01em}@media (min-width: 768px){button{padding:12px 24px}}button:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-hover);background:linear-gradient(135deg,var(--primary-green-dark) 0%,var(--primary-green) 100%)}button:active{transform:translateY(0)}button.secondary{background:linear-gradient(135deg,var(--accent-orange) 0%,var(--accent-orange-dark) 100%)}button.secondary:hover{background:linear-gradient(135deg,var(--accent-orange-dark) 0%,var(--accent-orange) 100%)}button.danger{background:linear-gradient(135deg,var(--accent-red) 0%,#D32F2F 100%)}button.danger:hover{background:linear-gradient(135deg,#D32F2F 0%,var(--accent-red) 100%)}input,textarea,select{border-radius:8px;border:2px solid var(--border-light);padding:14px 16px;font-size:16px;font-family:Inter,Poppins,sans-serif;transition:all .3s ease;background:var(--bg-white);width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;font-weight:400}@media (min-width: 768px){input,textarea,select{padding:12px 16px;font-size:1em}}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #4caf501a}.card{background:var(--bg-white);border-radius:16px;padding:16px;box-shadow:0 2px 12px var(--shadow);transition:all .3s ease;border:1px solid var(--border-light)}@media (min-width: 768px){.card{padding:24px}}.card:hover{box-shadow:0 4px 20px var(--shadow-hover);transform:translateY(-2px)}a{color:var(--primary-green);text-decoration:none;transition:color .3s ease}a:hover{color:var(--primary-green-dark)}.loading{display:inline-block;width:40px;height:40px;border:4px solid var(--fresh-mint);border-top-color:var(--primary-green);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.grocery-item{display:flex;align-items:center;padding:14px;margin:8px 0;background:var(--bg-white);border-radius:12px;border-left:4px solid var(--primary-green);box-shadow:0 2px 8px var(--shadow);transition:all .3s ease;gap:12px;min-height:60px}@media (min-width: 768px){.grocery-item{padding:16px}}.grocery-item:hover{box-shadow:0 4px 12px var(--shadow-hover);transform:translate(4px)}.grocery-item.bought{opacity:.6;border-left-color:var(--text-light)}.grocery-item.bought.mobile-bought-item{background:#f9f9f9;border-left-color:#ccc}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:.85em;font-weight:600;background:var(--fresh-mint);color:var(--text-dark)}.badge.primary{background:var(--primary-green);color:#fff}.badge.orange{background:var(--accent-orange);color:#fff}.container{max-width:1200px;margin:0 auto;padding:20px}.page-container{min-height:calc(100vh - 80px);padding:16px;max-width:1200px;margin:0 auto;width:100%}@media (min-width: 768px){.page-container{padding:24px}}.text-center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px}@media (min-width: 768px){.flex-between{flex-wrap:nowrap;align-items:center}}@media (max-width: 767px){.mobile-full-width{width:100%}.mobile-stack{flex-direction:column}.mobile-hide{display:none!important}}@media (min-width: 768px){.desktop-hide{display:none!important}}.gap-1{gap:8px}.gap-2{gap:16px}.gap-3{gap:24px}#root{min-height:100vh}main{min-height:calc(100vh - 80px);padding:0}.page-enter{opacity:0;transform:translateY(20px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity .3s ease,transform .3s ease}.empty-state{text-align:center;padding:60px 20px;color:var(--text-light)}.empty-state-icon{font-size:64px;margin-bottom:16px;opacity:.5}.empty-state h3{color:var(--text-dark);margin-bottom:8px}.empty-state p{color:var(--text-light);margin-bottom:24px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--bg-white);border-radius:16px;padding:32px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h2{margin:0;color:var(--text-dark)}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-light);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.modal-close:hover{background:var(--bg-light);color:var(--text-dark)}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-dark)}.form-input{width:100%}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:24px}.list-card{background:var(--bg-white);border-radius:16px;padding:24px;box-shadow:0 2px 12px var(--shadow);transition:all .3s ease;cursor:pointer;border:2px solid transparent;position:relative;overflow:hidden}.list-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-green) 0%,var(--accent-orange) 100%)}.list-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px var(--shadow-hover);border-color:var(--primary-green)}.list-card-title{font-size:1.5em;font-weight:600;color:var(--text-dark);margin-bottom:12px}.list-card-meta{color:var(--text-light);font-size:.9em;margin-top:8px}.list-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:20px}@media (min-width: 768px){.list-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:24px}}.modal-content{margin:16px;padding:24px}@media (min-width: 768px){.modal-content{margin:0;padding:32px}}.form-actions{flex-direction:column-reverse;gap:12px}.form-actions button{width:100%;min-height:48px}@media (min-width: 768px){.form-actions{flex-direction:row;justify-content:flex-end}.form-actions button{width:auto;min-height:44px}}.add-item-form{display:flex;gap:12px;flex-direction:column}.add-item-button{width:100%}.add-item-text{display:inline}@media (min-width: 768px){.add-item-form{flex-direction:row}.add-item-button{width:auto;min-width:140px}}@media (max-width: 767px){.card form button:not(.add-item-button),.modal-content button:not(.modal-close){width:100%}.grocery-item{flex-wrap:nowrap;padding:10px 12px;min-height:48px;gap:8px;align-items:center}.grocery-item .mobile-compact-content{flex:1;min-width:0;overflow:hidden}.grocery-item .mobile-compact-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.grocery-item.bought .mobile-compact-meta,.grocery-item.bought .mobile-compact-added-by{display:none}.grocery-item>button{width:auto;margin-top:0;flex-shrink:0}.mobile-compact-restore{padding:6px 8px!important;font-size:.8em!important}}@media (min-width: 768px){.grocery-item>button{width:auto;margin-top:0}.grocery-item.bought .mobile-compact-meta,.grocery-item.bought .mobile-compact-added-by{display:block}}.empty-state{padding:40px 20px}.empty-state-icon{font-size:48px}@media (min-width: 768px){.empty-state{padding:60px 20px}.empty-state-icon{font-size:64px}}.nav-brand-text{display:inline}.nav-desktop{display:none;gap:8px;align-items:center;flex:1;justify-content:center}.nav-user-desktop{display:none;align-items:center;gap:12px;flex:1;justify-content:flex-end}.nav-mobile-user,.nav-mobile{display:flex}.nav-mobile::-webkit-scrollbar{display:none}@media (min-width: 768px){.nav-brand-text{display:inline}.nav-desktop,.nav-user-desktop{display:flex}.nav-mobile-user,.nav-mobile{display:none}nav>div:first-child{border-bottom:none!important}}@media (hover: none) and (pointer: coarse){button:hover,.card:hover,.list-card:hover,.grocery-item:hover{transform:none}}.desktop-only{display:none!important}.mobile-only{display:inline!important}@media (min-width: 768px){.desktop-only{display:inline!important}.mobile-only{display:none!important}}@media (max-width: 767px){.mobile-compact-title{font-size:1.4em!important;line-height:1.2;margin-bottom:4px!important}.mobile-compact-subtitle{font-size:.8em!important}.mobile-compact-header{font-size:1.1em!important;margin-bottom:8px!important}.mobile-compact-list{gap:3px!important}.mobile-compact-content{margin-left:6px!important}.mobile-compact-name{font-size:.9em!important;line-height:1.2!important}.mobile-compact-meta{font-size:.75em!important;margin-top:1px!important}.mobile-compact-added-by{font-size:.7em!important;margin-top:1px!important}.mobile-compact-checkbox{width:20px!important;height:20px!important}.mobile-compact-delete{padding:4px 8px!important;min-width:32px!important;min-height:32px!important;font-size:.85em!important}.mobile-compact-add-form{padding:10px!important;margin-bottom:12px!important}.mobile-compact-input{padding:8px 10px!important;font-size:.9em!important}.mobile-compact-add-btn{padding:8px 12px!important;font-size:.85em!important;min-height:38px!important}.mobile-compact-back{padding:6px 10px!important;min-height:32px!important;font-size:.85em!important;margin-bottom:6px!important}.mobile-compact-invite{padding:6px 10px!important;min-height:32px!important;font-size:.85em!important}.page-container>div{margin-bottom:16px!important}button:not(.mobile-compact-delete):not(.mobile-compact-add-btn):not(.mobile-compact-back):not(.mobile-compact-invite),a{min-height:44px;min-width:44px}button{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.grocery-item{margin:2px 0!important}.flex-between h1{width:100%;margin-bottom:8px}.modal-content{margin:0;border-radius:16px 16px 0 0;max-height:85vh}.list-card{padding:20px}.page-container{padding:12px!important}}input[type=text],input[type=email],input[type=number],textarea{font-size:16px!important}@media (min-width: 768px){input[type=text],input[type=email],input[type=number],textarea{font-size:1em}}.meal-actions{display:flex;flex-direction:column;gap:10px}.meal-actions button{width:100%;min-height:44px;font-size:1em}@media (min-width: 768px){.meal-actions{flex-direction:row;flex-wrap:wrap}.meal-actions button{width:auto;min-height:auto}}
