.offline-indicator{position:fixed;top:0;left:0;right:0;z-index:1000;background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff;padding:.75rem 1rem;box-shadow:0 2px 8px #00000026;transform:translateY(-100%);transition:transform .3s ease-in-out,background .3s ease;animation:slideDown .3s ease-out forwards}.offline-indicator--online{background:linear-gradient(135deg,#51cf66,#40c057);animation:slideDown .3s ease-out forwards,fadeOut 3s ease-in-out 2s forwards}.offline-indicator--compact{padding:.5rem 1rem}.offline-indicator--compact .offline-indicator__content{align-items:center}.offline-indicator--compact .offline-indicator__text{flex-direction:row;gap:.5rem}.offline-indicator__content{display:flex;align-items:flex-start;gap:.75rem;max-width:1200px;margin:0 auto}.offline-indicator__icon{font-size:1.25rem;flex-shrink:0;margin-top:.125rem}.offline-indicator__text{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.offline-indicator__message{font-weight:600;font-size:.875rem;line-height:1.25}.offline-indicator__time{font-size:.75rem;opacity:.9;font-weight:400}.offline-indicator__actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.offline-indicator__retry-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.375rem .75rem;border-radius:4px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.25rem}.offline-indicator__retry-btn:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80}.offline-indicator__retry-btn:disabled{opacity:.7;cursor:not-allowed}.offline-indicator__retry-btn:active{transform:scale(.98)}.offline-indicator__close-btn{background:none;border:none;color:#fff;font-size:1rem;padding:.25rem;cursor:pointer;opacity:.8;transition:opacity .2s ease;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:2px}.offline-indicator__close-btn:hover{opacity:1;background:#ffffff1a}.offline-indicator__spinner{display:inline-block;animation:spin 1s linear infinite}.offline-indicator__progress{position:absolute;bottom:0;left:0;right:0;height:2px;background:#fff3;overflow:hidden}.offline-indicator__progress-bar{height:100%;background:#fff9;width:100%;animation:progressSlide 2s ease-in-out infinite}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes fadeOut{to{transform:translateY(-100%);opacity:0}}@keyframes progressSlide{0%{transform:translate(-100%)}50%{transform:translate(0)}to{transform:translate(100%)}}@media (max-width: 768px){.offline-indicator{padding:.5rem 1rem}.offline-indicator__content{gap:.5rem}.offline-indicator__message{font-size:.8125rem}.offline-indicator__time{font-size:.6875rem}.offline-indicator__retry-btn{padding:.25rem .5rem;font-size:.6875rem}.offline-indicator--compact{padding:.375rem .75rem}.offline-indicator--compact .offline-indicator__text{flex-direction:column;gap:.125rem}}@media (prefers-contrast: high){.offline-indicator{border-bottom:2px solid currentColor}.offline-indicator__retry-btn{border-color:currentColor}}@media (prefers-reduced-motion: reduce){.offline-indicator{animation:none;transform:translateY(0)}.offline-indicator--online,.offline-indicator__spinner,.offline-indicator__progress-bar{animation:none}}.network-error-fallback{display:flex;align-items:center;justify-content:center;min-height:300px;padding:2rem;background:#f8fafc;border-radius:12px;text-align:center}.network-error-fallback__content{max-width:500px;width:100%;background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 12px #0000001a}.network-error-fallback__icon{font-size:3rem;margin-bottom:1.5rem;line-height:1}.network-error-fallback__text{margin-bottom:2rem}.network-error-fallback__title{color:#374151;font-size:1.5rem;font-weight:700;margin:0 0 1rem;line-height:1.3}.network-error-fallback__message{color:#6b7280;font-size:1rem;line-height:1.6;margin:0 0 1.5rem}.network-error-fallback__status{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:20px;font-size:.875rem;font-weight:500;margin-bottom:1rem}.network-error-fallback__status.online{background:#dcfce7;color:#166534}.network-error-fallback__status.offline{background:#fef2f2;color:#991b1b}.network-error-fallback__status-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.online .network-error-fallback__status-indicator{background:#22c55e}.offline .network-error-fallback__status-indicator{background:#ef4444}.network-error-fallback__suggestions{text-align:start;margin-top:1.5rem;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.network-error-fallback__suggestions summary{padding:.75rem 1rem;background:#f9fafb;cursor:pointer;font-weight:500;color:#374151;transition:background .2s ease}.network-error-fallback__suggestions summary:hover{background:#f3f4f6}.network-error-fallback__suggestions summary::marker{color:#6b7280}.network-error-fallback__suggestions-list{padding:1rem;margin:0;list-style:none;font-size:.875rem;color:#6b7280;line-height:1.6}.network-error-fallback__suggestions-list li{margin-bottom:.5rem}.network-error-fallback__suggestions-list li:last-child{margin-bottom:0}.network-error-fallback__actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-bottom:1.5rem}.network-error-fallback__retry-btn,.network-error-fallback__reload-btn,.network-error-fallback__details-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none}.network-error-fallback__retry-btn:disabled,.network-error-fallback__reload-btn:disabled,.network-error-fallback__details-btn:disabled{opacity:.6;cursor:not-allowed}.network-error-fallback__retry-btn{background:#3b82f6;color:#fff}.network-error-fallback__retry-btn:hover:not(:disabled){background:#2563eb;transform:translateY(-1px)}.network-error-fallback__retry-btn:active:not(:disabled){transform:translateY(0)}.network-error-fallback__reload-btn{background:#059669;color:#fff}.network-error-fallback__reload-btn:hover{background:#047857;transform:translateY(-1px)}.network-error-fallback__reload-btn:active{transform:translateY(0)}.network-error-fallback__details-btn{background:#f3f4f6;color:#6b7280;border:1px solid #d1d5db}.network-error-fallback__details-btn:hover{background:#e5e7eb;color:#374151}.network-error-fallback__spinner{display:inline-block;animation:spin 1s linear infinite}.network-error-fallback__error-details{text-align:start;margin-top:1.5rem;border:1px solid #fecaca;border-radius:8px;background:#fef2f2;overflow:hidden}.network-error-fallback__error-details summary{padding:.75rem 1rem;background:#fee2e2;cursor:pointer;font-weight:500;color:#991b1b}.network-error-fallback__error-details summary:hover{background:#fecaca}.network-error-fallback__error-stack{padding:1rem;margin:0;background:#1f2937;color:#e5e7eb;font-family:Monaco,Menlo,monospace;font-size:.75rem;line-height:1.4;overflow-x:auto;white-space:pre-wrap;word-break:break-word}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.network-error-fallback{padding:1rem;min-height:250px}.network-error-fallback__content{padding:1.5rem}.network-error-fallback__icon{font-size:2.5rem;margin-bottom:1rem}.network-error-fallback__title{font-size:1.25rem}.network-error-fallback__message{font-size:.875rem}.network-error-fallback__actions{flex-direction:column}.network-error-fallback__retry-btn,.network-error-fallback__reload-btn,.network-error-fallback__details-btn{width:100%;justify-content:center}}@media (prefers-contrast: high){.network-error-fallback__content{border:2px solid #000}.network-error-fallback__retry-btn,.network-error-fallback__reload-btn{border:2px solid currentColor}.network-error-fallback__status{border:1px solid currentColor}}@media (prefers-reduced-motion: reduce){.network-error-fallback__spinner{animation:none}.network-error-fallback__retry-btn:hover,.network-error-fallback__reload-btn:hover{transform:none}}.accessibility-fab{position:fixed;bottom:20px;right:20px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#1e3a8a,#1e40af);border:none;box-shadow:0 4px 20px #00000026;cursor:pointer;z-index:1000;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);color:#fff;font-size:0}.accessibility-fab:hover{transform:scale(1.1);box-shadow:0 6px 25px #0003}.accessibility-fab:active{transform:scale(.95)}.accessibility-fab:focus{outline:3px solid rgba(255,255,255,.5);outline-offset:2px}.accessibility-fab--open{background:linear-gradient(135deg,#6b7280,#374151);transform:rotate(45deg)}@media (max-width: 768px){.accessibility-fab{bottom:16px;right:16px;width:48px;height:48px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.accessibility-toolbar{position:fixed;bottom:90px;right:20px;width:320px;max-height:70vh;background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000026;z-index:1001;display:flex;flex-direction:column;overflow:hidden;border:1px solid #e5e7eb}@media (max-width: 768px){.accessibility-toolbar{bottom:80px;right:16px;left:16px;width:auto;max-height:80vh;border-radius:12px}}@media (max-width: 1024px){.accessibility-toolbar{width:300px}}.accessibility-toolbar__overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0000004d;z-index:1000;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.accessibility-toolbar__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,#1e3a8a,#1e40af);color:#fff;border-bottom:1px solid rgba(255,255,255,.1)}.accessibility-toolbar__title{display:flex;align-items:center;gap:8px;margin:0;font-size:16px;font-weight:600}.accessibility-toolbar__close{background:none;border:none;color:#fff;cursor:pointer;padding:4px;border-radius:4px;transition:background-color .2s ease}.accessibility-toolbar__close:hover{background:#ffffff1a}.accessibility-toolbar__close:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.accessibility-toolbar__tabs{display:flex;background:#f9fafb;border-bottom:1px solid #e5e7eb;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.accessibility-toolbar__tabs::-webkit-scrollbar{display:none}.accessibility-toolbar__tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 8px;background:none;border:none;cursor:pointer;font-size:12px;font-weight:500;color:#6b7280;transition:all .2s ease;white-space:nowrap;min-width:0}.accessibility-toolbar__tab:hover{background:#0000000d;color:#1f2937}.accessibility-toolbar__tab:focus{outline:2px solid #1e3a8a;outline-offset:-2px}.accessibility-toolbar__tab--active{background:#fff;color:#1e3a8a;border-bottom:2px solid #1e3a8a}@media (max-width: 768px){.accessibility-toolbar__tab{padding:10px 6px;font-size:11px}}.accessibility-toolbar__content{flex:1;padding:20px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#e5e7eb transparent}.accessibility-toolbar__content::-webkit-scrollbar{width:6px}.accessibility-toolbar__content::-webkit-scrollbar-track{background:transparent}.accessibility-toolbar__content::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:3px}.accessibility-toolbar__content::-webkit-scrollbar-thumb:hover{background:#6b7280}.accessibility-setting{margin-bottom:20px}.accessibility-setting:last-child{margin-bottom:0}.accessibility-setting__label{display:block;font-size:14px;font-weight:600;color:#1f2937;margin-bottom:8px;cursor:pointer}.accessibility-setting__text{margin-left:8px;font-weight:500}.accessibility-setting__description{font-size:12px;color:#6b7280;margin:4px 0 0;line-height:1.4}.accessibility-setting__input{width:16px;height:16px;accent-color:#1e3a8a;cursor:pointer}.accessibility-setting__select{width:100%;padding:8px 12px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;font-size:14px;color:#1f2937;cursor:pointer;transition:border-color .2s ease}.accessibility-setting__select:focus{outline:none;border-color:#1e3a8a;box-shadow:0 0 0 3px #1e3a8a1a}.accessibility-setting__select:hover{border-color:#6b7280}.accessibility-toolbar__actions{display:flex;gap:12px;padding:16px 20px;background:#f9fafb;border-top:1px solid #e5e7eb}.accessibility-toolbar__reset{display:flex;align-items:center;gap:6px;padding:8px 12px;background:none;border:1px solid #e5e7eb;border-radius:8px;color:#6b7280;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.accessibility-toolbar__reset:hover{background:#f9fafb;color:#1f2937;border-color:#6b7280}.accessibility-toolbar__reset:focus{outline:2px solid #1e3a8a;outline-offset:2px}.accessibility-toolbar__close-btn{flex:1;padding:8px 16px;background:#1e3a8a;border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.accessibility-toolbar__close-btn:hover{background:#1e40af;transform:translateY(-1px)}.accessibility-toolbar__close-btn:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.accessibility-toolbar__close-btn:active{transform:translateY(0)}.high-contrast{--text-primary: #000000;--text-secondary: #333333;--background-primary: #ffffff;--background-secondary: #f0f0f0;--border-color: #000000;--primary-color: #0000ff;--primary-color-dark: #0000cc}.dyslexia-friendly{font-family:OpenDyslexic,Comic Sans MS,Trebuchet MS,sans-serif;letter-spacing:.05em;line-height:1.6}.protanopia{filter:hue-rotate(90deg) saturate(1.2)}.deuteranopia{filter:hue-rotate(180deg) saturate(1.2)}.tritanopia{filter:hue-rotate(270deg) saturate(1.2)}:focus-visible{outline:2px solid var(--primary-color, #1e3a8a);outline-offset:2px}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}[data-theme=dark] .accessibility-toolbar{background:#374151;border-color:#4b5563;color:#f9fafb}[data-theme=dark] .accessibility-toolbar .accessibility-toolbar__tabs{background:#4b5563}[data-theme=dark] .accessibility-toolbar .accessibility-toolbar__tab{color:#9ca3af}[data-theme=dark] .accessibility-toolbar .accessibility-toolbar__tab:hover{background:#ffffff0d;color:#f9fafb}[data-theme=dark] .accessibility-toolbar .accessibility-toolbar__tab--active{background:#374151;color:#60a5fa}[data-theme=dark] .accessibility-toolbar .accessibility-toolbar__content{background:#374151}[data-theme=dark] .accessibility-toolbar .accessibility-toolbar__actions{background:#4b5563}[data-theme=dark] .accessibility-toolbar .accessibility-setting__select{background:#4b5563;border-color:#4b5563;color:#f9fafb}[data-theme=dark] .accessibility-toolbar .accessibility-setting__select:focus{border-color:#60a5fa}@media (max-width: 768px){.accessibility-toolbar__header{padding:12px 16px}.accessibility-toolbar__title{font-size:14px}.accessibility-toolbar__content{padding:16px}.accessibility-toolbar__actions{padding:12px 16px;flex-direction:column}.accessibility-toolbar__close-btn{order:-1}}.privacy-consent-banner{position:fixed;bottom:0;left:0;right:0;z-index:2000;background:#000c;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transform:translateY(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);animation:slideUp .4s cubic-bezier(.4,0,.2,1) forwards}.privacy-consent-banner--animating{animation:slideDown .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.privacy-consent-banner__overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.3) 100%);pointer-events:none}.privacy-consent-banner__content{position:relative;background:#fff;border-radius:16px 16px 0 0;padding:24px;margin:0 16px;box-shadow:0 -4px 20px #00000026;border:1px solid #e5e7eb;border-bottom:none}@media (max-width: 768px){.privacy-consent-banner__content{margin:0 8px;padding:20px 16px;border-radius:12px 12px 0 0}}.privacy-consent-banner__header{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}@media (max-width: 768px){.privacy-consent-banner__header{gap:12px;margin-bottom:16px}}.privacy-consent-banner__icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:linear-gradient(135deg,#1e3a8a,#1e40af);border-radius:12px;color:#fff;flex-shrink:0}@media (max-width: 768px){.privacy-consent-banner__icon{width:40px;height:40px;border-radius:10px}}.privacy-consent-banner__title{flex:1}.privacy-consent-banner__title h3{margin:0 0 4px;font-size:18px;font-weight:700;color:#1f2937;line-height:1.3}@media (max-width: 768px){.privacy-consent-banner__title h3{font-size:16px}}.privacy-consent-banner__title p{margin:0;font-size:14px;color:#6b7280;line-height:1.4}@media (max-width: 768px){.privacy-consent-banner__title p{font-size:13px}}.privacy-consent-banner__body{margin-bottom:24px}.privacy-consent-banner__description{font-size:15px;color:#1f2937;line-height:1.5;margin:0 0 20px}@media (max-width: 768px){.privacy-consent-banner__description{font-size:14px;margin-bottom:16px}}.privacy-consent-banner__details{background:#f9fafb;border-radius:12px;padding:20px;border:1px solid #e5e7eb}.privacy-consent-banner__details h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#1f2937}@media (max-width: 768px){.privacy-consent-banner__details{padding:16px;border-radius:10px}.privacy-consent-banner__details h4{font-size:15px;margin-bottom:12px}}.privacy-consent-banner__purposes{display:flex;flex-direction:column;gap:16px}.privacy-consent-banner__purpose{padding-bottom:16px;border-bottom:1px solid rgba(0,0,0,.05)}.privacy-consent-banner__purpose:last-child{padding-bottom:0;border-bottom:none}.privacy-consent-banner__purpose-label{display:flex;align-items:flex-start;gap:12px;cursor:pointer;margin-bottom:4px}.privacy-consent-banner__purpose-input{width:18px;height:18px;accent-color:#1e3a8a;cursor:pointer;margin-top:2px;flex-shrink:0}.privacy-consent-banner__purpose-text{flex:1;font-size:14px;font-weight:500;color:#1f2937;line-height:1.4}.privacy-consent-banner__required{background:#1e3a8a;color:#fff;font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.privacy-consent-banner__purpose-legal{margin:0 0 0 30px;font-size:12px;color:#6b7280;font-style:italic}.privacy-consent-banner__actions{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}@media (max-width: 768px){.privacy-consent-banner__actions{gap:12px;margin-bottom:16px}}.privacy-consent-banner__customize{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:none;border:1px solid #e5e7eb;border-radius:8px;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;align-self:center}.privacy-consent-banner__customize:hover{background:#f9fafb;color:#1f2937;border-color:#6b7280}.privacy-consent-banner__customize:focus{outline:2px solid #1e3a8a;outline-offset:2px}.privacy-consent-banner__main-actions{display:flex;gap:12px}@media (max-width: 768px){.privacy-consent-banner__main-actions{flex-direction:column;gap:8px}}.privacy-consent-banner__reject{flex:1;padding:14px 20px;background:none;border:1px solid #e5e7eb;border-radius:8px;color:#6b7280;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.privacy-consent-banner__reject:hover{background:#f9fafb;color:#1f2937;border-color:#6b7280}.privacy-consent-banner__reject:focus{outline:2px solid #1e3a8a;outline-offset:2px}@media (max-width: 768px){.privacy-consent-banner__reject{padding:12px 16px;font-size:14px}}.privacy-consent-banner__accept{flex:1;padding:14px 20px;background:linear-gradient(135deg,#1e3a8a,#1e40af);border:none;border-radius:8px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.privacy-consent-banner__accept:hover{background:linear-gradient(135deg,#1e40af,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #1e3a8a4d}.privacy-consent-banner__accept:focus{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.privacy-consent-banner__accept:active{transform:translateY(0)}@media (max-width: 768px){.privacy-consent-banner__accept{padding:12px 16px;font-size:14px}}.privacy-consent-banner__footer{text-align:center;padding-top:16px;border-top:1px solid #e5e7eb}.privacy-consent-banner__footer p{margin:0;font-size:12px;color:#6b7280;line-height:1.4}@media (max-width: 768px){.privacy-consent-banner__footer p{font-size:11px}}.privacy-consent-banner__link{color:#1e3a8a;text-decoration:none;font-weight:500;transition:color .2s ease}.privacy-consent-banner__link:hover{color:#1e40af;text-decoration:underline}.privacy-consent-banner__link:focus{outline:2px solid #1e3a8a;outline-offset:1px;border-radius:2px}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__content{background:#374151;border-color:#4b5563}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__title h3{color:#f9fafb}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__title p{color:#9ca3af}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__description{color:#f9fafb}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__details{background:#4b5563;border-color:#4b5563}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__details h4,[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__purpose-text{color:#f9fafb}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__purpose-legal{color:#9ca3af}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__customize{border-color:#4b5563;color:#9ca3af}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__customize:hover{background:#4b5563;color:#f9fafb}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__reject{border-color:#4b5563;color:#9ca3af}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__reject:hover{background:#4b5563;color:#f9fafb}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__footer{border-top-color:#4b5563}[data-theme=dark] .privacy-consent-banner .privacy-consent-banner__footer p{color:#9ca3af}.high-contrast .privacy-consent-banner .privacy-consent-banner__content{border:2px solid #000000}.high-contrast .privacy-consent-banner .privacy-consent-banner__purpose-input{accent-color:#0000ff}.high-contrast .privacy-consent-banner .privacy-consent-banner__link{color:#00f;text-decoration:underline}@media (prefers-reduced-motion: reduce){.privacy-consent-banner{animation:none;transition:none}.privacy-consent-banner--animating{animation:none}}.privacy-consent-banner button:focus-visible{outline:2px solid #1e3a8a;outline-offset:2px}.privacy-consent-banner__content[aria-hidden=true]{display:none}.main-banner-carousel{position:relative;margin:4rem auto;max-width:min(120rem,100vw);width:calc(100% - 2rem);border-radius:2rem;overflow:hidden;box-shadow:0 20px 40px #0000001a;background:linear-gradient(135deg,#000c,#0009);cursor:grab;-ms-user-select:none;-moz-user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;user-select:none}.main-banner-carousel:focus{outline:3px solid var(--primary-main);outline-offset:4px}.main-banner-carousel.dragging{cursor:grabbing}@media only screen and (max-width: 56.25em){.main-banner-carousel.dragging .slides-container,.main-banner-carousel.dragging .slide{transition:none}.main-banner-carousel{width:calc(100% - 1rem);border-radius:1rem;margin:2rem auto}}@media only screen and (max-width: 37.5em){.main-banner-carousel{width:100%;border-radius:0;margin:0;box-shadow:none;touch-action:pan-y pinch-zoom}.main-banner-carousel:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;background:#ffffff1a;border-radius:50%;opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:5}}.main-banner-carousel .slides-container{position:relative;height:40vh;min-height:400px;overflow:hidden}@media only screen and (max-width: 56.25em){.main-banner-carousel .slides-container{height:40vh;min-height:300px}}@media only screen and (max-width: 37.5em){.main-banner-carousel .slides-container{height:30vh;min-height:250px}}.main-banner-carousel .slide{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;visibility:hidden;transition:all .8s cubic-bezier(.4,0,.2,1);transform:scale(1.1)}.main-banner-carousel .slide.active{opacity:1;visibility:visible;transform:scale(1);z-index:2}.main-banner-carousel .slide.slide-next{animation:slideInNext .8s cubic-bezier(.4,0,.2,1) forwards}.main-banner-carousel .slide.slide-prev{animation:slideInPrev .8s cubic-bezier(.4,0,.2,1) forwards}.main-banner-carousel .slide .image-container{position:relative;width:100%;height:100%;overflow:hidden}.main-banner-carousel .slide .image-container .image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;transition:transform .8s cubic-bezier(.4,0,.2,1)}.main-banner-carousel .slide .image-container .image-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0000004d,#0000001a,#0006);backdrop-filter:blur(1px);-webkit-backdrop-filter:blur(2px);z-index:1}.main-banner-carousel .slide:hover .image{transform:scale(1.05)}.main-banner-carousel .slide .content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#fff;z-index:3;max-width:600px;padding:2rem;background:#0003;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:1.5rem;border:1px solid rgba(255,255,255,.1)}@media only screen and (max-width: 56.25em){.main-banner-carousel .slide .content{padding:1.5rem;max-width:500px}}@media only screen and (max-width: 37.5em){.main-banner-carousel .slide .content{padding:1rem;max-width:100%;width:100%;left:0;transform:translateY(-50%);border-radius:0;border-left:none;border-right:none}}.main-banner-carousel .slide .content .title{font-size:clamp(2rem,5vw,4rem);font-weight:700;margin-bottom:1rem;text-shadow:0 4px 8px rgba(0,0,0,.5);color:#fff;opacity:0;transform:translateY(30px);animation:fadeInUp 1s ease-out .3s forwards;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,"Noto Color Emoji","Apple Color Emoji","Segoe UI Emoji",sans-serif}@media only screen and (max-width: 37.5em){.main-banner-carousel .slide .content .title{font-size:clamp(1.8rem,6vw,3rem)}}.main-banner-carousel .slide .content .subtitle{font-size:clamp(1rem,2.5vw,1.5rem);margin-bottom:2rem;line-height:1.6;text-shadow:0 2px 4px rgba(0,0,0,.7);opacity:0;transform:translateY(30px);animation:fadeInUp 1s ease-out .6s forwards}@media only screen and (max-width: 37.5em){.main-banner-carousel .slide .content .subtitle{font-size:clamp(.9rem,3vw,1.2rem);margin-bottom:1.5rem}}.main-banner-carousel .slide .content .cta-button{padding:1rem 2rem;background:transparent;border:none;border-radius:50px;color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 25px #d4a5744d;opacity:0;transform:translateY(30px);animation:fadeInUp 1s ease-out .9s forwards;display:inline-flex;align-items:center;gap:.5rem;position:relative;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,"Noto Color Emoji","Apple Color Emoji","Segoe UI Emoji",sans-serif}@media only screen and (max-width: 37.5em){.main-banner-carousel .slide .content .cta-button{padding:.8rem 1.5rem;font-size:1rem}}.main-banner-carousel .slide .content .cta-button:disabled{cursor:not-allowed;opacity:.5;pointer-events:none;background:#ffffff4d;box-shadow:none}.main-banner-carousel .slide .content .cta-button:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 5px 10px 5px #c7c5c366}.main-banner-carousel .slide .content .cta-button:not(:disabled):active{transform:translateY(0);box-shadow:0 4px 15px #d4a5744d}.main-banner-carousel .slide .content .cta-button:focus{outline:2px solid rgba(255,255,255,.8);outline-offset:2px}.main-banner-carousel .nav-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);color:#fff;width:50px;height:50px;border-radius:50%;cursor:pointer;z-index:10;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center}@media only screen and (max-width: 56.25em){.main-banner-carousel .nav-arrow{display:none;width:45px;height:45px}}@media only screen and (max-width: 37.5em){.main-banner-carousel .nav-arrow{width:40px;height:40px}}.main-banner-carousel .nav-arrow svg{width:24px;height:24px;transition:transform .3s ease}@media only screen and (max-width: 37.5em){.main-banner-carousel .nav-arrow svg{width:20px;height:20px}}.main-banner-carousel .nav-arrow:hover{background:#fff3;transform:translateY(-50%) scale(1.1)}.main-banner-carousel .nav-arrow:hover svg{transform:scale(1.2)}.main-banner-carousel .nav-arrow:active{transform:translateY(-50%) scale(.95)}.main-banner-carousel .nav-arrow:disabled{opacity:.5;cursor:not-allowed}.main-banner-carousel .nav-arrow.left-arrow{left:2rem}@media only screen and (max-width: 56.25em){.main-banner-carousel .nav-arrow.left-arrow{left:1rem}}@media only screen and (max-width: 37.5em){.main-banner-carousel .nav-arrow.left-arrow{left:.5rem}}.main-banner-carousel .nav-arrow.right-arrow{right:2rem}@media only screen and (max-width: 56.25em){.main-banner-carousel .nav-arrow.right-arrow{right:1rem}}@media only screen and (max-width: 37.5em){.main-banner-carousel .nav-arrow.right-arrow{right:.5rem}}.main-banner-carousel .dots-container{position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%);display:flex;gap:.75rem;z-index:10}@media only screen and (max-width: 37.5em){.main-banner-carousel .dots-container{bottom:1rem;gap:.5rem}}.main-banner-carousel .dots-container .dot{position:relative;width:8px;height:8px;border-radius:50%;border:1px solid rgba(255,255,255,.5);background:transparent;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;min-width:16px;min-height:16px}@media only screen and (max-width: 37.5em){.main-banner-carousel .dots-container .dot{width:6px;height:6px}}.main-banner-carousel .dots-container .dot .dot-progress{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:4px;height:4px;border-radius:50%;background:#ffffffb3;transition:all .3s cubic-bezier(.4,0,.2,1)}@media only screen and (max-width: 37.5em){.main-banner-carousel .dots-container .dot .dot-progress{width:3px;height:3px}}.main-banner-carousel .dots-container .dot.active{border-color:var(--primary-main);transform:scale(1.2)}.main-banner-carousel .dots-container .dot.active .dot-progress{background:var(--primary-main);width:8px;height:8px}@media only screen and (max-width: 37.5em){.main-banner-carousel .dots-container .dot.active .dot-progress{width:6px;height:6px}}.main-banner-carousel .dots-container .dot:hover:not(.active){border-color:#fffc;transform:scale(1.1)}.main-banner-carousel .dots-container .dot:hover:not(.active) .dot-progress{background:#ffffffe6}.main-banner-carousel .dots-container .dot:disabled{opacity:.5;cursor:not-allowed}.main-banner-carousel .autoplay-indicator{position:absolute;top:2rem;right:2rem;z-index:10}@media only screen and (max-width: 56.25em){.main-banner-carousel .autoplay-indicator{top:1rem;right:1rem}}@media only screen and (max-width: 37.5em){.main-banner-carousel .autoplay-indicator{top:.5rem;right:.5rem}}.main-banner-carousel .autoplay-indicator .autoplay-toggle{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);color:#fff;width:40px;height:40px;border-radius:50%;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:14px;display:flex;align-items:center;justify-content:center}@media only screen and (max-width: 37.5em){.main-banner-carousel .autoplay-indicator .autoplay-toggle{width:35px;height:35px;font-size:12px}}.main-banner-carousel .autoplay-indicator .autoplay-toggle:hover{background:#fff3;transform:scale(1.1)}.main-banner-carousel .autoplay-indicator .autoplay-toggle.playing{color:var(--primary-main)}.main-banner-carousel .autoplay-indicator .autoplay-toggle.paused{color:#ff6b6b}@keyframes slideInNext{0%{opacity:0;transform:translate(100%) scale(1.1)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes slideInPrev{0%{opacity:0;transform:translate(-100%) scale(1.1)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (hover: none) and (pointer: coarse){.main-banner-carousel .nav-arrow:active{background:#ffffff4d}.main-banner-carousel .dot:active{transform:scale(.9)}.main-banner-carousel .cta-button:active{transform:scale(.95)}}@media (prefers-reduced-motion: reduce){.main-banner-carousel .slide,.main-banner-carousel .image,.main-banner-carousel .nav-arrow,.main-banner-carousel .dot,.main-banner-carousel .cta-button{transition:none;animation:none}.main-banner-carousel .content .title,.main-banner-carousel .content .subtitle,.main-banner-carousel .content .cta-button{animation:none;opacity:1;transform:none}}.tooltip-wrapper{position:relative;z-index:40;display:inline-flex;align-items:center;cursor:help;vertical-align:middle}.tooltip{position:absolute;z-index:41;background:#000000e6;color:#fff;padding:.5rem .75rem;border-radius:.375rem;font-size:.875rem;white-space:nowrap;pointer-events:none;opacity:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 15px #0003;transform-origin:center}.tooltip.tooltip--visible{opacity:1}.tooltip:before{content:"";position:absolute;width:0;height:0;border:5px solid transparent}.tooltip--top{bottom:calc(100% + 4px);left:50%;transform:translate(-50%);animation:tooltipFadeInTop .2s ease forwards}.tooltip--top:before{top:100%;left:50%;margin-left:-5px;border-top-color:#000000e6}.tooltip--visible{opacity:1!important;animation:none}.tooltip--bottom{top:calc(100% + 4px);left:50%;transform:translate(-50%);animation:tooltipFadeInBottom .2s ease forwards;white-space:normal;max-width:300px;word-wrap:break-word}.tooltip--bottom:before{bottom:100%;left:50%;margin-left:-5px;border-bottom-color:#000000e6}.tooltip--left{right:calc(100% + 4px);top:50%;animation:tooltipFadeInLeft .2s ease forwards}.tooltip--left:before{left:100%;top:50%;margin-top:-5px;border-left-color:#000000e6}.tooltip--right{left:calc(100% + 4px);top:50%;animation:tooltipFadeInRight .2s ease forwards}.tooltip--right:before{right:100%;top:50%;margin-top:-5px;border-right-color:#000000e6}@keyframes tooltipFadeIn{0%{opacity:0}to{opacity:1}}@keyframes tooltipFadeInTop{0%{opacity:0;transform:translate(-50%) scale(.9)}to{opacity:1;transform:translate(-50%) scale(1)}}@keyframes tooltipFadeInBottom{0%{opacity:0;transform:translate(-50%) scale(.9)}to{opacity:1;transform:translate(-50%) scale(1)}}@keyframes tooltipFadeInLeft{0%{opacity:0;transform:translateY(-50%) scale(.9)}to{opacity:1;transform:translateY(-50%) scale(1)}}@keyframes tooltipFadeInRight{0%{opacity:0;transform:translateY(-50%) scale(.9)}to{opacity:1;transform:translateY(-50%) scale(1)}}@media only screen and (max-width: 37.5em){.tooltip{font-size:.8rem;padding:.4rem .6rem;max-width:200px;white-space:normal;z-index:41!important}.tooltip.tooltip--visible{opacity:1!important;display:block!important;visibility:visible!important}.tooltip-wrapper{position:relative!important;z-index:40!important;overflow:visible!important}}.business-hours-modal{width:100%;padding:0}.business-hours-modal__content{padding:2rem}.business-hours-modal__business-name{font-size:1.5rem;font-weight:700;color:var(--primary-main);margin-bottom:2rem;text-align:center;padding-bottom:1.5rem;border-bottom:2px solid rgba(0,0,0,.1)}.business-hours-modal__hours-list{display:flex;flex-direction:column;gap:.75rem}.business-hours-modal__day{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:#00000005;border-radius:.75rem;border:1px solid rgba(0,0,0,.05);transition:all .2s ease}.business-hours-modal__day:hover{background:#0000000a;border-color:#0000001a}.business-hours-modal__day.today{background:linear-gradient(135deg,#22c55e1a,#16a34a0d);border-color:#22c55e4d;box-shadow:0 2px 8px #22c55e1a}.business-hours-modal__day.today .business-hours-modal__day-name .day-label{font-weight:700;color:#16a34a}.business-hours-modal__day.closed{opacity:.6}.business-hours-modal__day.closed .business-hours-modal__day-hours .closed-text{color:#dc2626;font-weight:600}.business-hours-modal__day-name{display:flex;align-items:center;gap:.75rem;min-width:100px}.business-hours-modal__day-name .day-label{font-size:1rem;font-weight:600;color:var(--primary-main);letter-spacing:.3px}.business-hours-modal__day-name .today-badge{display:inline-flex;align-items:center;padding:.25rem .6rem;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:.5rem;box-shadow:0 2px 4px #22c55e4d}.business-hours-modal__day-hours{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;color:var(--primary-main)}.business-hours-modal__day-hours .separator{color:#0006;margin:0 .25rem}.business-hours-modal__day-hours .closed-text{color:#dc2626;font-weight:600}.business-hours-modal__no-hours{text-align:center;padding:3rem 2rem;color:#0009}.business-hours-modal__no-hours p{font-size:1.1rem;margin:0}.business-hours-modal__loading{display:flex;justify-content:center;align-items:center;padding:3rem 2rem;min-height:200px}@media only screen and (max-width: 37.5em){.business-hours-modal__content{padding:1.5rem}.business-hours-modal__business-name{font-size:1.3rem;margin-bottom:1.5rem}.business-hours-modal__day{padding:.85rem 1rem;flex-direction:column;align-items:flex-start;gap:.5rem}.business-hours-modal__day-name{min-width:auto;width:100%}.business-hours-modal__day-hours{font-size:1rem;width:100%}}:root{--primary-main: #202c4d;--primary-light: #3b82f6;--primary-dark: #1e40af;--secondary-main: #f8fafc;--secondary-light: #ffffff;--secondary-dark: #f1f5f9;--accent-main: #60a5fa;--accent-light: #93c5fd;--accent-dark: #3b82f6;--neutral-white: #ffffff;--neutral-light-gray: #faf8f6;--neutral-gray: #b6b3b1;--neutral-dark-gray: #2c2c2e;--neutral-black: #000000;--status-success: #28a745;--status-warning: #ffc107;--status-error: #dc3545;--status-info: #17a2b8;--text-primary: #000000;--text-secondary: #b6b3b1;--text-muted: #b6b3b1;--text-light: #faf8f6;--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-card: #ffffff;--bg-elevated: #ffffff;--border-light: #b6b3b1;--border-medium: #2c2c2e;--border-dark: #202c4d;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--primary-main-10: rgba(32, 44, 77, .1);--primary-main-20: rgba(32, 44, 77, .2);--primary-main-30: rgba(32, 44, 77, .3);--primary-main-50: rgba(32, 44, 77, .5)}:root.dark,[data-theme=dark]{--primary-main: #60a5fa;--primary-light: #93c5fd;--primary-dark: #3b82f6;--secondary-main: #1e293b;--secondary-light: #0f172a;--secondary-dark: #334155;--accent-main: #60a5fa;--accent-light: #93c5fd;--accent-dark: #3b82f6;--neutral-white: #0f172a;--neutral-light-gray: #1e293b;--neutral-gray: #475569;--neutral-dark-gray: #cbd5e1;--neutral-black: #f8fafc;--status-success: #28a745;--status-warning: #ffc107;--status-error: #dc3545;--status-info: #17a2b8;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #475569;--text-light: #1e293b;--bg-primary: #1e293b;--bg-secondary: #0f172a;--bg-tertiary: #334155;--bg-card: #1e293b;--bg-elevated: #334155;--border-light: rgba(255, 255, 255, .1);--border-medium: rgba(255, 255, 255, .2);--border-dark: rgba(255, 255, 255, .3);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .6);--primary-main-10: rgba(96, 165, 250, .1);--primary-main-20: rgba(96, 165, 250, .2);--primary-main-30: rgba(96, 165, 250, .3);--primary-main-50: rgba(96, 165, 250, .5)}.bg-transparent{background-color:transparent!important}.bg-white{background-color:var(--neutral-white)!important}.bg-white-transp{background-color:#fffc}.bg-light-gray{background-color:var(--secondary-main)!important}.bg-medium-gray{background-color:var(--neutral-gray)!important}.bg-light-blue{background-color:var(--status-info)!important}.bg-blue{background-color:var(--primary-main)!important}.bg-new{background-color:var(--primary-light)!important}.bg-blend{background-color:var(--accent-main)!important}.bg-single{background-color:var(--primary-main)!important}.bg-slow-roasting{background-color:#5f2af299!important}.bg-award{background-color:var(--neutral-gray)!important}.bg-black{background-color:var(--primary-main)!important;color:var(--secondary-main)}.bg-gray{background-color:var(--neutral-gray)!important}.text-white{color:var(--neutral-white)!important}.text-bluesky{color:var(--accent-main)!important}.text-gray{color:var(--neutral-gray)}.text-primary{color:var(--text-primary)!important}.text-secondary{color:var(--text-secondary)!important}.text-muted{color:var(--text-muted)!important}.text-light{color:var(--text-light)!important}.text-success{color:var(--status-success)!important}.text-error{color:var(--status-error)!important}.text-warning{color:var(--status-warning)!important}.text-info{color:var(--status-info)!important}.elegant-product-card{min-width:18rem;height:28rem;background:var(--secondary-main);box-shadow:0 4px 20px #00000014;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;cursor:pointer;display:flex;flex-direction:column;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-user-drag:none;-webkit-touch-callout:none;touch-action:pan-x}.elegant-product-card:hover{transform:none}.elegant-product-card:hover .elegant-product-card__overlay{opacity:0;visibility:hidden}.elegant-product-card:hover .elegant-product-card__image{transform:none}.elegant-product-card:hover .elegant-product-card__badge{transform:translate(100%);opacity:0}.elegant-product-card:hover .elegant-product-card__content{transform:none}.elegant-product-card:active{transform:scale(.98);transition:transform .1s ease}.elegant-product-card__image-container{position:relative;z-index:1;height:50%;background:#f8fafc;border-radius:16px 16px 0 0;flex-shrink:0}.elegant-product-card__intensity-wrapper{position:absolute;top:.5rem;left:50%;transform:translate(-50%);z-index:20;width:100%;height:2px;display:flex;justify-content:center;align-items:center;pointer-events:none}.elegant-product-card__intensity-wrapper .intensity-indicator{display:none!important}.elegant-product-card__intensity-wrapper:before{content:"";position:absolute;left:50%;top:0;transform:translate(-50%);width:40px;height:2px;background:#fff3;border-radius:1px;z-index:1}.elegant-product-card__intensity-wrapper:after{content:"";position:absolute;left:calc(50% - 20px);top:0;width:calc(40px * var(--intensity-percentage, 0) / 100);max-width:40px;height:2px;background:linear-gradient(to right,#fffffff2,#ffffffd9);border-radius:1px;z-index:2;box-shadow:0 0 3px #ffffff80;transition:width .4s cubic-bezier(.4,0,.2,1)}.elegant-product-card__image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;max-height:100%;max-width:100%;position:relative;z-index:1;transition:transform .4s cubic-bezier(.4,0,.2,1);user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-user-drag:none;-webkit-touch-callout:none;pointer-events:none}.elegant-product-card:hover .elegant-product-card__image,.elegant-product-card:active .elegant-product-card__image{pointer-events:auto}.elegant-product-card__overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s ease}.elegant-product-card__quick-view{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#fffffff2;border-radius:25px;color:var(--text-primary);font-weight:600;font-size:14px;border:1px solid rgba(255,255,255,.2);transition:all .2s ease}.elegant-product-card__quick-view:hover{background:#fff;transform:scale(1.05)}.elegant-product-card__content{padding:.875rem .75rem .75rem;display:flex;flex-direction:column;flex:1;position:relative;z-index:10;background:var(--secondary-main);gap:.375rem;justify-content:flex-start;overflow-y:auto;transition:transform .4s cubic-bezier(.4,0,.2,1);backface-visibility:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.elegant-product-card__main-content{display:flex;flex-direction:column;gap:.375rem;flex:1;min-height:0}.elegant-product-card__main-content .product-price{font-size:1rem;font-weight:600;color:var(--primary-main);text-align:center;margin:.25rem 0;padding:0}.elegant-product-card__footer-content{margin-top:auto;padding:.5rem 0 0;border-top:1px solid #e6e9ec;display:flex;flex-direction:column;align-content:center;gap:.25rem}.elegant-product-card__header{display:flex;justify-content:center;align-items:center;margin-bottom:0;gap:8px;text-align:center}.elegant-product-card__title{font-size:1.25rem;font-weight:600;color:#2e3646;text-align:center;line-height:1.4;margin:0;flex:1;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;letter-spacing:-.02em;text-transform:capitalize;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.elegant-product-card__weight{font-size:.875rem;font-weight:500;color:#6b7280;text-align:center;margin:0;opacity:.8;line-height:1.3}.elegant-product-card__footer{margin-top:auto;display:flex;justify-content:center;align-items:center;padding-top:8px}.elegant-product-card__price{font-size:16px;font-weight:600;color:var(--primary-main);text-align:center;padding:.35rem 1.2rem;border-radius:12px;border:1px solid rgba(var(--primary-main),.2)}.elegant-product-card__price.no-price{color:#999;background:#9999991a;border-color:#9993;font-size:14px}.elegant-product-card__details{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.elegant-product-card__roast-info{display:flex;align-items:center;justify-content:center;gap:4px;flex:1}.elegant-product-card__roast-level{font-size:.9rem;font-weight:600;color:#6b7280;text-transform:capitalize;text-align:center;padding:.375rem .75rem;border-radius:16px;background:#6b72800d;border:none;margin:0 auto;width:-moz-fit-content;width:fit-content}.elegant-product-card__intensity{display:flex;align-items:center}.elegant-product-card__badge{position:absolute;top:0;left:0;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;padding:4px 10px;border-radius:0 0 12px 12px;font-size:10px;font-weight:600;display:flex;align-items:center;gap:4px;box-shadow:0 2px 8px #f59e0b4d;transform:translate(100%);opacity:0;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.elegant-product-card__summary{font-size:.7rem;line-height:1.3;color:var(--text-secondary);margin:.25rem 0;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.elegant-product-card__details-row{display:flex;align-items:center;justify-content:center;gap:.5rem;margin:.25rem 0;flex-wrap:wrap;font-size:.7rem}.elegant-product-card__origins{display:flex;align-items:center;justify-content:center;gap:.25rem}.elegant-product-card__origin-flag{font-size:1.5rem;cursor:pointer;transition:transform .2s ease;display:flex;align-items:center;justify-content:center}.elegant-product-card__origin-flag:hover{transform:scale(1.2)}.elegant-product-card__origin-placeholder{font-size:.7rem;color:var(--text-secondary);opacity:.5;font-style:italic}.elegant-product-card__species{font-size:.7rem;color:var(--text-secondary);font-weight:500;text-transform:capitalize}.elegant-product-card__separator{color:var(--text-secondary);opacity:.4;font-size:.7rem}.elegant-product-card__made-in{display:inline-flex;align-items:center;gap:.25rem;font-size:.7rem;color:var(--text-secondary)}.elegant-product-card__made-in svg{width:10px;height:10px;opacity:.7}.elegant-product-card__taste-preview{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;gap:.5rem;margin:.375rem 0;padding:.5rem;background:#00000005;border-radius:.375rem;width:100%;align-items:center}.elegant-product-card__taste-item{display:flex!important;flex-direction:column!important;flex-wrap:nowrap!important;align-items:center;justify-content:flex-start;gap:.25rem;font-size:.65rem;flex:1 1 0;min-width:0}.elegant-product-card__taste-label{font-size:.65rem;font-weight:600;color:var(--text-primary);line-height:1;display:block;flex-shrink:0;text-transform:uppercase;letter-spacing:.025em;white-space:nowrap;text-align:center;width:100%}.elegant-product-card__taste-bar-container{display:flex!important;flex-direction:row!important;align-items:center;justify-content:flex-start;gap:.375rem;width:100%}.elegant-product-card__taste-bar{flex:1 1 auto;height:8px;background:#0000001a;border-radius:2px;overflow:hidden;position:relative;min-width:30px;max-width:100%}.elegant-product-card__taste-fill{height:100%;border-radius:2px;transition:width .3s ease;min-width:2px}.elegant-product-card__taste-fill--sweetness{background:linear-gradient(90deg,#f59e0b,#d97706)}.elegant-product-card__taste-fill--acidity{background:linear-gradient(90deg,#fde047,#facc15)}.elegant-product-card__taste-fill--body{background:linear-gradient(90deg,#92400e,#78350f)}.elegant-product-card__taste-fill--aroma{background:linear-gradient(90deg,#ef4444,#dc2626)}.elegant-product-card__taste-fill--bitterness{background:linear-gradient(90deg,#78350f,#654321)}.elegant-product-card__taste-fill--aftertaste{background:linear-gradient(90deg,#14b8a6,#0d9488)}.elegant-product-card__taste-value{font-weight:700;font-size:.75rem;color:var(--text-primary);line-height:1;flex-shrink:0;min-width:1rem;text-align:center}[data-theme=dark] .elegant-product-card{box-shadow:0 4px 20px #0000004d}[data-theme=dark] .elegant-product-card:hover{box-shadow:0 12px 40px #0006}[data-theme=dark] .elegant-product-card__image-container{background:#1f2937}[data-theme=dark] .elegant-product-card__quick-view{background:#1f2937f2;color:var(--text-primary);border-color:#ffffff1a}[data-theme=dark] .elegant-product-card__quick-view:hover{background:#374151}.product-card{background-color:var(--bg-card);border:1px solid var(--border-light);transition:background-color .3s ease,border-color .3s ease;border-radius:8px;box-shadow:var(--shadow-md);transition:transform .2s ease,box-shadow .2s ease,background-color .3s ease,border-color .3s ease;overflow:hidden;width:18rem!important;min-width:18rem!important;height:26rem}.product-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.product-card__link{text-decoration:none;color:inherit;display:block;height:100%}.product-card__image-container{position:relative;padding-top:100%;overflow:hidden;border-radius:8px 8px 0 0;clip-path:polygon(0 5%,100% 0,100% 95%,0 100%);height:70%}.product-card__image-container img{position:absolute;top:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.product-card__image{-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-user-drag:none;-webkit-touch-callout:none;pointer-events:none}.product-card__intensity-indicator{display:none}.product-card--skeleton{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;background:var(--secondary-main);min-height:28rem}.skeleton-product-card .skelaton{border-radius:16px;background-color:#e5e7eb;margin-bottom:0}.skeleton-product-card__image-container--skeleton{position:relative;overflow:hidden;background:#f8fafc}.skeleton-product-card__image-container--skeleton .skeleton-image{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:16px 16px 0 0;z-index:1}.skeleton-product-card__image-container--skeleton .skeleton-intensity-bar{position:absolute;top:.5rem;left:50%;transform:translate(-50%);width:40px;height:2px;background:#ffffff80;border-radius:1px;z-index:20;box-shadow:0 0 2px #0000001a}.skeleton-product-card__image-container--skeleton .skeleton-price{position:absolute;right:.5rem;bottom:.5rem;width:60px;height:24px;background:#fffffff2;border-radius:4px;animation:skeleton-shimmer 1.5s infinite;z-index:10;box-shadow:0 2px 4px #0000001a}.skeleton-product-card__intensity-wrapper--skeleton{pointer-events:none}.skeleton-product-card__content--skeleton{background:var(--secondary-main)!important}.skeleton-product-card__content--skeleton .skeleton-title{width:80%;height:1.25rem;background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:4px;margin-bottom:.5rem;display:block}.skeleton-product-card__content--skeleton .skeleton-summary{width:100%;height:.875rem;background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:4px;margin-bottom:.375rem;display:block}.skeleton-product-card__content--skeleton .skeleton-details-row{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.375rem}.skeleton-product-card__content--skeleton .skeleton-details-row .skeleton-origin{width:30px;height:20px;background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:4px;display:block}.skeleton-product-card__content--skeleton .skeleton-details-row .skeleton-separator{width:4px;height:4px;background:#d1d5db;border-radius:50%;display:block}.skeleton-product-card__content--skeleton .skeleton-details-row .skeleton-species{width:60px;height:14px;background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:4px;display:block}.skeleton-product-card__content--skeleton .skeleton-taste-preview{display:flex;gap:.5rem;margin-top:.5rem}.skeleton-product-card__content--skeleton .skeleton-taste-preview .skeleton-taste-item{flex:1;height:40px;background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:4px;display:block}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-product-card__content{height:5rem;padding:1rem!important;gap:.3rem;display:flex;flex-direction:column;position:absolute;bottom:0;left:0;right:0;font-weight:600;background:linear-gradient(to top,#1c324bf2,#1c324bb3,#1c324b4d);z-index:10;clip-path:polygon(0 15%,100% 0,100% 100%,0 100%);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);transition:height .3s ease}.skeleton-product-card__content:hover{height:8rem}.skeleton-product-card__content:hover .product-card__intensity-indicator{display:block}.skeleton-product-card__title{margin-bottom:.5rem;color:var(--text-primary);transition:color .3s ease;color:var(--secondary-main)!important;font-weight:600!important;font-size:1.4rem!important;-webkit-text-stroke:.1px var(--primary-dark);margin-bottom:0!important;text-align:center;letter-spacing:.05rem!important;line-height:1.2}.skeleton-product-card__details{flex-direction:column;gap:.5rem;color:var(--text-secondary);transition:color .3s ease;display:flex;text-align:center;justify-content:space-between;font-size:1.4rem!important}.skeleton-product-card__roast-level{gap:.15rem}.idle-timeout-notification{position:fixed;top:20px;right:20px;z-index:1000;max-width:400px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideInRight .3s ease-out;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.idle-timeout-notification__content{display:flex;align-items:flex-start;padding:16px;gap:12px}.idle-timeout-notification__icon{font-size:20px;flex-shrink:0;margin-top:2px}.idle-timeout-notification__text{flex:1;min-width:0}.idle-timeout-notification__title{font-weight:600;font-size:14px;color:#333;margin-bottom:4px}.idle-timeout-notification__message{font-size:13px;color:#666;line-height:1.4}.idle-timeout-notification__actions{display:flex;gap:8px;flex-shrink:0}.idle-timeout-notification__refresh-btn,.idle-timeout-notification__dismiss-btn{background:none;border:none;padding:6px;border-radius:4px;cursor:pointer;font-size:16px;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;height:32px}.idle-timeout-notification__refresh-btn:hover,.idle-timeout-notification__dismiss-btn:hover{background-color:#f5f5f5}.idle-timeout-notification__refresh-btn:active,.idle-timeout-notification__dismiss-btn:active{background-color:#e0e0e0}.idle-timeout-notification__refresh-btn:hover{background-color:#e3f2fd}.idle-timeout-notification__dismiss-btn:hover{background-color:#ffebee}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (prefers-color-scheme: dark){.idle-timeout-notification{background:#2d2d2d;border-color:#404040;color:#fff}.idle-timeout-notification__title{color:#fff}.idle-timeout-notification__message{color:#ccc}.idle-timeout-notification__refresh-btn:hover,.idle-timeout-notification__dismiss-btn:hover{background-color:#404040}.idle-timeout-notification__refresh-btn:hover{background-color:#1e3a5f}.idle-timeout-notification__dismiss-btn:hover{background-color:#5d1a1a}}@media (max-width: 480px){.idle-timeout-notification{top:10px;right:10px;left:10px;max-width:none}.idle-timeout-notification__content{padding:12px}.idle-timeout-notification__message{font-size:12px}}
