.header{background-color:var(--primary-color);color:#fff;padding:16px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}.header-content{display:flex;align-items:center;gap:12px;max-width:768px;margin:0 auto}.header-back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;min-width:40px;border:none;background-color:#fff3;color:#fff;font-size:24px;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease}.header-back:hover{background-color:#ffffff4d}.header-back:active{transform:scale(.95)}.header-title-section{flex:1;min-width:0}.header-title{font-size:20px;font-weight:700;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-subtitle{font-size:14px;opacity:.9;margin:2px 0 0}.header-action{display:flex;align-items:center;gap:8px}@media (min-width: 768px){.header{padding:20px}.header-title{font-size:24px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit;text-decoration:none;white-space:nowrap;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-dark)}.btn-secondary{background-color:var(--secondary-color);color:#fff}.btn-secondary:hover:not(:disabled){background-color:#2563eb}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-outline{background-color:transparent;border:2px solid var(--primary-color);color:var(--primary-color)}.btn-outline:hover:not(:disabled){background-color:var(--primary-light)}.btn-ghost{background-color:transparent;color:var(--text-primary)}.btn-ghost:hover:not(:disabled){background-color:var(--bg-secondary)}.btn-small{padding:8px 16px;font-size:14px;min-height:36px}.btn-medium{padding:12px 24px;font-size:16px;min-height:44px}.btn-large{padding:16px 32px;font-size:18px;min-height:52px}.btn-full{width:100%}.btn-icon{display:flex;align-items:center;font-size:1.2em}.card{background-color:var(--bg-primary);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border-color);transition:all .2s ease}.card-padding-small{padding:12px}.card-padding-medium{padding:16px}.card-padding-large{padding:24px}.card-padding-none{padding:0}.card-clickable{cursor:pointer}.card-hover:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-clickable:active{transform:scale(.99)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .2s ease;padding:16px}@media (min-width: 768px){.modal-overlay{align-items:center}}.modal-content{background-color:var(--bg-primary);border-radius:var(--radius) var(--radius) 0 0;max-height:90vh;width:100%;max-width:600px;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}@media (min-width: 768px){.modal-content{border-radius:var(--radius);max-height:80vh}}.modal-small{max-width:400px}.modal-medium{max-width:600px}.modal-large{max-width:800px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-color);flex-shrink:0}.modal-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;min-height:32px;border:none;background-color:transparent;color:var(--text-secondary);font-size:24px;cursor:pointer;border-radius:6px;transition:all .2s ease;padding:0}.modal-close:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.modal-body{padding:20px;overflow-y:auto;flex:1}.modal-body{-webkit-overflow-scrolling:touch}.confirm-dialog{padding:var(--spacing-md) 0}.confirm-message{font-size:15px;line-height:1.6;color:var(--text-primary);margin:0 0 24px;text-align:center}.confirm-actions{display:flex;gap:16px;margin-top:8px}.confirm-actions button{flex:1}.hamburger-menu{position:relative}.hamburger-button{background:none;border:none;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s}.hamburger-button:hover{opacity:.7}.hamburger-icon{display:flex;flex-direction:column;gap:4px;width:24px;height:18px}.hamburger-icon span{display:block;width:100%;height:3px;background-color:var(--text-primary);border-radius:2px;transition:all .3s ease}.hamburger-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:200px;z-index:1000;overflow:hidden;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:none;border:none;text-align:left;font-size:15px;color:var(--text-primary);cursor:pointer;transition:background-color .2s}.menu-item:hover{background-color:var(--bg-secondary)}.menu-item.logout{color:var(--danger-color)}.menu-item.logout:hover{background-color:#fee}.menu-icon{font-size:20px;display:flex;align-items:center;justify-content:center;width:24px}.menu-divider{height:1px;background-color:var(--border-color);margin:4px 0}.toast{position:fixed;top:90px;right:20px;left:20px;max-width:500px;margin:0 auto;padding:16px 20px;border-radius:12px;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;gap:12px;z-index:1000;font-size:15px;font-weight:500;transition:all .3s ease}.toast-visible{opacity:1;transform:translateY(0)}.toast-hidden{opacity:0;transform:translateY(-20px)}.toast-icon{font-size:20px;font-weight:700;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.toast-message{flex:1;line-height:1.4}.toast-close{background:none;border:none;font-size:18px;cursor:pointer;padding:4px;opacity:.6;transition:opacity .2s;flex-shrink:0}.toast-close:hover{opacity:1}.toast-success{background-color:#10b981;color:#fff}.toast-success .toast-icon{background-color:#fff3}.toast-error{background-color:#ef4444;color:#fff}.toast-error .toast-icon{background-color:#fff3}.toast-warning{background-color:#f59e0b;color:#fff}.toast-warning .toast-icon{background-color:#fff3}.toast-info{background-color:#3b82f6;color:#fff}.toast-info .toast-icon{background-color:#fff3}@media (max-width: 480px){.toast{top:70px;left:12px;right:12px;font-size:14px;padding:12px 16px}}.home-screen{display:flex;flex-direction:column;min-height:100vh}.home-content{flex:1;padding:20px;max-width:768px;width:100%;margin:0 auto}.home-hero{text-align:center;padding:20px 20px 16px}.home-hero-title{font-size:48px;margin:0 0 8px}.home-hero-subtitle{font-size:16px;font-weight:600;color:var(--text-secondary);margin:0}.home-user-info{display:flex;justify-content:flex-start;align-items:center;padding:12px 16px;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:var(--border-radius-lg);margin-bottom:var(--spacing-lg);color:#fff}.user-greeting{display:flex;align-items:center;gap:8px}.user-icon{font-size:1.25rem}.user-name{font-weight:600;font-size:.95rem}.home-screen .logout-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:6px 14px;border-radius:var(--border-radius);cursor:pointer;font-weight:600;transition:all .2s;font-size:.875rem;white-space:nowrap}.home-screen .logout-btn:hover{background:#ffffff40}.home-screen .logout-btn:active{transform:scale(.97)}.home-active-session{margin-bottom:32px;animation:fadeIn .3s ease}.session-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.session-info{color:var(--text-secondary);margin:0 0 16px;font-size:15px}.home-planned-sessions-notice{margin-bottom:24px;cursor:pointer;transition:all .2s ease;animation:fadeIn .3s ease}.home-planned-sessions-notice:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.notice-content{display:flex;align-items:center;gap:16px}.notice-icon{font-size:32px;flex-shrink:0}.notice-details{flex:1;min-width:0}.notice-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.notice-description{font-size:14px;color:var(--text-secondary);margin:0}.notice-arrow{font-size:24px;color:var(--text-secondary);flex-shrink:0}.session-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-item-count{font-size:14px;color:var(--text-secondary);margin:0}.home-actions{display:grid;grid-template-columns:1fr;gap:16px}.home-action-card{padding:24px;text-align:center}.home-action-card.featured{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #86efac;position:relative;overflow:hidden}.home-action-card.featured .action-title{color:#065f46}.home-action-card.featured .action-description{color:#047857}.ribbon{position:absolute;top:22px;right:-50px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:6px 50px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transform:rotate(45deg);box-shadow:0 2px 8px #00000026;z-index:1}.action-icon{font-size:48px;margin-bottom:12px}.action-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.action-description{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}@media (min-width: 600px){.home-actions{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.home-actions{grid-template-columns:repeat(4,1fr)}}@media (min-width: 768px){.home-content{padding:32px}}.input-wrapper{display:flex;flex-direction:column;gap:6px;width:100%}.input-label{font-size:14px;font-weight:600;color:var(--text-primary)}.required{color:var(--danger-color);margin-left:4px}.input-container{position:relative;display:flex;align-items:center}.input{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:16px;font-family:inherit;background-color:var(--bg-primary);color:var(--text-primary);transition:all .2s ease;min-height:44px}.input:focus{border-color:var(--primary-color);outline:none}.input:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.input-with-icon{padding-left:44px}.input-icon{position:absolute;left:12px;display:flex;align-items:center;color:var(--text-secondary);font-size:1.2em;pointer-events:none}.input-error{border-color:var(--danger-color)}.input-error-text{font-size:13px;color:var(--danger-color)}@media screen and (max-width: 768px){.input{font-size:16px}}.select-wrapper{display:flex;flex-direction:column;gap:6px;width:100%}.select-label{font-size:14px;font-weight:600;color:var(--text-primary)}.select{width:100%;padding:12px 40px 12px 16px;border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:16px;font-family:inherit;background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;min-height:44px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}.select:focus{border-color:var(--primary-color);outline:none}.select:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.select-error{border-color:var(--danger-color)}.select-error-text{font-size:13px;color:var(--danger-color)}.checkbox-wrapper{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none;min-height:44px;-webkit-tap-highlight-color:transparent}.checkbox-wrapper.disabled{opacity:.5;cursor:not-allowed}.checkbox-input{position:absolute;opacity:0;width:0;height:0}.checkbox-custom{display:flex;align-items:center;justify-content:center;width:24px;height:24px;min-width:24px;border:2px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);transition:all .2s ease;color:#fff}.checkbox-input:checked+.checkbox-custom{background-color:var(--primary-color);border-color:var(--primary-color)}.checkbox-input:focus+.checkbox-custom{box-shadow:0 0 0 3px var(--primary-light)}.checkbox-wrapper:active .checkbox-custom{transform:scale(.95)}.checkbox-label{flex:1;font-size:16px;color:var(--text-primary);line-height:1.4}@media (max-width: 768px){.checkbox-custom{width:28px;height:28px;min-width:28px}}.popular-items-browser{display:flex;flex-direction:column;max-height:70vh}.browser-header{display:flex;flex-direction:column;gap:16px;padding-bottom:16px;border-bottom:1px solid var(--border-color);flex-shrink:0}.browser-description{font-size:14px;color:var(--text-secondary);margin:0}.browser-filters{display:flex;gap:12px;flex-wrap:wrap}.search-input{flex:1;min-width:200px}.browser-actions-header{display:flex;justify-content:space-between;align-items:center}.selected-count{font-size:14px;font-weight:600;color:var(--primary-color)}.browser-content{flex:1;overflow-y:auto;padding:16px 0;min-height:0}.category-section{margin-bottom:24px}.category-section:last-child{margin-bottom:0}.category-title{font-size:16px;font-weight:700;color:var(--text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid var(--primary-color)}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.popular-item-card{display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .2s;border:2px solid transparent}.popular-item-card:hover{border-color:var(--primary-light);background-color:var(--bg-hover)}.popular-item-card.selected{border-color:var(--primary-color);background-color:var(--primary-light)}.item-checkbox{display:flex;align-items:center;pointer-events:none}.item-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.item-name{font-size:14px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-quantity{font-size:12px;color:var(--text-secondary)}.no-results{text-align:center;padding:40px 20px}.no-results p{font-size:16px;color:var(--text-secondary);margin:0 0 8px}.no-results-hint{font-size:14px;color:var(--text-tertiary)}.browser-footer{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid var(--border-color);flex-shrink:0}@media (max-width: 768px){.items-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}.popular-item-card{gap:8px}.item-name{font-size:13px}}@media (max-width: 480px){.items-grid{grid-template-columns:1fr}.browser-filters{flex-direction:column}.search-input{min-width:100%}}.master-list-screen{display:flex;flex-direction:column;min-height:100vh}.master-list-content{flex:1;padding:16px 16px 80px;max-width:768px;width:100%;margin:0 auto}.master-list-filters{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.items-list{display:flex;flex-direction:column;gap:12px}.item-card{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.item-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}.item-category{font-size:13px;color:var(--primary-color);background-color:var(--primary-light);padding:2px 8px;border-radius:4px}.item-frequency{font-size:13px;color:var(--text-secondary)}.item-notes{font-size:14px;color:var(--text-secondary);margin:4px 0 0;line-height:1.4}.item-actions{display:flex;gap:4px;flex-shrink:0}.item-action-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;min-width:40px;border:none;background-color:var(--bg-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;font-size:18px}.item-action-btn:hover{background-color:var(--border-color)}.item-action-btn:active{transform:scale(.95)}.item-action-btn.delete:hover{background-color:#fee2e2;color:var(--danger-color)}.empty-state p{font-size:15px;color:var(--text-secondary);margin:0}.fab-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:12px;z-index:100}.fab{width:56px;height:56px;border-radius:50%;color:#fff;border:none;font-size:32px;font-weight:300;cursor:pointer;box-shadow:var(--shadow-lg);transition:all .2s ease;display:flex;align-items:center;justify-content:center;line-height:1}.fab-primary{background-color:var(--primary-color)}.fab-primary:hover{background-color:var(--primary-dark);transform:scale(1.05)}.fab-secondary{background-color:#ff9800;font-size:24px}.fab-secondary:hover{background-color:#fb8c00;transform:scale(1.05)}.fab:active{transform:scale(.95)}@media (max-width: 768px){.fab-container{right:16px;bottom:16px}}@media (min-width: 768px){.master-list-content{padding:24px}.filter-row{grid-template-columns:2fr 1fr}.fab-container{right:calc(50% - 360px)}}.recommendation-banner{position:relative;display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;margin-bottom:16px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.banner-close{position:absolute;top:12px;right:12px;background:#fff3;border:none;color:#fff;font-size:18px;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.banner-close:hover{background:#ffffff4d}.banner-icon{font-size:48px;flex-shrink:0}.banner-content{flex:1}.banner-content h3{font-size:18px;font-weight:700;margin:0 0 8px;color:#fff}.banner-content p{font-size:14px;margin:0 0 16px;color:#fffffff2;line-height:1.5}.banner-content button{background:#fff;color:#4caf50;font-weight:600}.banner-content button:hover{background:#fffffff2}@media (max-width: 768px){.recommendation-banner{flex-direction:column;text-align:center}.banner-icon{font-size:40px}.banner-content h3{font-size:16px}.banner-content p{font-size:13px}}.planning-screen{display:flex;flex-direction:column;min-height:100vh}.planning-content{flex:1;padding:16px 16px 100px;max-width:768px;width:100%;margin:0 auto}.session-details{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;padding:16px;background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border)}.planning-filters{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.items-container{display:flex;flex-direction:column;gap:24px;margin-top:20px}.category-group{display:flex;flex-direction:column;gap:8px}.category-items{display:flex;flex-direction:column;gap:8px}.planning-item{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;transition:all .2s ease}.planning-item:hover{box-shadow:var(--shadow-lg)}.planning-item:active{transform:scale(.99)}.item-quantity{display:flex;align-items:center;gap:8px;margin-left:auto}.item-quantity label{font-size:14px;font-weight:600;color:var(--text-secondary)}.quantity-input{width:60px;padding:8px;border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:16px;text-align:center;font-weight:600}.planning-footer{position:fixed;bottom:0;left:0;right:0;background-color:var(--bg-primary);border-top:1px solid var(--border-color);padding:16px;box-shadow:0 -2px 10px #0000000d;z-index:50}.footer-content{max-width:768px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}.footer-info{font-size:15px;color:var(--text-secondary)}.footer-info strong{color:var(--primary-color);font-size:18px}@media (min-width: 768px){.planning-content{padding:24px 24px 120px}.planning-filters{flex-direction:row}.planning-filters>*:first-child{flex:2}}.planned-sessions-screen{display:flex;flex-direction:column;min-height:100vh}.planned-sessions-content{flex:1;padding:16px;max-width:768px;width:100%;margin:0 auto}.session-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.session-info{flex:1;min-width:0}.session-name{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.session-meta{font-size:13px;color:var(--text-secondary);margin:0}.session-planned-date{font-size:14px;color:var(--primary);font-weight:600;margin:4px 0 6px}.session-details{display:flex;flex-direction:column;height:100%;max-height:70vh;gap:16px}.details-header{display:flex;flex-direction:column;gap:8px;padding-bottom:16px;border-bottom:1px solid var(--border-color);flex-shrink:0}.details-scrollable{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-height:0}.detail-item-category{font-size:12px;color:var(--primary-color);background-color:var(--primary-light);padding:4px 8px;border-radius:4px}.details-actions{display:flex;gap:12px;padding-top:16px;border-top:1px solid var(--border-color);background-color:var(--bg-primary);position:sticky;bottom:0}@media (min-width: 768px){.planned-sessions-content{padding:24px}.sessions-list{gap:20px}}.progress-wrapper{display:flex;align-items:center;gap:12px;width:100%}.progress-bar{flex:1;background-color:var(--bg-secondary);border-radius:999px;overflow:hidden}.progress-small{height:6px}.progress-medium{height:8px}.progress-large{height:12px}.progress-fill{height:100%;transition:width .3s ease;border-radius:999px}.progress-primary{background-color:var(--primary-color)}.progress-secondary{background-color:var(--secondary-color)}.progress-success{background-color:var(--primary-color)}.progress-label{font-size:14px;font-weight:600;color:var(--text-secondary);min-width:45px;text-align:right}.shopping-screen{display:flex;flex-direction:column;min-height:100vh}.shopping-progress{background-color:var(--bg-primary);padding:20px;border-bottom:1px solid var(--border-color);box-shadow:var(--shadow)}.progress-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px}.stat{display:flex;flex-direction:column;align-items:center;gap:4px}.stat-value{font-size:24px;font-weight:700;color:var(--primary-color)}.stat-label{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.shopping-content{flex:1;padding:16px 16px 100px;max-width:768px;width:100%;margin:0 auto}.shopping-section{margin-bottom:32px}.section-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 12px;display:flex;align-items:center;gap:8px}.items-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.shopping-item{display:flex;align-items:center;justify-content:space-between;gap:12px}.shopping-item.bought{opacity:.8;background-color:#f0fdf4}.shopping-item.skipped{opacity:.6;background-color:#fef2f2}.item-info{flex:1;min-width:0}.item-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 4px;word-wrap:break-word}.shopping-item.bought .item-name{text-decoration:line-through}.item-quantity{font-size:14px;color:var(--text-secondary);margin:0}.item-price{font-size:14px;font-weight:600;color:var(--primary-color);margin:4px 0 0}.item-category{font-size:12px;color:var(--primary-color);background-color:var(--primary-light);padding:2px 8px;border-radius:4px;display:inline-block;margin-top:4px}.item-actions{display:flex;gap:8px;flex-shrink:0}.action-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;border:none;border-radius:var(--radius-sm);font-size:20px;cursor:pointer;transition:all .2s ease;background-color:var(--bg-secondary)}.action-btn.success{background-color:#dcfce7;color:#16a34a}.action-btn.success:hover{background-color:#bbf7d0}.action-btn.skip{background-color:#fee2e2;color:#dc2626}.action-btn.skip:hover{background-color:#fecaca}.action-btn.small{width:40px;height:40px;min-width:40px;font-size:18px}.action-btn:hover{background-color:var(--border-color)}.action-btn:active{transform:scale(.95)}.shopping-footer{position:fixed;bottom:0;left:0;right:0;background-color:var(--bg-primary);border-top:1px solid var(--border-color);padding:12px 16px;box-shadow:0 -2px 10px #0000000d;z-index:50;display:flex;gap:8px;max-width:768px;margin:0 auto}.shopping-footer>button{flex:1}.shopping-footer>button:first-child{flex:.8}.shopping-footer>button:nth-child(2){flex:.6}.shopping-footer>button:last-child{flex:1.2}.add-item-buttons{display:flex;gap:12px;margin-top:16px}.add-item-buttons button{flex:1}.master-items-list{max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;margin-top:8px}.master-item-card{display:flex;align-items:center;justify-content:space-between;gap:12px}.master-item-info{flex:1;min-width:0}.master-item-name{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.master-item-category{font-size:13px;color:var(--text-secondary);background-color:var(--bg-secondary);padding:2px 8px;border-radius:12px}.empty-message{text-align:center;padding:32px;color:var(--text-secondary);font-size:14px}@media (min-width: 768px){.shopping-content{padding:24px 24px 120px}.shopping-progress{padding:24px}}.history-screen{display:flex;flex-direction:column;min-height:100vh}.history-content{flex:1;padding:16px;max-width:768px;width:100%;margin:0 auto}.sessions-list,.session-card{display:flex;flex-direction:column;gap:16px}.session-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.session-date{display:flex;align-items:center;gap:8px}.date-icon{font-size:20px}.date-text{font-size:16px;font-weight:600;color:var(--text-primary)}.completion-badge{font-size:12px;font-weight:600;color:var(--primary-color);background-color:var(--primary-light);padding:4px 12px;border-radius:12px}.session-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:16px;background-color:var(--bg-secondary);border-radius:var(--radius-sm)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:4px}.stat-number{font-size:20px;font-weight:700;color:var(--primary-color)}.stat-text{font-size:12px;color:var(--text-secondary);text-align:center}.session-actions{display:flex;gap:12px}.session-actions button{flex:1}.empty-state{text-align:center;padding:60px 20px}.empty-state h3{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.empty-state p{font-size:15px;color:var(--text-secondary);margin:0 0 20px}.session-details{display:flex;flex-direction:column;gap:24px}.details-header{display:flex;flex-direction:column;gap:8px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.detail-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.detail-label{font-size:14px;font-weight:600;color:var(--text-secondary)}.detail-value{font-size:14px;color:var(--text-primary)}.details-section{display:flex;flex-direction:column;gap:12px}.details-section-title{font-size:16px;font-weight:700;color:var(--text-primary);margin:0}.details-items{display:flex;flex-direction:column;gap:8px}.detail-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;background-color:var(--bg-secondary);border-radius:var(--radius-sm)}.detail-item-info{display:flex;flex-direction:column;gap:4px;flex:1}.detail-item-name{font-size:15px;font-weight:500;color:var(--text-primary)}.detail-item-qty{font-size:13px;color:var(--text-secondary)}.detail-item-price{font-size:15px;font-weight:600;color:var(--primary-color)}.details-actions{display:flex;gap:12px;padding-top:16px;border-top:1px solid var(--border-color)}.details-actions button{flex:1}@media (min-width: 768px){.history-content{padding:24px}.sessions-list{gap:20px}}.inventory-screen{display:flex;flex-direction:column;min-height:100vh}.inventory-content{flex:1;padding:16px;max-width:768px;width:100%;margin:0 auto}.inventory-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.stat-card{text-align:center;cursor:default}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-card.warning{border-color:#f59e0b}.stat-icon{font-size:32px;margin-bottom:8px}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.stat-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.inventory-filters{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.filter-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.inventory-list{display:flex;flex-direction:column;gap:24px;margin-top:20px}.inventory-category{display:flex;flex-direction:column;gap:12px}.category-title{font-size:14px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0;padding:0 4px}.category-items{display:flex;flex-direction:column;gap:12px}.inventory-item{display:flex;flex-direction:column;gap:12px;transition:all .2s ease}.inventory-item.expired{border-left:4px solid #ef4444;background-color:#fef2f2}.inventory-item.expires-today,.inventory-item.expires-soon{border-left:4px solid #f59e0b;background-color:#fffbeb}.inventory-item.use-soon{border-left:4px solid #eab308}.inventory-item.fresh{border-left:4px solid #10b981}.item-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.item-info{flex:1}.item-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.item-expiry{font-size:13px;color:var(--text-secondary);margin:0}.inventory-item.expired .item-expiry{color:#dc2626;font-weight:600}.inventory-item.expires-today .item-expiry,.inventory-item.expires-soon .item-expiry{color:#d97706;font-weight:600}.item-actions{display:flex;align-items:center;gap:8px}.quantity-btn{width:36px;height:36px;border:2px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-primary);font-size:20px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.quantity-btn:hover:not(:disabled){background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.quantity-btn:active:not(:disabled){transform:scale(.95)}.quantity-btn:disabled{opacity:.3;cursor:not-allowed}.quantity-input{width:60px;height:36px;padding:8px;border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:16px;text-align:center;font-weight:600}.quantity-input:focus{border-color:var(--primary-color);outline:none}.item-footer{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid var(--border-color)}.item-date{font-size:12px;color:var(--text-secondary)}.delete-btn{background:none;border:none;font-size:18px;cursor:pointer;padding:4px 8px;opacity:.6;transition:all .2s ease}.delete-btn:hover{opacity:1;transform:scale(1.1)}.modal-form{display:flex;flex-direction:column;gap:16px}@media (max-width: 480px){.inventory-stats{grid-template-columns:repeat(3,1fr);gap:8px}.stat-icon{font-size:24px}.stat-value{font-size:20px}.stat-label{font-size:10px}.item-name{font-size:15px}.quantity-btn{width:32px;height:32px;font-size:18px}.quantity-input{width:50px;height:32px}}.inventory-item{animation:fadeIn .3s ease}.search-container{position:relative;margin-bottom:16px}.search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);max-height:320px;overflow-y:auto;z-index:100;margin-top:4px}.search-result-item{width:100%;padding:12px 16px;border:none;background:none;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:6px;border-bottom:1px solid var(--border-color);transition:background-color .2s}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background-color:var(--bg-secondary)}.result-name{font-size:15px;font-weight:500;color:var(--text-primary)}.result-meta{display:flex;align-items:center;gap:8px;font-size:12px}.result-category{color:var(--text-secondary);padding:2px 8px;background-color:var(--bg-secondary);border-radius:4px}.result-source{padding:2px 8px;border-radius:4px;font-weight:500}.result-source.master{background-color:#e0f2fe;color:#0369a1}.result-source.popular{background-color:#fef3c7;color:#d97706}.recipes-screen{display:flex;flex-direction:column;min-height:100vh}.recipes-content{flex:1;padding:16px;max-width:768px;width:100%;margin:0 auto}.info-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;background-color:#dbeafe;border:1px solid #93c5fd;border-radius:var(--radius-sm);margin-bottom:16px;animation:fadeIn .3s ease}.info-icon{font-size:20px;flex-shrink:0}.info-text{font-size:14px;color:#1e40af;line-height:1.4}.recipes-filters,.recipe-actions-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.recipes-list{display:flex;flex-direction:column;gap:16px;margin-top:20px}.recipe-card{cursor:pointer;transition:all .2s ease}.recipe-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.recipe-card:active{transform:scale(.99)}.recipe-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.recipe-name{font-size:18px;font-weight:700;color:var(--text-primary);margin:0;flex:1}.match-badge{padding:6px 12px;border-radius:var(--radius-full);font-size:13px;font-weight:600;white-space:nowrap}.match-badge.perfect{background-color:#d1fae5;color:#065f46}.match-badge.high{background-color:#dbeafe;color:#1e40af}.match-badge.medium{background-color:#fef3c7;color:#92400e}.match-badge.low{background-color:#fee2e2;color:#991b1b}.recipe-meta{display:flex;gap:16px;margin-bottom:12px;font-size:14px;color:var(--text-secondary);flex-wrap:wrap}.recipe-category,.recipe-time,.recipe-servings{display:flex;align-items:center;gap:4px}.expiring-alert{padding:8px 12px;background-color:#fffbeb;border:1px solid #fbbf24;border-radius:var(--radius-sm);color:#92400e;font-size:13px;font-weight:600;margin-bottom:12px}.recipe-ingredients-summary{display:flex;gap:16px;margin-bottom:12px;font-size:14px}.available-count{color:#059669;font-weight:600}.missing-count{color:#dc2626;font-weight:600}.recipe-stats{font-size:12px;color:var(--text-secondary);margin-bottom:12px}.recipe-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.recipe-actions button{flex:1}.recipe-detail{display:flex;flex-direction:column;gap:20px}.recipe-detail-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:14px;color:var(--text-secondary);padding-bottom:16px;border-bottom:1px solid var(--border-color)}.match-info{padding:12px 16px;background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-sm)}.match-info h4{margin:0;font-size:16px;color:#065f46}.ingredients-section h4,.missing-ingredients h4,.instructions-section h4{font-size:16px;font-weight:700;color:var(--text-primary);margin:0 0 12px}.ingredients-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.ingredients-list li{padding:10px 12px;border-radius:var(--radius-sm);font-size:14px;display:flex;align-items:center;gap:8px}.ingredients-list li.available{background-color:#f0fdf4;color:#065f46}.ingredients-list li.missing{background-color:#fef2f2;color:#991b1b}.missing-ingredients{padding:12px;background-color:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm)}.missing-ingredients ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.missing-ingredients li{font-size:14px;color:#991b1b}.instructions-text{font-size:14px;line-height:1.6;color:var(--text-primary);white-space:pre-wrap;margin:0}.recipe-form{max-height:70vh;overflow-y:auto}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.form-group{display:flex;flex-direction:column}.form-textarea{width:100%;padding:12px;border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;resize:vertical;min-height:80px}.form-textarea:focus{outline:none;border-color:var(--primary-color)}.ingredient-row{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:8px;align-items:center;margin-bottom:8px}.remove-ingredient-btn{width:32px;height:32px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--bg-primary);color:var(--text-secondary);font-size:16px;cursor:pointer;transition:all .2s ease}.remove-ingredient-btn:hover{background-color:#fee2e2;border-color:#dc2626;color:#dc2626}.cook-confirmation p{font-size:14px;color:var(--text-primary);margin:0 0 12px}.cook-confirmation ul{list-style:none;padding:0;margin:0 0 20px;display:flex;flex-direction:column;gap:8px}.cook-confirmation li{padding:10px 12px;background-color:var(--bg-secondary);border-radius:var(--radius-sm);font-size:14px;color:var(--text-primary)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.empty-icon{font-size:64px;margin-bottom:16px}.empty-state h3{font-size:20px;color:var(--text-primary);margin:0 0 8px}.empty-state p{font-size:14px;margin:0 0 24px}.loading{text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:16px}.modal-actions{display:flex;gap:12px;margin-top:8px}.modal-actions button{flex:1}@media (max-width: 480px){.recipe-header{flex-direction:column;align-items:flex-start}.match-badge{align-self:flex-start}.recipe-meta{gap:12px}.ingredient-row{grid-template-columns:1fr;gap:6px}.remove-ingredient-btn{width:100%}.form-row{grid-template-columns:1fr}}.recipe-card{animation:fadeIn .3s ease}.profile-screen{min-height:100vh;background-color:var(--bg-secondary)}.profile-content{padding:20px;display:flex;flex-direction:column;gap:20px}.profile-info-card{display:flex;flex-direction:column;align-items:center;gap:24px}.profile-avatar{display:flex;justify-content:center;margin-bottom:8px}.avatar-circle{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;box-shadow:var(--shadow-lg)}.profile-form{width:100%;display:flex;flex-direction:column;gap:20px}.profile-stats-card{display:flex;flex-direction:column;gap:16px}.card-title{font-size:18px;font-weight:600;margin:0;color:var(--text-primary)}.info-list{display:flex;flex-direction:column;gap:16px}.info-item{display:flex;flex-direction:column;gap:4px}.info-label{font-size:13px;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:15px;color:var(--text-primary);word-break:break-all}.user-id{font-family:monospace;font-size:12px;color:var(--text-secondary)}@media (max-width: 768px){.profile-content{padding:16px}.avatar-circle{width:80px;height:80px;font-size:40px}}.settings-screen{min-height:100vh;background-color:var(--bg-secondary)}.settings-content{padding:20px;display:flex;flex-direction:column;gap:20px}.settings-section{display:flex;flex-direction:column;gap:16px}.section-title{font-size:18px;font-weight:600;margin:0;color:var(--text-primary)}.section-description{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}.currency-preview{display:flex;align-items:center;gap:12px;padding:16px;background-color:var(--bg-secondary);border-radius:var(--radius-sm);margin-top:8px}.preview-label{font-size:14px;color:var(--text-secondary);font-weight:500}.preview-value{font-size:24px;font-weight:700;color:var(--primary-color)}.about-info{display:flex;flex-direction:column;gap:16px}.about-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-color)}.about-item:last-child{border-bottom:none}.about-label{font-size:15px;color:var(--text-secondary);font-weight:500}.about-value{font-size:15px;color:var(--text-primary);font-weight:600}@media (max-width: 768px){.settings-content{padding:16px}}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%)}.auth-container{width:100%;max-width:400px;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:32px;color:#fff}.auth-logo{font-size:4rem;margin:0 0 12px;animation:bounce 1s ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.auth-title{font-size:2rem;margin:0 0 8px;font-weight:700}.auth-subtitle{font-size:1rem;margin:0;opacity:.9}.auth-card{background:#fff;border-radius:var(--border-radius-lg);box-shadow:0 20px 60px #0000004d}.auth-form-title{font-size:1.5rem;margin:0 0 24px;text-align:center;color:var(--text-primary)}.auth-form{display:flex;flex-direction:column;gap:18px}.auth-error{padding:12px 16px;background-color:#fee;border:1px solid var(--danger-color);border-radius:var(--radius-sm);color:var(--danger-color);font-size:.875rem;text-align:center}.auth-form button[type=submit]{margin-top:12px}.auth-toggle{margin-top:24px;text-align:center;padding-top:24px;border-top:1px solid var(--border-color)}.auth-toggle-btn{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:.875rem;padding:8px;transition:opacity .2s}.auth-toggle-btn:hover:not(:disabled){opacity:.8;text-decoration:underline}.auth-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.auth-footer{text-align:center;margin-top:24px;color:#fff;font-size:.875rem;opacity:.8}@media (max-width: 480px){.auth-screen{padding:16px}.auth-logo{font-size:3rem}.auth-title{font-size:1.5rem}}.install-prompt{position:fixed;bottom:16px;left:16px;right:16px;z-index:1000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.install-prompt-content{background:#fff;border-radius:12px;padding:16px;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;gap:12px;border:1px solid var(--border-color)}.install-prompt-icon{font-size:32px;flex-shrink:0}.install-prompt-text{flex:1;min-width:0}.install-prompt-text h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.install-prompt-text p{font-size:13px;color:var(--text-secondary);margin:0}.install-prompt-actions{display:flex;gap:8px;align-items:center}.install-button{background:var(--primary-color);color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s}.install-button:hover{background:var(--primary-hover);transform:translateY(-1px)}.install-button:active{transform:translateY(0)}.dismiss-button{background:transparent;color:var(--text-secondary);border:none;font-size:20px;padding:8px;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.dismiss-button:hover{background:var(--bg-secondary);color:var(--text-primary)}@media (min-width: 768px){.install-prompt{left:auto;right:24px;bottom:24px;max-width:400px}}.app{min-height:100vh;display:flex;flex-direction:column}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #10b981;--primary-dark: #059669;--primary-light: #d1fae5;--secondary-color: #3b82f6;--danger-color: #ef4444;--warning-color: #f59e0b;--text-primary: #1f2937;--text-secondary: #6b7280;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--border-color: #e5e7eb;--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--radius: 12px;--radius-sm: 8px}body{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;background-color:var(--bg-secondary);color:var(--text-primary);line-height:1.6;overflow-x:hidden;-webkit-tap-highlight-color:transparent}#root{min-height:100vh;max-width:768px;margin:0 auto;background-color:var(--bg-primary);position:relative}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}html{scroll-behavior:smooth}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid var(--primary-color);outline-offset:2px}button{-webkit-user-select:none;user-select:none}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .3s ease-out}@media (max-width: 768px){button,a,input[type=checkbox]{min-height:44px;min-width:44px}}@supports (padding: max(0px)){body{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right))}}
