@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.charts-container{display:flex;flex-direction:column;gap:var(--spacing-lg)}.clickable-stat{cursor:pointer;transition:all .2s;border-radius:4px;padding:2px 4px}.clickable-stat:hover{background-color:var(--color-surface-hover);transform:translate(2px)}.chart-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.chart-controls{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.date-input{padding:8px 12px;border:1px solid #e2e8f0;border-radius:var(--radius-md);font-family:inherit}.bar-list{display:flex;flex-direction:column;gap:12px}.bar-item{display:flex;align-items:center;gap:var(--spacing-md)}.bar-label{width:150px;min-width:80px;font-size:.9rem;color:var(--color-text-main);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:480px){.bar-label{width:100px}}.bar-track{flex:1;background:#f1f5f9;height:24px;border-radius:99px;overflow:hidden;position:relative}.bar-fill{height:100%;background:var(--color-primary);border-radius:99px;transition:width 1s ease-out;display:flex;align-items:center;padding-right:8px;justify-content:flex-end}.bar-value{font-size:.75rem;color:#fff;font-weight:600}.seasonal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md)}.season-card{background:var(--color-background);border:1px solid rgba(0,0,0,.05);border-radius:var(--radius-md);padding:var(--spacing-md)}.season-header{margin-bottom:var(--spacing-md);text-align:center;font-weight:600;color:var(--color-primary-dark);display:flex;align-items:center;justify-content:center;gap:8px}.simple-list{list-style:none;padding:0;margin:0}.simple-list li{font-size:.85rem;padding:4px 0;border-bottom:1px solid #eee;display:flex;justify-content:space-between}.simple-list li:last-child{border-bottom:none}.count-badge{background:var(--color-primary-light);color:var(--color-primary-dark);padding:2px 6px;border-radius:99px;font-size:.75rem;font-weight:600}@media(max-width:1024px){.seasonal-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.seasonal-grid{grid-template-columns:1fr}.bar-item{flex-direction:column;align-items:stretch;gap:4px}.bar-label{width:100%}}:root{--color-primary: #5A7D58;--color-primary-dark: #3F5A3E;--color-primary-light: #E0EBE0;--color-secondary: #D4A373;--color-background: #F9FAF9;--color-surface: #FFFFFF;--color-surface-hover: #F2F4F2;--color-text-main: #2D3A2D;--color-text-muted: #6B7A6B;--color-accent: #E76F51;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -1px rgba(0, 0, 0, .03);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .05), 0 4px 6px -2px rgba(0, 0, 0, .025);--radius-md: 12px;--radius-lg: 16px;--font-main: "Inter", sans-serif;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{-webkit-text-size-adjust:100%}body{font-family:var(--font-main);background-color:var(--color-background);color:var(--color-text-main);line-height:1.5;min-height:100vh;min-height:100dvh}.app-container{max-width:1400px;margin:0 auto;padding:var(--spacing-lg);padding-bottom:90px;display:flex;flex-direction:column;gap:var(--spacing-lg)}header{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;border:1px solid rgba(0,0,0,.03)}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.logo-area h1{font-size:1.5rem;font-weight:700;color:var(--color-primary-dark);display:flex;align-items:center;gap:var(--spacing-sm)}.sync-status{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.85rem;color:var(--color-text-muted);background:var(--color-primary-light);padding:var(--spacing-xs) var(--spacing-sm);border-radius:999px;transition:all .3s ease}.status-dot{width:8px;height:8px;background-color:#10b981;border-radius:50%}.status-dot.offline{background-color:var(--color-accent)}.controls-area{display:flex;gap:var(--spacing-md);align-items:center}.week-nav{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--color-surface);padding:var(--spacing-xs);border-radius:var(--radius-md);border:1px solid #E5E7EB}.icon-btn{background:transparent;border:none;cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);color:var(--color-text-main);transition:background .2s;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:var(--color-surface-hover)}.current-week-label{min-width:140px;text-align:center;font-weight:600;font-size:.95rem;color:var(--color-primary-dark)}.btn-primary{background-color:var(--color-primary);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;font-size:.9rem}.btn-primary:hover{background-color:var(--color-primary-dark)}.btn-secondary{background-color:transparent;color:var(--color-text-main);border:1px solid #E5E7EB;padding:10px 20px;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;font-size:.9rem}.btn-secondary:hover{background:var(--color-surface-hover)}.btn-danger{background-color:var(--color-accent);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:var(--spacing-sm);font-size:.9rem}.btn-danger:hover{background-color:#c75a3e}.btn-text-sm{background:none;border:none;color:var(--color-primary);font-size:.8rem;font-weight:500;cursor:pointer;padding:0}.btn-text-sm:hover{text-decoration:underline}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-md);width:100%}.day-card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid rgba(0,0,0,.03);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden;transition:transform .2s,box-shadow .2s}.day-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.day-card.today{border:2px solid var(--color-primary);box-shadow:0 0 0 1px var(--color-primary-light),var(--shadow-sm)}.day-card.today .day-header{background:var(--color-primary);color:#fff}.day-card.today .day-header .date{color:#fffc}.day-header{background:var(--color-primary-light);color:var(--color-primary-dark);padding:var(--spacing-md);text-align:center;font-weight:600}.day-header .date{display:block;font-size:.8rem;color:var(--color-text-muted);font-weight:400;margin-top:2px}.meal-slots{padding:var(--spacing-sm);flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.meal-slot{background:var(--color-background);border:1px dashed #cbd5e1;border-radius:var(--radius-md);padding:var(--spacing-sm);min-height:100px;position:relative;transition:all .2s;display:flex;flex-direction:column}.meal-slot.drag-over{background:#ecfdf5;border-color:var(--color-primary);transform:scale(1.02)}.meal-slot-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--spacing-xs);pointer-events:none}.empty-state{flex:1;display:flex;align-items:center;justify-content:center;color:#94a3b8;cursor:pointer;border-radius:var(--radius-sm);padding:var(--spacing-lg);text-align:center}.empty-state:hover{color:var(--color-primary);background:#00000005}.meal-card{background:#fff;border:1px solid rgba(0,0,0,.05);box-shadow:var(--shadow-sm);border-radius:var(--radius-md);padding:var(--spacing-sm);cursor:grab;position:relative;transition:all .2s;-webkit-user-select:none;user-select:none;border-left:3px solid var(--color-primary)}.meal-card:active{cursor:grabbing}.meal-card:hover{box-shadow:var(--shadow-md)}.meal-name{font-weight:500;font-size:.9rem;color:var(--color-text-main);margin-bottom:4px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.meal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-xs);margin-top:var(--spacing-xs);opacity:1;transition:opacity .2s}.action-btn.delete,.action-btn.move{opacity:0;transition:opacity .2s}.meal-card:hover .action-btn.delete,.meal-card:hover .action-btn.move{opacity:1}@media(hover:none)and (pointer:coarse){.action-btn.move,.action-btn.delete{opacity:1}}.meal-card.pressing{transform:scale(.97);box-shadow:var(--shadow-md);border-left-color:var(--color-secondary)}.action-btn{width:24px;height:24px;padding:0;border-radius:6px;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;background:#f1f5f9;color:var(--color-text-muted)}.action-btn:hover{background:#e2e8f0;color:var(--color-text-main)}.action-btn.delete:hover{background:#fee2e2;color:var(--color-accent)}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .2s}.modal-overlay.active{opacity:1;pointer-events:all}.modal-content{background:var(--color-surface);width:90%;max-width:600px;max-height:85vh;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;transform:translateY(20px);transition:transform .2s}.modal-overlay.active .modal-content{transform:translateY(0)}.modal-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.modal-header h3{font-size:1.25rem;font-weight:600}.modal-body{padding:var(--spacing-lg);overflow-y:auto}.filter-bar{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.filter-category{display:flex;flex-direction:column;gap:6px}.filter-category-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.search-input{flex:1;padding:10px 12px;border:1px solid #e2e8f0;border-radius:var(--radius-md);font-family:inherit;font-size:14px}.filter-chips{display:flex;flex-wrap:wrap;gap:8px;padding-bottom:4px}.filter-chip{background:#f1f5f9;border:1px solid transparent;border-radius:99px;padding:4px 12px;font-size:12px;font-weight:500;color:var(--color-text-main);cursor:pointer;transition:all .2s}.filter-chip:hover{background:#e2e8f0}.filter-chip.active{background:var(--color-primary-light);color:var(--color-primary-dark);border-color:var(--color-primary)}.menu-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.menu-item{padding:var(--spacing-md);background:var(--color-background);border-radius:var(--radius-md);cursor:pointer;transition:background .2s;display:flex;justify-content:space-between;align-items:center}.menu-item:hover{background:var(--color-surface-hover);border:1px solid var(--color-primary-light)}.menu-item strong{display:block;font-weight:500}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);background:var(--color-surface);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-align:center}.stat-item h3{font-size:2rem;color:var(--color-primary);font-weight:700;margin-bottom:4px}.stat-item p{font-size:.85rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.content-split{display:grid;grid-template-columns:350px 1fr;gap:var(--spacing-lg);align-items:start}.add-panel{background:var(--color-surface);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);position:sticky;top:20px}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:6px}.form-input{width:100%;padding:10px;border:1px solid #e2e8f0;border-radius:var(--radius-md);font-family:inherit;font-size:14px}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.tag-chips-select{display:flex;flex-wrap:wrap;gap:6px}.tag-select-chip{cursor:pointer;font-size:.8rem;-webkit-user-select:none;user-select:none}.tag-select-chip input{display:none}.tag-select-chip span{display:block;background:#f1f5f9;padding:4px 10px;border-radius:99px;color:var(--color-text-muted);transition:all .2s;border:1px solid transparent}.tag-select-chip input:checked+span{background:var(--color-primary);color:#fff}.menu-row-list{display:flex;flex-direction:column;gap:var(--spacing-sm);background:var(--color-surface);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.menu-item-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border:1px solid #f1f5f9;border-radius:var(--radius-md);background:var(--color-background)}.menu-item-row:hover{border-color:var(--color-primary-light)}.menu-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.menu-info strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.menu-tags-text{font-size:.8rem;color:var(--color-text-muted)}.link-sm{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--color-primary);text-decoration:none}.link-sm:hover{text-decoration:underline}.menu-actions{display:flex;gap:var(--spacing-sm);opacity:.6}.menu-item-row:hover .menu-actions{opacity:1}.icon-btn-sm{background:#fff;border:1px solid #e2e8f0;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-muted)}.icon-btn-sm:hover{color:var(--color-primary);border-color:var(--color-primary)}.icon-btn-sm.delete:hover{color:var(--color-accent);border-color:var(--color-accent)}.icon-btn-xs{background:none;border:none;cursor:pointer;color:#999;display:flex;align-items:center;justify-content:center}.icon-btn-xs:hover{color:var(--color-accent)}.tag-manage-item{display:flex;justify-content:space-between;align-items:center;background:#f8f9fa;padding:6px 10px;border-radius:6px;margin-bottom:6px;font-size:.9rem}.menu-detail{display:flex;flex-direction:column;gap:20px}.menu-detail-header{display:flex;flex-direction:column;gap:8px}.menu-detail-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.menu-detail-tags{display:flex;flex-wrap:wrap;gap:6px}.tag-chip-sm{background:#f1f5f9;color:var(--color-text-muted);font-size:.75rem;padding:2px 8px;border-radius:12px}.menu-detail-ingredients{display:flex;flex-direction:column;gap:8px}.menu-detail-ingredients h4{margin:0;font-size:.95rem;color:var(--color-text-main)}.ingredient-row{display:flex;align-items:center;gap:6px}.ingredient-row.readonly{padding:6px 0;border-bottom:1px solid #f1f5f9;gap:8px}.ingredient-row.readonly:last-child{border-bottom:none}.ingredient-name{font-weight:500;flex:1;min-width:0}.ingredient-qty{color:var(--color-text-muted);font-size:.9rem;white-space:nowrap}.ingredient-note{color:var(--color-text-muted);font-size:.85rem;font-style:italic}.ingredient-input-name{flex:2;min-width:80px}.ingredient-input-amount{width:70px;flex:0 0 70px}.ingredient-select-unit,.ingredient-input-unit{width:90px;flex:0 0 90px}.ingredient-input-note{flex:1.5;min-width:60px}.add-ingredient-btn{display:flex;align-items:center;gap:4px;margin-top:4px}.menu-detail-actions{display:flex;flex-wrap:wrap;gap:8px;padding-top:12px;border-top:1px solid #f1f5f9}.menu-detail-actions .btn{display:flex;align-items:center;gap:6px;padding:8px 14px;font-size:.85rem;border-radius:var(--radius-md);cursor:pointer;font-weight:500}.menu-detail-actions .btn-primary{background:var(--color-primary);color:#fff;border:none}.menu-detail-actions .btn-primary:hover{background:var(--color-primary-dark)}.menu-detail-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.menu-detail-actions .btn-secondary{background:transparent;color:var(--color-text-main);border:1px solid #e2e8f0}.menu-detail-actions .btn-secondary:hover{background:var(--color-surface-hover)}.menu-detail-actions .btn-danger-outline{background:transparent;color:var(--color-accent);border:1px solid var(--color-accent)}.menu-detail-actions .btn-danger-outline:hover{background:#d9534f0d}.text-muted{color:var(--color-text-muted);font-size:.9rem}@media(max-width:600px){.ingredient-row:not(.readonly){flex-wrap:wrap}.ingredient-input-name{flex:1 1 100%}.ingredient-input-amount,.ingredient-select-unit,.ingredient-input-unit{flex:1 1 calc(30% - 4px);width:auto}.ingredient-input-note{flex:1 1 calc(40% - 4px);min-width:0}}.plan-week-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.plan-week-label{font-weight:600;font-size:.95rem;color:var(--color-text-main)}.plan-week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.plan-day-col{display:flex;flex-direction:column;gap:4px}.plan-day-col.today .plan-day-header{background:var(--color-primary);color:#fff}.plan-day-header{text-align:center;padding:6px 4px;background:var(--color-background);border-radius:8px}.plan-day-name{display:block;font-weight:600;font-size:.85rem}.plan-day-date{display:block;font-size:.7rem;opacity:.7}.plan-slot{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 4px;border:1px dashed #cbd5e1;border-radius:8px;background:var(--color-background);cursor:pointer;font-family:inherit;font-size:.7rem;color:var(--color-text-muted);transition:all .2s;min-height:52px}.plan-slot:hover{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary-dark)}.plan-slot.occupied{border-style:solid;border-color:#e2e8f0;background:#fff}.plan-slot.occupied:hover{border-color:var(--color-secondary);background:#fef7f0}.plan-slot.current-source{opacity:.4;cursor:not-allowed;border-color:var(--color-accent);background:#fee2e2}.plan-slot.current-source:hover{border-color:var(--color-accent);background:#fee2e2}.plan-slot-name{font-size:.65rem;font-weight:500;color:var(--color-text-main);text-align:center;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}.view-tabs{display:flex;gap:4px;background:var(--color-background);padding:4px;border-radius:var(--radius-md);margin-bottom:var(--spacing-md);overflow-x:auto}.view-tab{flex:1;padding:10px 16px;border:none;background:transparent;border-radius:10px;font-family:inherit;font-size:.9rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:all .25s ease;white-space:nowrap;text-align:center}.view-tab:hover{color:var(--color-text-main);background:var(--color-surface-hover)}.view-tab.active{background:var(--color-primary);color:#fff;font-weight:600;box-shadow:var(--shadow-sm)}@media(max-width:1024px){.week-grid{grid-template-columns:repeat(2,1fr)}.content-split{grid-template-columns:1fr}}@media(max-width:768px){.week-grid{grid-template-columns:1fr}header{flex-direction:column;gap:var(--spacing-md);text-align:center}.header-left{flex-direction:column;gap:var(--spacing-sm)}.controls-area{width:100%;justify-content:center;flex-wrap:wrap;gap:10px}.controls-area .btn-primary,.controls-area .btn-secondary{min-width:120px;justify-content:center;padding:10px 16px}.content-split{display:flex;flex-direction:column}.add-panel{order:-1;position:static;width:100%}.menu-row-list{width:100%}.stats-grid{grid-template-columns:1fr;gap:var(--spacing-sm)}.modal-content{width:95%;max-height:90vh}.btn-primary,.btn-secondary,.icon-btn{padding:12px 20px}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(0,0,0,.06);padding:6px 0;padding-bottom:max(6px,env(safe-area-inset-bottom));z-index:900;box-shadow:0 -2px 10px #0000000a}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 16px;border-radius:10px;text-decoration:none;color:var(--color-text-muted);font-size:.7rem;font-weight:500;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.bottom-nav-item:hover{color:var(--color-text-main)}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-item.active svg{filter:drop-shadow(0 1px 3px rgba(90,125,88,.3))}.toast-container{position:fixed;bottom:80px;right:var(--spacing-md);z-index:1100;display:flex;flex-direction:column-reverse;gap:var(--spacing-sm);pointer-events:none}.toast{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--color-surface);border-radius:var(--radius-md);padding:12px 16px;box-shadow:var(--shadow-lg),0 0 0 1px #0000000d;pointer-events:all;animation:toast-in .3s ease-out;max-width:380px;font-size:.9rem}.toast-success{border-left:3px solid #10B981;color:var(--color-text-main)}.toast-success svg:first-child{color:#10b981}.toast-error{border-left:3px solid var(--color-accent);color:var(--color-text-main)}.toast-error svg:first-child{color:var(--color-accent)}.toast-info{border-left:3px solid var(--color-primary);color:var(--color-text-main)}.toast-info svg:first-child{color:var(--color-primary)}.toast-message{flex:1}.toast-action{background:none;border:none;color:var(--color-primary);font-weight:600;font-size:.85rem;cursor:pointer;padding:2px 6px;border-radius:4px;white-space:nowrap}.toast-action:hover{background:var(--color-primary-light)}.toast-close{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:2px;display:flex;align-items:center;border-radius:4px}.toast-close:hover{background:var(--color-surface-hover)}@keyframes toast-in{0%{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:768px){.toast-container{left:var(--spacing-md);right:var(--spacing-md)}.toast{max-width:none}}.skeleton{background:linear-gradient(90deg,var(--color-surface-hover) 25%,#e8e8e8 50%,var(--color-surface-hover) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:var(--color-text-muted);gap:12px}.empty-state-container svg{color:var(--color-primary-light);opacity:.6}.empty-state-container h3{font-size:1.1rem;color:var(--color-text-main);margin:0;font-weight:600}.empty-state-container p{font-size:.9rem;max-width:300px;line-height:1.5;margin:0}.empty-state-container .btn-primary{margin-top:8px}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:4px}button:focus-visible,a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}input:focus-visible,select:focus-visible{outline:2px solid var(--color-primary);outline-offset:0;border-color:var(--color-primary)}.btn-loading{position:relative;pointer-events:none;opacity:.7}.btn-loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-top:-8px;margin-left:-8px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:btn-spin .6s linear infinite}@keyframes btn-spin{to{transform:rotate(360deg)}}.btn-danger{background:var(--color-accent);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-danger:hover{background:#d44a4a}.sharing-section{background:var(--color-primary-light);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);border:1px solid rgba(90,125,88,.15)}.sharing-section-header{display:flex;flex-direction:column;gap:2px;margin-bottom:var(--spacing-sm)}.sharing-section-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary-dark)}.sharing-section-hint{font-size:.75rem;color:var(--color-text-muted)}.menu-name-row{display:flex;align-items:center;gap:8px}.ingredient-badge{font-size:.65rem;color:#94a3b8;font-weight:400}.shared-badge{display:inline-flex;align-items:center;gap:3px;font-size:.7rem;font-weight:600;color:var(--color-primary-dark);background:var(--color-primary-light);border:1px solid rgba(90,125,88,.2);border-radius:99px;padding:1px 6px}.bring-export-list{display:flex;flex-direction:column;gap:6px;max-height:360px;overflow-y:auto}.bring-export-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--color-border, #e0e0e0);border-radius:10px;cursor:pointer;transition:all .15s ease;background:var(--color-surface)}.bring-export-item:hover{background:var(--color-surface-hover)}.bring-export-item.selected{background:var(--color-primary-light);border-color:var(--color-primary)}.bring-export-item input[type=checkbox]{accent-color:var(--color-primary);width:16px;height:16px;flex-shrink:0}.bring-export-item-info{display:flex;flex-direction:column;min-width:0}.bring-export-item-name{font-weight:500;font-size:.95rem}.bring-export-item-spec{font-size:.8rem;color:var(--color-text-muted)}.bring-btn{border-color:#4caf50;color:#388e3c}.bring-btn:hover{background:#e8f5e9}.bring-icon-btn{color:#388e3c!important}.bring-icon-btn:hover{background:#e8f5e9!important}.action-btn.bring{color:#388e3c}.action-btn.bring:hover{background:#e8f5e9}
