:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f9f9f9;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}*{margin:0;padding:0;box-sizing:border-box}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.98)}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:#f8fafc;color:#1f2937;line-height:1.6;margin:0;padding:0 0 80px}.app{min-height:100vh;display:flex;flex-direction:column;max-width:1200px;margin:0 auto;width:100%;padding:1rem;box-sizing:border-box}.main-content{flex:1;display:flex;flex-direction:column;width:100%;align-items:center}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#6b7280}.spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top:3px solid #dc2626;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@media (max-width: 768px){body{padding-bottom:70px}.app{padding:.5rem}.loading-spinner{padding:1.5rem}.spinner{width:32px;height:32px}.loading-message,.error-message,.no-meals-message{padding:1.5rem;font-size:1rem}}.header{text-align:center;margin-bottom:1rem;padding:1.5rem;color:#1f2937;width:100%;max-width:800px;margin-left:auto;margin-right:auto}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.header-title{text-align:left}.logo-container{display:flex;align-items:center;margin-bottom:.5rem}.header-logo{height:6rem;width:auto;max-width:480px}.header-buttons{display:flex;align-items:center;gap:.75rem}.subscriptions-btn{background:#fffffff2;border:1px solid rgba(156,163,175,.2);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#9ca3af;transition:all .2s ease;padding:0;box-shadow:0 2px 4px #0000001a;aspect-ratio:1;flex-shrink:0}.subscriptions-btn:hover{background:#fff;color:#dc2626;border-color:#dc26264d;transform:scale(1.05);box-shadow:0 4px 8px #00000026}.subscriptions-btn:active{transform:scale(.95);box-shadow:0 1px 2px #0000001a}.subscriptions-btn svg{width:20px;height:20px;color:currentColor;stroke:currentColor;fill:none;display:block;flex-shrink:0;opacity:.7}.subscriptions-btn:hover svg{opacity:1;color:#dc2626}.share-btn{background:#fffffff2;border:1px solid rgba(156,163,175,.2);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#9ca3af;transition:all .2s ease;padding:0;box-shadow:0 2px 4px #0000001a;aspect-ratio:1;flex-shrink:0}.share-btn:hover{background:#fff;color:#2563eb;border-color:#2563eb4d;transform:scale(1.05);box-shadow:0 4px 8px #00000026}.share-btn:active{transform:scale(.95);box-shadow:0 1px 2px #0000001a}.share-btn svg{width:20px;height:20px;color:currentColor;stroke:currentColor;fill:none;display:block;flex-shrink:0;opacity:.7}.share-btn:hover svg{opacity:1;color:#2563eb}.header h1{font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.header p{font-size:1rem;opacity:.9;margin:0}.header-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:1.25rem;display:flex;flex-direction:column;gap:1.25rem}.cafeteria-selector-block{display:flex;flex-direction:column;gap:.5rem}.cafeteria-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.selector-label{font-size:.75rem;font-weight:500;color:#6b7280;margin-bottom:.25rem;text-align:left}.select-wrapper{position:relative;display:inline-block;width:100%}.cafeteria-select,.time-select{appearance:none;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:.625rem 2.5rem .625rem .75rem;font-size:.875rem;font-weight:500;color:#1f2937;cursor:pointer;transition:all .2s ease;width:100%;height:2.5rem;box-shadow:0 1px 2px #0000000d}.cafeteria-select:hover,.time-select:hover{border-color:#dc2626;box-shadow:0 2px 4px #dc26261a}.cafeteria-select:focus,.time-select:focus{outline:none;border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.cafeteria-select:disabled,.time-select:disabled{opacity:.6;cursor:not-allowed;background:#f9fafb}.select-chevron{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:#6b7280;pointer-events:none;transition:all .2s ease}.select-wrapper:hover .select-chevron{color:#dc2626}.selector-loading{font-size:.875rem;color:#6b7280;font-style:italic;padding:.625rem .75rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb;height:2.5rem;display:flex;align-items:center}.selector-error{font-size:.875rem;color:#dc2626;font-weight:500;padding:.625rem .75rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;height:2.5rem;display:flex;align-items:center}.cafeteria-address{font-size:.875rem;font-weight:400;color:#9ca3af;margin:0;line-height:1.4;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;max-width:100%;text-align:left}.date-time-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:nowrap;gap:.25rem}.date-navigation-group{display:flex;align-items:center;gap:.5rem;width:auto;flex-shrink:0}.menu-time-selector{display:flex;align-items:center;width:auto;flex-shrink:0}.menu-time-selector .select-wrapper{min-width:100px;max-width:120px;width:auto;flex-shrink:0;display:flex;align-items:center}@media (max-width: 720px){.date-time-row{align-items:flex-start;flex-wrap:wrap}.menu-time-selector{align-self:flex-end}}@media (max-width: 480px){.date-time-row{flex-wrap:nowrap;gap:.125rem}.date-navigation-group{flex-shrink:1;min-width:0}.menu-time-selector{flex-shrink:0;align-self:center}}.menu-time-selector .time-select{height:2rem;padding:.3125rem 1.5rem .3125rem .5rem;font-size:.75rem;border-radius:6px;width:100%;max-width:120px;line-height:1.25rem;vertical-align:middle}.nav-button{background:#fff;border:1px solid #e5e7eb;border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#6b7280;transition:all .2s ease;padding:0;flex-shrink:0}.nav-button svg{width:16px;height:16px;transition:transform .2s ease}.nav-button:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;color:#374151;transform:scale(1.05)}.nav-button:hover:not(:disabled) svg{transform:scale(1.1)}.nav-button:active:not(:disabled){transform:scale(.95)}.nav-button:disabled{opacity:.4;cursor:not-allowed;border-color:#f3f4f6}.nav-button:disabled:hover{transform:none;background:#fff}.nav-button:disabled svg{opacity:.4}.date-pill{background:#fef2f2;border:1px solid #fecaca;padding:.5rem .75rem;border-radius:9999px;color:#dc2626;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-width:fit-content;text-align:center;height:2rem;display:flex;align-items:center;justify-content:center}.date-pill:hover{background:#fee2e2;border-color:#fca5a5;transform:translateY(-1px);box-shadow:0 2px 4px #dc262626}.date-pill:active{transform:translateY(0);box-shadow:0 1px 2px #dc26261a}@media (max-width: 768px){.header{padding:1rem}.header-top{margin-bottom:1.25rem}.header-logo{height:4.5rem;max-width:360px}.header-card{padding:1rem;gap:1rem}.cafeteria-selector-block{gap:.375rem}.date-time-row{gap:.5rem}.date-navigation-group{gap:.25rem;width:auto;flex-shrink:0}.menu-time-selector{flex-shrink:0}.menu-time-selector .select-wrapper{min-width:90px;max-width:100px;width:auto;flex-shrink:0}.cafeteria-select,.time-select{font-size:.8rem;padding:.5rem 2.25rem .5rem .625rem;height:2.25rem}.menu-time-selector .time-select{height:1.75rem;padding:.25rem 1.25rem .25rem .375rem;font-size:.7rem}.selector-label{font-size:.7rem}.cafeteria-address{font-size:.75rem;line-height:1.3}.date-pill{font-size:.8rem;padding:.375rem .625rem;height:1.75rem}.nav-button{width:1.75rem;height:1.75rem}.nav-button svg{width:14px;height:14px}.subscriptions-btn{width:36px;height:36px;min-width:36px;min-height:36px}.subscriptions-btn svg{width:18px;height:18px}.share-btn{width:36px;height:36px;min-width:36px;min-height:36px}.share-btn svg{width:18px;height:18px}}@media (max-width: 480px){.header{padding:.875rem}.header-top{margin-bottom:1rem}.header-logo{height:4rem;max-width:320px}.header-card{padding:.875rem;gap:.875rem}.cafeteria-selector-block{gap:.25rem}.date-time-row{gap:.125rem}.date-navigation-group{gap:.125rem;width:auto}.cafeteria-select,.time-select{font-size:.75rem;padding:.5rem 2rem .5rem .5rem;height:2rem}.menu-time-selector .time-select{height:1.5rem;padding:.125rem 1rem .125rem .25rem;font-size:.65rem}.menu-time-selector .select-wrapper{min-width:70px;max-width:80px;width:auto}.selector-label{font-size:.65rem}.cafeteria-address{font-size:.7rem;line-height:1.2}.selector-loading,.selector-error{font-size:.75rem;padding:.5rem .625rem;height:2rem}.date-pill{font-size:.7rem;padding:.125rem .375rem;height:1.5rem}.nav-button{width:1.375rem;height:1.375rem}.nav-button svg{width:11px;height:11px}.subscriptions-btn{width:32px;height:32px;min-width:32px;min-height:32px}.subscriptions-btn svg{width:16px;height:16px}.share-btn{width:32px;height:32px;min-width:32px;min-height:32px}.share-btn svg{width:16px;height:16px}}@media (max-width: 350px){.date-time-row{gap:.25rem}.menu-time-selector .time-select{height:1.5rem;padding:.2rem 1rem .2rem .25rem;font-size:.65rem}.menu-time-selector .select-wrapper{min-width:60px;max-width:70px}}.cafeteria-status{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;font-weight:500;transition:all .2s ease}.cafeteria-status.open{color:#16a34a}.cafeteria-status.closed{color:#dc2626}.status-main{display:flex;align-items:center;gap:.5rem;flex-wrap:nowrap}.status-icon{flex-shrink:0}.status-icon.open{color:#16a34a}.status-icon.closed{color:#dc2626}.status-text{font-weight:600;text-transform:uppercase;letter-spacing:.025em;font-size:.75rem}.next-change{display:flex;align-items:center;gap:.25rem;font-size:.7rem;opacity:.8;margin-left:.5rem;padding-left:.5rem;border-left:1px solid currentColor}.clock-icon{color:currentColor;opacity:.7}.next-change-text{white-space:nowrap}.cafeteria-status.compact{padding:.375rem .625rem;font-size:.8rem}.cafeteria-status.compact .status-text{font-size:.7rem}.cafeteria-status.compact .next-change{font-size:.65rem;margin-left:.375rem;padding-left:.375rem}.cafeteria-status.inline{padding:.25rem .5rem;font-size:.7rem;background:#ffffffe6;border-radius:6px}.cafeteria-status.ribbon{padding:.375rem .75rem;font-size:.7rem;background:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:0 0 0 8px}.cafeteria-status.ribbon .status-text{font-size:.65rem;font-weight:600}.cafeteria-status.ribbon .next-change{font-size:.6rem;margin-left:.375rem;padding-left:.375rem}.cafeteria-status:hover{opacity:.8}.status-details{border-top:1px solid currentColor;padding-top:.5rem;margin-top:.5rem;opacity:.8;font-size:.75rem}.status-reason{margin-bottom:.5rem;font-style:italic}.opening-hours{display:flex;flex-direction:column;gap:.25rem}.hours-text{margin:0;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.7rem;line-height:1.4;white-space:pre-line;background-color:#0000000d;padding:.5rem;border-radius:4px;overflow-x:auto}@media (max-width: 640px){.cafeteria-status{padding:.375rem .5rem;font-size:.8rem}.status-main{gap:.375rem}.next-change{margin-left:.375rem;padding-left:.375rem;font-size:.65rem}.hours-text{font-size:.65rem;padding:.25rem}}.cafeteria-status{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.language-switcher{display:flex;align-items:center;gap:4px;padding:6px 8px;border:1px solid rgba(156,163,175,.2);border-radius:8px;background:#fffffff2;color:#9ca3af;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500;min-width:36px;min-height:36px;box-shadow:0 2px 4px #0000001a;position:relative;overflow:hidden}.language-switcher:hover{background:#fff;border-color:#9ca3af66;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.language-switcher:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.language-switcher:focus-visible{outline:2px solid #dc2626;outline-offset:2px;background:#fff}.lang-flag{display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.lang-code{font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:#6b7280}.lang-indicator{display:flex;align-items:center;justify-content:center;color:#9ca3af;transition:transform .2s ease}.language-switcher:hover .lang-indicator{transform:translateY(1px);color:#6b7280}.language-switcher.compact{padding:4px 6px;min-width:32px;min-height:32px;gap:3px}.language-switcher.compact .lang-flag svg{width:14px!important;height:10px!important}.language-switcher.compact .lang-code{font-size:9px}.language-switcher.compact .lang-indicator svg{width:9px;height:9px}.language-switcher.large{padding:8px 12px;min-width:44px;min-height:44px;gap:6px}.language-switcher.large .lang-flag svg{width:20px!important;height:15px!important}.language-switcher.large .lang-code{font-size:12px}.language-switcher.large .lang-indicator svg{width:12px;height:12px}@media (prefers-color-scheme: dark){.language-switcher{background:#fffffff2;border-color:#9ca3af33;color:#9ca3af}.language-switcher:hover{background:#fff;border-color:#9ca3af66}}@media (prefers-contrast: high){.language-switcher{background:#fff;border-color:#000;color:#000}.language-switcher:hover{background:#f0f0f0;border-color:#000}.lang-indicator{color:#666}.language-switcher:hover .lang-indicator{color:#000}}@media (prefers-reduced-motion: reduce){.language-switcher{transition:none}.language-switcher:hover,.language-switcher:active,.language-switcher:hover .lang-indicator{transform:none}}.meals-container{max-width:800px;margin:0 auto;padding:1rem;width:100%}.meals-list{display:flex;flex-direction:column;gap:1.25rem;max-width:100%;margin:0 auto;width:100%}.loading-message,.error-message,.no-meals-message{text-align:center;padding:2rem;color:#6b7280;font-size:1.1rem}.error-message{color:#dc2626}.meal-card-skeleton{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 2px 4px #0000000d;border:1px solid #e5e7eb;display:flex;flex-direction:column;gap:.75rem;position:relative;overflow:hidden}.skeleton-content{display:flex;flex-direction:column;gap:.5rem}.skeleton-title{height:1.125rem;background:#e5e7eb;border-radius:4px;width:80%}.skeleton-subtitle{height:.875rem;background:#e5e7eb;border-radius:4px;width:60%}.skeleton-tags{display:flex;gap:.5rem;margin-bottom:.5rem}.skeleton-tag{width:24px;height:24px;background:#e5e7eb;border-radius:6px}.skeleton-price{height:1.2rem;background:#e5e7eb;border-radius:4px;width:30%;margin-top:auto}.skeleton-image{aspect-ratio:1.5;background:#e5e7eb;border-radius:8px;max-height:120px;overflow:hidden;position:relative}.shimmer{background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb);background-size:200% 100%;animation:shimmer 1.5s infinite}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.loading-spinner .spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top:3px solid #dc2626;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.meals-container{padding:.5rem}.meals-list{gap:1rem}.loading-message,.error-message,.no-meals-message{padding:1.5rem;font-size:1rem}.skeleton-header{width:32px;height:32px}.skeleton-image{max-height:100px}.skeleton-tag{width:20px;height:20px}}.tag-tooltip-container{position:relative;display:inline-block;cursor:pointer}.tag-tooltip{position:fixed;z-index:1000;max-width:280px;min-width:180px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 8px 20px -5px #0000001a,0 6px 8px -5px #0000000a,0 0 0 1px #0000000d;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:tooltipFadeIn .2s ease-out;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:12px;line-height:1.4;color:#374151;overflow:hidden}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.tooltip-arrow{position:absolute;width:0;height:0;border:6px solid transparent}.tooltip-arrow--top{bottom:-6px;left:50%;transform:translate(-50%);border-top-color:#fff;border-bottom:none}.tooltip-arrow--bottom{top:-6px;left:50%;transform:translate(-50%);border-bottom-color:#fff;border-top:none}.tooltip-arrow--top:after{content:"";position:absolute;top:-7px;left:-6px;border:6px solid transparent;border-top-color:#e5e7eb;border-bottom:none}.tooltip-arrow--bottom:after{content:"";position:absolute;top:-5px;left:-6px;border:6px solid transparent;border-bottom-color:#e5e7eb;border-top:none}.tooltip-content{padding:12px}.tooltip-header{display:flex;align-items:center;gap:6px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #f3f4f6}.tooltip-icon{font-size:14px;line-height:1}.tooltip-title{font-weight:600;color:#111827;font-size:13px}.tooltip-items{display:flex;flex-direction:column;gap:8px}.tooltip-item{padding:0}.tooltip-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.tooltip-item-name{font-weight:500;color:#111827;font-size:12px;flex:1}.tooltip-item-id{font-size:11px;color:#6b7280;font-family:Monaco,Menlo,Ubuntu Mono,monospace;background:#f9fafb;padding:1px 4px;border-radius:3px;border:1px solid #e5e7eb;margin-left:8px;white-space:nowrap}.tooltip-item-description{margin:0;color:#6b7280;font-size:11px;line-height:1.3}@media (max-width: 768px){.tag-tooltip{max-width:calc(100vw - 32px);min-width:240px;font-size:12px}.tooltip-content{padding:10px}.tooltip-header{margin-bottom:6px;padding-bottom:4px}.tooltip-items{gap:6px}.tooltip-item-description{font-size:11px}}@media (max-width: 480px){.tag-tooltip{min-width:260px;max-width:calc(100vw - 24px)}.tooltip-content{padding:12px}.tooltip-header{margin-bottom:8px;padding-bottom:6px}.tooltip-title{font-size:14px}.tooltip-item-name{font-size:13px}.tooltip-item-description{font-size:11px}}@media (hover: none) and (pointer: coarse){.tag-tooltip-container{cursor:default}.tag-tooltip{min-width:240px}.tooltip-content{padding:10px}}@media (prefers-contrast: high){.tag-tooltip{border:2px solid #000000;box-shadow:0 4px 12px #0000004d}.tooltip-arrow--top:after{border-top-color:#000}.tooltip-arrow--bottom:after{border-bottom-color:#000}.tooltip-item-id{background:#fff;border:1px solid #000000;color:#000}}@media (prefers-reduced-motion: reduce){.tag-tooltip{animation:none}}.tag-tooltip{background:#fff!important;border-color:#e5e7eb!important;color:#374151!important}.tooltip-title,.tooltip-item-name{color:#111827!important}.tooltip-item-description{color:#6b7280!important}.tooltip-item-id{background:#f9fafb!important;border-color:#e5e7eb!important;color:#6b7280!important}.tooltip-header{border-bottom-color:#f3f4f6!important}.tooltip-arrow--top{border-top-color:#fff!important}.tooltip-arrow--bottom{border-bottom-color:#fff!important}.tooltip-arrow--top:after{border-top-color:#e5e7eb!important}.tooltip-arrow--bottom:after{border-bottom-color:#e5e7eb!important}.tag-tooltip-container:focus-visible{outline:2px solid #3b82f6;outline-offset:2px;border-radius:4px}@media (hover: hover) and (pointer: fine){.tag-tooltip-container:hover .tag-tooltip{transform:translateY(0) scale(1)}}.meal-subscription-btn{position:absolute!important;top:8px!important;right:8px!important;z-index:30!important;width:36px!important;height:36px!important;min-width:36px!important;min-height:36px!important;max-width:36px!important;max-height:36px!important;aspect-ratio:1/1!important;border-radius:50%!important;border:1px solid rgba(156,163,175,.2)!important;display:flex!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important;box-sizing:border-box!important;padding:0!important;margin:0!important;line-height:1!important;background:#fffffff2!important;color:#9ca3af!important;cursor:pointer!important;box-shadow:0 2px 4px #0000001a!important;user-select:none!important;-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;transform:translateZ(0) scale(1);backface-visibility:hidden;-webkit-font-smoothing:antialiased;transition:all .2s ease}.meal-subscription-btn .subscribe-icon{color:#9ca3af;opacity:.7}.meal-subscription-btn:hover:not(:disabled){background:#fff!important;color:#dc2626!important;border-color:#dc26264d!important;transform:translateZ(0) scale(1.05)!important;box-shadow:0 4px 8px #00000026!important}.meal-subscription-btn:active:not(:disabled){transform:translateZ(0) scale(.95)!important;box-shadow:0 1px 2px #0000001a!important}.meal-subscription-btn.subscribed{background:#dc2626e6!important;color:#fff!important;border-color:transparent!important}.meal-subscription-btn.subscribed .subscribed-icon{color:#fff!important;opacity:1!important}.meal-subscription-btn.subscribed:hover:not(:disabled){background:#dc2626!important;color:#fff!important;transform:translateZ(0) scale(1.05)!important;box-shadow:0 4px 12px #dc26264d!important}.meal-subscription-btn.loading{opacity:.7!important;cursor:not-allowed!important;transform:translateZ(0) scale(1)!important}.meal-subscription-btn:disabled{opacity:.5!important;cursor:not-allowed!important;transform:translateZ(0) scale(1)!important}.subscribed-icon,.subscribe-icon,.loading-spinner{width:20px;height:20px;color:currentColor;stroke:currentColor;fill:none;display:block;flex-shrink:0}.subscribed-icon{fill:currentColor;animation:pulse 2s infinite}.subscribe-icon{fill:none;opacity:.7;color:#9ca3af}.meal-subscription-btn:hover .subscribe-icon{opacity:1;color:#dc2626}.meal-subscription-btn.subscribed:hover .subscribed-icon{color:#fff;opacity:1}.loading-spinner{animation:spin 1s linear infinite;color:#dc2626}.permission-request{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.permission-content{background:#fff;padding:24px;border-radius:12px;max-width:400px;width:90%;text-align:center;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.permission-content h3{margin:0 0 12px;color:#111827;font-size:18px;font-weight:600}.permission-content p{margin:0 0 20px;color:#6b7280;font-size:14px;line-height:1.5}.permission-buttons{display:flex;gap:12px;justify-content:center}.permission-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:120px}.permission-btn.allow{background:#dc2626;color:#fff}.permission-btn.allow:hover{background:#b91c1c;transform:translateY(-1px)}.permission-btn.deny{background:#f3f4f6;color:#374151}.permission-btn.deny:hover{background:#e5e7eb;transform:translateY(-1px)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 480px){.meal-subscription-btn{width:28px;height:28px;min-width:28px;min-height:28px;font-size:14px}.subscribed-icon,.subscribe-icon,.loading-spinner{width:16px;height:16px}.permission-content{margin:20px;padding:20px}.permission-buttons{flex-direction:column}.permission-btn{width:100%}}.meal-rating{display:flex;align-items:center;gap:.5rem}.rating-container{display:flex;flex-direction:column;gap:.25rem}.stars-container{display:flex;gap:.125rem}.star-button{background:none;border:none;padding:0;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:2px}.star-button:hover{transform:scale(1.1)}.star-button:disabled{cursor:not-allowed;opacity:.6}.star{font-size:1rem;color:#d1d5db;transition:color .2s ease;line-height:1}.star-button.filled .star{color:#fbbf24}.star-button.user-rating .star{color:#f59e0b}.star-button.hovered .star{color:#fbbf24;transform:scale(1.1)}.rating-info{display:flex;flex-direction:column;gap:.125rem;font-size:.75rem;color:#6b7280;line-height:1.2}.average-rating{font-weight:500;color:#374151}.user-rating-text{font-style:italic;color:#f59e0b;font-weight:500}@media (max-width: 768px){.star{font-size:.875rem}.star-button{width:18px;height:18px}.rating-info{font-size:.7rem}}@media (max-width: 480px){.star{font-size:.8rem}.star-button{width:16px;height:16px}.rating-info{font-size:.65rem}}.lightbox-overlay{position:fixed;inset:0;background:#f0f0f066;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;animation:lightbox-fade-in .3s ease-out;touch-action:manipulation}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}.lightbox-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:1rem}.lightbox-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#000000b3;transition:all .2s ease;z-index:10;padding:0}.lightbox-close:hover{color:#000000e6;transform:scale(1.1)}.lightbox-close:active{transform:scale(.95)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#000c;border:none;border-radius:50%;width:56px;height:56px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s ease;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #00000026}.lightbox-nav:hover:not(.disabled){background:#000000e6;transform:translateY(-50%) scale(1.1)}.lightbox-nav:active:not(.disabled){transform:translateY(-50%) scale(.95)}.lightbox-nav.disabled{opacity:.3;cursor:not-allowed}.lightbox-nav-prev{left:1rem}.lightbox-nav-next{right:1rem}.lightbox-image-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;max-width:90vw;max-height:90vh;user-select:none;-webkit-user-select:none}.lightbox-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:8px;box-shadow:0 8px 32px #0000004d;animation:lightbox-image-in .3s ease-out}@keyframes lightbox-image-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.lightbox-counter{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #00000026;z-index:10}@media (max-width: 768px){.lightbox-container{padding:.5rem}.lightbox-close{top:.5rem;right:.5rem;width:28px;height:28px}.lightbox-nav{width:48px;height:48px}.lightbox-nav-prev{left:.5rem}.lightbox-nav-next{right:.5rem}.lightbox-counter{bottom:1rem;font-size:.8rem;padding:.4rem .8rem}@media (max-width: 480px){.lightbox-nav{display:none}}}@media (min-width: 769px){.lightbox-image-container{max-width:85vw;max-height:85vh}}@media (min-width: 1024px){.lightbox-image-container{max-width:80vw;max-height:80vh}.lightbox-nav{width:64px;height:64px}.lightbox-nav-prev{left:2rem}.lightbox-nav-next{right:2rem}}@media (min-width: 1440px){.lightbox-image-container{max-width:70vw}}@media (prefers-reduced-motion: reduce){.lightbox-overlay,.lightbox-image,.lightbox-close,.lightbox-nav{animation:none;transition:none}}.lightbox-close:focus,.lightbox-nav:focus{outline:2px solid #60a5fa;outline-offset:2px}@media (prefers-contrast: high){.lightbox-overlay{background:#fff}.lightbox-close{color:#000;background:#ffffffe6;border-radius:4px;padding:4px}.lightbox-nav,.lightbox-counter{background:#000;color:#fff;border:2px solid black}}.lazy-image-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f3f4f6;color:#9ca3af;font-size:.9rem;border-radius:8px;overflow:hidden}.lazy-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:opacity .3s ease;z-index:3}.lazy-image-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f3f4f6;color:#9ca3af;font-size:.9rem;z-index:1}.lazy-image-container img{z-index:2}.lazy-image-container img:not([style*="display: none"])+.lazy-image-placeholder{display:none}.lazy-image-skeleton{position:absolute;top:0;left:0;width:100%;height:100%;background:#e5e7eb;border-radius:8px;overflow:hidden;z-index:2}.skeleton-shimmer{width:100%;height:100%;background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.lazy-image-container.loading{background:#f9fafb}.lazy-image-container.loading .lazy-image-skeleton{background:#f3f4f6}.lazy-image-container.error .lazy-image-placeholder{background:#fef2f2;color:#dc2626;border:1px dashed #fca5a5}.meal-card{background:#fff;border-radius:12px;padding:1rem;border:1px solid #e5e7eb;display:flex;flex-direction:column;gap:.75rem;position:relative;overflow:hidden;cursor:default;-webkit-user-select:none;user-select:none}.meal-card:focus,.meal-card:focus-visible{outline:none!important;border:none}.meal-card:focus-visible{outline:none!important;-webkit-focus-ring-color:transparent}.meal-card,.meal-card:hover,.meal-card:focus,.meal-card:focus-visible,.meal-card:active{outline:none!important;border:1px solid #e5e7eb!important;transform:none!important;box-shadow:none!important;transition:none!important}.meal-card *{transition:none!important}.meal-card:hover{border-color:#e5e7eb!important;box-shadow:none!important;transform:none!important;background:#fff!important}.meal-card *:focus,.meal-card *:focus-visible{outline:none!important}.meal-card *:focus-visible{-webkit-focus-ring-color:transparent;outline:none!important}.meal-info{display:flex;flex-direction:column;gap:.5rem;padding-top:.5rem}.meal-info.has-name-tags{padding-top:1.25rem}.meal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;padding-top:.25rem;padding-left:0!important;background:transparent!important;position:relative}.meal-header-left{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;flex:1;padding-left:0;background:transparent!important}.meal-subscription-header{flex-shrink:0}.meal-name{font-size:1.125rem;font-weight:400;color:#111827;margin:0;padding:0;padding-top:.5rem;overflow:visible;text-overflow:ellipsis;white-space:nowrap;align-self:flex-start;width:100%}@media (max-width: 480px){.meal-name{padding-top:.25rem}}.meal-name-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.meal-english-name{margin:-.375rem 0 .125rem}.meal-name-en{font-size:.875rem;color:#6b7280;font-style:italic;margin:0;font-weight:500;line-height:1.3}.meal-cafeteria-status{margin:.5rem 0;display:flex;justify-content:flex-start}.meal-price-tags-rating-container{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin:.75rem 0;padding-left:0}.meal-price-section{flex-shrink:0;display:flex;align-items:center}.meal-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:0;flex:1;justify-content:center;align-items:center}.meal-rating-container{flex-shrink:0;display:flex;align-items:center}.dietary-tags{display:flex;flex-wrap:wrap;gap:.5rem}.dietary-tags svg{width:24px;height:24px;border-radius:6px;box-shadow:0 1px 3px #0000001a;transition:transform .2s ease;cursor:pointer}.dietary-tags svg:hover{transform:scale(1.1)}.name-tags-ribbon{position:absolute;top:0;left:60px;transform:translateY(-15px);background:transparent;color:transparent;padding:0 1rem;font-size:.75rem;font-weight:600;line-height:1;text-align:center;min-width:auto;box-shadow:none;transition:none;z-index:9;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;clip-path:none}@media (max-width: 768px){.name-tags-ribbon{left:60px}}@media (max-width: 480px){.name-tags-ribbon{position:absolute;top:0;left:50px;clip-path:none;border-radius:6px}.name-tags-ribbon:before{display:none}}.name-tags-content{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap;width:auto;height:100%;min-height:100%}.name-tags-ribbon svg{width:60px!important;height:60px!important;min-width:60px!important;min-height:60px!important;max-width:60px!important;max-height:60px!important;border-radius:3px!important;cursor:pointer!important;transition:all .2s ease!important}.name-tags-ribbon svg:hover{transform:none}@media (max-width: 480px){.name-tags-ribbon svg{width:56px!important;height:56px!important;min-width:56px!important;min-height:56px!important;max-width:56px!important;max-height:56px!important}}.name-tags-ribbon span{display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-width:100%;min-height:100%}.meal-price{font-size:1.2rem;font-weight:700;color:#dc2626;margin-top:auto;display:flex;align-items:baseline;justify-content:space-between;gap:12px;line-height:1}.upload-toggle-btn{width:100%;padding:.75rem 1rem;background:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;color:#495057;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.meal-images-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-top:.75rem;max-width:100%}.image-grid-item{aspect-ratio:4/3;border-radius:8px;overflow:hidden;background:#f8f9fa;border:2px solid #e5e7eb;transition:all .2s ease;cursor:pointer}.image-grid-item:hover{border-color:#f3f4f6;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.grid-image{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.image-grid-item:hover .grid-image{transform:scale(1.05)}.placeholder-item{background:#f3f4f6;display:flex;align-items:center;justify-content:center;border:2px dashed #d1d5db}.placeholder-item:hover{border-color:#9ca3af;background:#f9fafb}.share-photo-item{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px dashed #dee2e6;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.share-photo-item:hover{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-color:#f3f4f6;transform:translateY(-2px);box-shadow:0 4px 12px #3498db33}.share-photo-content{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1rem;color:#6b7280;transition:color .2s ease}.share-photo-item:hover .share-photo-content{color:#374151}.share-photo-icon{font-size:1.5rem;margin-bottom:.5rem}.share-photo-text{font-size:.8rem;font-weight:500;line-height:1.2}.upload-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.upload-modal{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.upload-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #e5e7eb}.upload-modal-header h3{margin:0;font-size:1.125rem;font-weight:400;color:#111827}.upload-modal-close{background:none;border:none;font-size:1.25rem;color:#6b7280;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s ease}.upload-modal-close:hover{background:#f3f4f6;color:#374151}.upload-modal-content{padding:1rem 1.5rem 1.5rem}.image-preview-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.image-preview-container{position:relative;max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center;touch-action:pan-y pinch-zoom;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.preview-close-btn{position:absolute;top:-2.5rem;right:0;background:#fff3;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:50%;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.preview-close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.preview-image-wrapper{max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.preview-image{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px;box-shadow:0 20px 25px -5px #0000004d;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;pointer-events:none}.preview-nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:#fff3;border:none;color:#fff;font-size:2rem;cursor:pointer;padding:1rem .75rem;border-radius:8px;transition:all .2s ease;z-index:10;display:flex;align-items:center;justify-content:center;min-width:3rem;height:3rem;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.preview-nav-btn:hover{background:#ffffff4d;transform:translateY(-50%) scale(1.1)}.preview-nav-prev{left:-4rem}.preview-nav-next{right:-4rem}.preview-counter{position:absolute;bottom:-2.5rem;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500;z-index:10;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.additional-images-section{margin-top:.75rem}.additional-images-title{margin:0 0 .5rem;font-size:.85rem;font-weight:400;color:#374151;display:flex;align-items:center;gap:.25rem}.additional-images-gallery{display:flex;gap:.5rem;overflow-x:auto;padding:.25rem 0;scrollbar-width:thin;scrollbar-color:#cbd5e0 transparent}.additional-images-gallery::-webkit-scrollbar{height:4px}.additional-images-gallery::-webkit-scrollbar-track{background:transparent}.additional-images-gallery::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:2px}.additional-images-gallery::-webkit-scrollbar-thumb:hover{background:#a0aec0}.additional-image-item{flex-shrink:0;width:80px;height:60px;border-radius:6px;overflow:hidden;border:2px solid #e5e7eb;transition:border-color .2s ease}.additional-image-item:hover{border-color:#f3f4f6}.additional-image{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.additional-image-item:hover .additional-image{transform:scale(1.05)}.user-images-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.user-images-section h4{margin:0 0 .75rem;font-size:.9rem;font-weight:400;color:#374151;display:flex;align-items:center;gap:.5rem}.user-images-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:.5rem;margin-bottom:.75rem}.user-image-item{aspect-ratio:1;border-radius:8px;overflow:hidden;border:2px solid #e5e7eb;transition:border-color .2s ease}.user-image-item:hover{border-color:#f3f4f6}.user-image{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.user-image-item:hover .user-image{transform:scale(1.05)}.upload-section{margin-top:.75rem}.upload-toggle-btn{width:100%;padding:.75rem 1rem;background:#f8f9fa;border:1px dashed #d1d5db;border-radius:8px;color:#6b7280;font-size:.9rem;font-weight:400;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.upload-toggle-btn:hover{background:#f0f9ff;border-color:#f3f4f6;color:#374151}.upload-container{margin-top:.75rem;padding:1rem;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.pending-uploads{margin-top:.75rem;padding:.75rem;background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px}.pending-info{margin:0;font-size:.85rem;color:#856404;text-align:center;font-weight:500}@media (max-width: 768px){.meal-card{padding:.75rem}.meal-info{gap:.375rem}.meal-info.has-name-tags{padding-top:.5rem}.meal-name{font-size:1rem}.meal-name-en{font-size:.8rem}.meal-price{font-size:1.1rem}.meal-price-tags-rating-container{flex-direction:row;gap:.25rem;align-items:center}.meal-price-section{flex-shrink:0}.meal-tags{justify-content:center;flex:1;gap:.25rem}.meal-rating-container{flex-shrink:0}.name-tags svg{width:44px;height:44px}.dietary-tags svg{width:18px;height:18px}.meal-image-container{margin-top:.375rem}.meal-images-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.5rem;margin-top:.5rem}.image-grid-item{aspect-ratio:4/3}.share-photo-icon{font-size:1.25rem;margin-bottom:.375rem}.share-photo-text{font-size:.75rem}.upload-modal{margin:.5rem;max-height:95vh}.upload-modal-header{padding:1rem 1rem .75rem}.upload-modal-content{padding:.75rem 1rem 1rem}.image-preview-overlay{padding:.5rem}.preview-close-btn{top:-2rem;width:2rem;height:2rem;font-size:1.25rem}.preview-nav-btn{font-size:1.5rem;padding:.75rem .5rem;min-width:2.5rem;height:2.5rem}.preview-nav-prev{left:-3rem}.preview-nav-next{right:-3rem}.preview-counter{bottom:-2rem;padding:.375rem .75rem;font-size:.8rem}.additional-images-gallery{gap:.375rem}.additional-image-item{width:70px;height:52px}.additional-images-title{font-size:.8rem;margin-bottom:.375rem}.user-images-grid{grid-template-columns:repeat(auto-fit,minmax(70px,1fr));gap:.375rem}.upload-toggle-btn{padding:.625rem .875rem;font-size:.85rem}}@media (min-width: 769px) and (max-width: 1024px){.name-tags svg{width:46px;height:46px}.dietary-tags svg{width:22px;height:22px}.meal-image-container{margin-top:.5rem}.meal-images-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem}.preview-nav-btn{font-size:1.75rem;padding:.875rem .625rem;min-width:2.75rem;height:2.75rem}.preview-nav-prev{left:-3.5rem}.preview-nav-next{right:-3.5rem}.additional-images-gallery{gap:.5rem}.additional-image-item{width:80px;height:60px}.additional-images-title{font-size:.85rem}}@media (min-width: 1025px){.name-tags svg{width:48px;height:48px}.dietary-tags svg{width:24px;height:24px}.meal-image-container{margin-top:.5rem}.meal-images-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.preview-nav-btn{font-size:2rem;padding:1rem .75rem;min-width:3rem;height:3rem}.preview-nav-prev{left:-4rem}.preview-nav-next{right:-4rem}.additional-images-gallery{gap:.5rem}.additional-image-item{width:90px;height:68px}.additional-images-title{font-size:.9rem}}.community-photos-section{padding-top:1rem;border-top:1px solid #e5e7eb}.section-title{margin:0 0 .75rem;font-size:.9rem;font-weight:400;color:#6b7280;display:flex;align-items:center;gap:.5rem}.photos-gallery{max-width:100%;overflow:hidden}.photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;max-width:600px}.photos-grid.empty-state{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.photos-grid.empty-state .add-photo-tile{grid-column:1}.photo-item{aspect-ratio:4/3;border-radius:8px;overflow:hidden;border:2px solid #e5e7eb;transition:all .2s ease;position:relative}.photo-item.clickable{cursor:pointer}.photo-item:hover{border-color:#f3f4f6;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.photo-item:focus{outline:none}.photo-image{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.photo-item .lazy-image-container{width:100%;height:100%;border-radius:0}.photo-item .lazy-image{border-radius:0}.photo-item:hover .photo-image,.photo-item:hover .lazy-image{transform:scale(1.05)}.more-photos-tile{aspect-ratio:4/3;border-radius:8px;overflow:hidden;border:2px solid #e5e7eb;position:relative;cursor:pointer;transition:all .2s ease;background:linear-gradient(135deg,#6b7280,#4b5563)}.more-photos-tile:hover{border-color:#f3f4f6;transform:translateY(-2px) scale(1.03);box-shadow:0 4px 12px #0000001a,0 0 4px #00000026}.more-photos-tile:focus{outline:none}.more-photos-bg{width:100%;height:100%;object-fit:cover;transition:transform .2s ease;position:absolute;top:0;left:0;z-index:1}.more-photos-tile:hover .more-photos-bg,.more-photos-tile:hover .more-photos-bg .lazy-image{transform:scale(1.05)}.more-photos-bg .lazy-image-container{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:0;z-index:1}.more-photos-bg .lazy-image{border-radius:0;transition:transform .2s ease}.more-photos-overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease;z-index:2}.more-photos-tile:hover .more-photos-overlay{background:#00000080}.more-photos-content{display:flex;align-items:center;justify-content:center;color:#fff;text-align:center}.more-photos-text{font-size:.875rem;font-weight:500;color:#ffffffe6;text-shadow:0 1px 3px rgba(0,0,0,.7);letter-spacing:.025em;line-height:1;transition:all .2s ease;background:#0003;padding:.375rem .75rem;border-radius:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.add-photo-tile{aspect-ratio:4/3;border-radius:8px;border:2px dashed #d1d5db;background:linear-gradient(135deg,#f9fafb,#f3f4f6);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.add-photo-tile:hover{border-color:#dc2626;background:linear-gradient(135deg,#fef2f2,#fee2e2);box-shadow:0 4px 12px #dc262626}.add-photo-tile:active{transform:scale(.98)}.add-photo-tile.uploading{pointer-events:none;border-color:#dc2626;background:linear-gradient(135deg,#fef2f2,#fecaca)}.add-photo-content{display:flex;flex-direction:column;align-items:center;gap:0rem;padding:.5rem;text-align:center}.camera-icon-wrapper{display:flex;align-items:center;justify-content:center;width:32px;height:32px;transition:all .2s ease}.add-photo-tile:hover .camera-icon-wrapper{transform:scale(1.1)}.camera-icon{color:#dc2626;transition:color .2s ease;stroke-width:1.5}.add-photo-text{font-size:.75rem;color:#6b7280;font-weight:500;line-height:1.3;white-space:nowrap;text-align:center;min-width:80px;display:block}.add-photo-tile:hover .add-photo-text{color:#374151}.upload-spinner{width:28px;height:28px;border:3px solid #e5e7eb;border-top:3px solid #dc2626;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.upload-feedback{margin-top:.75rem;padding:.5rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500;text-align:center}.upload-feedback.success{background:#d1f2eb;color:#0f5132;border:1px solid #a3e3d0}.upload-feedback.error{background:#f8d7da;color:#721c24;border:1px solid #f1aeb5}.upload-feedback.info{background:#cff4fc;color:#055160;border:1px solid #9eeaf9}@media (max-width: 480px){.photos-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.photos-grid.empty-state{grid-template-columns:repeat(3,1fr)}.camera-icon-wrapper{width:40px;height:40px}.add-photo-text{font-size:.7rem}}@media (min-width: 481px) and (max-width: 768px){.photos-grid{grid-template-columns:repeat(3,1fr);gap:.625rem}}@media (min-width: 769px){.photos-grid{grid-template-columns:repeat(3,1fr);max-width:600px}}.lane-badge{position:absolute;top:0;left:0;background:#e0e7ff;color:#3730a3;padding:.5rem 1.25rem .5rem .75rem;font-size:.75rem;font-weight:600;line-height:1;text-align:center;min-width:3rem;box-shadow:0 2px 8px #3b82f633;transition:all .2s ease;z-index:10;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;clip-path:polygon(0 0,100% 0,85% 100%,0 100%)}.lane-badge:before{content:"";position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 0 1rem 1rem;border-color:transparent transparent rgba(0,0,0,.05) transparent}.lane-badge:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(0,0,0,.05) 100%);clip-path:polygon(0 0,100% 0,85% 100%,0 100%);z-index:-1}.lane-badge:hover{box-shadow:0 4px 12px #3b82f64d}.lane-badge.lane-main-a{background:#e0e7ff;color:#3730a3;box-shadow:0 2px 8px #3b82f633}.lane-badge.lane-main-a:hover{box-shadow:0 4px 12px #3b82f64d}.lane-badge.lane-main-b{background:#f3e8ff;color:#6b21a8;box-shadow:0 2px 8px #8b5cf633}.lane-badge.lane-main-b:hover{box-shadow:0 4px 12px #8b5cf64d}.lane-badge.lane-main-c{background:#e0f2fe;color:#0e7490;box-shadow:0 2px 8px #06b6d433}.lane-badge.lane-main-c:hover{box-shadow:0 4px 12px #06b6d44d}.lane-badge.lane-main-v{background:#f0fdf4;color:#166534;box-shadow:0 2px 8px #84cc1633}.lane-badge.lane-main-v:hover{box-shadow:0 4px 12px #84cc164d}.lane-badge.lane-dessert{background:#fef3c7;color:#92400e;box-shadow:0 2px 8px #f59e0b33}.lane-badge.lane-dessert:hover{box-shadow:0 4px 12px #f59e0b4d}.lane-badge.lane-vegetable{background:#d1fae5;color:#065f46;box-shadow:0 2px 8px #10b98133}.lane-badge.lane-vegetable:hover{box-shadow:0 4px 12px #10b9814d}.lane-badge.lane-side{background:#f3e8ff;color:#6b21a8;box-shadow:0 2px 8px #8b5cf633}.lane-badge.lane-side:hover{box-shadow:0 4px 12px #8b5cf64d}.lane-badge.lane-buffet{background:#fee2e2;color:#991b1b;box-shadow:0 2px 8px #ef444433}.lane-badge.lane-buffet:hover{box-shadow:0 4px 12px #ef44444d}.lane-badge.lane-default{background:#f3f4f6;color:#374151;box-shadow:0 2px 8px #6b728033}.lane-badge.lane-default:hover{box-shadow:0 4px 12px #6b72804d}.lane-badge.lane-station{background:#fef3c7;color:#92400e;box-shadow:0 2px 8px #f59e0b33}.lane-badge.lane-station:hover{box-shadow:0 4px 12px #f59e0b4d}.lane-badge.lane-service{background:#dbeafe;color:#1e40af;box-shadow:0 2px 8px #3b82f633}.lane-badge.lane-service:hover{box-shadow:0 4px 12px #3b82f64d}.lane-badge.lane-special{background:#fce7f3;color:#be185d;box-shadow:0 2px 8px #ec489933}.lane-badge.lane-special:hover{box-shadow:0 4px 12px #ec48994d}@media (max-width: 768px){.lane-badge{top:0;left:0;padding:.375rem .875rem .375rem .625rem;font-size:.7rem;min-width:2.5rem;clip-path:polygon(0 0,100% 0,80% 100%,0 100%)}.lane-badge:before{border-width:0 0 .75rem .75rem}}.install-banner{position:fixed;bottom:0;left:0;right:0;background:#fff;color:#1f2937;z-index:1000;animation:slideUp .4s cubic-bezier(.4,0,.2,1);box-shadow:0 -4px 20px #0000001a;border-top:2px solid #dc2626}.install-banner-content{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;max-width:1200px;margin:0 auto;gap:16px}.install-banner-info{display:flex;align-items:center;gap:12px;flex:1}.install-banner-icon{font-size:24px;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.install-banner-text{flex:1;min-width:0}.install-banner-text h4{margin:0 0 2px;font-size:16px;font-weight:600;color:#1f2937;line-height:1.2}.install-banner-text p{margin:0;font-size:13px;color:#4b5563;line-height:1.3}.install-banner-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.install-banner-btn{background:#dc2626;color:#fff;border:none;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:60px}.install-banner-btn:hover{background:#b91c1c;transform:translateY(-1px)}.install-banner-btn:active{transform:translateY(0)}.dismiss-banner-btn{background:transparent;color:#6b7280;border:none;padding:8px;border-radius:50%;font-size:18px;font-weight:300;cursor:pointer;transition:all .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center;line-height:1}.dismiss-banner-btn:hover{background:#0000001a;color:#374151}.dismiss-banner-btn:active{transform:scale(.95)}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.install-banner-content{padding:14px 16px;gap:12px}.install-banner-icon{font-size:20px}.install-banner-text h4{font-size:15px}.install-banner-text p{font-size:12px}.install-banner-btn{padding:7px 14px;font-size:13px}.dismiss-banner-btn{width:28px;height:28px;font-size:16px}}@media (max-width: 480px){.install-banner-content{padding:12px 14px;gap:10px}.install-banner-info{gap:10px}.install-banner-icon{font-size:18px}.install-banner-text h4{font-size:14px}.install-banner-text p{font-size:11px}.install-banner-btn{padding:6px 12px;font-size:12px;min-width:50px}.dismiss-banner-btn{width:26px;height:26px;font-size:15px}}body{padding-bottom:80px}@media (max-width: 768px){body{padding-bottom:70px}}@media (max-width: 480px){body{padding-bottom:65px}}.offline-indicator{position:fixed;top:0;left:0;right:0;background:#fef3c7;color:#92400e;padding:8px 16px;text-align:center;font-size:14px;z-index:1000;display:flex;align-items:center;justify-content:center;gap:8px}.offline-icon{font-size:16px}.notification-preferences-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.notification-preferences-modal{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;background:#f8f9fa;border-radius:12px 12px 0 0}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#2c3e50}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:4px;border-radius:4px;color:#6b7280;transition:all .2s ease}.close-button:hover{background:#e5e7eb;color:#374151}.modal-content{padding:24px}.loading{text-align:center;padding:20px;color:#6b7280;font-size:1rem}.message{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:.9rem}.message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.message button{background:none;border:none;color:inherit;font-size:1.2rem;cursor:pointer;padding:0;width:20px;height:20px}.section{margin-bottom:24px}.section h3{margin:0 0 12px;font-size:1.1rem;font-weight:600;color:#374151}.section-description{margin:0 0 16px;color:#6b7280;font-size:.9rem;line-height:1.5}.permission-status,.subscription-status{display:flex;align-items:center;gap:12px;padding:12px;background:#f8f9fa;border-radius:8px;border:1px solid #e5e7eb}.status{font-weight:500;font-size:.9rem}.status.granted{color:#059669}.status.denied{color:#dc2626}.status.unsupported{color:#d97706}.status.unknown{color:#6b7280}.subscribed,.not-subscribed{display:flex;align-items:center;gap:12px;width:100%}.preferences-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:16px}.preference-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8f9fa;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:.9rem}.preference-item:hover{background:#e3f2fd;border-color:#3498db}.preference-item input[type=checkbox]{width:16px;height:16px;cursor:pointer}.meal-name{font-weight:500;color:#374151}.btn-primary,.btn-secondary{padding:8px 16px;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.9rem}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover:not(:disabled){background:#2980b9;transform:translateY(-1px)}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563;transform:translateY(-1px)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.5;cursor:not-allowed;transform:none}.info-section{margin-top:24px;padding:16px;background:#f8f9fa;border-radius:8px;border-left:4px solid #3498db}.info-section h4{margin:0 0 12px;font-size:1rem;font-weight:600;color:#374151}.info-section ul{margin:0;padding-left:20px;color:#6b7280;font-size:.9rem;line-height:1.6}.info-section li{margin-bottom:6px}@media (max-width: 768px){.notification-preferences-overlay{padding:10px}.notification-preferences-modal{max-height:95vh}.modal-header{padding:16px 20px}.modal-header h2{font-size:1.3rem}.modal-content{padding:20px}.preferences-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.preference-item{padding:6px 10px;font-size:.85rem}.permission-status,.subscription-status{flex-direction:column;align-items:flex-start;gap:8px}.subscribed,.not-subscribed{flex-direction:column;align-items:flex-start;gap:8px;width:100%}}@media (max-width: 480px){.modal-header{padding:12px 16px}.modal-header h2{font-size:1.2rem}.modal-content{padding:16px}.preferences-grid{grid-template-columns:1fr}.preference-item{padding:8px 12px}}.subscription-manager-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.subscription-manager{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:80vh;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.subscription-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.subscription-header h2{margin:0;color:#111827;font-size:18px;font-weight:600}.close-btn{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.close-btn:hover{background:#f3f4f6;color:#374151}.subscription-content{padding:24px;max-height:calc(80vh - 80px);overflow-y:auto}.no-subscriptions{text-align:center;color:#6b7280;padding:40px 20px}.no-subscriptions p{margin:8px 0;font-size:14px}.subscriptions-list{margin-bottom:24px}.subscription-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:12px;background:#f9fafb;transition:all .2s ease}.subscription-item:hover{background:#f3f4f6;border-color:#d1d5db}.subscription-info h3{margin:0 0 4px;color:#111827;font-size:16px;font-weight:600}.subscription-info p{margin:0;color:#6b7280;font-size:12px}.unsubscribe-btn{background:#dc2626;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.unsubscribe-btn:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}.unsubscribe-btn:disabled{opacity:.5;cursor:not-allowed}.subscription-actions{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.notification-preferences-btn,.test-notification-btn,.clear-history-btn{padding:10px 16px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;flex:1;min-width:120px}.notification-preferences-btn{background:#3498db;color:#fff;border-color:#3498db}.notification-preferences-btn:hover{background:#2980b9;border-color:#2980b9;transform:translateY(-1px)}.test-notification-btn:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.test-notification-btn:disabled{opacity:.5;cursor:not-allowed}.clear-history-btn:hover{background:#f9fafb;border-color:#9ca3af}.subscription-status{padding:16px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.subscription-status p{margin:8px 0;font-size:14px;color:#374151}.permission-hint{color:#dc2626!important;font-size:12px!important;margin-top:8px!important}.enable-notifications-btn{background:#dc2626;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-top:8px}.enable-notifications-btn:hover{background:#b91c1c;transform:translateY(-1px)}@media (max-width: 480px){.subscription-manager-overlay{padding:10px}.subscription-manager{max-height:90vh}.subscription-content{padding:16px;max-height:calc(90vh - 80px)}.subscription-header{padding:16px 20px}.subscription-item{flex-direction:column;align-items:flex-start;gap:12px}.unsubscribe-btn{align-self:flex-end}.subscription-actions{flex-direction:column}.test-notification-btn,.clear-history-btn{width:100%}}.image-comparison-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.image-comparison-modal{background:#fff;border-radius:12px;max-width:1400px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.comparison-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:2px solid #e1e5e9;background:#f8f9fa;border-radius:12px 12px 0 0}.comparison-header h2{margin:0;color:#2c3e50;font-size:1.5rem;font-weight:600}.comparison-content{display:grid;grid-template-columns:1fr 1fr;gap:30px;padding:30px}.comparison-section{display:flex;flex-direction:column;gap:20px}.section-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:2px solid #e1e5e9}.section-header h3{margin:0;color:#2c3e50;font-size:1.2rem;font-weight:600}.new-image-section .section-header{border-bottom-color:#f39c12}.existing-images-section .section-header{border-bottom-color:#27ae60}.image-actions{display:flex;gap:10px}.btn-fullscreen{background:#3498db;color:#fff;border:none;border-radius:6px;padding:8px 12px;cursor:pointer;font-size:1rem;transition:all .2s ease}.btn-fullscreen:hover{background:#2980b9;transform:translateY(-1px)}.image-container{position:relative;background:#f8f9fa;border-radius:8px;overflow:hidden;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center}.comparison-image{max-width:100%;max-height:100%;object-fit:contain;cursor:pointer;transition:transform .2s ease}.comparison-image:hover{transform:scale(1.02)}.image-metadata{background:#f8f9fa;border-radius:8px;padding:15px}.metadata-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid #e9ecef}.metadata-row:last-child{border-bottom:none}.metadata-row .value{color:#6c757d;font-size:.9rem}.metadata-row svg{color:#495057;flex-shrink:0}.session-id{font-family:monospace;background:#e9ecef;padding:2px 6px;border-radius:3px;font-size:.8rem}.action-buttons{display:flex;gap:12px}.btn-approve,.btn-reject{flex:1;padding:12px 20px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:8px}.no-existing-images{text-align:center;padding:40px 20px;color:#6c757d;background:#f8f9fa;border-radius:8px;border:2px dashed #e1e5e9}.no-existing-images p{margin:8px 0}.no-existing-images p:first-child{font-weight:600;color:#495057}.existing-thumbnails{display:flex;gap:10px;flex-wrap:wrap;padding:10px 0}.thumbnail{position:relative;width:80px;height:80px;border-radius:6px;overflow:hidden;cursor:pointer;border:3px solid transparent;transition:all .2s ease}.thumbnail:hover{border-color:#3498db;transform:scale(1.05)}.thumbnail.selected{border-color:#27ae60;box-shadow:0 0 0 2px #27ae604d}.thumbnail img{width:100%;height:100%;object-fit:cover}.thumbnail-order{position:absolute;top:2px;right:2px;background:#000000b3;color:#fff;font-size:.7rem;font-weight:600;padding:2px 6px;border-radius:3px}.fullscreen-overlay{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1100;cursor:pointer}.fullscreen-content{position:relative;max-width:95vw;max-height:95vh;display:flex;flex-direction:column;align-items:center;cursor:default}.fullscreen-content img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:8px;box-shadow:0 10px 30px #00000080}.fullscreen-info{background:#000c;color:#fff;padding:15px 20px;border-radius:8px;margin-top:15px;text-align:center}.fullscreen-info h4{margin:0 0 8px;font-size:1.1rem;font-weight:600}.fullscreen-info p{margin:0;opacity:.8;font-size:.9rem}.fullscreen-close{position:absolute;top:20px;right:20px;background:#000000b3;color:#fff;border:none;border-radius:50%;width:50px;height:50px;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.fullscreen-close:hover{background:#000000e6;transform:scale(1.1)}@media (max-width: 1024px){.comparison-content{grid-template-columns:1fr;gap:20px}.image-comparison-modal{margin:10px;max-height:95vh}}@media (max-width: 768px){.image-comparison-overlay{padding:10px}.comparison-header{padding:15px 20px}.comparison-header h2{font-size:1.2rem}.comparison-content{padding:20px;gap:15px}.existing-thumbnails{gap:8px}.thumbnail{width:60px;height:60px}.action-buttons{flex-direction:column}}.fullscreen-modal-overlay{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1200;cursor:pointer}.fullscreen-modal-content{display:flex;flex-direction:column;max-width:95vw;max-height:95vh;background:#000c;border-radius:12px;overflow:hidden;cursor:default;box-shadow:0 20px 60px #00000080}.fullscreen-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#000000e6;border-bottom:1px solid rgba(255,255,255,.1)}.image-info h3{margin:0 0 8px;color:#fff;font-size:1.1rem;font-weight:600}.image-meta{display:flex;gap:12px;align-items:center}.status-badge{padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:600;text-transform:uppercase}.status-pending{background:#f39c12;color:#fff}.status-approved{background:#27ae60;color:#fff}.status-rejected{background:#e74c3c;color:#fff}.status-unknown{background:#6c757d;color:#fff}.image-counter{color:#ffffffb3;font-size:.9rem}.header-actions{display:flex;gap:10px;align-items:center}.btn-delete-header{background:#e74c3c33;border:1px solid #e74c3c;color:#e74c3c;border-radius:6px;padding:8px 12px;cursor:pointer;font-size:1rem;transition:all .2s ease}.btn-delete-header:hover{background:#e74c3c;color:#fff}.btn-close{background:none;border:none;color:#ffffffb3;font-size:2rem;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.btn-close:hover{background:#ffffff1a;color:#fff}.fullscreen-image-container{position:relative;flex:1;display:flex;align-items:center;justify-content:center;min-height:0;padding:20px}.image-loading{color:#ffffffb3;font-size:1.1rem}.fullscreen-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 10px 30px #00000080}.nav-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#000000b3;border:none;color:#fff;width:60px;height:60px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.nav-arrow:hover:not(.disabled){background:#000000e6;transform:translateY(-50%) scale(1.1)}.nav-arrow.disabled{opacity:.3;cursor:not-allowed}.nav-prev{left:20px}.nav-next{right:20px}.fullscreen-footer{background:#000000e6;border-top:1px solid rgba(255,255,255,.1);padding:20px}.image-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;color:#fff}.detail-group{display:flex;flex-direction:column;gap:8px}.detail-item{display:flex;align-items:center;gap:8px;padding:4px 0}.detail-item.full-width{grid-column:1 / -1;flex-direction:column;align-items:flex-start;gap:6px}.detail-item svg{color:#fffc;flex-shrink:0}.detail-label{font-weight:600;color:#fffc;font-size:.9rem;min-width:80px}.detail-value{color:#fff;font-size:.9rem}.order-badge{background:#3498db;color:#fff;padding:4px 8px;border-radius:12px;font-size:.8rem;font-weight:600}.detail-item.full-width .detail-value{text-align:left;background:#ffffff1a;padding:8px 12px;border-radius:4px;width:100%}.session-id{font-family:monospace;background:#ffffff1a;padding:2px 6px;border-radius:3px;font-size:.8rem}.delete-confirm-overlay{position:absolute;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10}.delete-confirm-modal h4{margin:0 0 15px;color:#2c3e50;font-size:1.3rem;font-weight:600}.delete-confirm-actions{display:flex;gap:12px;margin-top:25px}@media (max-width: 768px){.fullscreen-modal-content{max-width:100vw;max-height:100vh;border-radius:0}.fullscreen-header{padding:12px 15px}.image-info h3{font-size:1rem}.fullscreen-image-container{padding:15px}.nav-arrow{width:50px;height:50px;font-size:2.5rem}.nav-prev{left:10px}.nav-next{right:10px}.fullscreen-footer{padding:15px}.image-details{grid-template-columns:1fr;gap:15px}.detail-item{flex-direction:column;align-items:flex-start;gap:4px}.detail-value{text-align:left}.delete-confirm-modal{padding:20px;width:95%}.delete-confirm-actions{flex-direction:column}}@media (max-width: 480px){.header-actions{gap:5px}.btn-delete-header{padding:6px 10px;font-size:.9rem}.btn-close{width:35px;height:35px;font-size:1.8rem}.nav-arrow{width:45px;height:45px;font-size:2rem}}.reorder-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow:hidden}.reorder-modal{background:#fff;border-radius:12px;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.reorder-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:2px solid #e1e5e9;background:#f8f9fa;border-radius:12px 12px 0 0}.reorder-header h2{margin:0;color:#2c3e50;font-size:1.5rem;font-weight:600}.close-button{background:none;border:none;font-size:2rem;color:#6c757d;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-button:hover{background:#e9ecef;color:#495057}.reorder-instructions{padding:15px 30px;background:#e3f2fd;border-bottom:1px solid #bbdefb;color:#1565c0;font-size:.9rem;line-height:1.4}.reorder-content{flex:1;overflow-y:auto;padding:20px 30px;min-height:0;scroll-behavior:smooth}.images-list{display:flex;flex-direction:column;gap:12px;min-height:200px;padding:10px 0;transition:all .2s ease}.images-list.dragging-active{background:#3498db0d;border-radius:8px;border:2px dashed rgba(52,152,219,.3)}.reorder-item{display:flex;align-items:center;gap:15px;padding:15px;background:#f8f9fa;border:2px solid #e1e5e9;border-radius:8px;transition:all .2s ease;cursor:grab;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;will-change:transform}.reorder-item:hover{border-color:#3498db;box-shadow:0 2px 8px #0000001a}.reorder-item.dragging{opacity:.3;transform:scale(.95) rotate(2deg);cursor:grabbing;pointer-events:none;box-shadow:0 8px 25px #00000026}.reorder-item.drag-over{border-color:#27ae60;background:#e8f5e8;transform:scale(1.05);box-shadow:0 4px 15px #27ae604d;transition:all .15s ease}.drag-handle{display:flex;flex-direction:column;align-items:center;gap:5px;min-width:40px;cursor:grab;padding:8px;border-radius:6px;transition:background-color .2s ease}.drag-handle:hover{background:#3498db1a}.reorder-item.dragging .drag-handle{cursor:grabbing;background:#3498db33}.order-number{background:#3498db;color:#fff;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem}.drag-icon{color:#6c757d;font-size:1.2rem;font-weight:700;line-height:.8}.image-preview{width:80px;height:80px;border-radius:6px;overflow:hidden;flex-shrink:0;background:#e9ecef;display:flex;align-items:center;justify-content:center}.image-preview img{width:100%;height:100%;object-fit:cover}.image-info{flex:1;min-width:0}.image-details{display:flex;align-items:center;gap:6px;color:#6c757d;font-size:.8rem;margin-bottom:4px}.image-details svg{flex-shrink:0}.reorder-controls{display:flex;flex-direction:column;gap:4px}.btn-move-up,.btn-move-down{background:#3498db;color:#fff;border:none;border-radius:4px;width:32px;height:32px;cursor:pointer;font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-move-up:hover:not(.disabled),.btn-move-down:hover:not(.disabled){background:#2980b9;transform:scale(1.1)}.btn-move-up.disabled,.btn-move-down.disabled{background:#bdc3c7;cursor:not-allowed;opacity:.5}.reorder-footer{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-top:2px solid #e1e5e9;background:#f8f9fa;border-radius:0 0 12px 12px}.footer-info{font-size:.9rem}.changes-indicator{color:#f39c12;font-weight:600}.no-changes{color:#6c757d}.footer-actions{display:flex;gap:12px}.btn-reset,.btn-cancel,.btn-save{padding:10px 20px;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.9rem;display:flex;align-items:center;gap:8px}.btn-reset{background:#6c757d;color:#fff}.btn-reset:hover:not(:disabled){background:#5a6268}.btn-cancel{background:#e9ecef;color:#495057}.btn-cancel:hover:not(:disabled){background:#dee2e6}.btn-save{background:#27ae60;color:#fff}.btn-save:hover:not(:disabled){background:#229954;transform:translateY(-1px);box-shadow:0 4px 12px #27ae604d}.btn-save.no-changes{background:#3498db}.btn-save.no-changes:hover:not(:disabled){background:#2980b9}.btn-reset:disabled,.btn-cancel:disabled,.btn-save:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 768px){.reorder-overlay{padding:10px}.reorder-modal{max-height:95vh}.reorder-header{padding:15px 20px}.reorder-header h2{font-size:1.2rem}.reorder-instructions{padding:12px 20px;font-size:.8rem}.reorder-content{padding:15px 20px}.reorder-item{padding:12px;gap:12px}.image-preview{width:60px;height:60px}.order-number{width:25px;height:25px;font-size:.8rem}.btn-move-up,.btn-move-down{width:28px;height:28px;font-size:1rem}.reorder-footer{padding:15px 20px;flex-direction:column;gap:15px;align-items:stretch}.footer-actions{justify-content:center}}@media (max-width: 480px){.reorder-item{flex-direction:column;align-items:center;text-align:center;gap:10px;padding:15px 10px}.drag-handle{flex-direction:row;gap:10px}.image-info{order:-1}.reorder-controls{flex-direction:row;gap:8px}.footer-actions{flex-direction:column;gap:8px}.btn-reset,.btn-cancel,.btn-save{width:100%}}.admin-review{max-width:1400px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e1e5e9}.admin-header h1{margin:0;color:#2c3e50;font-size:2rem;font-weight:600}.stats{display:flex;gap:20px}.stat{display:flex;flex-direction:column;align-items:center;padding:10px 15px;background:#f8f9fa;border-radius:8px;min-width:80px}.stat-label{font-size:.8rem;color:#6c757d;font-weight:500;text-transform:uppercase}.stat-value{font-size:1.5rem;font-weight:700;color:#2c3e50}.stat-value.pending{color:#f39c12}.stat-value.approved{color:#27ae60}.stat-value.rejected{color:#e74c3c}.error-message{background:#f8d7da;color:#721c24;padding:12px 16px;border-radius:6px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;color:#721c24;font-size:1.2rem;cursor:pointer;padding:0;width:20px;height:20px}.global-review-notes{margin-bottom:20px}.global-review-notes textarea{width:100%;min-height:80px;padding:12px;border:2px solid #e1e5e9;border-radius:6px;font-family:inherit;font-size:.9rem;resize:vertical;transition:border-color .2s ease}.global-review-notes textarea:focus{outline:none;border-color:#3498db}.loading,.no-meals{text-align:center;padding:60px 20px;color:#6c757d;font-size:1.1rem}.meals-list{display:flex;flex-direction:column;gap:20px}.meal-card{background:#fff;border:2px solid #e1e5e9;border-radius:12px;overflow:hidden;transition:all .2s ease}.meal-card:hover{border-color:#3498db;box-shadow:0 4px 12px #0000001a}.meal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;background:#f8f9fa;cursor:pointer;transition:background-color .2s ease}.meal-header:hover{background:#e9ecef}.meal-info{flex:1}.meal-id{margin:0 0 10px;color:#2c3e50;font-size:1.3rem;font-weight:600}.meal-stats{display:flex;gap:10px;margin-bottom:8px;flex-wrap:wrap}.stat-badge{padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:600;text-transform:uppercase}.stat-badge.approved{background:#d4edda;color:#155724}.stat-badge.pending{background:#fff3cd;color:#856404}.stat-badge.rejected{background:#f8d7da;color:#721c24}.meal-dates{color:#6c757d;font-size:.9rem}.expand-icon{font-size:1.2rem;color:#6c757d;transition:transform .2s ease}.meal-content{padding:25px;border-top:1px solid #e1e5e9}.loading-images,.no-images{text-align:center;padding:40px 20px;color:#6c757d;font-style:italic}.image-section{margin-bottom:30px}.image-section:last-child{margin-bottom:0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #e1e5e9}.approved-section .section-header{border-bottom-color:#27ae60}.pending-section .section-header{border-bottom-color:#f39c12}.rejected-section .section-header{border-bottom-color:#e74c3c}.section-header h4{margin:0;color:#2c3e50;font-size:1.1rem;font-weight:600}.section-actions{display:flex;gap:10px}.btn-reorder{background:#3498db;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.9rem;display:flex;align-items:center;gap:8px}.btn-reorder:hover{background:#2980b9;transform:translateY(-1px)}.images-grid{display:grid;gap:15px}.approved-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.pending-grid,.rejected-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.image-item{background:#fff;border:2px solid #e1e5e9;border-radius:8px;overflow:hidden;transition:all .2s ease;position:relative}.image-item:hover{border-color:#3498db;box-shadow:0 2px 8px #0000001a}.approved-item{border-color:#d4edda}.approved-item:hover{border-color:#27ae60}.pending-item{border-color:#fff3cd}.pending-item:hover{border-color:#f39c12}.rejected-item{border-color:#f8d7da}.rejected-item:hover{border-color:#e74c3c}.image-order{position:absolute;top:8px;left:8px;background:#000000b3;color:#fff;padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:600;z-index:2}.image-preview{aspect-ratio:4/3;background:#f8f9fa;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden}.image-preview img{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.image-preview:hover img{transform:scale(1.05)}.image-meta{padding:12px;background:#f8f9fa}.meta-item{display:flex;align-items:center;gap:6px;color:#6c757d;font-size:.8rem;margin-bottom:4px}.meta-item svg{flex-shrink:0}.meta-item span{word-break:break-word}.review-notes{color:#495057;font-size:.8rem;font-style:italic;background:#e9ecef;padding:6px 8px;border-radius:4px;margin-top:4px}.image-actions{display:flex;gap:6px;padding:10px;background:#f8f9fa;border-top:1px solid #e1e5e9;flex-wrap:wrap}.image-actions button{flex:1;min-width:40px;height:40px;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000001a}.btn-compare{background:#3498db;color:#fff}.btn-compare:hover{background:#2980b9;transform:translateY(-2px);box-shadow:0 4px 12px #3498db4d}.btn-fullscreen{background:#6c757d;color:#fff}.btn-fullscreen:hover{background:#5a6268;transform:translateY(-2px);box-shadow:0 4px 12px #6c757d4d}.btn-approve{background:#27ae60;color:#fff}.btn-approve:hover{background:#229954;transform:translateY(-2px);box-shadow:0 4px 12px #27ae604d}.btn-reject{background:#e74c3c;color:#fff}.btn-reject:hover{background:#c0392b;transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c4d}.btn-delete{background:#dc3545;color:#fff}.btn-delete:hover{background:#c82333;transform:translateY(-2px);box-shadow:0 4px 12px #dc35454d}.delete-confirm-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.delete-confirm-modal{background:#fff;border-radius:12px;padding:30px;max-width:400px;width:90%;text-align:center;box-shadow:0 20px 60px #0000004d}.delete-confirm-modal h3{margin:0 0 15px;color:#2c3e50;font-size:1.3rem;font-weight:600}.delete-confirm-modal p{margin:12px 0;color:#495057;line-height:1.5}.delete-warning{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;padding:15px;color:#856404}.delete-warning strong{color:#495057;font-weight:600}.delete-actions{display:flex;gap:12px;margin-top:25px}.btn-cancel,.btn-confirm-delete{flex:1;padding:12px 20px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:1rem}.btn-cancel{background:#6c757d;color:#fff}.btn-cancel:hover{background:#5a6268}.btn-confirm-delete{background:#e74c3c;color:#fff}.btn-confirm-delete:hover{background:#c0392b;transform:translateY(-1px);box-shadow:0 4px 12px #e74c3c4d}@media (max-width: 1024px){.admin-header{flex-direction:column;gap:20px;align-items:flex-start}.stats{gap:10px}.stat{min-width:60px;padding:8px 12px}.approved-grid,.pending-grid,.rejected-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}@media (max-width: 768px){.admin-review{padding:15px}.admin-header h1{font-size:1.5rem}.meal-header{padding:15px 20px}.meal-id{font-size:1.1rem}.meal-content{padding:20px}.stats{flex-wrap:wrap;gap:8px}.stat{min-width:50px;padding:6px 10px}.stat-value{font-size:1.2rem}.approved-grid,.pending-grid,.rejected-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.image-actions{gap:2px}.image-actions button{min-width:32px;height:32px;font-size:.9rem}.delete-confirm-modal{padding:20px;width:95%}.delete-actions{flex-direction:column}}@media (max-width: 480px){.admin-review{padding:10px}.admin-header{padding-bottom:15px}.meal-header{padding:12px 15px}.meal-content{padding:15px}.approved-grid,.pending-grid,.rejected-grid{grid-template-columns:1fr}.section-header{flex-direction:column;gap:10px;align-items:flex-start}.image-actions{grid-template-columns:repeat(2,1fr);gap:4px}.image-actions button{min-width:auto}}.admin-access{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.access-card{background:#fff;padding:40px;border-radius:12px;box-shadow:0 10px 30px #0003;max-width:500px;width:100%;text-align:center}.access-card h2{margin:0 0 20px;color:#2c3e50;font-size:2rem;font-weight:600}.access-card p{margin:0 0 16px;color:#6c757d;line-height:1.6}.access-card code{background:#f8f9fa;padding:4px 8px;border-radius:4px;font-family:Courier New,monospace;color:#e74c3c;font-weight:600}.admin-info{margin-top:30px;text-align:left;padding:20px;background:#f8f9fa;border-radius:8px;border-left:4px solid #3498db}.admin-info h3{margin:0 0 16px;color:#2c3e50;font-size:1.2rem;font-weight:600}.admin-info ul{margin:0;padding-left:20px;color:#495057}.admin-info li{margin-bottom:8px;line-height:1.5}.admin-route{min-height:100vh;background:#f8f9fa}.admin-route .admin-header{background:#fff;padding:30px 20px;text-align:center;border-bottom:2px solid #e9ecef;box-shadow:0 2px 4px #0000001a}.admin-route .admin-header h1{margin:0 0 8px;color:#2c3e50;font-size:2.5rem;font-weight:700}.admin-route .admin-header p{margin:0;color:#6c757d;font-size:1.1rem}@media (max-width: 768px){.access-card{padding:30px 20px}.access-card h2{font-size:1.5rem}.admin-route .admin-header h1{font-size:2rem}}@media (max-width: 480px){.admin-access{padding:10px}.access-card{padding:20px 15px}.admin-info{padding:15px}}.footer{background:#f8fafc;color:#1f2937;padding:1rem 0 .5rem;margin-top:auto;border-top:1px solid #e5e7eb}.footer-content{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;flex-direction:column;gap:.75rem}.footer-info{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:1rem}.footer-links{display:flex;gap:1rem;align-items:center}.footer-link{display:flex;align-items:center;gap:.25rem;color:#6b7280;text-decoration:none;transition:color .2s ease;font-size:.8rem;padding:.25rem .5rem;border-radius:4px}.footer-link:hover{color:#dc2626;background-color:#dc26261a}.version-btn{background:none;border:none;cursor:pointer;font-family:inherit;font-size:inherit;position:relative}.version-btn:hover{color:#dc2626;background-color:#dc26261a}.version-btn.has-update{color:#dc2626;font-weight:500}.version-btn.has-update:hover{background-color:#dc262626}.update-indicator{color:#dc2626;font-size:.6rem;margin-left:.25rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.version-info{background:#fffc;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;margin:.5rem 0;text-align:center}.version-details{margin-bottom:1rem}.version-details p{margin:.25rem 0;font-size:.8rem;color:#6b7280}.version-latest{color:#059669!important}.version-outdated{color:#dc2626!important}.check-update-btn{background:#dc2626;color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;font-size:.8rem;cursor:pointer;transition:background-color .2s ease}.check-update-btn:hover:not(:disabled){background:#b91c1c}.check-update-btn:disabled{background:#9ca3af;cursor:not-allowed}.version-actions{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.force-update-btn{background:#059669;color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;font-size:.8rem;cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;gap:.25rem}.force-update-btn:hover{background:#047857}.force-update-btn:active{background:#065f46}.footer-bottom{border-top:1px solid #e5e7eb;padding-top:.75rem;text-align:center;display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.footer-bottom p{color:#9ca3af;font-size:.75rem;margin:0}.heart-icon{color:#dc2626;display:inline-block;margin:0 .25rem;animation:heartbeat 2s ease-in-out infinite}.developer-name{color:#dc2626;font-weight:600;font-style:italic}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media (max-width: 768px){.footer{padding:.75rem 0 .5rem}.footer-content{padding:0 .5rem}.footer-info{flex-direction:column;align-items:center;gap:.5rem}.footer-links{gap:.75rem}.footer-bottom{flex-direction:column;gap:.25rem}.version-info{margin:.25rem 0;padding:.75rem}.version-actions{flex-direction:column;gap:.25rem}.force-update-btn,.check-update-btn{width:100%;justify-content:center}}@media (max-width: 480px){.footer{padding:.5rem 0 .25rem}.footer-link{font-size:.75rem}.footer-bottom p{font-size:.7rem}.version-details p{font-size:.75rem}}
