.leaflet-image-layer,.leaflet-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane,.leaflet-pane>canvas,.leaflet-pane>svg,.leaflet-tile,.leaflet-tile-container,.leaflet-zoom-box{left:0;position:absolute;top:0}.leaflet-container{overflow:hidden}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile{-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.leaflet-tile::selection{background:#0000}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{height:1600px;-webkit-transform-origin:0 0;width:1600px}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-height:none!important;max-width:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer{max-height:none!important;max-width:none!important;padding:0;width:auto}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{box-sizing:border-box;height:0;width:0;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{height:1px;width:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{pointer-events:visiblePainted;pointer-events:auto;position:relative;z-index:800}.leaflet-bottom,.leaflet-top{pointer-events:none;position:absolute;z-index:1000}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{clear:both;float:left}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-pan-anim .leaflet-tile,.leaflet-zoom-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-control,.leaflet-popup-pane{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:grabbing}.leaflet-image-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-image-layer.leaflet-interactive,.leaflet-marker-icon.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{background:#ffffff80;border:2px dotted #38f}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{border-radius:4px;box-shadow:0 1px 5px #000000a6}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;color:#000;display:block;height:26px;line-height:26px;text-align:center;text-decoration:none;width:26px}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:focus,.leaflet-bar a:hover{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom:none;border-bottom-left-radius:4px;border-bottom-right-radius:4px}.leaflet-bar a.leaflet-disabled{background-color:#f4f4f4;color:#bbb;cursor:default}.leaflet-touch .leaflet-bar a{height:30px;line-height:30px;width:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{background:#fff;border-radius:5px;box-shadow:0 1px 5px #0006}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);height:36px;width:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{height:44px;width:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{background:#fff;color:#333;padding:6px 10px 6px 6px}.leaflet-control-layers-scrollbar{overflow-x:hidden;overflow-y:scroll;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{border-top:1px solid #ddd;height:0;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{color:#333;line-height:1.4;padding:0 5px}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:focus,.leaflet-control-attribution a:hover{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;height:.6669em;vertical-align:initial!important;width:1em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{background:#fffc;border:2px solid #777;border-top:none;box-sizing:border-box;line-height:1.1;padding:2px 5px 1px;text-shadow:1px 1px #fff;white-space:nowrap}.leaflet-control-scale-line:not(:first-child){border-bottom:none;border-top:2px solid #777;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers{box-shadow:none}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-layers{background-clip:padding-box;border:2px solid #0003}.leaflet-popup{margin-bottom:20px;position:absolute;text-align:center}.leaflet-popup-content-wrapper{border-radius:12px;padding:1px;text-align:left}.leaflet-popup-content{font-size:13px;font-size:1.08333em;line-height:1.3;margin:13px 24px 13px 20px;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{height:20px;left:50%;margin-left:-20px;margin-top:-1px;overflow:hidden;pointer-events:none;position:absolute;width:40px}.leaflet-popup-tip{height:17px;margin:-10px auto 0;padding:1px;pointer-events:auto;transform:rotate(45deg);width:17px}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;box-shadow:0 3px 14px #0006;color:#333}.leaflet-container a.leaflet-popup-close-button{background:#0000;border:none;color:#757575;font:16px/24px Tahoma,Verdana,sans-serif;height:24px;position:absolute;right:0;text-align:center;text-decoration:none;top:0;width:24px}.leaflet-container a.leaflet-popup-close-button:focus,.leaflet-container a.leaflet-popup-close-button:hover{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678,M12=0.70710678,M21=-0.70710678,M22=0.70710678);margin:0 auto;width:24px}.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{background-color:#fff;border:1px solid #fff;border-radius:3px;box-shadow:0 1px 3px #0006;color:#222;padding:6px;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;white-space:nowrap}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before,.leaflet-tooltip-top:before{background:#0000;border:6px solid #0000;content:"";pointer-events:none;position:absolute}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{border-top-color:#fff;bottom:0;margin-bottom:-12px}.leaflet-tooltip-bottom:before{border-bottom-color:#fff;margin-left:-6px;margin-top:-12px;top:0}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{margin-top:-6px;top:50%}.leaflet-tooltip-left:before{border-left-color:#fff;margin-right:-12px;right:0}.leaflet-tooltip-right:before{border-right-color:#fff;left:0;margin-left:-12px}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}:root{--font-title:"LuckyFellasUpright",cursive;--font-body:"GillSansMT",sans-serif;--font-special:"Aurora",sans-serif;--chocolate-brown:#31231f;--dark-chocolate:#2a1a0e;--antique-gold:#c39616;--darker-gold:#b8941f;--cream:#bdac92;--light-cream:#faf7f0;--black:#000;--white:#fff;--text-muted:#8b7355;--shadow-color:#31231f33;--primary-navy:var(--antique-gold);--secondary-navy:var(--chocolate-brown);--accent-gold:var(--antique-gold);--accent-orange:var(--antique-gold);--warm-beige:var(--cream);--text-light:var(--cream);--text-dark:var(--antique-gold);--background-dark:var(--chocolate-brown);--background-medium:var(--chocolate-brown);--background-light:var(--cream);--border-color:var(--antique-gold);--hover-gold:var(--darker-gold);--card-bg:var(--chocolate-brown);--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:50%;--shadow-sm:0 1px 2px #0000001a;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 15px #0000001a;--shadow-xl:0 20px 25px #00000026;--transition-fast:0.15s ease;--transition-normal:0.3s ease;--transition-slow:0.5s ease;--z-dropdown:100;--z-sticky:200;--z-modal:1000;--z-toast:2000;--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1200px}@font-face{font-family:LuckyFellasUpright;font-style:normal;font-weight:400;src:url(/static/media/LuckyFellasUpright.5502788bb1170762532d.otf) format("opentype")}*{box-sizing:border-box}body,html{background-color:var(--light-cream)}body{font-size:16px;line-height:1.6;margin:0}body,h1,h2,h3,h4,h5,h6{color:var(--chocolate-brown)}h1,h2,h3,h4,h5,h6{font-family:var(--font-title);line-height:1.2;margin:0 0 var(--spacing-md) 0}h1{font-size:3rem}h2{font-size:2.25rem}h3{font-size:1.875rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{color:var(--chocolate-brown);margin:0 0 var(--spacing-md) 0}a{color:var(--antique-gold);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--darker-gold)}ol,ul{margin:0 0 var(--spacing-md) 0;padding-left:var(--spacing-lg)}li,ol,ul{color:var(--chocolate-brown)}li{margin-bottom:var(--spacing-xs)}img{height:auto;max-width:100%}code{background-color:var(--cream);border-radius:var(--radius-sm);color:var(--chocolate-brown);font-family:Courier New,monospace;font-size:.875rem;padding:var(--spacing-xs) var(--spacing-sm)}table{border-collapse:collapse;margin-bottom:var(--spacing-md);width:100%}td,th{border-bottom:1px solid var(--cream);color:var(--chocolate-brown);padding:var(--spacing-sm);text-align:left}th{background-color:var(--light-cream);font-weight:600}input,select,textarea{color:var(--chocolate-brown)}input::placeholder,textarea::placeholder{color:var(--text-muted)}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid var(--antique-gold);outline-offset:2px}.dark-bg{background-color:var(--chocolate-brown)}.dark-bg,.dark-bg h1,.dark-bg h2,.dark-bg h3,.dark-bg h4,.dark-bg h5,.dark-bg h6,.dark-bg li,.dark-bg p{color:var(--white)}.light-bg{background-color:var(--white)}.light-bg,.light-bg h1,.light-bg h2,.light-bg h3,.light-bg h4,.light-bg h5,.light-bg h6,.light-bg li,.light-bg p{color:var(--chocolate-brown)}@media (max-width:768px){body{font-size:14px}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}}@media (max-width:480px){h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.25rem}}.loading-spinner{border-radius:var(--radius-full);border-top:3px solid var(--antique-gold);margin:0 auto}.loading-spinner.small{border-width:2px;height:20px;width:20px}.loading-spinner.medium{border-width:3px;height:32px;width:32px}.loading-spinner.large{border-width:4px;height:48px;width:48px}.loading-spinner.extra-large{border-width:4px;height:60px;width:60px}.loading-spinner.primary{border-top-color:var(--antique-gold)}.loading-spinner.secondary{border-top-color:var(--chocolate-brown)}.btn{align-items:center;border:none;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);cursor:pointer;display:inline-flex;font-family:var(--font-body);font-size:1rem;font-weight:500;justify-content:center;min-height:44px;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;transition:all var(--transition-normal)}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:linear-gradient(135deg,var(--antique-gold),var(--darker-gold));color:var(--white)}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-lg)}.btn-secondary{background:var(--cream);border:1px solid var(--antique-gold);color:var(--chocolate-brown)}.btn-secondary:hover:not(:disabled){background:var(--antique-gold);color:var(--white)}.btn-danger{background:#dc3545;color:var(--white)}.btn-danger:hover:not(:disabled){background:#c82333;transform:translateY(-1px)}.btn-small{font-size:.875rem;min-height:36px;padding:var(--spacing-xs) var(--spacing-sm)}.btn-large{font-size:1.125rem;min-height:52px;padding:var(--spacing-md) var(--spacing-lg)}.card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;transition:box-shadow var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg)}.card-header{background:var(--light-cream);border-bottom:1px solid #e2e8f0}.card-body,.card-footer,.card-header{padding:var(--spacing-lg)}.card-footer{background:var(--light-cream);border-top:1px solid #e2e8f0}.form-group{margin-bottom:var(--spacing-md)}.form-label{color:var(--chocolate-brown);display:block;font-weight:500;margin-bottom:var(--spacing-sm)}.form-input,.form-select,.form-textarea{border:1px solid #d1d5db;border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;padding:var(--spacing-sm) var(--spacing-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--antique-gold);box-shadow:0 0 0 3px #c396161a;outline:none}.form-textarea{min-height:100px;resize:vertical}.modal-backdrop{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:var(--spacing-lg);position:fixed;right:0;top:0;z-index:var(--z-modal)}.modal-content{background-color:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:95vh;max-width:90vw;overflow:hidden;position:relative}.modal-header{border-bottom:1px solid #e2e8f0;padding:var(--spacing-lg)}.modal-body{flex:1 1;overflow-y:auto;padding:var(--spacing-lg)}.modal-close{color:var(--text-muted);padding:var(--spacing-sm);transition:color var(--transition-fast)}.modal-close:hover{color:var(--chocolate-brown)}.modal-small .modal-content{width:400px}.modal-medium .modal-content{width:600px}.modal-large .modal-content{width:800px}.modal-xlarge .modal-content{width:1200px}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-primary{color:var(--antique-gold)}.text-danger{color:#dc3545}.text-success{color:#28a745}.m-0{margin:0}.m-1{margin:var(--spacing-sm)}.m-2{margin:var(--spacing-md)}.m-3{margin:var(--spacing-lg)}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.p-0{padding:0}.p-1{padding:var(--spacing-sm)}.p-2{padding:var(--spacing-md)}.p-3{padding:var(--spacing-lg)}.d-none{display:none}.d-block{display:block}.d-flex{display:flex}.d-grid{display:grid}@media (max-width:768px){.modal-content{margin:var(--spacing-sm);width:95vw!important}.btn{margin-bottom:var(--spacing-sm);width:100%}.d-md-none{display:none}.d-md-block{display:block}}@media (max-width:480px){.modal-backdrop{padding:var(--spacing-sm)}.card{border-radius:var(--radius-md)}}.wine-comparison-container{background:var(--white);margin:0 auto;max-width:1200px;min-height:100vh;padding:var(--spacing-xl)}.comparison-header{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg)}.comparison-header h1{color:var(--chocolate-brown);margin-bottom:var(--spacing-md)}.comparison-header p{color:var(--text-muted)}.back-button{margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.wine-comparison-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.wine-slot{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:200px}.wine-selection-section,.wine-slot.filled{box-shadow:var(--shadow-md)}.wine-selection-section{background:var(--white);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);padding:var(--spacing-xl)}.selection-controls{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:space-between;margin-bottom:var(--spacing-lg)}.selection-controls h2{color:var(--chocolate-brown);margin:0}.control-buttons{gap:var(--spacing-md)}.wine-selection-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.wine-selector-card{background:var(--light-cream);border:1px solid #e2e8f0;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-lg)}.selector-header{align-items:center;margin-bottom:var(--spacing-md)}.selector-header h3{color:var(--chocolate-brown);font-size:1.25rem;margin:0}.selector-header button{background:#dc3545;border:none;border-radius:var(--radius-full);color:var(--white);cursor:pointer;font-size:1rem;height:24px;width:24px}.wine-select{border:1px solid #d1d5db;color:var(--chocolate-brown);font-size:1rem;margin-bottom:var(--spacing-md);padding:var(--spacing-sm);width:100%}.selected-wine-preview,.wine-select{background:var(--white);border-radius:var(--radius-md)}.selected-wine-preview{margin-top:var(--spacing-md);padding:var(--spacing-md)}.wine-basic-info h4{color:var(--chocolate-brown);font-size:1.1rem;margin:var(--spacing-sm) 0}.wine-basic-info p{color:var(--text-muted);font-size:.95rem;margin:var(--spacing-xs) 0}.comparison-results{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-xl)}.comparison-results h2{color:var(--chocolate-brown);font-size:2rem;margin-bottom:var(--spacing-xl);text-align:center}.overall-comparison{background:var(--light-cream);border-left:4px solid var(--antique-gold);border-radius:var(--radius-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg)}.overall-comparison h3{color:var(--chocolate-brown);margin-bottom:var(--spacing-md)}.overall-comparison p{color:var(--chocolate-brown);font-size:1.1rem;line-height:1.6;margin:0}.wine-profiles h3{color:var(--chocolate-brown);font-size:1.75rem;margin-bottom:var(--spacing-lg);text-align:center}.profiles-grid{grid-gap:var(--spacing-xl);display:grid;gap:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.wine-profile-card{background:var(--white);border:2px solid var(--cream);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg)}.wine-profile-card h4{border-bottom:2px solid var(--cream);color:var(--antique-gold);font-size:1.5rem;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm);text-align:center}.wine-profile-card h5{border-left:3px solid var(--antique-gold);color:var(--chocolate-brown);font-size:1.25rem;margin:var(--spacing-lg) 0 var(--spacing-md) 0;padding-left:var(--spacing-sm)}.detailed-tasting-notes,.food-pairings,.serving-recommendations,.tasting-profile,.value-assessment{margin-bottom:var(--spacing-lg)}.profile-grid{grid-gap:var(--spacing-sm);display:grid;gap:var(--spacing-sm);grid-template-columns:1fr 1fr;margin-top:var(--spacing-sm)}.profile-grid div{background:var(--light-cream);border-radius:var(--radius-sm);color:var(--chocolate-brown);font-size:.95rem;padding:var(--spacing-sm)}.detailed-tasting-notes p{color:var(--chocolate-brown);line-height:1.5;margin:var(--spacing-sm) 0}.pairings-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.pairing-tag{background:var(--antique-gold);border-radius:var(--radius-sm);color:var(--white);font-size:.9rem;padding:var(--spacing-xs) var(--spacing-sm)}.serving-recommendations p{border-radius:var(--radius-sm);margin:var(--spacing-sm) 0;padding:var(--spacing-sm)}.serving-recommendations p,.value-assessment p{background:var(--light-cream);color:var(--chocolate-brown)}.value-assessment p{border-left:3px solid var(--antique-gold);border-radius:var(--radius-md);font-style:italic;margin:0;padding:var(--spacing-md)}.head-to-head{background:var(--light-cream);border-radius:var(--radius-lg);margin:var(--spacing-xl) 0;padding:var(--spacing-xl)}.head-to-head h3{color:var(--chocolate-brown);font-size:1.75rem;margin-bottom:var(--spacing-lg);text-align:center}.comparison-categories{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg)}.comparison-category{background:var(--white);border-left:4px solid var(--antique-gold);border-radius:var(--radius-md);padding:var(--spacing-lg)}.comparison-category h4{color:var(--chocolate-brown);margin-bottom:var(--spacing-md);text-transform:capitalize}.comparison-category p{color:var(--chocolate-brown);line-height:1.6;margin:0}.recommendations{background:var(--white);border:2px solid var(--antique-gold);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.recommendations h3{color:var(--chocolate-brown);font-size:1.75rem;margin-bottom:var(--spacing-lg);text-align:center}.recommendations-grid{grid-gap:var(--spacing-lg);gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.recommendation-card{background:var(--light-cream);border:1px solid var(--cream);border-radius:var(--radius-md);padding:var(--spacing-lg);text-align:center}.recommendation-card h4{color:var(--antique-gold);font-size:1.1rem;margin-bottom:var(--spacing-md);text-transform:capitalize}.recommendation-card p{color:var(--chocolate-brown);font-weight:500;margin:0}.error-banner{background:#fee;border:1px solid #feb2b2;border-radius:var(--radius-md);color:#c53030;justify-content:space-between;margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.error-banner button{background:none;border:none;color:#c53030;cursor:pointer;font-size:1.2rem}.comparison-loading,.loading-state{background:var(--white);border-radius:var(--radius-lg);margin:var(--spacing-xl) 0;padding:var(--spacing-2xl);text-align:center}.loading-content h3{color:var(--chocolate-brown);margin:var(--spacing-lg) 0 var(--spacing-md) 0}.loading-content p{color:var(--text-muted);margin:0}.empty-state{background:var(--light-cream);border-radius:var(--radius-lg);margin:var(--spacing-xl) 0;padding:var(--spacing-2xl)}.empty-content h3{color:var(--chocolate-brown);margin-bottom:var(--spacing-md)}.empty-content p{color:var(--text-muted);margin-bottom:var(--spacing-lg)}.wine-image-admin{background:var(--light-cream);margin:0 auto;max-width:1400px;min-height:100vh;padding:var(--spacing-xl)}.admin-controls{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg)}.filter-controls{grid-gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-controls,.stats-grid{display:grid;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stats-grid{grid-gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card{background:var(--light-cream);border-radius:var(--radius-md);padding:var(--spacing-md);text-align:center}.stat-number{color:var(--antique-gold);font-size:2rem;font-weight:600}.stat-label{color:var(--text-muted);font-size:.875rem}.wines-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.wine-admin-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg);transition:transform var(--transition-normal)}.wine-admin-card:hover{transform:translateY(-2px)}.wine-admin-image{background:#f8f9fa;border-radius:var(--radius-md);height:200px;margin-bottom:var(--spacing-md);object-fit:contain;width:100%}.image-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.drink-detail-page{background:var(--light-cream);color:var(--chocolate-brown);min-height:100vh}.drink-detail-container{overflow:hidden}.drink-header{background:linear-gradient(135deg,var(--chocolate-brown),var(--dark-chocolate));color:var(--white);padding:var(--spacing-2xl);position:relative;text-align:center}.drink-header h1{color:var(--white);font-size:2.5rem;font-weight:700;margin-bottom:var(--spacing-md);text-shadow:2px 2px 4px #0000004d}.drink-subtitle{color:var(--cream);font-size:1.25rem;margin-bottom:var(--spacing-lg);opacity:.9}.drink-price-section{align-items:center;display:flex;gap:var(--spacing-lg);justify-content:center;margin-top:var(--spacing-lg)}.drink-price{font-size:2rem;font-weight:700;text-shadow:1px 1px 2px #0003}.drink-bin{color:var(--cream);font-size:1rem;opacity:.8}.drink-content{background:var(--white);padding:var(--spacing-2xl)}.drink-info-grid{grid-gap:var(--spacing-2xl);display:grid;gap:var(--spacing-2xl);grid-template-columns:1fr 2fr;margin-bottom:var(--spacing-2xl)}@media (max-width:768px){.drink-info-grid{gap:var(--spacing-lg);grid-template-columns:1fr}}.info-card{background:var(--light-cream);border:1px solid var(--cream);border-left:4px solid var(--antique-gold);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.wine-details-section h3{border-bottom:2px solid var(--cream);color:var(--chocolate-brown);font-size:1.5rem;font-weight:600;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm)}.info-grid{grid-gap:var(--spacing-md);gap:var(--spacing-md)}.info-item{border-bottom:1px solid var(--cream);padding:var(--spacing-sm) 0}.info-item:last-child{border-bottom:none}.info-label{color:var(--text-muted);font-weight:500}.info-value{color:var(--chocolate-brown);font-weight:600;text-align:right}.wine-detail-container{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl)}.wine-detail-container .tasting-section:first-child{margin-bottom:var(--spacing-xl)}.wine-detail-container .tasting-section{margin-bottom:var(--spacing-lg);min-height:400px}.wine-detail-container .tasting-section:first-child .rating-distribution{background:var(--light-cream);border:1px solid var(--cream);border-radius:var(--radius-md);margin-top:var(--spacing-lg);padding:var(--spacing-lg)}.wine-detail-container .individual-ratings{border-top:2px solid var(--cream);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg)}.varietals-grid{grid-gap:var(--spacing-md);background:var(--light-cream);border:1px solid var(--cream);border-radius:var(--radius-md);display:grid;gap:var(--spacing-md);padding:var(--spacing-lg)}.varietal-item{background:var(--white);border-left:3px solid var(--antique-gold);border-radius:var(--radius-sm);padding:var(--spacing-md)}.varietal-info{align-items:center;display:flex;justify-content:space-between}.varietal-percentage{color:var(--antique-gold);font-size:1.1rem;font-weight:700}.varietal-name{color:var(--chocolate-brown);font-weight:500}.winery-location-section{background:var(--white);border:2px solid var(--antique-gold);border-radius:var(--radius-lg);margin:var(--spacing-xl) 0;padding:var(--spacing-xl);text-align:center}.winery-location-section h3{align-items:center;color:var(--chocolate-brown);display:flex;font-size:1.75rem;gap:var(--spacing-sm);justify-content:center;margin-bottom:var(--spacing-lg)}.location-info{font-size:1.1rem}.location-enhancement{font-size:1rem}.map-placeholder{border:2px dashed var(--cream);border-radius:var(--radius-md);margin-top:var(--spacing-lg)}.map-placeholder,.producer-section{background:var(--light-cream);padding:var(--spacing-xl)}.producer-section{border-radius:var(--radius-lg);margin:var(--spacing-xl) 0}.producer-section h3{color:var(--chocolate-brown);font-size:1.5rem;margin-bottom:var(--spacing-lg);text-align:center}.producer-info{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.producer-detail{background:var(--white);border-left:3px solid var(--antique-gold);border-radius:var(--radius-md);padding:var(--spacing-md)}.producer-detail strong{color:var(--chocolate-brown);display:block;margin-bottom:var(--spacing-xs)}.producer-detail span{color:var(--antique-gold);font-weight:500}.tasting-section h3,.tasting-section h4{align-items:center;border-bottom:2px solid var(--cream);color:var(--chocolate-brown);display:flex;font-size:1.25rem;font-weight:600;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm)}.tasting-content{border-left:4px solid var(--antique-gold);font-size:1.05rem;line-height:1.7;margin:0;padding:var(--spacing-lg)}.tasting-notes-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg)}.tasting-note-card{background:var(--white);border:1px solid var(--cream);border-left:4px solid var(--antique-gold);border-radius:var(--radius-md);padding:var(--spacing-lg)}.tasting-note-card h4{align-items:center;border-bottom:1px solid var(--cream);color:var(--chocolate-brown);display:flex;font-size:1.1rem;font-weight:600;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm)}.vintage-info{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg)}.vintage-detail{background:var(--light-cream);border-left:3px solid var(--antique-gold);border-radius:var(--radius-md);padding:var(--spacing-lg)}.vintage-detail h4{color:var(--chocolate-brown);font-size:1.1rem;font-weight:600;margin-bottom:var(--spacing-md)}.back-button{align-items:center;background:var(--cream);border:1px solid var(--antique-gold);border-radius:var(--radius-md);color:var(--chocolate-brown);display:inline-flex;font-weight:500;gap:var(--spacing-sm);left:var(--spacing-lg);margin-bottom:var(--spacing-lg);padding:var(--spacing-sm) var(--spacing-lg);position:absolute;top:var(--spacing-lg);transition:all var(--transition-normal)}.back-button:hover{background:var(--antique-gold);color:var(--white);transform:translateX(-2px)}.skip-link{background:var(--chocolate-brown);color:var(--white)}.loading-state{color:var(--chocolate-brown);flex-direction:column;gap:var(--spacing-lg);min-height:50vh}.loading-spinner{border-top:3px solid var(--cream);border:3px solid var(--cream);border-top-color:var(--antique-gold)}.error-state{color:var(--chocolate-brown);flex-direction:column;gap:var(--spacing-lg);justify-content:center;min-height:50vh}.error-icon{font-size:4rem;opacity:.7}.error-state h2{color:var(--chocolate-brown);font-size:2rem;font-weight:700;margin:0}.error-state p{color:var(--text-muted);font-size:1.1rem;margin:0}.ai-enhancement-notice{background:linear-gradient(135deg,var(--light-cream),var(--cream));border:1px solid var(--antique-gold);border-radius:var(--radius-lg);margin-top:var(--spacing-xl);padding:var(--spacing-lg)}.ai-notice-content{align-items:center;color:var(--chocolate-brown);display:flex;font-size:.9rem;font-style:italic;gap:var(--spacing-sm)}.food-pairings-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.food-pairing-card{background:var(--light-cream);border:1px solid var(--cream);border-left:3px solid var(--antique-gold);border-radius:var(--radius-md);padding:var(--spacing-md)}.food-pairing-content{align-items:flex-start;display:flex;gap:var(--spacing-sm)}.food-pairing-icon{color:var(--antique-gold);flex-shrink:0;font-size:1.2rem}.food-pairing-text{color:var(--chocolate-brown);font-weight:500;line-height:1.4}.cellaring-info{background:var(--light-cream);border-left:4px solid var(--antique-gold);border-radius:var(--radius-md);padding:var(--spacing-lg)}.location-placeholder{margin:var(--spacing-lg) 0}.location-notice{background:var(--light-cream);border:2px dashed var(--cream);border-radius:var(--radius-md);padding:var(--spacing-lg);text-align:center}.location-icon{color:var(--antique-gold);font-weight:600}.location-icon,.location-text{margin-bottom:var(--spacing-sm)}.location-text{color:var(--chocolate-brown);font-size:.9rem}.location-note{color:var(--text-muted);font-size:.8rem;font-style:italic}.landing-container{background:linear-gradient(135deg,var(--chocolate-brown),var(--dark-chocolate));min-height:100vh}.features-grid{grid-gap:var(--spacing-xl);gap:var(--spacing-xl);margin:0 auto;max-width:1200px;padding:var(--spacing-xl)}.feature-card{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--spacing-xl);transition:transform var(--transition-normal)}.feature-card:hover{transform:translateY(-4px)}.feature-icon{margin-bottom:var(--spacing-lg)}.feature-title{color:var(--chocolate-brown);margin-bottom:var(--spacing-md)}.feature-description{color:var(--text-muted);line-height:1.6}.api-integration-dashboard{margin:0 auto;max-width:1000px;padding:var(--spacing-lg)}.integration-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg)}.integration-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg)}.integration-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.integration-status{border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;padding:var(--spacing-xs) var(--spacing-sm)}.status-active{background:#d4edda;color:#155724}.status-inactive{background:#f8d7da;color:#721c24}.status-pending{background:#fff3cd;color:#856404}.phase-dashboard{margin:0 auto;max-width:1200px;padding:var(--spacing-xl)}.phase-header{margin-bottom:var(--spacing-xl);text-align:center}.phase-title{color:var(--chocolate-brown);font-size:2.5rem;margin-bottom:var(--spacing-md)}.phase-description{color:var(--text-muted);font-size:1.25rem;margin:0 auto;max-width:600px}.phase-sections{grid-gap:var(--spacing-xl);display:grid;gap:var(--spacing-xl)}.phase-section{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl)}.section-title{color:var(--chocolate-brown);font-size:1.5rem;margin-bottom:var(--spacing-lg)}@media (max-width:768px){.filter-controls,.wine-comparison-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.wines-grid{grid-template-columns:1fr}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.25rem}.features-grid{grid-template-columns:1fr;padding:var(--spacing-lg)}}@media (max-width:480px){.phase-dashboard,.wine-comparison-container,.wine-image-admin{padding:var(--spacing-md)}.hero-title,.phase-title{font-size:2rem}.stats-grid{grid-template-columns:1fr}}.lwin-info{background:linear-gradient(135deg,#f8f4e6,#ede4d0);border:1px solid var(--antique-gold);border-radius:var(--radius-md);margin-top:var(--spacing-sm);padding:var(--spacing-md);position:relative}.lwin-info:before{content:"🏷️";font-size:1.2rem;position:absolute;right:var(--spacing-sm);top:var(--spacing-sm)}.lwin-info .info-label{color:var(--chocolate-brown);font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.lwin-info .info-value{color:var(--text-primary);font-family:Courier New,monospace;font-weight:500;word-break:break-all}.lwin-confidence{background:var(--antique-gold);border-radius:var(--radius-sm);color:var(--white);display:inline-block;font-size:.75rem;font-weight:500;margin-left:var(--spacing-sm);padding:2px 8px}.lwin-sources{border-top:1px solid var(--border-light);margin-top:var(--spacing-xs);padding-top:var(--spacing-xs)}.lwin-sources small{color:var(--text-muted);font-style:italic}.ai-enhancement-notice .ai-notice-content{align-items:center;background:linear-gradient(135deg,#e8f4f8,#d6e8f0);border:1px solid #a3d5e8;border-radius:var(--radius-md);color:var(--text-muted);display:flex;font-size:.9rem;gap:var(--spacing-sm);margin-top:var(--spacing-lg);padding:var(--spacing-md)}.ai-enhancement-notice .ai-notice-content span[aria-hidden=true]{font-size:1.2rem}.wine-label-container .image-attribution{background:#ffffffe6;border-radius:var(--radius-sm);color:var(--text-muted);font-size:.8rem;margin-top:var(--spacing-xs);padding:var(--spacing-xs);text-align:center}.wine-label-container .image-source-lwin{color:var(--antique-gold);font-weight:600}.wine-label-container .image-source-ai{color:var(--chocolate-brown)}.container{max-width:var(--breakpoint-xl);padding:0 var(--spacing-lg)}.container-fluid{padding:0 var(--spacing-lg);width:100%}.container-sm{margin:0 auto;max-width:var(--breakpoint-sm)}.container-md{margin:0 auto;max-width:var(--breakpoint-md)}.container-lg{margin:0 auto;max-width:var(--breakpoint-lg)}.container-xl{margin:0 auto;max-width:var(--breakpoint-xl)}.grid{grid-gap:var(--spacing-md);gap:var(--spacing-md)}.grid-1{grid-template-columns:1fr}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-auto{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.flex-column{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1 1}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-around{justify-content:space-around}.align-start{align-items:flex-start}.align-center{align-items:center}.align-end{align-items:flex-end}.align-stretch{align-items:stretch}.admin-dashboard{margin:0 auto;max-width:1200px;padding:var(--spacing-xl)}.admin-dashboard h1{color:var(--chocolate-brown);font-size:2.5rem;margin-bottom:var(--spacing-xl);text-align:center}.logout-button{background:#dc3545;border-radius:var(--radius-md);color:var(--white);padding:var(--spacing-sm) var(--spacing-md);position:absolute;right:var(--spacing-lg);top:var(--spacing-lg);transition:background var(--transition-normal)}.logout-button:hover{background:#c82333}.admin-navigation{margin:0 auto;max-width:1200px;padding:var(--spacing-xl)}.nav-section{margin-bottom:var(--spacing-2xl)}.nav-section h2{border-bottom:2px solid #e2e8f0;color:var(--chocolate-brown);font-size:1.8rem;font-weight:600;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm);text-align:center}.nav-buttons{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));justify-items:center}.add-drink-form{background:#f8f9fa;border:1px solid #dee2e6;border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg)}.form-row{grid-gap:var(--spacing-md);gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.form-full-width{grid-column:1/-1}.drink-management-list{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.drink-management-list h2{background:var(--light-cream);border-bottom:1px solid #e2e8f0;margin:0;padding:var(--spacing-lg)}.drinks-list{max-height:600px;overflow-y:auto}.drink-item{border-bottom:1px solid #e2e8f0;padding:var(--spacing-lg);transition:background-color var(--transition-normal)}.drink-item:hover{background-color:#f8f9fa}.drink-item:last-child{border-bottom:none}@media (max-width:768px){.container,.container-fluid{padding:0 var(--spacing-md)}.admin-dashboard,.admin-navigation{padding:var(--spacing-md)}.form-row,.nav-buttons{gap:var(--spacing-sm);grid-template-columns:1fr}.logout-button{margin-bottom:var(--spacing-md);position:static;width:100%}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}@media (max-width:480px){.container,.container-fluid{padding:0 var(--spacing-sm)}.admin-dashboard,.admin-navigation{padding:var(--spacing-sm)}.add-drink-form,.drink-management-list{border-left:none;border-radius:0;border-right:none;margin:0 calc(var(--spacing-sm)*-1)}}.App{background:var(--light-cream);min-height:100vh;padding:var(--spacing-xl);text-align:center}.title{color:var(--chocolate-brown);font-family:var(--font-title);font-size:3rem;text-shadow:1px 1px 2px #0000001a}.categories,.title{margin-bottom:var(--spacing-xl)}.categories{display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:center}.menu-container{margin:0 auto;max-width:1200px}.drink-card,.menu-container{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-lg)}.drink-card{border:1px solid #e2e8f0;margin-bottom:var(--spacing-md);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.drink-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.drink-name{color:var(--chocolate-brown);font-family:var(--font-title);font-size:1.5rem}.drink-name,.drink-price{margin-bottom:var(--spacing-sm)}.drink-price{color:var(--antique-gold);font-size:1.25rem;font-weight:600}.drink-description{color:var(--chocolate-brown);font-size:1rem;line-height:1.6}.wine-comparison{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin:var(--spacing-lg) auto;max-width:1200px;padding:var(--spacing-xl)}.comparison-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:var(--spacing-lg)}.wine-slot{background:var(--white);border:2px dashed var(--antique-gold);border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center;transition:border-color var(--transition-normal)}.wine-slot:hover{background:var(--light-cream);border-color:var(--darker-gold)}.wine-slot.filled{background:var(--white);border-style:solid}.login-container{background:var(--light-cream);display:flex;justify-content:center;padding:var(--spacing-lg)}.login-form{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:400px;padding:var(--spacing-2xl);width:100%}.login-title{color:var(--chocolate-brown)}.landing-hero,.login-title{margin-bottom:var(--spacing-xl);text-align:center}.landing-hero{background:linear-gradient(135deg,var(--chocolate-brown),var(--dark-chocolate));border-radius:var(--radius-lg);color:var(--white);padding:var(--spacing-2xl) 0}.hero-title{font-size:4rem;margin-bottom:var(--spacing-lg);text-shadow:2px 2px 4px #0000004d}.hero-subtitle{font-size:1.5rem;margin-bottom:var(--spacing-xl);opacity:.9}.drink-detail-container{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin:0 auto;max-width:1200px;padding:var(--spacing-xl)}.drink-detail-header{border-bottom:2px solid var(--cream);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);text-align:center}.drink-detail-title{color:var(--chocolate-brown);font-family:var(--font-title);font-size:2.5rem;margin-bottom:var(--spacing-md)}.drink-detail-info{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:var(--spacing-xl)}.detail-section{background:var(--light-cream);border-left:4px solid var(--antique-gold);border-radius:var(--radius-md);padding:var(--spacing-lg)}.detail-section h3{color:var(--chocolate-brown);font-size:1.25rem;margin-bottom:var(--spacing-md)}.detail-section div,.detail-section p{color:var(--chocolate-brown);line-height:1.6;margin-bottom:var(--spacing-sm)}.detail-value{color:var(--antique-gold);font-weight:600}.winery-location{background:var(--white);border:2px solid var(--cream);border-radius:var(--radius-lg);margin:var(--spacing-xl) 0;padding:var(--spacing-lg)}.winery-location h3{color:var(--chocolate-brown);font-size:1.5rem;margin-bottom:var(--spacing-lg);text-align:center}.location-info{color:var(--text-muted);margin-bottom:var(--spacing-md);text-align:center}.location-enhancement{color:var(--antique-gold);font-style:italic}.tasting-section{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin:var(--spacing-xl) 0;padding:var(--spacing-xl)}.tasting-section h4{align-items:center;color:var(--chocolate-brown);display:flex;font-size:1.25rem;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.tasting-content{background:var(--light-cream);border-left:3px solid var(--antique-gold);color:var(--chocolate-brown);line-height:1.6}.error-message,.tasting-content{border-radius:var(--radius-md);padding:var(--spacing-md)}.error-message{background:#fee;border:1px solid #feb2b2;color:#c53030;margin-bottom:var(--spacing-md)}.success-message{background:#f0fff4;border:1px solid #9ae6b4;border-radius:var(--radius-md);color:#2f855a}.success-message,.warning-message{margin-bottom:var(--spacing-md);padding:var(--spacing-md)}.warning-message{background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-md);color:#92400e}@media (max-width:768px){.App{padding:var(--spacing-md)}.title{margin-bottom:var(--spacing-lg)}.hero-title,.title{font-size:2.5rem}.hero-subtitle{font-size:1.25rem}.categories{align-items:center;flex-direction:column}.comparison-grid{gap:var(--spacing-md);grid-template-columns:1fr}}@media (max-width:480px){.title{line-height:1.2;margin-bottom:var(--spacing-md)}.hero-title,.title{font-size:2rem}.login-form{padding:var(--spacing-lg)}.menu-container{padding:var(--spacing-sm)}}@font-face{font-family:Aurora;font-style:normal;font-weight:400;src:url(/static/media/AuroraType.380bff9f2a5b2a83b7c3.otf) format("opentype")}@font-face{font-family:GillSansMT;font-style:normal;font-weight:400;src:url(/static/media/GillSansMT.b007384538f12caa4fc4.ttf) format("truetype")}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--chocolate-brown);color:var(--cream);font-family:var(--font-body)}.back-button,.category-button,.compare-button,.compare-wines-btn,.cta-button,.landing-title,.menu-nav-button,.spirits-button,.title,.wine-country-header,.wine-main-header,.wine-region-header{letter-spacing:4pt!important}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.tenant-login-container{align-items:center;background:linear-gradient(135deg,#f8f4e3,#e8dfc7);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px}.tenant-login-card{animation:slideIn .6s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;max-width:440px;overflow:hidden;width:100%}.restaurant-branding{background-color:#d4af37;color:#31231f;padding:30px 40px;position:relative;text-align:center}.restaurant-branding:after{background:linear-gradient(90deg,#fff3,#fff9 50%,#fff3);bottom:0;content:"";height:4px;left:0;position:absolute;right:0}.restaurant-name{font-family:Georgia,serif;font-size:2rem;text-shadow:0 1px 2px #0000001a}.restaurant-description{font-size:1rem;font-weight:500;margin:0 0 8px;opacity:.9}.restaurant-location{font-size:.85rem;font-style:italic;opacity:.8}.login-content{padding:40px}.login-header{margin-bottom:32px;text-align:center}.login-header h2{color:#31231f;font-size:1.5rem;font-weight:600;margin:0 0 8px}.login-subtitle{color:#666;font-size:.95rem;margin:0}.login-form{margin-bottom:24px}.input-group{margin-bottom:20px}.input-group label{color:#31231f;display:block;font-size:.9rem;font-weight:500;margin-bottom:6px}.input-group input{background:#fafafa;border:2px solid #e1e1e1;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:all .3s ease;width:100%}.input-group input:focus{background:#fff;border-color:#d4af37;box-shadow:0 0 0 3px #d4af371a;outline:none}.input-group input:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}.error-message{background:#fef2f2;gap:8px}.error-icon,.login-button{font-size:1rem}.login-button{align-items:center;background-color:#d4af37;border:none;border-radius:8px;box-shadow:0 2px 4px #d4af3733;color:#31231f;cursor:pointer;display:flex;font-weight:600;gap:8px;justify-content:center;padding:14px 24px;transition:all .3s ease;width:100%}.login-button:hover:not(:disabled){background-color:#c19d2e;box-shadow:0 4px 8px #d4af374d;transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.loading-spinner{border:2px solid #31231f4d;border-top-color:#31231f;height:16px;width:16px}.login-footer{border-top:1px solid #e1e1e1;padding-top:24px}.back-to-public-button{align-items:center;background:none;border:none;border-radius:6px;color:#666;cursor:pointer;display:inline-flex;font-size:.9rem;gap:4px;margin-bottom:16px;padding:8px 16px;transition:all .3s ease}.back-to-public-button:hover{background:#f5f5f5;color:#31231f}.help-links{display:flex;gap:16px;justify-content:center;margin-bottom:20px}.navigation-buttons{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px}.restaurant-info{background:#f8f9fa;color:#666;font-size:.85rem;margin-top:16px;padding:16px}.restaurant-info p{margin:4px 0}.restaurant-info strong{color:#31231f}.help-link-button{background:none;border:none;border-radius:4px;color:#d4af37;cursor:pointer;font-size:.85rem;padding:4px 8px;text-decoration:underline;transition:all .3s ease}.help-link-button:hover{background:#d4af371a;color:#c19d2e}.powered-by{color:#888;margin-top:32px;text-align:center}.powered-by strong{color:#d4af37;font-weight:600}@media (max-width:480px){.tenant-login-container{padding:16px}.login-content{padding:32px 24px}.restaurant-branding{padding:24px}.restaurant-name{font-size:1.6rem}.login-header h2{font-size:1.3rem}}.tenant-login-card.dark-theme{background:#2a2a2a;color:#f5f5f5}.tenant-login-card.dark-theme .login-header h2{color:#f5f5f5}.tenant-login-card.dark-theme .input-group label{color:#e1e1e1}.tenant-login-card.dark-theme .input-group input{background:#3a3a3a;border-color:#555;color:#f5f5f5}.tenant-login-card.dark-theme .input-group input:focus{background:#4a4a4a}.tenant-login-card.dark-theme .login-footer{border-top-color:#444}.tenant-login-card.dark-theme .back-to-public-button{color:#ccc}.tenant-login-card.dark-theme .back-to-public-button:hover{background:#444;color:#f5f5f5}.lucky-dog-access{align-items:center;background:linear-gradient(135deg,#f8f4e3,#e8dfc7);display:flex;justify-content:center;min-height:100vh;padding:40px 20px}.lucky-dog-card{animation:slideIn .8s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000026;max-width:600px;overflow:hidden;width:100%}.lucky-dog-header{background:linear-gradient(135deg,#d4af37,#c19d2e);color:#31231f;padding:40px;position:relative;text-align:center}.lucky-dog-header:after{background:linear-gradient(90deg,#fff3,#fffc 50%,#fff3);bottom:0;content:"";height:6px;left:0;position:absolute;right:0}.lucky-dog-header h2{font-family:Georgia,serif;font-size:2.5rem;font-weight:700;margin:0 0 12px;text-shadow:0 2px 4px #0000001a}.tagline{font-size:1.2rem;font-weight:600;margin:0 0 8px;opacity:.95}.location{font-size:1rem;font-style:italic;margin:0;opacity:.8}.lucky-dog-content{padding:40px}.description{color:#444;font-size:1.1rem;line-height:1.6;margin-bottom:32px;text-align:center}.access-buttons{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:40px}.admin-login-button,.view-menu-button{align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;flex:1 1;font-size:1.1rem;font-weight:600;gap:8px;justify-content:center;min-width:200px;padding:16px 24px;transition:all .3s ease}.view-menu-button{background:linear-gradient(135deg,#d4af37,#c19d2e);box-shadow:0 4px 12px #d4af374d;color:#31231f}.view-menu-button:hover{box-shadow:0 8px 20px #d4af3766;transform:translateY(-2px)}.admin-login-button{background:linear-gradient(135deg,#31231f,#2a1f1c);border:2px solid #d4af37;box-shadow:0 4px 12px #31231f33;color:#d4af37}.admin-login-button:hover{background:linear-gradient(135deg,#3a2a26,#31231f);box-shadow:0 8px 20px #31231f4d;transform:translateY(-2px)}.restaurant-details{background:#f8f9fa;border-radius:12px;margin-bottom:32px;padding:24px}.detail-item{color:#555;font-size:1rem;gap:12px;margin-bottom:12px}.detail-item:last-child{margin-bottom:0}.detail-item .icon{font-size:1.2rem;text-align:center;width:20px}.detail-item a{color:#d4af37;font-weight:500;text-decoration:none}.detail-item a:hover{text-decoration:underline}.hours-info{background:#f1f3f4;border-radius:12px;margin-bottom:24px;padding:24px}.hours-info h4{color:#31231f;font-size:1.2rem;margin:0 0 16px;text-align:center}.hours-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.day-hours{display:flex;font-size:.95rem;justify-content:space-between;padding:4px 0}.day{color:#31231f;font-weight:600}.hours{color:#666}.powered-by-badge{background:#31231f;color:#d4af37;font-size:.9rem;font-weight:500;padding:16px;text-align:center}@media (max-width:768px){.lucky-dog-access{padding:20px 16px}.lucky-dog-header{padding:32px 24px}.lucky-dog-header h2{font-size:2rem}.lucky-dog-content{padding:32px 24px}.access-buttons{flex-direction:column}.admin-login-button,.view-menu-button{min-width:auto;width:100%}.hours-grid{gap:4px;grid-template-columns:1fr}}@media (max-width:480px){.lucky-dog-header h2{font-size:1.7rem}.description,.tagline{font-size:1rem}.hours-info,.restaurant-details{padding:20px}}.google-map-container{background:#f5f5f5;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin:20px 0;overflow:hidden;position:relative}.google-map-container.compact{border-radius:8px;margin:10px 0}.map-loading{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#6c757d;display:flex;flex-direction:column;height:100%;justify-content:center}.loading-spinner{border:4px solid #e9ecef;border-top-color:#8b4513;margin-bottom:15px}.map-loading p{font-size:16px;font-weight:500;margin:0}.map-error{align-items:center;background:linear-gradient(135deg,#fff5f5,#fed7d7);color:#e53e3e;display:flex;flex-direction:column;height:100%;justify-content:center;padding:20px;text-align:center}.error-icon{font-size:48px;margin-bottom:15px}.map-error h3{color:#c53030;font-size:18px;font-weight:600;margin:0 0 10px}.map-error p{font-size:14px;line-height:1.4;margin:5px 0}.error-help{font-style:italic;opacity:.8}.map-legend{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border-radius:8px;box-shadow:0 2px 8px #00000026;max-width:200px;padding:12px;position:absolute;right:15px;top:15px;z-index:1000}.map-legend h4{border-bottom:1px solid #e2e8f0;color:#2d3748;font-size:14px;font-weight:600;margin:0 0 8px;padding-bottom:6px}.legend-items{display:flex;flex-direction:column;gap:4px}.legend-item{align-items:center;display:flex;font-size:12px;gap:8px}.legend-icon{font-size:14px;text-align:center;width:16px}.legend-text{color:#4a5568;font-weight:500;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:768px){.map-legend{border-radius:0;border-radius:0 0 8px 8px;margin-top:10px;max-width:none;position:static}.google-map-container{border-radius:8px}.legend-items{flex-direction:row;flex-wrap:wrap;gap:8px}.legend-item{flex:0 0 auto;max-width:120px}}@media (max-width:480px){.map-legend{padding:8px}.map-legend h4{font-size:12px}.legend-item{font-size:11px;max-width:100px}.map-loading p{font-size:14px}.map-error h3{font-size:16px}.map-error p{font-size:12px}}.gm-style .gm-style-iw-c{border-radius:8px;padding:0}.gm-style .gm-style-iw-t:after{background:linear-gradient(45deg,#fff 50%,#0000 0)}.legend-item:hover{background:#8b45131a;border-radius:4px;margin:-2px -4px;padding:2px 4px;transition:all .2s ease}.google-map-container.drink-detail{border:2px solid #e2e8f0;margin:30px 0}.google-map-container.producer-detail{box-shadow:0 6px 20px #0000001a;margin:20px 0}.google-map-container{animation:fadeInScale .6s ease-out}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.static-map-fallback{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;padding:30px;text-align:center}.fallback-header h3{color:#495057;font-size:1.5rem;margin:0 0 10px}.fallback-header p{color:#6c757d;font-size:1rem;margin:0 0 30px}.location-list{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:600px}.location-item{align-items:flex-start;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;gap:15px;padding:20px;text-align:left}.location-icon{flex-shrink:0;font-size:2rem}.location-details h4{color:#495057;font-size:1.2rem;margin:0 0 10px}.location-details p{color:#6c757d;font-size:.9rem;margin:5px 0}.view-on-google-maps{background:#8b4513;border-radius:6px;color:#fff;display:inline-block;font-size:.9rem;font-weight:500;margin-top:10px;padding:8px 16px;text-decoration:none;transition:all .3s ease}.view-on-google-maps:hover{background:#6d2e0b;box-shadow:0 4px 12px #8b45134d;transform:translateY(-1px)}.professional-ratings{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 12px #00000014;margin-bottom:1.5rem;padding:1.5rem}.professional-ratings.compact{box-shadow:0 1px 6px #0000000f;margin-bottom:1rem;padding:1rem}.ratings-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.loading-spinner{border:3px solid #f3f3f3;height:32px;width:32px}.no-ratings{color:#6c757d;padding:2rem;text-align:center}.no-ratings-icon{display:block;font-size:2rem;margin-bottom:1rem}.no-ratings p{color:#495057;font-weight:500;margin:0 0 .5rem}.no-ratings small{color:#6c757d;font-size:.875rem}.ratings-summary{align-items:center;display:flex;gap:1rem}.aggregate-score{align-items:baseline;display:flex;gap:.25rem}.score-value{font-size:1.5rem;font-weight:700}.score-scale{color:#6c757d;font-size:1rem;font-weight:500}.ratings-meta{display:flex;flex-direction:column;gap:.25rem}.ratings-count{color:#495057;font-size:.875rem;font-weight:500}.consensus-badge{color:#667eea;font-size:.75rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.ratings-header{align-items:flex-start;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.ratings-header h3{color:#2c3e50;font-size:1.5rem;font-weight:600;margin:0}.ratings-summary-badge{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #667eea4d;color:#fff;display:flex;gap:1rem;padding:1rem 1.5rem}.aggregate-score-large{font-size:2.5rem;font-weight:700;line-height:1}.ratings-meta-large{display:flex;flex-direction:column;gap:.25rem}.ratings-meta-large span:first-child{font-size:.9rem;font-weight:500;opacity:.9}.consensus{font-size:.8rem;font-weight:600;letter-spacing:.5px;opacity:.8;text-transform:uppercase}.ratings-distribution{margin-bottom:2rem}.ratings-distribution h4{color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0 0 1rem}.distribution-chart{display:flex;flex-direction:column;gap:.75rem}.distribution-bar{grid-gap:1rem;align-items:center;display:grid;gap:1rem;grid-template-columns:120px 1fr 40px}.tier-label{color:#495057;font-size:.875rem;font-weight:500}.bar-container{background-color:#f8f9fa;border-radius:10px;height:20px;overflow:hidden;position:relative}.bar-fill{border-radius:10px;min-width:2px;transition:width .3s ease}.count-label{color:#495057;font-size:.875rem;font-weight:600;text-align:center}.individual-ratings{margin-bottom:2rem}.individual-ratings h4{color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0 0 1.5rem}.ratings-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.rating-card{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;font-family:inherit;font-size:inherit;padding:1rem;position:relative;text-align:left;transition:all .3s ease;width:100%}.rating-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.rating-card.selected{background:#fff;border-color:#667eea;box-shadow:0 6px 20px #667eea33}.rating-header{justify-content:space-between;margin-bottom:1rem}.rating-header,.source-info{align-items:center;display:flex}.source-info{gap:.5rem}.source-logo{font-size:1.2rem}.source-name{color:#2c3e50;font-size:.9rem;font-weight:600}.credibility-badge{background:#e3f2fd;border-radius:12px;color:#1565c0;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.score-display{align-items:baseline;display:flex;gap:.5rem;margin-bottom:.75rem}.score-main{font-size:1.8rem;font-weight:700;line-height:1}.score-normalized{color:#6c757d;font-size:.875rem;font-weight:500}.reviewer-info{color:#495057;font-size:.875rem;font-style:italic;margin-bottom:.5rem}.review-date{color:#6c757d;font-size:.8rem;margin-bottom:.75rem}.rating-review{border-top:1px solid #dee2e6;margin-top:.75rem;padding-top:.75rem}.rating-review p{color:#495057;font-size:.9rem;font-style:italic;line-height:1.5;margin:0}.ratings-methodology{border-top:1px solid #dee2e6;padding-top:1.5rem}.ratings-methodology details{cursor:pointer}.ratings-methodology summary{color:#667eea;font-size:.9rem;font-weight:600;outline:none;padding:.5rem 0;-webkit-user-select:none;user-select:none}.ratings-methodology summary:hover{color:#5a67d8}.methodology-content{color:#495057;font-size:.875rem;line-height:1.6;padding:1rem 0}.methodology-content ul{margin:.5rem 0 0;padding-left:1.5rem}.methodology-content li{margin-bottom:.5rem}.methodology-content strong{color:#2c3e50}@media (max-width:768px){.professional-ratings{padding:1rem}.ratings-header{align-items:stretch;flex-direction:column;gap:1rem}.ratings-summary-badge{justify-content:center;text-align:center}.ratings-grid{grid-template-columns:1fr}.distribution-bar{gap:.5rem;grid-template-columns:100px 1fr 30px}.tier-label{font-size:.8rem}}@media (max-width:480px){.ratings-summary{flex-direction:column;gap:.5rem;text-align:center}.aggregate-score-large{font-size:2rem}.score-main{font-size:1.5rem}}.producer-information{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 12px #00000014;margin-bottom:1.5rem;padding:1.5rem}.producer-information.compact{box-shadow:0 1px 6px #0000000f;margin-bottom:1rem;padding:1rem}.producer-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:3rem}.no-producer-info{color:#6c757d;padding:2rem;text-align:center}.no-info-icon{display:block;font-size:2rem;margin-bottom:1rem}.no-producer-info p{color:#495057;font-weight:500;margin:0 0 .5rem}.no-producer-info small{color:#6c757d;font-size:.875rem}.producer-summary{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between}.producer-basic h4{color:#2c3e50;font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.producer-basic .location{color:#667eea;font-size:.9rem;font-weight:500;margin:0 0 .25rem}.producer-basic .founded{color:#6c757d;font-size:.875rem;margin:0}.techniques-compact{display:flex;flex-direction:column;flex-shrink:0;gap:.5rem}.technique-badge.compact{font-size:.75rem;padding:.25rem .5rem}.producer-header{border-bottom:2px solid #e9ecef;margin-bottom:2rem;padding-bottom:1rem}.producer-title h3{color:#2c3e50;font-size:1.5rem;font-weight:600;line-height:1.2;margin:0 0 .5rem}.producer-subtitle{align-items:center;display:flex;gap:1rem}.location-name{color:#667eea;font-size:1rem;font-weight:500}.founded-year{background:#f8f9fa;border:1px solid #e9ecef;border-radius:15px;color:#6c757d;font-size:.9rem;padding:.25rem .75rem}.website-link{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;font-size:.9rem;font-weight:500;padding:.75rem 1.25rem;text-decoration:none;transition:all .3s ease}.website-link:hover{box-shadow:0 4px 15px #667eea66;color:#fff;text-decoration:none;transform:translateY(-2px)}.content-tabs{border-bottom:2px solid #e9ecef;display:flex;margin-bottom:1.5rem;overflow-x:auto}.tab-button{background:none;border:none;border-bottom:3px solid #0000;color:#6c757d;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease;white-space:nowrap}.tab-button:hover{background:#f8f9fa;color:#495057}.tab-button.active{background:#f8f9fa;border-bottom-color:#667eea;color:#667eea}.tab-content{min-height:300px}.overview-tab{display:flex;flex-direction:column;gap:2rem}.accolades-section h4,.philosophy-section h4,.techniques-section h4{color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0 0 1rem}.philosophy-section p{color:#495057;font-size:1rem;line-height:1.6;margin:0}.techniques-grid{display:flex;flex-wrap:wrap;gap:.75rem}.technique-badge{align-items:center;border-radius:20px;box-shadow:0 2px 6px #00000026;color:#fff;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem}.technique-icon{font-size:1rem}.technique-label{white-space:nowrap}.accolades-list{display:flex;flex-direction:column;gap:.75rem}.accolade-item{align-items:center;background:#f8f9fa;border-left:4px solid #ffc107;border-radius:8px;display:flex;gap:.75rem;padding:.75rem}.accolade-icon{flex-shrink:0;font-size:1.2rem}.accolade-text{color:#495057;font-size:.9rem;line-height:1.4}.more-accolades{color:#6c757d;font-size:.875rem;font-style:italic;margin:.5rem 0 0;text-align:center}.details-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.detail-section h4{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem}.detail-items{display:flex;flex-direction:column;gap:.75rem}.detail-item{align-items:flex-start;background:#f8f9fa;border-left:3px solid #667eea;border-radius:6px;padding:.75rem}.detail-label{color:#495057;flex-shrink:0;font-size:.9rem;font-weight:600;margin-right:1rem}.detail-value{color:#2c3e50;flex-grow:1;font-size:.9rem;text-align:right}.history-content h4{color:#2c3e50;font-size:1.3rem;font-weight:600;margin:0 0 1.5rem}.history-text{color:#495057;font-size:1rem;line-height:1.7}.history-text p{margin:0 0 1.5rem}.history-text p:last-child{margin-bottom:0}.location-content{display:flex;flex-direction:column;gap:1.5rem}.map-placeholder{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;min-height:300px}.map-info h4{color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0 0 1rem}.map-info p{color:#495057;font-size:.9rem;margin:0 0 .75rem}.map-actions{margin-top:1.5rem}.map-action-button{background:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.map-action-button:hover{background:#218838;box-shadow:0 4px 12px #28a7454d;transform:translateY(-2px)}.map-visual{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;justify-content:center;overflow:hidden;position:relative}.map-mockup{color:#fff;position:relative;text-align:center}.map-marker{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));font-size:3rem;margin-bottom:1rem}.map-region{font-size:1.2rem;font-weight:600;text-shadow:0 1px 3px #0000004d}@media (max-width:768px){.producer-information{padding:1rem}.producer-header{align-items:stretch;flex-direction:column;gap:1rem}.producer-subtitle{align-items:flex-start;flex-direction:column;gap:.5rem}.content-tabs{justify-content:flex-start}.tab-button{font-size:.875rem;padding:.5rem 1rem}.details-grid,.map-placeholder{grid-template-columns:1fr}.techniques-grid{justify-content:center}}@media (max-width:480px){.producer-summary{flex-direction:column;gap:1rem}.techniques-compact{flex-direction:row;flex-wrap:wrap}.detail-item{flex-direction:column;gap:.5rem}.detail-item,.detail-value{text-align:left}.producer-title h3{font-size:1.3rem}}.producer-map-section{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin:30px 0;overflow:hidden}.map-header{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #dee2e6;padding:20px 24px 16px}.map-header h3{align-items:center;color:#2d3748;display:flex;font-size:20px;font-weight:600;gap:8px;margin:0 0 8px}.map-header h3:before{content:"🗺️";font-size:24px}.map-description{color:#6c757d;font-size:14px;line-height:1.4;margin:0}.producer-map-placeholder{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px dashed #ced4da;border-radius:12px;margin:30px 0;padding:40px 20px;text-align:center}.placeholder-content{margin:0 auto;max-width:400px}.placeholder-icon{font-size:48px;margin-bottom:16px;opacity:.7}.producer-map-placeholder h4{color:#495057;font-size:18px;font-weight:600;margin:0 0 12px}.producer-map-placeholder p{color:#6c757d;font-size:14px;line-height:1.5;margin:8px 0}.producer-info{background:#8b45131a;border-left:4px solid #8b4513;border-radius:8px;margin-top:16px;padding:12px}.producer-info strong{color:#8b4513}.producer-details{grid-gap:16px;background:#fff;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));padding:20px 24px}.producer-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:16px;transition:all .3s ease}.producer-card:hover{border-color:#8b4513;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.producer-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.producer-header h4{color:#2d3748;flex:1 1;font-size:16px;font-weight:600;margin:0 8px 0 0}.producer-type{align-items:center;background:#8b4513;border-radius:12px;color:#fff;display:flex;font-size:12px;font-weight:500;gap:4px;padding:4px 8px;white-space:nowrap}.producer-address{align-items:flex-start;line-height:1.4}.producer-address,.producer-established{color:#6c757d;display:flex;font-size:14px;gap:6px;margin:8px 0}.producer-established{align-items:center}.producer-website{align-items:center;background:#8b4513;border-radius:6px;color:#fff;display:inline-flex;font-size:14px;font-weight:500;gap:4px;margin-top:12px;padding:8px 12px;text-decoration:none;transition:all .3s ease}.producer-website:hover{background:sienna;color:#fff;text-decoration:none;transform:translateX(2px)}@media (max-width:768px){.producer-map-section{border-radius:8px;margin:20px 0}.map-header{padding:16px 20px 12px}.map-header h3{font-size:18px}.map-description{font-size:13px}.producer-details{gap:12px;grid-template-columns:1fr;padding:16px 20px}.producer-card{padding:12px}.producer-header{align-items:flex-start;flex-direction:column;gap:8px}.producer-header h4{font-size:15px;margin-right:0}.producer-type{align-self:flex-start}.producer-map-placeholder{margin:20px 0;padding:30px 16px}.placeholder-icon{font-size:40px}.producer-map-placeholder h4{font-size:16px}}@media (max-width:480px){.map-header{padding:12px 16px 10px}.map-header h3{font-size:16px}.map-header h3:before{font-size:20px}.producer-details{padding:12px 16px}.producer-card{padding:10px}.producer-header h4{font-size:14px}.producer-type{font-size:11px;padding:3px 6px}.producer-address,.producer-established{font-size:13px}.producer-website{font-size:13px;padding:6px 10px}}.producer-card{animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.producer-details:has(.producer-card:only-child) .producer-card{margin:0 auto;max-width:500px}.producer-card:has(.producer-type:contains("Region")){background:linear-gradient(135deg,#e8f5e8,#f0f8f0);border-color:#28a745}.producer-card:has(.producer-type:contains("Region")) .producer-type{background:#28a745}.producer-website:focus{outline:2px solid #8b4513;outline-offset:2px}.producer-card:focus-within{border-color:#8b4513;box-shadow:0 0 0 2px #8b451333}.landing-page{background:var(--chocolate-brown);color:var(--cream);font-family:var(--font-body);margin:0;min-height:100vh;padding:0}.skip-link{background:var(--antique-gold);border-radius:4px;color:var(--chocolate-brown);font-weight:700;left:6px;padding:8px;position:absolute;text-decoration:none;top:-40px;z-index:1000}.skip-link:focus{top:6px}.landing-header{background:#c396161a;border-bottom:3px solid var(--antique-gold);padding:2rem 1rem;text-align:center}.landing-title{color:#f8f4e3;font-family:var(--font-title);font-size:3rem;font-weight:700;margin:0 0 .5rem;text-shadow:2px 2px 4px #00000080}.landing-subtitle{color:var(--cream);font-size:1.2rem;font-style:italic;margin:0}.landing-content{margin:0 auto;max-width:1200px;padding:2rem 1rem}.about-section{background:#bdac921a;border:2px solid var(--antique-gold);border-radius:12px;box-shadow:0 4px 6px #0000004d;margin-bottom:3rem;padding:2rem}.about-title{color:#f8f4e3;font-size:2rem;margin-bottom:1rem;text-align:center}.about-text{color:var(--cream);font-size:1.1rem;line-height:1.6;margin-bottom:1rem}.about-text h3{color:#f8f4e3;margin-bottom:1rem;margin-top:2rem}.menu-navigation{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center}.menu-nav-button{background:var(--antique-gold);border:2px solid var(--antique-gold);border-radius:12px;box-shadow:0 4px 8px #0000004d;color:var(--chocolate-brown);cursor:pointer;font-family:var(--font-title);font-size:1.2rem;font-weight:700;letter-spacing:1px;min-width:250px;padding:1rem 2rem;text-transform:uppercase;transition:all .3s ease}.menu-nav-button:hover{background:var(--darker-gold);box-shadow:0 6px 12px #0006;color:var(--chocolate-brown);transform:translateY(-2px)}.menu-nav-button:focus{outline:3px solid #f8f4e3;outline-offset:2px}.menu-nav-button:active{box-shadow:0 2px 4px #0000004d;transform:translateY(0)}.restaurant-info{background:#c396161a;border:1px solid var(--antique-gold);border-radius:8px;margin-top:2rem;padding:1.5rem}.restaurant-info h3{color:#f8f4e3;margin-bottom:1rem}.info-grid{margin-top:1rem}.info-item{text-align:left}.info-item h4{color:var(--antique-gold);font-size:1.2rem;margin-bottom:.5rem}.info-item p{color:var(--cream);margin-bottom:.3rem}.call-to-action{background:#c396160d;border:2px solid var(--antique-gold);border-radius:12px;margin-top:2rem;padding:2rem;text-align:center}.call-to-action h3{color:#f8f4e3;font-size:1.8rem;margin-bottom:1rem}.call-to-action p{color:var(--cream);font-size:1.1rem;margin-bottom:1.5rem}.cta-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.cta-button{background:var(--antique-gold);border:2px solid var(--antique-gold);border-radius:8px;color:var(--chocolate-brown);cursor:pointer;font-family:var(--font-title);font-size:1.2rem;font-weight:700;letter-spacing:1px;padding:1rem 2rem;text-transform:uppercase;transition:all .3s ease}.cta-button:hover{background:var(--darker-gold);box-shadow:0 4px 8px #0000004d;transform:translateY(-2px)}.cta-button:focus{outline:3px solid #f8f4e3;outline-offset:2px}.landing-footer{background:#c396161a;border-top:2px solid var(--antique-gold);color:var(--cream);font-size:.9rem;padding:2rem 1rem;text-align:center}.landing-footer p{margin:.5rem 0}.wine-button{background:#722f37!important;border-color:#722f37!important;color:#f8f4e3!important}.wine-button:hover{background:#8b3a44!important;color:#f8f4e3!important}.beer-button{background:#d4af37!important;border-color:#d4af37!important;color:var(--chocolate-brown)!important}.beer-button:hover{background:#e6c547!important}.wine-cta{background:#722f37!important;border-color:#722f37!important;color:#f8f4e3!important}.wine-cta:hover{background:#8b3a44!important;color:#f8f4e3!important}.beer-cta{background:#d4af37!important;border-color:#d4af37!important;color:var(--chocolate-brown)!important}.beer-cta:hover{background:#e6c547!important}@media (max-width:768px){.landing-title{font-size:2rem}.landing-subtitle{font-size:1rem}.about-section{margin-bottom:2rem;padding:1.5rem}.about-title{font-size:1.5rem}.about-text{font-size:1rem}.cta-buttons,.menu-navigation{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;justify-items:center}}@media (max-width:480px){.landing-header{padding:1.5rem 1rem}.landing-title{font-size:1.8rem}.about-section{padding:1rem}.menu-nav-button{font-size:1.1rem;min-width:200px}.cta-buttons,.menu-navigation{grid-template-columns:1fr}}.restaurant-setup{align-items:center;background:linear-gradient(135deg,#f8f4e3,#e8e4d7);display:flex;justify-content:center;min-height:100vh;padding:2rem}.setup-container{background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000001a;max-width:800px;padding:3rem;width:100%}.setup-header{text-align:center}.setup-header h1{color:#31231f;font-family:Georgia,serif;font-size:2.5rem;margin-bottom:1rem}.progress-bar{background-color:#e0e0e0;border-radius:4px;height:8px;margin-bottom:1rem;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#d4af37,#f0c674);border-radius:4px;height:100%;transition:width .3s ease}.step-indicator{color:#666;font-size:1rem}.setup-step{margin-bottom:2rem}.setup-step h2{color:#31231f;font-size:2rem;margin-bottom:.5rem}.setup-step p{color:#666;font-size:1.1rem;margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group label{color:#31231f;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:2px solid #e0e0e0;padding:.75rem;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#d4af37;box-shadow:0 0 0 3px #d4af371a}.theme-customization{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.color-section h3,.font-section h3{color:#31231f;margin-bottom:1rem}.color-inputs{display:flex;flex-direction:column;gap:1rem}.color-input-group{align-items:center;display:flex;gap:1rem}.color-input-group input[type=color]{border:none;border-radius:8px;cursor:pointer;height:40px;width:50px}.color-input-group span{color:#666;font-family:monospace;font-size:.9rem}.preview-section{grid-column:1/-1;margin-top:2rem}.theme-preview{border-radius:12px;margin-top:1rem}.dropzone{border:3px dashed #d0d0d0;border-radius:16px;cursor:pointer;margin-bottom:2rem;padding:3rem;text-align:center;transition:all .3s ease}.dropzone.active,.dropzone:hover{background-color:#d4af370d;border-color:#d4af37}.dropzone-content{align-items:center;display:flex;flex-direction:column;gap:1rem}.upload-icon{font-size:3rem;opacity:.6}.dropzone p{color:#666;margin:0}.file-types{color:#999!important;font-size:.9rem}.processing-status{align-items:center;background-color:#f0f8ff;border-radius:8px;display:flex;gap:1rem;margin-bottom:1rem;padding:1rem}.spinner{animation:spin 1s linear infinite;border:2px solid #e0e0e0;border-left-color:#d4af37;border-radius:50%;height:20px;width:20px}.processed-results,.uploaded-files{background-color:#f9f9f9;border-radius:12px;margin-bottom:1rem;padding:1.5rem}.processed-results h3,.uploaded-files h3{color:#31231f;margin-bottom:1rem}.file-item{align-items:center;background:#fff;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.75rem}.file-name{font-weight:500}.file-size{color:#666;font-size:.9rem}.menu-result{background:#fff;border-radius:8px;margin-bottom:1rem;padding:1rem}.menu-result h4{color:#31231f;margin-bottom:.5rem}.stats{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.stats span{background-color:#e8e4d7;border-radius:20px;color:#31231f;font-size:.9rem;padding:.25rem .75rem}.suggestions{margin-top:1rem}.suggestion{border-radius:8px;font-size:.9rem;margin-bottom:.5rem;padding:.5rem 1rem}.suggestion.warning{background-color:#fff3cd;border-left:4px solid #ffc107;color:#856404}.suggestion.info{background-color:#d1ecf1;border-left:4px solid #17a2b8;color:#0c5460}.skip-option{border-top:1px solid #e0e0e0;margin-top:2rem;padding-top:2rem;text-align:center}.link-button{background:none;border:none;color:#d4af37;cursor:pointer;font-size:inherit;text-decoration:underline}.link-button:hover{color:#b8941f}.setup-summary{grid-gap:2rem;display:grid;gap:2rem;margin-bottom:2rem}.summary-section{background-color:#f9f9f9;border-radius:12px;padding:1.5rem}.summary-section h3{border-bottom:2px solid #d4af37;color:#31231f;margin-bottom:1rem;padding-bottom:.5rem}.summary-item{line-height:1.5;margin-bottom:.75rem}.summary-item strong{color:#31231f;margin-right:.5rem}.theme-summary{align-items:center;display:flex;gap:2rem}.color-preview{display:flex;gap:.5rem}.color-swatch{border:2px solid #e0e0e0;border-radius:6px;height:30px;width:30px}.font-preview{display:flex;flex-direction:column;gap:.5rem}.font-preview span{color:#31231f}.setup-actions{align-items:center;border-top:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-top:3rem;padding-top:2rem}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;min-width:120px;padding:.75rem 2rem;transition:all .3s ease}.btn-primary{background-color:#d4af37}.btn-primary:hover:not(:disabled){background-color:#b8941f;box-shadow:0 4px 12px #d4af374d}.btn-primary:disabled{background-color:#ccc}.btn-secondary{background-color:#f5f5f5;border:2px solid #e0e0e0;color:#31231f}.btn-secondary:hover:not(:disabled){background-color:#e8e8e8;border-color:#d0d0d0}.error-message{align-items:center;background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24;display:flex;gap:1rem;margin-bottom:2rem;padding:1rem}.error-message button{background:none;border:none;color:#721c24;cursor:pointer;font-size:1.2rem;margin-left:auto}@media (max-width:768px){.restaurant-setup{padding:1rem}.setup-container{padding:2rem}.setup-header h1{font-size:2rem}.theme-customization{gap:1.5rem}.form-row,.theme-customization{grid-template-columns:1fr}.theme-summary{align-items:flex-start}.setup-actions,.theme-summary{flex-direction:column;gap:1rem}.btn-primary,.btn-secondary{width:100%}}.sommelai-landing{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);color:#fff;font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh}.landing-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1a2ef2;border-bottom:1px solid #ffffff1a;left:0;padding:1rem 0;position:fixed;right:0;top:0;z-index:1000}.nav-content{justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.nav-content,.nav-logo{align-items:center;display:flex}.nav-logo{gap:.5rem}.nav-logo-img{height:32px;width:32px}.nav-brand{color:#d4af37;font-size:1.5rem;font-weight:700}.nav-actions{align-items:center;display:flex;gap:1rem}.nav-subscriber-login-btn{background:#0000;border:1px solid #d4af37;border-radius:6px;color:#d4af37;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.nav-subscriber-login-btn:hover{background:#d4af37;color:#1a1a2e}.nav-demo-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.nav-demo-btn:hover{background:#fff3}.hero-section{align-items:center;display:flex;min-height:100vh;padding-top:80px}.hero-content{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px;padding:0 2rem}.hero-title{font-size:3.5rem;font-weight:800;line-height:1.1;margin-bottom:1.5rem}.highlight{color:#d4af37}.hero-subtitle{color:#fffc;font-size:1.2rem;line-height:1.6;margin-bottom:2rem}.hero-buttons{display:flex;gap:1rem}.cta-primary{background:linear-gradient(135deg,#d4af37,#b8941f);border:none;border-radius:8px;color:#1a1a2e;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.cta-primary:hover{box-shadow:0 10px 30px #d4af374d;transform:translateY(-2px)}.cta-primary.large{font-size:1.2rem;padding:1.25rem 2.5rem}.cta-secondary{background:#0000;border:2px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.cta-secondary:hover{background:#ffffff1a;border-color:#fff9}.hero-visual{display:flex;justify-content:center}.platform-preview{perspective:1000px}.screen-mockup{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;min-height:400px;transform:rotateY(-15deg) rotateX(5deg);transition:transform .3s ease;width:350px}.screen-mockup:hover{transform:rotateY(-10deg) rotateX(2deg)}.mockup-header{border-bottom:1px solid #ffffff1a;padding:1rem}.mockup-dots{display:flex;gap:.5rem}.mockup-dots span{background:#ffffff4d;border-radius:50%;height:12px;width:12px}.mockup-content{padding:2rem}.feature-preview h3{color:#d4af37;margin-bottom:1rem}.feature-preview p{color:#fffc;line-height:1.6}.features-section{background:#ffffff05;padding:6rem 0}.features-content{margin:0 auto;max-width:1200px;padding:0 2rem}.section-title{color:#d4af37;font-size:2.5rem;font-weight:700;margin-bottom:3rem;text-align:center}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.feature-card{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;padding:2rem;text-align:center;transition:all .3s ease}.feature-card:hover{background:#ffffff14;border-color:#d4af374d;transform:translateY(-5px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#d4af37;font-size:1.3rem;margin-bottom:1rem}.feature-card p{color:#fffc;line-height:1.6}.pricing-section{background:#0003;padding:6rem 0}.pricing-content{margin:0 auto;max-width:1000px;padding:0 2rem}.pricing-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:3rem}.pricing-card{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;padding:2.5rem;position:relative;text-align:center;transition:all .3s ease}.pricing-card.featured{border-color:#d4af37;transform:scale(1.05)}.pricing-card:hover{border-color:#d4af3780;transform:translateY(-5px)}.pricing-card.featured:hover{transform:scale(1.05) translateY(-5px)}.popular-badge{background:linear-gradient(135deg,#d4af37,#b8941f);border-radius:20px;color:#1a1a2e;font-size:.9rem;font-weight:600;left:50%;padding:.5rem 1.5rem;position:absolute;top:-12px;transform:translateX(-50%)}.pricing-card h3{color:#d4af37;font-size:1.5rem;margin-bottom:1rem}.price{margin-bottom:2rem}.currency{font-size:1.2rem;vertical-align:top}.amount{font-size:3rem;font-weight:700}.period{color:#ffffffb3;font-size:1rem}.features-list{list-style:none;margin-bottom:2rem;padding:0}.features-list li{color:#fffc;padding:.5rem 0}.features-list li:before{color:#d4af37;content:"✓";font-weight:700;margin-right:.5rem}.pricing-btn{background:linear-gradient(135deg,#d4af37,#b8941f);border:none;border-radius:8px;color:#1a1a2e;cursor:pointer;font-weight:600;padding:1rem 2rem;transition:all .3s ease;width:100%}.pricing-btn:hover{box-shadow:0 10px 30px #d4af374d;transform:translateY(-2px)}.cta-section{background:linear-gradient(135deg,#d4af37,#b8941f);color:#1a1a2e;padding:6rem 0;text-align:center}.cta-content{margin:0 auto;max-width:800px;padding:0 2rem}.cta-section h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.cta-section p{font-size:1.2rem;margin-bottom:2rem;opacity:.8}.cta-section .cta-primary{background:#1a1a2e;color:#d4af37}.cta-section .cta-primary:hover{background:#2a2a4e}.landing-footer{background:#0a0a1a;border-top:1px solid #ffffff1a;padding:3rem 0}.footer-content{justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.footer-brand,.footer-content{align-items:center;display:flex}.footer-brand{gap:.5rem}.footer-logo{height:24px;width:24px}.footer-brand span{color:#d4af37;font-size:1.2rem;font-weight:600}.footer-links{display:flex;gap:2rem}.footer-links a{color:#ffffffb3;text-decoration:none;transition:color .3s ease}.footer-links a:hover{color:#d4af37}@media (max-width:768px){.hero-content{gap:2rem;grid-template-columns:1fr;text-align:center}.hero-title{font-size:2.5rem}.nav-content{padding:0 1rem}.features-grid,.pricing-grid{grid-template-columns:1fr}.pricing-card.featured{transform:none}.pricing-card.featured:hover{transform:translateY(-5px)}.footer-content{flex-direction:column;gap:2rem}.footer-links{flex-wrap:wrap;justify-content:center}}.subscriber-login-page{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);color:#fff;font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh}.login-container{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px;min-height:100vh;padding:2rem}.login-header{gap:2rem;left:2rem;position:absolute;top:2rem;z-index:10}.login-header,.login-logo{align-items:center;display:flex}.login-logo{gap:.5rem}.login-form-section{align-items:center;display:flex;justify-content:center}.login-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:16px;box-shadow:0 20px 40px #0000004d;max-width:400px;padding:3rem;width:100%}.login-card h1{color:#1a1a2e;font-size:2rem;font-weight:700;margin-bottom:.5rem;text-align:center}.login-subtitle{color:#555;font-size:1rem;font-weight:500;margin-bottom:2rem;text-align:center}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{color:#1a1a2e}.subscriber-login-page .form-input{background:#fff!important;border:1px solid #ccc!important;border-radius:8px;color:#1a1a2e!important;cursor:text;font-size:1rem;padding:1rem;pointer-events:auto;transition:all .3s ease;user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.subscriber-login-page .form-input:focus{background:#fff!important;border-color:#d4af37!important;box-shadow:0 0 0 3px #d4af371a!important;outline:none!important}.subscriber-login-page .form-input::placeholder{color:#999!important}.login-btn{background:linear-gradient(135deg,#d4af37,#b8941f);border:none;border-radius:8px;color:#1a1a2e;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:1rem;transition:all .3s ease}.login-btn:hover:not(:disabled){box-shadow:0 10px 30px #d4af374d;transform:translateY(-2px)}.login-btn:disabled{cursor:not-allowed;opacity:.7}.login-footer{margin-top:2rem;text-align:center}.forgot-password-btn{background:none;border:none;color:#d4af37;cursor:pointer;font-size:.9rem;margin-bottom:1rem;text-decoration:underline;transition:color .3s ease}.forgot-password-btn:hover{color:#f0c85a}.signup-prompt{color:#666;font-size:.9rem}.signup-link{background:none;border:none;color:#d4af37;cursor:pointer;font-weight:500;margin-left:.5rem;text-decoration:underline;transition:color .3s ease}.signup-link:hover{color:#f0c85a}.login-features{display:flex;flex-direction:column;justify-content:center;padding:2rem}.login-features h3{color:#d4af37;font-size:1.5rem;font-weight:700;margin-bottom:2rem;text-align:center}.feature-list{gap:1.5rem}.feature-icon{font-size:1.5rem;min-width:2rem}@media (max-width:768px){.login-container{gap:2rem;grid-template-columns:1fr;min-height:auto;padding:1rem}.login-header{justify-content:space-between;left:auto;margin-bottom:2rem;position:relative;top:auto}.login-card{padding:2rem 1.5rem}.login-features{order:-1;padding:1rem}.login-features h3{font-size:1.2rem;margin-bottom:1rem}.feature-list{gap:1rem}.feature-item{padding:.75rem}}@media (max-width:480px){.login-card{padding:1.5rem}.login-card h1{font-size:1.5rem}.form-input,.login-btn{padding:.75rem}}.menu-access-page{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);color:#fff;font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh}.access-container{grid-gap:3rem;align-items:center;display:grid;gap:3rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1000px;min-height:100vh;padding:2rem}.access-header{align-items:center;display:flex;justify-content:space-between;left:2rem;position:absolute;right:2rem;top:2rem;z-index:10}.back-to-home-btn{background:#0000;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.back-to-home-btn:hover{background:#ffffff1a;border-color:#ffffff80}.restaurant-info h1{color:#d4af37;font-size:1.5rem;font-weight:700;margin:0}.restaurant-info p{color:#ffffffb3;font-size:.9rem;margin:.25rem 0 0}.access-form-section{align-items:center;display:flex;justify-content:center}.access-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;max-width:350px;padding:2.5rem;text-align:center;width:100%}.access-icon{font-size:3rem;margin-bottom:1rem}.access-card h2{color:#d4af37;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.access-subtitle{color:#ffffffb3;font-size:.95rem;line-height:1.4;margin-bottom:2rem}.access-form{display:flex;flex-direction:column;gap:1.5rem;text-align:left}.form-group{gap:.5rem}.form-group label{color:#ffffffe6}.form-input{background:#ffffff0d;border:1px solid #fff3;border-radius:8px;color:#fff;font-size:1rem;letter-spacing:2px;padding:1rem;text-align:center;transition:all .3s ease}.form-input:focus{background:#ffffff14;border-color:#d4af37;box-shadow:0 0 0 3px #d4af371a;outline:none}.form-input::placeholder{color:#ffffff80;letter-spacing:normal}.error-message{background:#dc35451a;border:1px solid #dc35454d;border-radius:6px;font-size:.9rem;padding:.75rem}.access-btn{background:linear-gradient(135deg,#d4af37,#b8941f);border:none;border-radius:8px;color:#1a1a2e;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:1rem;transition:all .3s ease}.access-btn:hover:not(:disabled){box-shadow:0 10px 30px #d4af374d;transform:translateY(-2px)}.access-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.access-footer{margin-top:1.5rem}.help-text{color:#fff9;font-size:.85rem;line-height:1.4}.access-features{display:flex;flex-direction:column;justify-content:center;padding:1rem}.access-features h3{color:#d4af37;font-size:1.3rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.feature-list{display:flex;flex-direction:column;gap:1rem}.feature-item{background:#ffffff08;border:1px solid #ffffff1a;gap:1rem}.feature-item:hover{border-color:#d4af374d;transform:translateX(5px)}.feature-item .feature-icon{min-width:2rem}.feature-content{display:flex;flex-direction:column;gap:.25rem}.feature-content strong{color:#ffffffe6;font-size:.95rem;font-weight:600}.feature-content span{color:#fff9;font-size:.85rem;line-height:1.3}@media (max-width:768px){.access-container{gap:1.5rem;grid-template-columns:1fr;min-height:auto;padding:1rem}.access-header{flex-direction:column;gap:1rem;left:auto;margin-bottom:1rem;position:relative;right:auto;top:auto}.access-card{max-width:100%;padding:2rem 1.5rem}.access-features{order:-1;padding:.5rem}.access-features h3{font-size:1.1rem;margin-bottom:1rem}.feature-item{padding:.75rem}.feature-content strong{font-size:.9rem}.feature-content span{font-size:.8rem}}@media (max-width:480px){.access-card{padding:1.5rem 1rem}.access-card h2{font-size:1.3rem}.access-btn,.form-input{padding:.75rem}}.restaurant-selection-page{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);color:#fff;font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;padding:2rem}.selection-container{margin:0 auto;max-width:1200px}.selection-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:3rem;padding-bottom:2rem}.header-content h1{color:#d4af37;font-size:2.5rem;margin-bottom:.5rem}.header-content p{color:#ffffffb3}.logout-btn{background:#0000;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.logout-btn:hover{background:#ffffff1a;border-color:#ffffff80}.restaurants-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-bottom:3rem}.restaurant-card{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;cursor:pointer;overflow:hidden;padding:2rem;position:relative}.restaurant-card:hover{background:#ffffff14;border-color:#d4af374d;box-shadow:0 20px 40px #0000004d}.restaurant-card:before{background:linear-gradient(135deg,#d4af37,#b8941f);content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.restaurant-card:hover:before{opacity:1}.restaurant-image{align-items:center;display:flex;justify-content:center;margin-bottom:1.5rem}.restaurant-image img{border:2px solid #ffffff1a;border-radius:12px;height:80px;object-fit:cover;width:80px}.restaurant-placeholder{align-items:center;background:#d4af371a;border:2px solid #d4af3733;border-radius:12px;display:flex;font-size:2rem;height:80px;justify-content:center;width:80px}.restaurant-info{margin-bottom:1.5rem;text-align:center}.restaurant-info h3{color:#d4af37;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.restaurant-location{color:#fffc;font-size:1rem;margin-bottom:.25rem}.restaurant-type{color:#fff9;font-size:.9rem;font-style:italic}.restaurant-stats{border-bottom:1px solid #ffffff1a;border-top:1px solid #ffffff1a;justify-content:space-around;margin-bottom:1.5rem;padding:1rem 0}.stat{align-items:center;flex-direction:column;gap:.25rem}.stat-value{color:#d4af37;font-size:1.5rem}.stat-label{color:#fff9;font-size:.8rem}.restaurant-actions{text-align:center}.manage-btn{background:linear-gradient(135deg,#d4af37,#b8941f);border:none;border-radius:8px;color:#1a1a2e;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease;width:100%}.manage-btn:hover{box-shadow:0 10px 30px #d4af374d;transform:translateY(-2px)}.selection-footer{border-top:1px solid #ffffff1a;padding-top:2rem;text-align:center}.selection-footer p{color:#ffffffb3;margin-bottom:1rem}.add-restaurant-btn{background:#0000;border:2px solid #d4af37;border-radius:8px;color:#d4af37;cursor:pointer;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.add-restaurant-btn:hover{background:#d4af37;color:#1a1a2e}.no-restaurants{margin:0 auto;max-width:500px;padding:4rem 2rem;text-align:center}.no-restaurants h2{color:#d4af37;font-size:2rem;margin-bottom:1rem}.no-restaurants p{color:#ffffffb3;margin-bottom:2rem}.back-btn{background:linear-gradient(135deg,#d4af37,#b8941f);border:none;border-radius:8px;color:#1a1a2e;cursor:pointer;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.back-btn:hover{box-shadow:0 10px 30px #d4af374d;transform:translateY(-2px)}@media (max-width:768px){.selection-header{flex-direction:column;gap:1rem;text-align:center}.header-content h1{font-size:2rem}.restaurants-grid{gap:1.5rem;grid-template-columns:1fr}.restaurant-card{padding:1.5rem}.restaurant-stats{padding:.75rem 0}.stat-value{font-size:1.2rem}}@media (max-width:480px){.restaurant-card,.restaurant-selection-page{padding:1rem}.restaurant-info h3{font-size:1.2rem}.restaurant-image img,.restaurant-placeholder{height:60px;width:60px}.restaurant-placeholder{font-size:1.5rem}}.setup-restaurant-page{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);color:#fff;font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh}.setup-container{display:flex;flex-direction:column;margin:0 auto;max-width:1000px;min-height:100vh;padding:2rem}.setup-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:3rem}.back-to-login-btn{background:#0000;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.back-to-login-btn:hover{background:#ffffff1a;border-color:#ffffff80}.setup-logo{align-items:center;display:flex;gap:.5rem}.logo-img{height:32px;width:32px}.logo-text{color:#d4af37;font-size:1.5rem;font-weight:700}.setup-content{display:flex;flex:1 1;flex-direction:column;justify-content:center;text-align:center}.setup-content,.setup-welcome{margin-bottom:3rem}.setup-welcome h1{color:#d4af37;font-size:2.5rem;font-weight:700;margin-bottom:1rem}.setup-subtitle{color:#fffc;font-size:1.2rem;line-height:1.6}.setup-steps{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:3rem}.step-item{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;display:flex;gap:1rem;padding:1.5rem;transition:all .3s ease}.step-item:hover{background:#ffffff14;border-color:#d4af374d;transform:translateY(-2px)}.step-icon{align-items:center;background:linear-gradient(135deg,#d4af37,#b8941f);border-radius:50%;color:#1a1a2e;display:flex;flex-shrink:0;font-size:1.1rem;font-weight:700;height:40px;justify-content:center;width:40px}.step-content{text-align:left}.step-content h3{color:#d4af37;font-size:1rem;font-weight:600;margin-bottom:.25rem}.step-content p{color:#ffffffb3;font-size:.9rem;line-height:1.4}.setup-actions{margin-bottom:2rem}.setup-btn{background:linear-gradient(135deg,#d4af37,#b8941f);border:none;border-radius:8px;color:#1a1a2e;cursor:pointer;font-size:1.1rem;font-weight:600;margin-bottom:1rem;padding:1.25rem 2.5rem;transition:all .3s ease}.setup-btn:hover{box-shadow:0 10px 30px #d4af374d;transform:translateY(-2px)}.setup-time{color:#fff9;font-size:.9rem}.setup-features{background:#ffffff08;border:1px solid #ffffff1a;border-radius:16px;padding:2rem}.setup-features h3{color:#d4af37;font-size:1.3rem;margin-bottom:1.5rem;text-align:center}.feature-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.feature-item{background:#ffffff05;border:1px solid #ffffff0d;gap:.75rem;padding:1rem;transition:all .3s ease}.feature-item:hover{background:#ffffff0d;border-color:#d4af3733}.feature-item .feature-icon{font-size:1.5rem;min-width:1.5rem}.feature-item span:last-child{color:#ffffffe6;font-size:.95rem;font-weight:500}@media (max-width:768px){.setup-container{padding:1rem}.setup-header{flex-direction:column;gap:1rem;margin-bottom:2rem}.setup-welcome h1{font-size:2rem}.setup-steps{gap:1rem;grid-template-columns:1fr}.step-item{padding:1rem}.step-content h3{font-size:.95rem}.step-content p{font-size:.85rem}.feature-grid{grid-template-columns:1fr}.setup-features{padding:1.5rem}}@media (max-width:480px){.setup-welcome h1{font-size:1.8rem}.setup-btn,.setup-subtitle{font-size:1rem}.setup-btn{padding:1rem 2rem}.step-item{flex-direction:column;gap:.75rem}.step-content,.step-item{text-align:center}}.advanced-search-interface{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:800px;padding:1.5rem}.advanced-search-interface.compact{max-width:600px;padding:1rem}.search-header{margin-bottom:2rem;text-align:center}.search-title{color:#2c3e50;font-size:1.8rem;font-weight:700;margin:0 0 .5rem}.search-subtitle{color:#6c757d;font-size:1rem;line-height:1.5;margin:0}.compact .search-header{margin-bottom:1rem}.compact .search-title{font-size:1.4rem}.compact .search-subtitle{font-size:.9rem}.search-bar-container{align-items:flex-start;display:flex;gap:.75rem;margin-bottom:1.5rem}.search-input-wrapper{flex:1 1;position:relative}.search-input{background:#fff;border:2px solid #e1e5e9;border-radius:12px;padding:1rem 3rem 1rem 1rem;transition:all .3s ease;width:100%}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-button{background:#667eea;font-size:1.2rem;padding:.5rem;position:absolute;right:.5rem;top:50%;transform:translateY(-50%);transition:all .2s ease}.search-button:hover:not(:disabled){background:#5a6fd8;transform:translateY(-50%) scale(1.05)}.search-button:disabled{background:#cbd5e0;transform:translateY(-50%)}.filter-toggle{background:#fff;border:2px solid #e1e5e9;border-radius:12px;cursor:pointer;font-size:1rem;padding:1rem 1.5rem;position:relative;transition:all .3s ease;white-space:nowrap}.filter-toggle:hover{border-color:#667eea}.filter-toggle.active{background:#667eea;border-color:#667eea;color:#fff}.filter-count{align-items:center;background:#dc3545;border-radius:50%;color:#fff;display:flex;font-size:.75rem;font-weight:600;height:20px;justify-content:center;position:absolute;right:-8px;top:-8px;width:20px}.advanced-filters{background:#f8f9fa;border:1px solid #e1e5e9;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.filter-row{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 2fr;margin-bottom:1.5rem}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label,.filter-label{color:#495057;font-size:.9rem;font-weight:600}.price-range{gap:.75rem}.price-range input{border:1px solid #e1e5e9;border-radius:6px;font-size:.9rem;padding:.5rem}.price-range span{color:#6c757d;font-size:.9rem}.filter-chips{display:flex;flex-wrap:wrap;gap:.5rem}.filter-chip{background:#fff;border:1px solid #e1e5e9;border-radius:20px;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s ease}.filter-chip:hover{border-color:#667eea}.filter-chip.selected{background:#667eea;border-color:#667eea;color:#fff}.filter-actions{display:flex;gap:1rem;justify-content:flex-end}.apply-filters,.clear-filters{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.clear-filters{background:#6c757d;color:#fff}.apply-filters{background:#667eea;color:#fff}.clear-filters:hover{background:#5a6268}.apply-filters:hover{background:#5a6fd8}.search-suggestions{margin-bottom:2rem}.search-suggestions h4{color:#495057;font-size:1.1rem;margin:0 0 1rem}.suggestion-chips{display:flex;flex-wrap:wrap;gap:.75rem}.suggestion-chip{background:#fff;border:1px solid #e1e5e9;border-radius:25px;color:#495057;cursor:pointer;font-size:.9rem;padding:.75rem 1.25rem;transition:all .2s ease}.suggestion-chip:hover{background:#667eea;border-color:#667eea;color:#fff;transform:translateY(-1px)}.search-history{margin-bottom:2rem}.search-history h4{color:#495057;font-size:1.1rem;margin:0 0 1rem}.history-items{display:flex;flex-direction:column;gap:.5rem}.history-item{align-items:center;background:#fff;border:1px solid #e1e5e9;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:.75rem 1rem;text-align:left;transition:all .2s ease}.history-item:hover{background:#f8f9fa;border-color:#667eea}.history-query{color:#495057;font-size:.9rem}.history-count{color:#6c757d;font-size:.8rem}.search-error{background:#f8d7da;border-radius:8px;color:#721c24;margin-bottom:1rem;padding:2rem;text-align:center}.retry-button{background:#dc3545;font-weight:600;margin-top:1rem;padding:.5rem 1rem}.search-results{margin-top:2rem}.results-header{border-bottom:2px solid #e1e5e9;margin-bottom:1.5rem;padding-bottom:1rem}.results-header h4{color:#2c3e50;font-size:1.3rem;margin:0}.search-confidence{background:#28a745;border-radius:15px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.search-intent{background:#e3f2fd;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.intent-summary{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.intent-summary strong{color:#1976d2;margin-right:.5rem}.intent-tag{background:#1976d2;border-radius:15px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.results-list{display:flex;flex-direction:column}.result-item{background:#fff;border:2px solid #e1e5e9;border-radius:12px;cursor:pointer;padding:1.5rem;text-align:left;transition:all .3s ease;width:100%}.result-item:hover{border-color:#667eea;box-shadow:0 4px 15px #667eea26;transform:translateY(-2px)}.result-item.selected{background:#f8f9ff;border-color:#667eea}.result-main{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.result-info{flex:1 1}.result-name{color:#2c3e50;font-size:1.2rem;font-weight:700;margin:0 0 .5rem}.result-description{color:#6c757d;line-height:1.5;margin:0 0 .5rem}.result-price{background:#28a745;border-radius:15px;color:#fff;font-size:.9rem;font-weight:600;padding:.25rem .75rem}.result-score{align-items:center;display:flex;flex-direction:column;gap:.25rem}.score-circle{background:linear-gradient(135deg,#667eea,#764ba2);font-size:.9rem}.score-label{color:#6c757d;font-size:.8rem}.result-explanation{background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;margin-bottom:1rem;padding:1rem}.result-explanation p{color:#495057;font-style:italic;line-height:1.5;margin:0}.result-tags{display:flex;flex-wrap:wrap;gap:.5rem}.result-tag{border-radius:15px;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.result-tag.category{background:#17a2b8;color:#fff}.result-tag.region{background:#fd7e14;color:#fff}.result-tag.ai-enhanced{background:#6f42c1;color:#fff}.additional-suggestions{border-top:1px solid #e1e5e9;margin-top:2rem;padding-top:2rem}.additional-suggestions h4{color:#495057;font-size:1.1rem;margin:0 0 1rem}.search-footer{border-top:1px solid #e1e5e9;margin-top:2rem;padding-top:1rem;text-align:center}.ai-disclaimer{color:#6c757d;font-size:.9rem;font-style:italic;margin:0}@media (max-width:768px){.advanced-search-interface{padding:1rem}.search-bar-container{flex-direction:column;gap:.5rem}.filter-row{gap:1rem;grid-template-columns:1fr}.filter-actions{justify-content:stretch}.apply-filters,.clear-filters{flex:1 1}.results-header{align-items:flex-start;flex-direction:column;gap:.5rem}.result-main{flex-direction:column;gap:1rem}.result-score{align-self:flex-end}.filter-chips,.suggestion-chips{justify-content:center}}@media (max-width:480px){.search-title{font-size:1.5rem}.result-name{font-size:1.1rem}.score-circle{font-size:.8rem;height:40px;width:40px}}.recommendation-engine{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 20px 40px #0000001a;color:#fff;margin:0 auto;max-width:1200px;overflow:hidden;padding:2rem;position:relative}.recommendation-engine:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='100' height='100' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='50' cy='50' r='1' fill='rgba(255,255,255,0.05)'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.recommendation-engine.compact{border-radius:12px;padding:1rem}.recommendation-header{margin-bottom:2rem;position:relative;text-align:center;z-index:1}.recommendation-header h3{font-size:2.5rem;font-weight:700;margin:0 0 .5rem;text-shadow:2px 2px 4px #0000004d}.recommendation-header p{font-size:1.1rem;margin:0;opacity:.9}.compact .recommendation-header h3{font-size:1.8rem}.compact .recommendation-header p{font-size:1rem}.recommendation-controls{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:2rem;position:relative;z-index:1}.control-group{display:flex;flex-direction:column;gap:.5rem;min-width:120px}.control-group label{font-size:.9rem;font-weight:600;opacity:.9}.control-group input,.control-group select{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:none;border-radius:8px;color:#fff;font-size:1rem;padding:.75rem;transition:all .3s ease}.control-group input:focus,.control-group select:focus{background:#ffffff40;box-shadow:0 0 0 2px #ffffff4d;outline:none}.control-group select option{background:#2c3e50;color:#fff}.preferences-btn,.refresh-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.preferences-btn{background:#fff3;border:2px solid #ffffff4d;color:#fff}.preferences-btn:hover{background:#ffffff4d;box-shadow:0 5px 15px #0003;transform:translateY(-2px)}.refresh-btn{background:linear-gradient(45deg,#ff6b6b,#feca57);border:none;color:#fff}.refresh-btn:hover{box-shadow:0 5px 15px #ff6b6b4d;transform:translateY(-2px)}.refresh-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.loading-state{padding:3rem;position:relative;z-index:1}.loading-spinner{margin:0 auto 1rem}.error-state{background:#e74c3c33;border:2px solid #e74c3c4d;border-radius:12px;margin:1rem 0;padding:2rem;position:relative;z-index:1}.error-state h4{color:#ff6b6b;margin:0 0 .5rem}.recommendations-container{position:relative;z-index:1}.recommendations-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin-bottom:2rem}.compact .recommendations-grid{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.recommendation-card{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff26;border:2px solid #fff3;border-radius:16px;cursor:pointer;overflow:hidden;padding:1.5rem;position:relative;text-align:left;transition:all .3s ease;width:100%}.recommendation-card:before{background:linear-gradient(90deg,#ff6b6b,#4ecdc4,#45b7d1,#96ceb4);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.recommendation-card.selected:before,.recommendation-card:hover:before{transform:scaleX(1)}.recommendation-card:hover{background:#ffffff40;border-color:#fff6;box-shadow:0 10px 30px #0003;transform:translateY(-5px)}.recommendation-card.selected{background:#ffffff4d;border-color:#ffffff80;box-shadow:0 10px 30px #0000004d}.card-header{gap:1rem;margin-bottom:1rem}.recommendation-info{flex:1 1}.recommendation-name{color:#fff;font-size:1.2rem;font-weight:700;line-height:1.3;margin:0 0 .5rem}.recommendation-description{font-size:.95rem;line-height:1.4;margin:0 0 .5rem;opacity:.9}.recommendation-price{background:#feca5733;border-radius:6px;color:#feca57;display:inline-block;font-size:1.1rem;font-weight:600;padding:.25rem .5rem}.recommendation-score{align-items:center;display:flex;flex-direction:column;gap:.25rem;min-width:60px}.score-circle{box-shadow:0 4px 12px #0003;color:#fff;font-size:.85rem;font-weight:700;height:50px;width:50px}.score-label{font-size:.75rem;font-weight:600;opacity:.8}.recommendation-reasoning{background:#ffffff1a;border-left:4px solid #ffffff4d;border-radius:8px;margin:1rem 0;padding:1rem}.recommendation-reasoning p{font-style:italic;line-height:1.4;margin:0;opacity:.9}.recommendation-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}.rec-tag{border-radius:20px;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.rec-tag.category{background:#744ba2b3;color:#fff}.rec-tag.match-type{background:#4ecdc4b3;color:#fff}.rec-tag.ai-enhanced{background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;overflow:hidden;position:relative}.rec-tag.ai-enhanced:before{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes shimmer{0%{left:-100%}to{left:100%}}.feedback-buttons{display:flex;gap:.5rem;justify-content:center;margin-top:1rem}.feedback-btn{align-items:center;background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;gap:.25rem;padding:.5rem 1rem;transition:all .3s ease}.feedback-btn:hover{box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.feedback-btn.like:hover{background:#2ecc71b3}.feedback-btn.dislike:hover{background:#e74c3cb3}.feedback-received{background:#2ecc714d;border-radius:8px;font-weight:600;margin-top:1rem;padding:.75rem;text-align:center}.learning-progress{background:#ffffff1a;border:2px solid #fff3;border-radius:12px;margin-top:2rem;padding:1.5rem;text-align:center}.learning-progress h4{color:#fff;font-size:1.3rem;margin:0 0 1rem}.learning-progress p{line-height:1.5;margin:0 0 1rem;opacity:.9}.interaction-stats{display:flex;font-size:.9rem;gap:1rem;justify-content:center;opacity:.8}.preferences-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.preferences-modal{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 25px 50px #0000004d;color:#fff;max-height:80vh;max-width:600px;overflow-y:auto;position:relative;width:90%}.modal-header{border-bottom:2px solid #fff3;padding:2rem 2rem 1rem}.modal-header h3{font-size:1.8rem}.close-button{color:#fff;font-size:2rem}.close-button:hover{background:#fff3;transform:rotate(90deg)}.modal-content{padding:2rem}.preference-group,fieldset.preference-group{border:none;margin-bottom:2rem;padding:0}.preference-group label,fieldset.preference-group legend{color:#fff;display:block;font-size:1.1rem;font-weight:600;margin-bottom:.75rem}.preference-group select{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:none;border-radius:8px;color:#fff;font-size:1rem;padding:.75rem;width:100%}.preference-group select option{background:#2c3e50;color:#fff}.preference-chips{display:flex;flex-wrap:wrap;gap:.5rem}.preference-chip{background:#ffffff1a;border:2px solid #ffffff4d;border-radius:25px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.preference-chip:hover{background:#fff3;transform:translateY(-2px)}.preference-chip.selected{background:#ffffff4d;border-color:#fff9;box-shadow:0 4px 12px #0003}.price-range{align-items:center;display:flex;gap:1rem}.price-range input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:none;border-radius:8px;color:#fff;flex:1 1;font-size:1rem;padding:.75rem}.price-range input::placeholder{color:#ffffffb3}.price-range span{color:#fffc;font-weight:600}.modal-footer{border-top:2px solid #fff3;display:flex;gap:1rem;justify-content:flex-end;padding:1rem 2rem 2rem}.modal-footer button{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.save-btn{background:linear-gradient(45deg,#2ecc71,#27ae60);color:#fff}.save-btn:hover{box-shadow:0 5px 15px #2ecc714d;transform:translateY(-2px)}.cancel-btn{background:#fff3;border:2px solid #ffffff4d;color:#fff}.cancel-btn:hover{background:#ffffff4d}@media (max-width:768px){.recommendation-engine{border-radius:12px;padding:1rem}.recommendation-header h3{font-size:2rem}.recommendation-controls{align-items:stretch;flex-direction:column}.control-group{min-width:auto}.recommendations-grid{gap:1rem;grid-template-columns:1fr}.card-header{align-items:flex-start;flex-direction:column}.recommendation-score{align-self:flex-end;margin-top:.5rem}.preferences-modal{margin:1rem;width:95%}.modal-content,.modal-footer,.modal-header{padding:1rem}.price-range{align-items:stretch;flex-direction:column}.interaction-stats{flex-direction:column;gap:.5rem}}@media (max-width:480px){.recommendation-engine{padding:.75rem}.recommendation-header h3{font-size:1.6rem}.recommendation-card{padding:1rem}.feedback-buttons{flex-direction:column}.preferences-modal{margin:.5rem;width:98%}}@media (prefers-contrast:high){.recommendation-engine{background:#000;border:3px solid #fff}.recommendation-card{background:#111;border:2px solid #fff}.rec-tag{border:1px solid #fff}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.close-button:hover,.feedback-btn:hover,.recommendation-card:hover{transform:none}}.beverage-comparison-tool{align-items:center;background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.comparison-container{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border:1px solid #444;border-radius:16px;box-shadow:0 20px 60px #00000080;color:#f5f5f5;max-height:90vh;max-width:1200px;overflow-y:auto;width:90%}.comparison-header{background:linear-gradient(135deg,#2d1810,#3d2418);border-bottom:1px solid #333;border-radius:16px 16px 0 0;padding:30px 30px 20px;text-align:center}.comparison-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#d4af37,#f4e4a6);-webkit-background-clip:text;background-clip:text;font-size:2.2rem;font-weight:600;margin:0 0 10px}.comparison-header p{color:#bbb;font-size:1.1rem;margin:0}.close-button-container{position:absolute;right:15px;top:15px;z-index:10}.close-button{align-items:center;background:#ffffff1a;border:1px solid #555;border-radius:50%;color:#ccc;display:flex;height:40px;justify-content:center;transition:all .3s ease;width:40px}.close-button:hover{background:#e74c3c33;border-color:#e74c3c;color:#ff6b6b}.category-selection{padding:30px}.category-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:30px}.category-card{background:linear-gradient(135deg,#2a2a2a,#3d3d3d);border:2px solid #444;cursor:pointer;overflow:hidden;padding:30px 20px;position:relative;text-align:center;transition:all .3s ease}.category-card:hover{border-color:#d4af37;box-shadow:0 8px 25px #d4af3733;transform:translateY(-3px)}.category-card:hover .category-icon{transform:scale(1.1)}.category-icon{display:block;font-size:3rem;margin-bottom:15px;transition:transform .3s ease}.category-card h3{color:#d4af37;font-size:1.4rem;font-weight:600;margin:15px 0 10px}.category-card p{color:#aaa;font-size:.95rem;line-height:1.4;margin:0}.beverage-selection{padding:30px}.back-button{border:1px solid #555;border-radius:6px;font-size:.9rem;margin-bottom:20px;padding:8px 16px}.beverage-search-section{margin:30px 0}.beverage-search-section h3{color:#d4af37;font-size:1.2rem;margin-bottom:15px}.search-container{max-width:600px;position:relative}.beverage-search-input{background:#2a2a2a;border:2px solid #444;border-radius:8px;color:#f5f5f5;font-size:1rem;padding:15px 20px;transition:all .3s ease;width:100%}.beverage-search-input:focus{border-color:#d4af37;box-shadow:0 0 0 3px #d4af371a;outline:none}.beverage-search-input::placeholder{color:#888}.selected-beverage-display{align-items:center;background:#d4af371a;border:1px solid #d4af37;border-radius:6px;color:#d4af37;display:flex;justify-content:space-between;margin-top:10px;padding:10px 15px}.selected-beverage-display button{background:none;border:none;color:#d4af37;cursor:pointer;font-size:1.2rem;margin-left:10px;padding:0}.beverage-dropdown{background:#2a2a2a;border:2px solid #444;border-radius:0 0 8px 8px;border-top:none;box-shadow:0 8px 25px #0000004d;left:0;max-height:400px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:100}.dropdown-item{border-bottom:1px solid #333;cursor:pointer;padding:15px;transition:background-color .2s ease}.dropdown-item:hover{background:#353535}.dropdown-item:last-child{border-bottom:none}.dropdown-item-content{align-items:center;display:flex;gap:15px}.dropdown-item-image{border-radius:6px;flex-shrink:0;height:50px;object-fit:cover;width:50px}.dropdown-item-info{flex:1 1}.dropdown-item-info h4{color:#f5f5f5;font-size:1rem;font-weight:600;margin:0 0 5px}.dropdown-item-info p{color:#bbb;font-size:.9rem;margin:0 0 3px}.dropdown-item-region{color:#888!important;font-size:.85rem!important}.dropdown-item-price{color:#d4af37;flex-shrink:0;font-size:1.1rem;font-weight:600}.dropdown-more{background:#252525;border-top:1px solid #333;color:#888;font-size:.9rem;padding:10px 15px;text-align:center}.second-beverage-section{margin-top:30px}.second-beverage-section h3{color:#d4af37;font-size:1.2rem;margin-bottom:20px}.second-beverage-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.beverage-card.clickable:hover{box-shadow:0 6px 20px #d4af3733;transform:translateY(-2px)}.comparison-step-one{padding:30px}.error-message{background:#e74c3c1a;border:1px solid #e74c3c;color:#ff6b6b;margin-bottom:20px;padding:15px}.comparison-type-selector{display:flex;gap:15px;justify-content:center;margin-bottom:30px}.type-button{background:#0000;border:2px solid #555;border-radius:8px;color:#ccc;cursor:pointer;font-size:1rem;padding:12px 24px;transition:all .3s ease}.type-button:hover{border-color:#d4af37;color:#d4af37}.type-button.active{background:linear-gradient(135deg,#d4af37,#f4e4a6);border-color:#d4af37;color:#1a1a1a;font-weight:600}.external-comparison,.internal-comparison{grid-gap:30px;display:grid;gap:30px}.beverage-selector{margin-bottom:20px}.beverage-selector h3{color:#d4af37;font-size:1.3rem;margin:0 0 20px}.beverage-grid{grid-gap:15px;gap:15px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.beverage-card{background:linear-gradient(135deg,#2a2a2a,#1f1f1f);border:2px solid #333;overflow:hidden;padding:15px;position:relative}.beverage-card:before{background:linear-gradient(90deg,#0000,#d4af371a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.beverage-card:hover{border-color:#d4af37;box-shadow:0 10px 25px #d4af3733;transform:translateY(-2px)}.beverage-card:hover:before{left:100%}.beverage-card.selected{background:linear-gradient(135deg,#d4af371a,#f4e4a60d);border-color:#d4af37;box-shadow:0 8px 20px #d4af374d}.beverage-card.clickable:hover{background:linear-gradient(135deg,#d4af3726,#f4e4a614);cursor:pointer}.beverage-card.large{padding:25px;text-align:center}.beverage-image{background:#333;border-radius:8px;height:120px;margin-bottom:10px;object-fit:cover;width:100%}.beverage-card.large .beverage-image{height:200px;margin-bottom:20px}.beverage-info h4{color:#f5f5f5;font-size:1.1rem;font-weight:600;margin:0 0 5px}.beverage-category{color:#999;font-size:.9rem;margin:0 0 8px;text-transform:capitalize}.rating{color:#d4af37;font-size:.9rem;font-weight:600}.price{color:#4caf50;font-size:1.3rem;font-weight:700;margin:5px 0}.external-input{background:#0000004d;border:1px solid #333;border-radius:12px;padding:25px}.external-input h3{color:#d4af37;font-size:1.3rem;margin:0 0 15px}.external-beverage-input{background:#1a1a1a;border:2px solid #444;border-radius:8px;color:#f5f5f5;font-family:inherit;font-size:1rem;margin-bottom:20px;padding:15px;resize:vertical;width:100%}.external-beverage-input:focus{border-color:#d4af37;box-shadow:0 0 0 3px #d4af371a;outline:none}.external-beverage-input::placeholder{color:#777}.compare-button{background:linear-gradient(135deg,#d4af37,#f4e4a6);border:none;border-radius:8px;color:#1a1a1a;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px 30px;transition:all .3s ease;width:100%}.compare-button:hover:not(:disabled){box-shadow:0 8px 25px #d4af3766;transform:translateY(-2px)}.compare-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.second-beverage-selector{border-top:1px solid #333;margin-top:30px;padding-top:30px}.comparison-results{padding:30px}.results-header{align-items:center;border-bottom:1px solid #333;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.results-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#d4af37,#f4e4a6);-webkit-background-clip:text;background-clip:text;font-size:2rem;margin:0}.back-button{background:#0000;border:2px solid #555;border-radius:8px;color:#ccc;cursor:pointer;padding:10px 20px;transition:all .3s ease}.back-button:hover{border-color:#d4af37;color:#d4af37}.beverages-comparison{grid-gap:30px;align-items:center;display:grid;gap:30px;grid-template-columns:1fr auto 1fr;margin-bottom:40px}.comparison-analysis{align-items:center;display:flex;flex-direction:column}.similarity-score{text-align:center}.score-circle{align-items:center;background:linear-gradient(135deg,#d4af371a,#f4e4a60d);border:4px solid #d4af37;border-radius:50%;box-shadow:0 0 30px #d4af374d;display:flex;flex-direction:column;height:120px;justify-content:center;width:120px}.score{color:#d4af37;font-size:2rem;font-weight:700;line-height:1}.label{color:#ccc;font-size:.9rem;margin-top:5px}.detailed-comparison{grid-gap:30px;display:grid;gap:30px}.comparison-section h3{align-items:center;color:#d4af37;display:flex;font-size:1.4rem;gap:10px;margin:0 0 20px}.differences,.similarities{grid-gap:10px;display:grid;gap:10px}.difference-item,.similarity-item{align-items:flex-start;background:#0000004d;border-left:4px solid #4caf50;border-radius:8px;display:flex;gap:12px;padding:12px}.difference-item{border-left-color:#ff9800}.difference-badge,.similarity-badge{color:#4caf50;flex-shrink:0;font-size:1.1rem;font-weight:700;margin-top:2px}.difference-badge{color:#ff9800}.sommelier-note{background:linear-gradient(135deg,#d4af371a,#f4e4a60d);border:1px solid #d4af374d;border-radius:12px;font-style:italic;line-height:1.6;padding:20px}.alternative-recommendations{grid-gap:15px;display:grid;gap:15px}.recommendation-item{background:#0000004d;border:1px solid #333;padding:20px;position:relative}.recommendation-item h4{color:#d4af37;font-size:1.2rem;margin:0 0 10px}.recommendation-item p{color:#ccc;line-height:1.5;margin:0 0 10px}.match-score{background:linear-gradient(135deg,#4caf50,#66bb6a);border-radius:20px;color:#fff;font-size:.9rem;font-weight:600;padding:4px 12px;position:absolute;right:15px;top:15px}.action-buttons{border-top:1px solid #333;justify-content:center;margin-top:40px;padding-top:30px}.primary-button,.secondary-button{border:2px solid #0000;border-radius:8px;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px 30px;transition:all .3s ease}.primary-button{background:linear-gradient(135deg,#d4af37,#f4e4a6);color:#1a1a1a}.primary-button:hover{box-shadow:0 8px 25px #d4af3766;transform:translateY(-2px)}.secondary-button{background:#0000;border-color:#555;color:#ccc}.secondary-button:hover{border-color:#d4af37;color:#d4af37}.comparison-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px;text-align:center}.loading-spinner{border:4px solid #333;border-top-color:#d4af37}.comparison-loading p{color:#ccc;font-size:1.1rem;margin:0}.tasting-notes{margin-top:15px}.tasting-notes strong{color:#d4af37;display:block;margin-bottom:5px}.tasting-notes p{color:#ccc;margin:0}.description,.tasting-notes p{font-size:.95rem;line-height:1.4}.description{color:#bbb;margin:10px 0}@media (max-width:768px){.comparison-container{margin:10px;width:95%}.beverages-comparison{gap:20px;grid-template-columns:1fr}.comparison-type-selector{flex-direction:column;gap:10px}.beverage-grid{gap:10px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.action-buttons{flex-direction:column}.score-circle{height:100px;width:100px}.score{font-size:1.5rem}}@media (max-width:480px){.comparison-header{padding:20px 15px 15px}.comparison-header h2{font-size:1.8rem}.comparison-results,.comparison-step-one{padding:20px 15px}.beverage-grid{grid-template-columns:1fr 1fr}}.restaurant-admin-selector{color:#fff}.selector-header{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin-bottom:30px}.header-left h2{font-size:2.2rem}.create-button{align-items:center;background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease;white-space:nowrap}.create-button:hover{box-shadow:0 5px 15px #48bb7866;transform:translateY(-2px)}.selector-filters{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:25px;padding:25px}.search-section{flex:1 1;min-width:250px}.filter-section{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.filter-select,.sort-select{background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#2d3748;cursor:pointer;font-size:1rem;min-width:140px;padding:12px 15px;transition:all .3s ease}.filter-select:focus,.sort-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.view-toggle{background:#e2e8f0;border-radius:10px;display:flex;gap:5px;padding:5px}.view-button{background:none;border:none;border-radius:8px;cursor:pointer;font-size:1.1rem;padding:8px 12px;transition:all .3s ease}.view-button.active{background:#fff;box-shadow:0 2px 5px #0000001a}.restaurant-list{min-height:400px}.empty-state{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;color:#2d3748;padding:60px 20px;text-align:center}.empty-icon{font-size:4rem;margin-bottom:20px;opacity:.6}.empty-state h3{font-size:1.5rem;font-weight:700;margin:0 0 10px}.empty-state p{color:#666;font-size:1.1rem;margin:0 0 25px}.empty-action-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .3s ease}.empty-action-button:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.restaurant-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.restaurant-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;color:#2d3748;padding:25px;transition:all .3s ease}.restaurant-card:hover{box-shadow:0 15px 40px #00000026;transform:translateY(-5px)}.card-header{align-items:flex-start;display:flex;gap:15px;justify-content:space-between;margin-bottom:20px}.restaurant-name{font-size:1.3rem;line-height:1.3;margin:0}.card-badges{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.card-content{margin-bottom:20px}.restaurant-info{grid-gap:12px;gap:12px}.info-item{font-size:.9rem;gap:10px}.info-icon{font-size:1.1rem;opacity:.7;text-align:center;width:20px}.info-text{color:#666;flex:1 1;word-break:break-all}.card-actions{display:flex;flex-wrap:wrap;gap:10px}.action-button{flex:1 1;gap:6px;justify-content:center;min-width:80px;padding:8px 16px}.action-button.edit{background:linear-gradient(135deg,#a8edea,#fed6e3);color:#2d3748}.restaurant-table{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;color:#2d3748;overflow:hidden;width:100%}.restaurant-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.restaurant-table th{font-size:.9rem;font-weight:700;letter-spacing:.5px;padding:20px;text-align:left;text-transform:uppercase}.restaurant-table td{border-bottom:1px solid #e2e8f0;padding:20px;vertical-align:middle}.restaurant-table tbody tr:hover{background:#667eea0d}.table-restaurant{display:flex;flex-direction:column;gap:5px}.restaurant-slug{color:#666;font-family:monospace;font-size:.85rem}.table-contact{color:#666;display:flex;flex-direction:column;font-size:.9rem;gap:3px}.table-actions{align-items:center;display:flex;gap:8px}.table-action-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;transition:all .3s ease;width:36px}.table-action-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.table-action-button.secondary{background:linear-gradient(135deg,#ffecd2,#fcb69f);color:#8b4513}.table-action-button.edit{background:linear-gradient(135deg,#a8edea,#fed6e3);color:#2d3748}.table-action-button:hover{box-shadow:0 3px 10px #0003;transform:translateY(-2px)}.plan-badge{border:2px solid #0000}.plan-badge.plan-free{border-color:#cbd5e0}.status-badge{font-size:.75rem;font-weight:700}.status-badge.status-active{background:#c6f6d5;color:#22543d}.status-badge.status-inactive{background:#fed7d7;color:#742a2a}.status-badge.status-suspended{background:#feebc8;color:#7b341e}.modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:20px}.modal-content{border-radius:15px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;width:100%}.modal-header{border-bottom:2px solid #e2e8f0;padding:30px 30px 20px;position:relative}.modal-header h3{color:#2d3748;font-size:1.5rem;font-weight:700}.modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;position:absolute;right:20px;top:20px;transition:all .3s ease;width:32px}.modal-close:hover{background:#f7fafc;color:#2d3748}.restaurant-form{padding:30px}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group.full-width{grid-column:1/-1}.form-group label{color:#2d3748;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:12px 15px;transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-actions{border-top:2px solid #e2e8f0;gap:15px;padding-top:20px}.form-button{border:none;border-radius:8px;cursor:pointer;font-weight:600;min-width:120px;padding:12px 24px;transition:all .3s ease}.form-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.form-button.secondary{background:#e2e8f0;color:#4a5568}.form-button:hover{box-shadow:0 5px 15px #0003;transform:translateY(-2px)}@media (max-width:768px){.selector-header{align-items:flex-start;flex-direction:column}.selector-filters{align-items:stretch;flex-direction:column}.filter-section{justify-content:stretch}.filter-select,.sort-select{flex:1 1;min-width:auto}.restaurant-grid{grid-template-columns:1fr}.restaurant-table{display:block;overflow-x:auto;white-space:nowrap}.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.modal-content{margin:10px;max-height:calc(100vh - 20px)}}@media (max-width:480px){.card-actions{flex-direction:column}.action-button{flex:none}.table-actions{flex-direction:column}.modal-header,.restaurant-form{padding:20px}}.subscription-management{color:#fff}.subscription-header{margin-bottom:40px;text-align:center}.subscription-header h2{font-size:2.5rem;font-weight:700;margin:0 0 10px}.subscription-header p{font-size:1.1rem;margin:0;opacity:.9}.subscription-loading{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:400px}.subscription-stats{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:40px}.plan-distribution{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;margin-bottom:30px;padding:30px}.plan-distribution h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin:0 0 25px}.distribution-bars{grid-gap:20px;display:grid;gap:20px}.distribution-item{display:flex;flex-direction:column;gap:10px}.distribution-label{align-items:center;display:flex;justify-content:space-between}.plan-count{color:#2d3748;font-weight:600}.distribution-bar{background:#e2e8f0;border-radius:6px;height:12px;overflow:hidden}.distribution-fill{border-radius:6px;height:100%;transition:all .5s ease}.distribution-fill.plan-free{background:linear-gradient(135deg,#e2e8f0,#cbd5e0)}.distribution-fill.plan-pro{background:linear-gradient(135deg,#667eea,#764ba2)}.distribution-fill.plan-enterprise{background:linear-gradient(135deg,#ffd89b,#19547b)}.subscription-filters{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:25px;padding:25px}.search-input{align-items:center;display:flex;min-width:250px;position:relative}.search-icon{color:#666;font-size:1.1rem;left:15px;position:absolute;z-index:1}.search-input input{background:#fff;border:2px solid #e2e8f0;border-radius:10px;font-size:1rem;padding:12px 15px 12px 45px;transition:all .3s ease;width:100%}.search-input input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.filter-select{background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#2d3748;cursor:pointer;font-size:1rem;min-width:140px;padding:12px 15px;transition:all .3s ease}.filter-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.subscription-table-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;overflow:hidden}.subscription-table{color:#2d3748;width:100%}.subscription-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.subscription-table th{font-size:.9rem;font-weight:700;letter-spacing:.5px;padding:20px;text-align:left;text-transform:uppercase}.subscription-table td{border-bottom:1px solid #e2e8f0;padding:20px;vertical-align:middle}.subscription-table tbody tr:hover{background:#667eea0d}.restaurant-info{display:flex;flex-direction:column;gap:5px}.restaurant-name{font-size:1rem}.restaurant-email{color:#666;font-size:.85rem}.status-select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;padding:8px 12px;transition:all .3s ease}.status-select.status-active{background:#c6f6d5;border-color:#9ae6b4;color:#22543d}.status-select.status-inactive{background:#fed7d7;border-color:#feb2b2;color:#742a2a}.status-select.status-suspended{background:#feebc8;border-color:#f6d792;color:#7b341e}.cost-info{display:flex;flex-direction:column;gap:2px}.cost-amount{color:#2d3748;font-size:1.1rem;font-weight:700}.cost-period{color:#666;font-size:.8rem}.billing-info{color:#666;font-size:.9rem}.subscription-actions{display:flex;gap:10px}.action-button{border-radius:8px;font-size:.9rem;padding:10px 16px}.action-button:hover{box-shadow:0 3px 10px #0003}.upgrade-modal{max-width:900px}.plan-options{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));padding:30px}.plan-option{background:#fff;border:3px solid #e2e8f0;border-radius:15px;padding:25px;position:relative;transition:all .3s ease}.plan-option:hover{border-color:#667eea;box-shadow:0 10px 30px #667eea26;transform:translateY(-5px)}.plan-option.current{background:linear-gradient(135deg,#f0fff4,#c6f6d5);border-color:#48bb78}.plan-option.current:before{background:#48bb78;border-radius:20px;color:#fff;content:"Current Plan";font-size:.8rem;font-weight:700;left:20px;padding:4px 12px;position:absolute;top:-12px}.plan-header{border-bottom:2px solid #e2e8f0;margin-bottom:25px;padding-bottom:20px;text-align:center}.plan-header h4{color:#2d3748;font-size:1.5rem;font-weight:700;margin:0 0 10px}.plan-price{align-items:baseline;color:#667eea;display:flex;font-size:2rem;font-weight:700;gap:5px;justify-content:center}.price-period{color:#666;font-size:.9rem;font-weight:500}.plan-features{margin-bottom:25px}.plan-features ul{list-style:none;margin:0;padding:0}.plan-features li{align-items:center;color:#2d3748;display:flex;gap:10px;padding:8px 0}.feature-icon{color:#48bb78;font-weight:700;width:16px}.plan-action{text-align:center}.plan-button{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:700;padding:12px 24px;transition:all .3s ease;width:100%}.plan-button.current{background:#48bb78;color:#fff;cursor:not-allowed}.plan-button.free{background:#e2e8f0;color:#4a5568}.plan-button.pro{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.plan-button.enterprise{background:linear-gradient(135deg,#ffd89b,#19547b);color:#fff}.plan-button:not(.current):hover{box-shadow:0 5px 15px #0003;transform:translateY(-2px)}.modal-actions{border-top:2px solid #e2e8f0;padding:30px;text-align:center}.modal-button{border:none;border-radius:8px;cursor:pointer;font-weight:600;min-width:120px;padding:12px 24px;transition:all .3s ease}.modal-button.secondary{background:#e2e8f0;color:#4a5568}.modal-button:hover{box-shadow:0 5px 15px #0003;transform:translateY(-2px)}@media (max-width:768px){.subscription-filters{align-items:stretch;flex-direction:column}.search-input{min-width:auto}.subscription-table-container{overflow-x:auto}.subscription-table{min-width:800px}.plan-options{grid-template-columns:1fr}.upgrade-modal{margin:10px;max-height:calc(100vh - 20px)}.subscription-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:480px){.subscription-header h2{font-size:2rem}.stat-card{padding:20px}.stat-number{font-size:1.8rem}.modal-actions,.plan-distribution,.plan-option,.plan-options,.subscription-filters{padding:20px}}.platform-analytics{color:#fff}.analytics-loading{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:400px}.analytics-header{align-items:flex-start;gap:20px;margin-bottom:30px}.header-left h2{font-size:2.5rem;font-weight:700;margin:0 0 10px}.header-left p{font-size:1.1rem;margin:0;opacity:.9}.header-controls{gap:15px}.time-range-select{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #ffffff4d;border-radius:10px;color:#2d3748;cursor:pointer;font-size:1rem;min-width:140px;padding:12px 15px;transition:all .3s ease}.time-range-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.analytics-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:15px;box-shadow:0 10px 30px #0000001a;gap:5px;margin-bottom:30px;overflow-x:auto;padding:8px}.nav-button{align-items:center;background:none;border:none;border-radius:10px;color:#666;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:12px 20px;transition:all .3s ease;white-space:nowrap}.nav-button:hover{background:#667eea1a;color:#667eea}.nav-button.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 5px 15px #667eea4d;color:#fff}.analytics-content{min-height:500px}.overview-analytics{grid-gap:30px;display:grid;gap:30px}.metrics-grid{grid-gap:25px;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.metric-card{box-shadow:0 10px 30px #0000001a;color:#2d3748;gap:20px;padding:25px;transition:all .3s ease}.metric-card:hover{box-shadow:0 15px 40px #00000026}.metric-card.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.metric-card.revenue{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff}.metric-icon{background:#fff3;border-radius:15px;font-size:2.5rem}.metric-card:not(.primary):not(.revenue) .metric-icon{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.metric-content{flex:1 1}.metric-value{font-size:2.2rem;line-height:1;margin:0 0 5px}.metric-label{letter-spacing:.5px;opacity:.8;text-transform:uppercase}.metric-change{font-weight:600;margin-top:8px;padding:4px 8px}.metric-change.positive{background:#48bb7833;color:#22543d}.metric-change.negative{background:#f5656533;color:#742a2a}.metric-change.neutral{background:#a0aec033;color:#2d3748}.metric-card.primary .metric-change,.metric-card.revenue .metric-change{background:#fff3;color:#ffffffe6}.chart-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;padding:30px}.chart-section h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin:0 0 25px}.plan-distribution-chart{grid-gap:20px;display:grid;gap:20px}.plan-segment{display:flex;flex-direction:column;gap:10px}.segment-info{align-items:center;display:flex;justify-content:space-between}.segment-count{color:#2d3748;font-weight:600}.segment-bar{background:#e2e8f0;border-radius:6px;height:12px;overflow:hidden}.segment-fill{border-radius:6px;height:100%;transition:all .5s ease}.segment-fill.plan-free{background:linear-gradient(135deg,#e2e8f0,#cbd5e0)}.segment-fill.plan-pro{background:linear-gradient(135deg,#667eea,#764ba2)}.segment-fill.plan-enterprise{background:linear-gradient(135deg,#ffd89b,#19547b)}.top-restaurants{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;padding:30px}.top-restaurants h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin:0 0 25px}.restaurant-leaderboard{grid-gap:15px;display:grid;gap:15px}.leaderboard-item{align-items:center;background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;display:flex;gap:20px;padding:20px;transition:all .3s ease}.leaderboard-item:hover{border-color:#667eea;transform:translateX(5px)}.rank{color:#667eea;font-size:1.5rem;font-weight:700;text-align:center;width:40px}.restaurant-info{flex:1 1}.restaurant-name{color:#2d3748;font-size:1.1rem;font-weight:700;margin:0 0 8px}.restaurant-stats{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.stat{background:#fff;color:#666;font-size:.9rem;padding:4px 8px}.status-indicator{border-radius:50%;height:12px;width:12px}.status-indicator.active{background:#48bb78}.status-indicator.inactive{background:#f56565}.plan-badge{font-size:.75rem;font-weight:700}.plan-badge.plan-free{background:#e2e8f0;color:#4a5568}.plan-badge.plan-pro{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.plan-badge.plan-enterprise{background:linear-gradient(135deg,#ffd89b,#19547b);color:#fff}.financial-analytics{grid-gap:30px;display:grid;gap:30px}.financial-metrics{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.revenue-chart,.usage-chart{align-items:center;display:flex;height:300px;justify-content:center}.chart-placeholder{justify-content:center;padding:20px;position:relative}.chart-bars,.chart-placeholder{align-items:end;display:flex;height:100%;width:100%}.chart-bars{gap:8px;max-width:600px}.chart-bar{align-items:center;display:flex;flex:1 1;flex-direction:column;height:100%}.bar-fill{border-radius:4px 4px 0 0;min-height:5px;transition:all .3s ease;width:100%}.bar-label{color:#666;font-size:.8rem;font-weight:500;margin-top:8px}.chart-line{height:100%;position:relative;width:100%}.chart-point{background:#667eea;border-radius:50%;box-shadow:0 0 10px #667eea80;height:8px;position:absolute;transform:translate(-50%,50%);width:8px}.usage-analytics{grid-gap:30px;display:grid;gap:30px}.usage-metrics{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.performance-analytics{grid-gap:30px;display:grid;gap:30px}.performance-metrics{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.performance-trends{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;padding:30px}.performance-trends h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin:0 0 25px}.kpi-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.kpi-item{background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;padding:20px;text-align:center;transition:all .3s ease}.kpi-item:hover{border-color:#667eea;transform:translateY(-5px)}.kpi-label{color:#666;font-size:.9rem;font-weight:500;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.kpi-value{color:#2d3748;font-size:1.8rem;font-weight:700;margin-bottom:8px}.kpi-trend{border-radius:12px;display:inline-block;font-size:.8rem;font-weight:600;padding:4px 8px}.kpi-trend.positive{background:#48bb7833;color:#22543d}.kpi-trend.negative{background:#f5656533;color:#742a2a}@media (max-width:768px){.analytics-header{align-items:flex-start;flex-direction:column}.header-controls{justify-content:stretch;width:100%}.time-range-select{flex:1 1;min-width:auto}.analytics-nav{-webkit-overflow-scrolling:touch;overflow-x:auto}.financial-metrics,.metrics-grid,.performance-metrics,.usage-metrics{grid-template-columns:1fr}.restaurant-stats{align-items:flex-start;flex-direction:column;gap:8px}.kpi-grid{grid-template-columns:1fr}.chart-bars{gap:4px}}@media (max-width:480px){.header-left h2{font-size:2rem}.metric-card{flex-direction:column;padding:20px;text-align:center}.metric-icon{font-size:2rem;height:50px;width:50px}.metric-value{font-size:1.8rem}.chart-section,.performance-trends,.top-restaurants{padding:20px}.leaderboard-item{flex-direction:column;gap:15px;text-align:center}.rank{width:auto}.restaurant-info{text-align:center}.kpi-item{padding:15px}.kpi-value{font-size:1.5rem}}.tenant-pairing-manager{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1200px;padding:20px}.header{margin-bottom:30px;text-align:center}.header h2{color:#2c3e50;font-size:2.2rem;margin-bottom:10px}.header p{color:#7f8c8d;font-size:1.1rem}.no-tenant{background:#f8f9fa;border-radius:12px;margin:40px 0;padding:60px 20px;text-align:center}.no-tenant h3{color:#6c757d;margin-bottom:10px}.notification{animation:slideIn .3s ease-out;border-radius:8px;margin-bottom:20px;padding:12px 20px}.notification.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.notification.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.tabs{border-bottom:2px solid #e9ecef;display:flex;gap:0;margin-bottom:30px}.tabs button{background:none;border:none;border-bottom:3px solid #0000;color:#6c757d;cursor:pointer;font-size:1rem;font-weight:500;padding:15px 25px;transition:all .3s ease;white-space:nowrap}.tabs button:hover{background:#f8f9fa;color:#495057}.tabs button.active{background:#d4af370d;border-bottom-color:#d4af37;color:#d4af37}.tab-content{min-height:500px}.menu-upload-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:30px}.upload-options{max-width:600px}.form-group{margin-bottom:25px}.form-group label{color:#2c3e50;display:block;font-weight:600;margin-bottom:8px}.form-group input,.form-group textarea{border:2px solid #e9ecef;border-radius:8px;font-size:1rem;padding:12px 15px;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#d4af37;box-shadow:0 0 0 3px #d4af371a;outline:none}.form-group textarea{min-height:120px;resize:vertical}.file-name{background:#e9ecef;border-radius:4px;color:#6c757d;display:inline-block;font-size:.9rem;margin-top:8px;padding:4px 8px}.generate-btn,.upload-btn{background:linear-gradient(135deg,#d4af37,#f1c40f);border:none;border-radius:8px;box-shadow:0 4px 15px #d4af374d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px 30px;transition:all .3s ease}.generate-btn:hover,.upload-btn:hover{box-shadow:0 6px 20px #d4af3766;transform:translateY(-2px)}.generate-btn:disabled,.upload-btn:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.uploaded-menus{margin-top:40px}.uploaded-menus h4{color:#2c3e50;margin-bottom:20px}.menu-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.menu-card{background:#fff;border:2px solid #e9ecef;border-radius:10px;padding:20px;transition:all .3s ease}.menu-card:hover{border-color:#d4af37;box-shadow:0 4px 15px #0000001a;transform:translateY(-2px)}.menu-card h5{color:#2c3e50;font-size:1.2rem;margin-bottom:10px}.menu-card p{color:#6c757d;margin:5px 0}.inventory-upload-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:30px}.inventory-tabs{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:30px 0}.beverage-section{background:#fafbfc;border:2px solid #e9ecef;border-radius:12px;padding:25px}.beverage-section h4{align-items:center;color:#2c3e50;display:flex;font-size:1.3rem;gap:10px;margin-bottom:20px}.beverage-inventory-section{width:100%}.section-header{margin-bottom:20px}.add-btn{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:background .3s ease}.add-btn:hover{background:#218838}.beverage-form{grid-gap:15px;background:#fff;border:2px solid #e9ecef;border-radius:8px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px;padding:20px}.beverage-form input{border:1px solid #ddd;border-radius:6px;font-size:.95rem;padding:10px 12px}.beverage-form input:focus{border-color:#d4af37;box-shadow:0 0 0 2px #d4af371a;outline:none}.form-actions{gap:10px;grid-column:1/-1}.form-actions button{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px}.form-actions button[type=submit]{background:#28a745;color:#fff}.form-actions button[type=button]{background:#6c757d;color:#fff}.beverage-list{display:flex;flex-direction:column;gap:15px}.beverage-item{align-items:flex-start;background:#fff;border:1px solid #e9ecef;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:15px;padding:15px;transition:all .3s ease}.beverage-item:hover{border-color:#d4af37;box-shadow:0 2px 8px #0000001a}.beverage-info h5{color:#2c3e50;font-size:1.1rem;margin-bottom:5px}.beverage-info p{color:#6c757d;font-size:.95rem;margin-bottom:10px}.beverage-details{gap:10px}.beverage-details span{background:#e9ecef;border-radius:4px;color:#495057}.remove-btn{align-items:center;background:#dc3545;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.2rem;height:30px;justify-content:center;transition:background .3s ease;width:30px}.remove-btn:hover{background:#c82333}.pairings-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:30px}.pairings-header{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:30px}.pairings-header h3{color:#2c3e50;margin:0}.pairings-grid{grid-gap:25px;gap:25px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.pairing-card{background:#fafbfc;border:2px solid #e9ecef;border-radius:12px;padding:25px;transition:all .3s ease}.pairing-card:hover{border-color:#d4af37;box-shadow:0 8px 25px #00000026;transform:translateY(-3px)}.pairing-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.pairing-header h4{color:#2c3e50;font-size:1.2rem;line-height:1.3;margin:0}.confidence{background:linear-gradient(135deg,#28a745,#20c997);border-radius:20px;color:#fff;font-size:.85rem;padding:6px 12px;white-space:nowrap}.pairing-body p{color:#495057;line-height:1.5;margin:10px 0}.pairing-body p strong{color:#2c3e50}.explanation{color:#6c757d!important;font-size:.95rem;font-style:italic}.pairing-details{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px}.pairing-details span{border-radius:15px;font-size:.8rem;font-weight:500;padding:6px 12px}.pairing-details .type{background:#d4af371a;border:1px solid #d4af374d;color:#d4af37}.pairing-details .occasion{background:#3498db1a;border:1px solid #3498db4d;color:#3498db}.no-pairings{color:#6c757d;padding:60px 20px}.no-pairings p{font-size:1.1rem;margin:0}.analytics-section{background:#fff;box-shadow:0 2px 10px #0000001a;padding:30px}.analytics-section h3{color:#2c3e50;margin-bottom:30px;text-align:center}.analytics-grid{grid-gap:25px;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.analytics-card{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #e9ecef;border-radius:12px;padding:25px;text-align:center;transition:all .3s ease}.analytics-card:hover{border-color:#d4af37;box-shadow:0 8px 25px #0000001a;transform:translateY(-3px)}.analytics-card h4{color:#2c3e50;font-size:1.2rem;margin-bottom:10px}.analytics-card p{color:#6c757d;font-size:.95rem;line-height:1.4;margin-bottom:20px}.metric{color:#d4af37;font-size:2.5rem;font-weight:700;text-shadow:0 2px 4px #0000001a}@media (max-width:768px){.tenant-pairing-manager{padding:15px}.header h2{font-size:1.8rem}.tabs{flex-wrap:wrap}.tabs button{font-size:.9rem;padding:12px 15px}.pairings-header{align-items:stretch;flex-direction:column}.beverage-form,.inventory-tabs,.pairings-grid{grid-template-columns:1fr}.analytics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.analytics-grid{grid-template-columns:1fr}.pairing-header{flex-direction:column;gap:10px}.confidence{align-self:flex-start}}.business-admin-dashboard{font-family:Arial,sans-serif}.business-admin-dashboard,.business-admin-loading{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.business-admin-loading{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center}.loading-spinner{height:50px;margin-bottom:20px;width:50px}.business-admin-error{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px;text-align:center}.business-admin-error h2{font-size:2rem;margin-bottom:10px}.business-admin-error button{background:#fff;border:none;border-radius:8px;color:#667eea;cursor:pointer;font-weight:600;margin-top:20px;padding:12px 24px;transition:all .3s ease}.business-admin-error button:hover{box-shadow:0 5px 15px #0003;transform:translateY(-2px)}.admin-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #fff3;box-shadow:0 2px 20px #0000001a;padding:15px 30px}.header-content{align-items:center;display:flex;justify-content:space-between;max-width:1400px}.header-left h1{color:#2d3748;font-size:1.8rem;font-weight:700;margin:0 0 5px}.user-info{align-items:center;display:flex;gap:15px}.user-email{color:#666;font-size:.9rem}.admin-badge{font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.admin-badge.platform{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.admin-badge.restaurant{background:linear-gradient(135deg,#ffecd2,#fcb69f);color:#8b4513}.logout-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .3s ease}.logout-button:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.error-banner{align-items:center;background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff;display:flex;gap:10px;padding:12px 30px;position:relative}.error-icon{font-size:1.2rem}.error-text{flex:1 1;font-weight:500}.error-close{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:24px;justify-content:center;padding:0;transition:background .3s ease;width:24px}.error-close:hover{background:#fff3}.admin-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border-bottom:1px solid #fff3;padding:0 30px}.nav-tabs{display:flex;margin:0 auto;max-width:1400px;overflow-x:auto}.nav-tab{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:#666;font-weight:500;padding:15px 25px;transition:all .3s ease;white-space:nowrap}.nav-tab.active,.nav-tab:hover{background:#667eea0d;color:#667eea}.nav-tab.active{border-bottom-color:#667eea}.admin-content{margin:0 auto;max-width:1400px;min-height:calc(100vh - 200px);padding:30px}.overview-section{color:#fff}.overview-header{margin-bottom:40px;text-align:center}.overview-header h2{font-size:2.5rem;font-weight:700;margin:0 0 10px}.overview-header p{font-size:1.1rem;margin:0;opacity:.9}.overview-stats{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:40px}.stat-card{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;display:flex;gap:20px;padding:25px;transition:all .3s ease}.stat-card:hover{box-shadow:0 15px 40px #00000026;transform:translateY(-5px)}.stat-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;color:#fff;display:flex;font-size:2.5rem;height:60px;justify-content:center;width:60px}.stat-content{flex:1 1}.stat-number{color:#2d3748;font-size:2.2rem;font-weight:700;margin:0 0 5px}.stat-label{color:#666;font-size:.9rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.quick-actions{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;padding:30px}.quick-actions h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin:0 0 20px}.action-buttons{display:flex;flex-wrap:wrap;gap:15px}.action-button{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.action-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.action-button.secondary{background:linear-gradient(135deg,#ffecd2,#fcb69f);color:#8b4513}.action-button:hover{box-shadow:0 5px 15px #0003;transform:translateY(-2px)}.restaurant-detail{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;color:#2d3748;padding:30px}.restaurant-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.restaurant-header h2{font-size:2rem;font-weight:700;margin:0}.admin-button{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.admin-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.admin-button:hover{box-shadow:0 5px 15px #0003;transform:translateY(-2px)}.restaurant-info{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 1fr}.actions-section h3,.info-section h3{color:#2d3748;font-size:1.3rem;font-weight:700;margin:0 0 20px}.info-grid{grid-gap:15px;gap:15px}.info-item{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:10px 0}.info-item label{color:#4a5568;font-weight:600}.info-item span{color:#2d3748}.plan-badge{border-radius:20px;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.plan-badge.free{background:#e2e8f0;color:#4a5568}.plan-badge.pro{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.plan-badge.enterprise{background:linear-gradient(135deg,#ffd89b,#19547b);color:#fff}.status-badge{border-radius:20px;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.status-badge.active{background:#c6f6d5;color:#22543d}.status-badge.inactive{background:#fed7d7;color:#742a2a}.action-list{grid-gap:15px;display:grid;gap:15px}.action-item{align-items:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;display:flex;gap:15px;padding:15px;text-align:left;transition:all .3s ease;width:100%}.action-item:hover{background:#edf2f7;border-color:#667eea;transform:translateX(5px)}.action-icon{font-size:1.5rem;text-align:center;width:40px}.action-text{color:#2d3748;font-weight:500}@media (max-width:768px){.header-content{gap:15px}.header-content,.user-info{align-items:flex-start;flex-direction:column}.user-info{gap:8px}.admin-content{padding:20px 15px}.overview-stats{grid-template-columns:1fr}.stat-card{padding:20px}.restaurant-info{grid-template-columns:1fr}.restaurant-header{align-items:flex-start;gap:15px}.action-buttons,.restaurant-header{flex-direction:column}.nav-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (max-width:480px){.admin-nav,.header-content{padding:0 15px}.overview-header h2{font-size:2rem}.stat-number{font-size:1.8rem}.restaurant-header h2{font-size:1.5rem}}.pairing-management-section{color:#2d3748}.no-restaurant-selected{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;padding:40px;text-align:center}.selection-prompt h3{color:#2d3748;font-size:1.8rem;font-weight:700;margin:0 0 10px}.selection-prompt p{color:#666;font-size:1.1rem;margin:0 0 30px}.restaurant-selection-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:30px}.restaurant-selection-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;padding:25px;position:relative;text-align:left;transition:all .3s ease}.restaurant-selection-card:hover{border-color:#667eea;box-shadow:0 8px 25px #00000026;transform:translateY(-3px)}.restaurant-selection-card h4{color:#2d3748;font-size:1.3rem;font-weight:700;margin:0 0 10px}.restaurant-selection-card p{color:#666;line-height:1.5;margin:0 0 15px}.restaurant-meta{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.restaurant-meta span{align-items:center;color:#666;display:flex;font-size:.9rem;gap:8px}.select-restaurant-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 20px;transition:all .3s ease;width:100%}.select-restaurant-btn:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.no-restaurants{background:#f7fafc;border:2px dashed #e2e8f0;border-radius:12px;margin-top:30px;padding:40px}.no-restaurants p{color:#666;font-size:1.1rem;margin:0}.pairing-management-section .section-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:15px;box-shadow:0 10px 30px #0000001a;margin-bottom:30px;padding:30px;text-align:center}.pairing-management-section .section-header h2{color:#2d3748;font-size:2.2rem;font-weight:700;margin:0 0 10px}.pairing-management-section .section-header p{color:#666;font-size:1.1rem;margin:0}.phase4-dashboard{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;min-height:100vh;padding:2rem}.phase4-dashboard.error,.phase4-dashboard.loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:50vh}.loading-spinner{border:4px solid #ffffff4d;border-top-color:#fff;margin-bottom:1rem}.dashboard-header{margin-bottom:3rem;text-align:center}.dashboard-header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.dashboard-header p{font-size:1.2rem;font-weight:300;opacity:.9}.dashboard-tabs{flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:2rem}.dashboard-tabs button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #fff3;border-radius:25px;color:#fff;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem}.dashboard-tabs button:hover{background:#fff3;border-color:#fff6;transform:translateY(-2px)}.dashboard-tabs button.active{background:#ffffff4d;border-color:#fff9;box-shadow:0 4px 15px #fff3}.dashboard-content{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;box-shadow:0 8px 32px #0000001a}.phase4-overview h3{font-size:1.8rem;font-weight:600;margin-bottom:1.5rem}.overview-metrics{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:3rem}.metric-card{background:#ffffff26;border-radius:15px;transition:transform .3s ease}.metric-card:hover{transform:translateY(-5px)}.metric-card h3{letter-spacing:1px;opacity:.8}.metric-card h3,.metric-value{margin-bottom:.5rem}.metric-change{font-size:.85rem;opacity:.7}.recent-activity{background:#ffffff0d;border-radius:15px}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{align-items:center;background:#ffffff1a;border-left:4px solid;border-radius:10px;justify-content:space-between;padding:1rem}.activity-item.high-impact{border-left-color:#ff6b6b}.activity-item.medium-impact{border-left-color:#feca57}.activity-item.low-impact{border-left-color:#48dbfb}.activity-message{flex:1 1;font-weight:500}.activity-time{font-size:.85rem;opacity:.7}.guest-profile-section{padding:1rem 0}.profile-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.profile-stats{display:flex;font-size:.9rem;gap:1.5rem}.profile-stats span{background:#ffffff26;border-radius:20px;padding:.5rem 1rem}.profile-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:2fr 1fr}.preferences-section h4{font-size:1.2rem;margin-bottom:1rem}.preference-list{display:flex;flex-direction:column;gap:1rem}.preference-item{align-items:center;background:#ffffff1a;border-radius:10px;display:flex;gap:1rem;padding:1rem}.preference-name{font-weight:500;min-width:150px}.confidence-bar{background:#fff3;border-radius:4px;height:8px}.confidence-fill{background:linear-gradient(90deg,#48dbfb,#0abde3);transition:width .5s ease}.confidence-value{color:#48dbfb;min-width:50px;text-align:right}.profile-metrics{display:flex;flex-direction:column;gap:1rem}.metric{border-radius:10px}.profile-metrics .metric-value{color:#48dbfb;font-weight:700}.no-guest-message{padding:3rem;text-align:center}.enable-button{background:linear-gradient(45deg,#48dbfb,#0abde3);border:none;border-radius:25px;color:#fff;cursor:pointer;font-weight:600;margin-top:1rem;padding:1rem 2rem;transition:transform .3s ease}.enable-button:hover{transform:translateY(-2px)}.interactive-menu-section h3{font-size:1.8rem;margin-bottom:2rem}.interaction-metrics{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.interaction-card{background:#ffffff1a;border-radius:15px;padding:1.5rem;text-align:center}.interaction-card h4{font-size:.9rem;letter-spacing:1px;margin-bottom:1rem;opacity:.8;text-transform:uppercase}.big-number{color:#48dbfb;font-size:3rem;font-weight:700;margin-bottom:.5rem}.interaction-card small{font-size:.8rem;opacity:.7}.menu-features{background:#ffffff0d;border-radius:15px;padding:1.5rem}.feature-status h4{margin-bottom:1rem}.features-list{display:flex;flex-direction:column;gap:.75rem}.feature-item{align-items:center;background:#ffffff1a;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem 1rem}.feature-item.active{border-left:4px solid #48dbfb}.status{background:#fff3;border-radius:12px;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.analytics-section h3{font-size:1.8rem;margin-bottom:2rem}.analytics-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.analytics-card{background:#ffffff1a;border-radius:15px;padding:1.5rem}.analytics-card h4{color:#48dbfb;font-size:1.1rem;margin-bottom:1rem}.insight-stats,.revenue-stats{display:flex;flex-direction:column;gap:.75rem}.stat{background:#ffffff1a;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem}.stat-value{font-weight:700}.stat-value.growth{color:#48dbfb}.popular-list,.trending-list{display:flex;flex-direction:column;gap:.75rem}.popular-item,.trending-item{align-items:center;background:#ffffff1a;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem}.category-name,.item-name{flex:1 1;font-weight:500}.item-stats{font-size:.85rem;opacity:.8}.growth-indicator{color:#48dbfb;font-size:.9rem;font-weight:700}.inventory-ai-section h3{font-size:1.8rem;margin-bottom:2rem}.inventory-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.inventory-card{background:#ffffff1a;border-radius:15px;padding:1.5rem}.inventory-card h4{color:#feca57;font-size:1.1rem;margin-bottom:1rem}.alerts-list,.recommendations-list{display:flex;flex-direction:column;gap:1rem}.alert-item{align-items:center;background:#ffffff1a;border-left:4px solid;border-radius:10px;display:flex;justify-content:space-between;padding:1rem}.alert-item.high{border-left-color:#ff6b6b}.alert-item.medium{border-left-color:#feca57}.alert-item.low{border-left-color:#48dbfb}.alert-info{flex:1 1}.item-name{display:block;font-weight:600;margin-bottom:.25rem}.stock-info{font-size:.85rem;opacity:.8}.urgency-badge{border-radius:12px;font-size:.7rem;font-weight:700;padding:.25rem .75rem;text-transform:uppercase}.urgency-badge.high{background:#ff6b6b;color:#fff}.urgency-badge.medium{background:#feca57;color:#333}.urgency-badge.low{background:#48dbfb;color:#fff}.recommendation-item{border-left:4px solid #48dbfb;border-radius:10px;padding:1rem}.rec-header{margin-bottom:.5rem}.rec-item{font-weight:600}.rec-category{background:#fff3;border-radius:12px;font-size:.8rem;padding:.25rem .75rem}.rec-reasoning{font-size:.9rem;line-height:1.4;margin-bottom:.75rem;opacity:.9}.rec-metrics{align-items:center;display:flex;justify-content:space-between}.roi{color:#48dbfb}.priority,.roi{font-weight:700}.priority{border-radius:12px;font-size:.7rem;padding:.25rem .75rem}.priority.high{background:#ff6b6b;color:#fff}.priority.medium{background:#feca57;color:#333}.optimization-stats{display:flex;flex-direction:column;gap:1rem}.optimization-metric{background:#ffffff1a;border-radius:8px;display:flex;justify-content:space-between;padding:1rem}.optimization-metric .metric-value{color:#48dbfb;font-weight:700}@media (max-width:1200px){.inventory-grid,.profile-content{grid-template-columns:1fr}}@media (max-width:768px){.phase4-dashboard{padding:1rem}.dashboard-header h1{font-size:2rem}.dashboard-header p{font-size:1rem}.dashboard-tabs{gap:.5rem}.dashboard-tabs button{font-size:.85rem;padding:.5rem 1rem}.dashboard-content{padding:1rem}.overview-metrics{grid-template-columns:1fr}.interaction-metrics{grid-template-columns:repeat(2,1fr)}.analytics-grid{grid-template-columns:1fr}.profile-header{align-items:flex-start;flex-direction:column}.profile-stats{flex-direction:column;gap:.5rem}}@media (max-width:480px){.interaction-metrics{grid-template-columns:1fr}.big-number,.metric-value{font-size:2rem}}.phase5-dashboard{background:linear-gradient(135deg,#667eea,#764ba2);color:#333;min-height:100vh}.phase5-dashboard.error,.phase5-dashboard.loading{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center}.loading-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.loading-overlay .spinner{animation:spin 1s linear infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:40px;width:40px}.error-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:12px;color:#fff;padding:2rem;text-align:center}.error-container h2{color:#ff6b6b;margin-bottom:1rem}.error-container button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;margin-top:1rem;padding:.75rem 1.5rem;transition:background .3s ease}.error-container button:hover{background:#5a67d8}.error-toast{background:#ff6b6b;border-radius:6px;box-shadow:0 4px 12px #0003;gap:1rem;padding:1rem;position:fixed;right:20px;top:20px;z-index:1000}.error-toast,.error-toast button{align-items:center;color:#fff;display:flex}.error-toast button{background:none;border:none;cursor:pointer;font-size:1.2rem;height:24px;justify-content:center;padding:0;width:24px}.dashboard-header{background:#ffffff1a;border-bottom:1px solid #fff3;padding:2rem}.header-content{margin:0 auto;max-width:1200px}.header-content h1{color:#fff;font-size:2rem;font-weight:600;margin:0 0 .5rem}.header-content p{color:#fffc;font-size:1.1rem;margin:0 0 1.5rem}.header-actions{flex-wrap:wrap;gap:2rem}.realtime-toggle{align-items:center;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem}.realtime-toggle input[type=checkbox]{margin:0}.service-status{display:flex;flex-wrap:wrap;gap:1rem}.status-indicator{background:#ffffff1a;border-radius:20px;color:#fff;font-size:.8rem;font-weight:500;padding:.25rem .75rem}.status-indicator.healthy{background:#48bb78}.status-indicator.warning{background:#ed8936}.status-indicator.error{background:#f56565}.dashboard-tabs{background:#ffffff1a;border-bottom:1px solid #fff3;display:flex;gap:0;overflow-x:auto}.dashboard-tabs button{background:none;border:none;border-bottom:3px solid #0000;color:#ffffffb3;cursor:pointer;font-size:.9rem;padding:1rem 1.5rem;transition:all .3s ease;white-space:nowrap}.dashboard-tabs button:hover{background:#ffffff1a;color:#fff}.dashboard-tabs button.active{background:#ffffff26;border-bottom-color:#667eea;color:#fff}.dashboard-content{margin:0 auto;max-width:1200px;padding:2rem}.overview-grid{grid-gap:1.5rem;gap:1.5rem;margin-bottom:2rem}.metric-card h3{color:#fffc;font-size:.9rem;letter-spacing:.5px;margin:0 0 1rem;text-transform:uppercase}.metric-trend{border-radius:20px;display:inline-block;font-size:.8rem;padding:.25rem .5rem}.metric-trend.positive{background:#48bb78;color:#fff}.metric-trend.negative{background:#f56565;color:#fff}.metric-trend.neutral{background:#ed8936;color:#fff}.recent-activity{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;padding:1.5rem}.recent-activity h3{color:#fff;font-size:1.2rem;margin:0 0 1rem}.activity-list{max-height:300px;overflow-y:auto}.activity-item{align-items:flex-start;border-bottom:1px solid #ffffff1a;display:flex;gap:1rem;padding:.75rem 0}.activity-item:last-child{border-bottom:none}.activity-icon{font-size:1.2rem;text-align:center;width:24px}.activity-details p{color:#fff;font-size:.9rem;margin:0}.activity-details small{color:#fff9;font-size:.8rem}.analytics-controls,.automation-controls,.ml-controls,.recognition-controls{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.analytics-controls h3,.automation-controls h3,.ml-controls h3,.recognition-controls h3{color:#fff;font-size:1.2rem;margin:0 0 1rem}.control-buttons{display:flex;flex-wrap:wrap;gap:1rem}.control-buttons button,.upload-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-block;font-size:.9rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.control-buttons button:hover,.upload-button:hover{box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.upload-button{overflow:hidden;position:relative}.ml-insights,.predictions-display,.recognition-results{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;margin-top:1.5rem;padding:1.5rem}.ml-insights h4,.predictions-display h4,.recognition-results h4{color:#fff;font-size:1.1rem;margin:0 0 1rem}.insights-grid,.predictions-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.insight-card,.prediction-card{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:1rem}.insight-card h5,.prediction-card h5{color:#fff;font-size:.9rem;margin:0 0 .5rem}.insight-card p,.prediction-card p{color:#fffc;font-size:.8rem;margin:0}.prediction-metrics{display:flex;flex-direction:column;gap:.5rem}.prediction-metrics .metric{align-items:center;display:flex;justify-content:space-between}.trend{border-radius:12px;font-size:.7rem;font-weight:500;padding:.2rem .5rem}.trend.up{background:#48bb78;color:#fff}.trend.down{background:#f56565;color:#fff}.trend.stable{background:#ed8936;color:#fff}.results-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.result-item{border:1px solid #fff3;border-radius:8px;gap:1rem;padding:1rem}.result-image,.result-item{background:#ffffff1a;display:flex}.result-image{align-items:center;border-radius:6px;height:80px;justify-content:center;overflow:hidden;width:80px}.result-image img{height:100%;object-fit:cover;width:100%}.result-details h5{color:#fff;font-size:.9rem;margin:0 0 .5rem}.result-details p{color:#fffc;font-size:.8rem;margin:0 0 .25rem}.automation-rules{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;margin-top:1.5rem;padding:1.5rem}.automation-rules h4{color:#fff;font-size:1.1rem;margin:0 0 1rem}.rules-list{display:flex;flex-direction:column;gap:1rem}.rule-item{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:1rem}.rule-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.rule-name{color:#fff;font-size:.9rem;font-weight:500}.rule-status{border-radius:12px;font-size:.7rem;font-weight:500;padding:.2rem .5rem}.rule-status.active{background:#48bb78;color:#fff}.rule-status.inactive{background:#f56565;color:#fff}.rule-status.pending{background:#ed8936;color:#fff}.rule-description{color:#fffc;font-size:.8rem;margin:0 0 .5rem}.rule-metrics{color:#fff9;display:flex;font-size:.8rem;gap:1rem}.upload-section{display:flex;flex-wrap:wrap;gap:1rem}@media (max-width:768px){.header-content{padding:1rem}.header-content h1{font-size:1.5rem}.header-actions{align-items:flex-start;gap:1rem}.dashboard-tabs,.header-actions{flex-direction:column}.dashboard-content{padding:1rem}.overview-grid{gap:1rem;grid-template-columns:1fr}.control-buttons{flex-direction:column}.results-list{grid-template-columns:1fr}.result-item,.rule-header{flex-direction:column}.rule-header{align-items:flex-start;gap:.5rem}}@media (max-width:480px){.dashboard-content,.header-content{padding:.5rem}.metric-value{font-size:2rem}.service-status{flex-direction:column;gap:.5rem}}.ml-insights{background:linear-gradient(135deg,#4ecdc4,#44a08d);min-height:100vh;padding:2rem}.ml-insights.loading{align-items:center;display:flex;justify-content:center}.insights-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.insights-header h2{color:#fff;font-size:2rem;font-weight:600;margin:0}.time-range-select{background:#ffffff1a;border:1px solid #ffffff4d;border-radius:6px;color:#fff;font-size:.9rem;padding:.5rem 1rem}.time-range-select option{background:#333;color:#fff}.insights-nav{background:#ffffff1a;border:1px solid #fff3;border-radius:12px;display:flex;gap:0;margin-bottom:2rem;overflow:hidden}.insights-nav button{background:none;border:none;color:#ffffffb3;cursor:pointer;flex:1 1;font-size:.9rem;padding:1rem 1.5rem;text-align:center;transition:all .3s ease}.insights-nav button:hover{background:#ffffff1a;color:#fff}.insights-nav button.active{background:#fff3;color:#fff}.insights-content{margin:0 auto;max-width:1200px}.insights-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;padding:2rem}.insights-section h3{color:#fff;font-size:1.5rem;font-weight:600;margin:0 0 2rem}.behavior-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.behavior-card{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:1.5rem}.behavior-card h4{color:#fff;font-size:1.1rem;font-weight:500;margin:0 0 1rem}.cluster-list{display:flex;flex-direction:column;gap:1rem}.cluster-item{background:#ffffff1a;border:1px solid #fff3;border-radius:6px;padding:1rem}.cluster-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.cluster-name{color:#fff;font-size:.9rem;font-weight:500}.cluster-size{color:#ffffffb3;font-size:.8rem}.cluster-preferences{display:flex;flex-wrap:wrap;gap:.5rem}.preference-tag{background:#4ecdc44d;border:1px solid #4ecdc480;border-radius:12px;color:#fff;font-size:.7rem;padding:.2rem .5rem}.pattern-metrics{display:flex;flex-direction:column;gap:1rem}.metric{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;display:flex;justify-content:space-between;padding:.75rem}.metric span:first-child{color:#fffc;font-size:.9rem}.metric span:last-child{color:#fff;font-weight:500}.sensitivity-level{background:#4ecdc44d;border:1px solid #4ecdc480;border-radius:12px;font-size:.8rem;padding:.2rem .5rem}.success-chart{text-align:center}.success-rate{margin-bottom:1rem}.rate-value{color:#fff;display:block;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.rate-label{color:#ffffffb3;font-size:.9rem}.success-breakdown{display:flex;flex-direction:column;gap:.5rem}.breakdown-item{align-items:center;background:#ffffff1a;border-radius:4px;display:flex;font-size:.8rem;justify-content:space-between;padding:.5rem}.breakdown-item span:first-child{color:#fffc}.breakdown-item span:last-child{color:#fff;font-weight:500}.seasonal-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.seasonal-card{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:1.5rem}.seasonal-card h4{color:#fff;font-size:1.1rem;font-weight:500;margin:0 0 1rem;text-align:center}.seasonal-trends{margin-bottom:1.5rem}.trend-item{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:.5rem 0}.trend-item:last-child{border-bottom:none}.trend-item span:first-child{color:#fffc;font-size:.8rem}.category-name{color:#fff;font-size:.8rem;font-weight:500}.trend-value{border-radius:12px;font-size:.7rem;font-weight:500;padding:.2rem .5rem}.trend-value.up{background:#48bb78;color:#fff}.trend-value.down{background:#f56565;color:#fff}.trend-value.stable{background:#ed8936;color:#fff}.seasonal-recommendations h5{color:#fff;font-size:.9rem;margin:0 0 .5rem}.seasonal-recommendations ul{list-style-type:disc;margin:0;padding-left:1.2rem}.seasonal-recommendations li{color:#fffc;font-size:.8rem;margin-bottom:.25rem}.group-analysis{display:flex;flex-direction:column;gap:2rem}.group-metrics{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.metric-card h4{font-weight:400}.metric-change{color:#ffffffb3}.group-preferences{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:1.5rem}.group-preferences h4{color:#fff;font-size:1.1rem;margin:0 0 1rem}.size-preferences{display:flex;flex-direction:column;gap:1rem}.size-pref-item{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;display:flex;justify-content:space-between;padding:1rem}.size-label{color:#fff;font-size:.9rem;font-weight:500}.pref-details{color:#fffc;display:flex;font-size:.8rem;gap:1rem}.regional-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.regional-card{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:1.5rem}.regional-card h4{color:#fff;font-size:1.1rem;font-weight:500;margin:0 0 1rem;text-align:center}.regional-stats{margin-bottom:1.5rem}.stat-item{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:.5rem 0}.stat-item:last-child{border-bottom:none}.stat-item span:first-child{color:#fffc;font-size:.8rem}.stat-item span:last-child{color:#fff;font-size:.8rem;font-weight:500}.growth-rate{border-radius:12px;font-size:.7rem;font-weight:500;padding:.2rem .5rem}.growth-rate.positive{background:#48bb78;color:#fff}.growth-rate.negative{background:#f56565;color:#fff}.growth-rate.stable{background:#ed8936;color:#fff}.regional-preferences h5{color:#fff;font-size:.9rem;margin:0 0 .5rem}.preference-tags{display:flex;flex-wrap:wrap;gap:.5rem}.pref-tag{background:#4ecdc44d;border:1px solid #4ecdc480;border-radius:12px;color:#fff;font-size:.7rem;padding:.2rem .5rem}@media (max-width:768px){.ml-insights{padding:1rem}.insights-header{align-items:flex-start;gap:1rem}.insights-header,.insights-nav{flex-direction:column}.behavior-grid,.group-metrics,.regional-grid,.seasonal-grid{grid-template-columns:1fr}.group-analysis{gap:1rem}.size-pref-item{align-items:flex-start;flex-direction:column;gap:.5rem}}@media (max-width:480px){.insights-header h2,.metric-value{font-size:1.5rem}.rate-value{font-size:2rem}}.predictive-analytics{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:2rem}.predictive-analytics.loading{align-items:center;display:flex;justify-content:center}.loading-spinner .spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin:0 auto 20px;width:50px}.analytics-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.analytics-header h2{color:#fff;font-size:2rem;font-weight:600;margin:0}.header-controls{align-items:center;display:flex;gap:1rem}.period-select{background:#ffffff1a;border:1px solid #ffffff4d;border-radius:6px;color:#fff;font-size:.9rem;padding:.5rem 1rem}.period-select option{background:#333;color:#fff}.refresh-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;font-size:.9rem;padding:.5rem 1rem;transition:all .3s ease}.refresh-button:hover:not(:disabled){box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.analytics-nav{background:#ffffff1a;border:1px solid #fff3;border-radius:12px;display:flex;gap:0;margin-bottom:2rem;overflow:hidden}.analytics-nav button{background:none;border:none;color:#ffffffb3;cursor:pointer;flex:1 1;font-size:.9rem;padding:1rem 1.5rem;text-align:center;transition:all .3s ease}.analytics-nav button:hover{background:#ffffff1a;color:#fff}.analytics-nav button.active{background:#fff3;color:#fff}.analytics-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;padding:2rem}.analytics-section h3{color:#fff;font-size:1.5rem;font-weight:600;margin:0 0 2rem}.forecast-overview{margin-bottom:2rem}.forecast-summary{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.summary-card{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:1.5rem;text-align:center}.summary-card h4{color:#fffc;font-size:.9rem;letter-spacing:.5px;margin:0 0 1rem;text-transform:uppercase}.trend-indicator{align-items:center;display:flex;gap:.5rem;justify-content:center;margin-bottom:1rem}.trend-arrow{font-size:2rem}.trend-value{color:#fff;font-size:1.5rem;font-weight:700}.trend-description{color:#fffc;font-size:.8rem;margin:0}.peak-info,.top-category{display:flex;flex-direction:column;gap:.5rem}.category-name,.peak-period{color:#fff;font-size:1.2rem;font-weight:500}.category-growth,.peak-increase{color:#48bb78;font-size:.9rem;font-weight:500}.forecast-details h4{color:#fff;font-size:1.2rem;margin:0 0 1rem}.category-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.category-forecast{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:1.5rem}.category-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.category-forecast .category-name{color:#fff;font-size:1rem;font-weight:500}.category-trend{border-radius:12px;font-size:.8rem;font-weight:500;padding:.2rem .5rem}.category-trend.up{background:#48bb78;color:#fff}.category-trend.down{background:#f56565;color:#fff}.category-trend.stable{background:#ed8936;color:#fff}.forecast-chart{margin-bottom:1rem}.chart-bar{background:#fff3;border-radius:4px;height:8px;margin-bottom:.5rem;overflow:hidden}.bar-fill{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;height:100%;transition:width .5s ease}.category-insights p,.confidence-label{color:#fffc;font-size:.8rem}.category-insights p{margin:0}.event-overview{margin-bottom:2rem}.event-metrics{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.metric-card{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:1.5rem}.metric-card h4{color:#fffc;font-size:.9rem;letter-spacing:.5px;margin:0 0 1rem;text-transform:uppercase}.metric-value{color:#fff;font-size:2rem;margin:0 0 .5rem}.metric-change{border-radius:12px;display:inline-block;font-size:.8rem;padding:.2rem .5rem}.metric-change.positive{background:#48bb78;color:#fff}.metric-change.negative{background:#f56565;color:#fff}.metric-change.warning{background:#ed8936;color:#fff}.metric-change.neutral{background:#fff3;color:#fff}.upcoming-events h4{color:#fff;font-size:1.2rem;margin:0 0 1rem}.event-list{display:flex;flex-direction:column;gap:1rem}.event-item{align-items:flex-start;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;display:flex;gap:2rem;justify-content:space-between;padding:1.5rem}.event-info h5{color:#fff;font-size:1rem;font-weight:500;margin:0 0 .5rem}.event-date{color:#ffffffb3;font-size:.8rem}.event-predictions{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.prediction-item{align-items:center;display:flex;font-size:.8rem;justify-content:space-between}.prediction-item span:first-child{color:#fffc}.prediction-item span:last-child{color:#fff;font-weight:500}.impact-value.positive{color:#48bb78}.inventory-overview{margin-bottom:2rem}.optimization-metrics{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.inventory-recommendations h4{color:#fff;font-size:1.2rem;margin:0 0 1rem}.recommendation-list{display:flex;flex-direction:column;gap:1rem}.recommendation-item{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:1.5rem}.rec-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.rec-item{color:#fff;font-size:1rem;font-weight:500}.rec-action{border-radius:6px;font-size:.8rem;font-weight:500;padding:.3rem .75rem}.rec-action.increase{background:#48bb78;color:#fff}.rec-action.decrease{background:#f56565;color:#fff}.rec-action.maintain{background:#ed8936;color:#fff}.rec-details{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.detail-item{align-items:center;display:flex;font-size:.8rem;justify-content:space-between}.detail-item span:first-child{color:#fffc}.detail-item span:last-child{color:#fff;font-weight:500}.revenue-overview{margin-bottom:2rem}.revenue-metrics{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.revenue-strategies h4{color:#fff;font-size:1.2rem;margin:0 0 1rem}.strategy-list{display:flex;flex-direction:column;gap:1rem}.strategy-item{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:1.5rem}.strategy-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.strategy-header h5{color:#fff;font-size:1rem;font-weight:500;margin:0}.strategy-impact{color:#48bb78;font-size:1.1rem;font-weight:600}.strategy-description{color:#fffc;font-size:.9rem;line-height:1.4;margin:0 0 1rem}.strategy-metrics{color:#ffffffb3;display:flex;font-size:.8rem;gap:2rem}@media (max-width:768px){.predictive-analytics{padding:1rem}.analytics-header{align-items:flex-start;gap:1rem}.analytics-header,.analytics-nav{flex-direction:column}.category-grid,.event-metrics,.forecast-summary,.optimization-metrics,.revenue-metrics{grid-template-columns:1fr}.event-item{flex-direction:column;gap:1rem}.event-predictions{min-width:auto}.rec-details{grid-template-columns:1fr}.strategy-header{align-items:flex-start}.strategy-header,.strategy-metrics{flex-direction:column;gap:.5rem}}@media (max-width:480px){.analytics-header h2,.metric-value{font-size:1.5rem}.trend-value{font-size:1.2rem}}.integrated-enhancement-demo{background:linear-gradient(135deg,#667eea,#764ba2);color:#333;font-family:Arial,sans-serif;margin:0 auto;max-width:1200px;min-height:100vh;padding:2rem}.demo-header{background:#fff;border-radius:15px;box-shadow:0 10px 30px #0000001a;margin-bottom:2rem;padding:2rem}.demo-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#ff6b6b,#4ecdc4,#45b7d1);-webkit-background-clip:text;background-clip:text;margin-bottom:1rem}.demo-header p{color:#666;font-size:1.2rem;margin:0 auto;max-width:600px}.rate-limit-panel{background:#fff;border-radius:10px;box-shadow:0 5px 15px #0000001a;margin-bottom:2rem;padding:1.5rem}.rate-limit-panel h3{color:#333;margin-bottom:1rem}.rate-limit-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.rate-limit-item{border:1px solid #e0e0e0;border-radius:8px;padding:1rem;text-align:center}.api-name{color:#555;font-size:.9rem}.api-name,.rate-info .remaining{font-weight:700;margin-bottom:.5rem}.rate-info .remaining{display:block;font-size:1.1rem}.rate-bar{background:#e0e0e0;border-radius:4px;height:8px;overflow:hidden;width:100%}.rate-fill{height:100%;transition:width .3s ease,background-color .3s ease}.beverage-selection{background:#fff;border-radius:10px;box-shadow:0 5px 15px #0000001a;margin-bottom:2rem;padding:2rem}.beverage-selection h2{color:#333;margin-bottom:1.5rem}.beverage-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.beverage-card{background:#fafafa;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;padding:1.5rem;transition:all .3s ease}.beverage-card:hover{border-color:#667eea;box-shadow:0 10px 25px #0000001a;transform:translateY(-5px)}.beverage-card.selected{background:linear-gradient(135deg,#4ecdc4,#44a08d);border-color:#4ecdc4;color:#fff}.beverage-category{background:#667eea;border-radius:15px;color:#fff;display:inline-block;font-size:.8rem;font-weight:700;margin-bottom:1rem;padding:.3rem .8rem;text-transform:uppercase}.beverage-card.selected .beverage-category{background:#fff3}.beverage-card h3{font-size:1.3rem;margin-bottom:.8rem}.beverage-card p{line-height:1.4;margin-bottom:1rem;opacity:.8}.beverage-details{font-size:.9rem;gap:.5rem}.beverage-details span{background:#0000001a;padding:.3rem .6rem}.beverage-card.selected .beverage-details span{background:#fff3}.loading-panel{background:#fff;border-radius:15px;box-shadow:0 10px 30px #0000001a;margin-bottom:2rem;padding:3rem;text-align:center}.loading-spinner{border:6px solid #e0e0e0;border-top-color:#667eea;height:60px;margin:0 auto 1.5rem;width:60px}.loading-steps{margin-top:1.5rem}.loading-steps .step{animation:pulse 2s infinite;color:#666;margin:.5rem 0}.processing-metrics{background:#fff;border-radius:10px;box-shadow:0 5px 15px #0000001a;margin-bottom:2rem;padding:1.5rem}.metrics-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.metric{background:#f8f9fa;border-radius:8px;padding:1rem;text-align:center}.metric-label{color:#666;display:block;font-size:.9rem;margin-bottom:.5rem}.metric-value{color:#667eea;font-size:1.5rem}.enhancement-summary{background:#fff;border-radius:10px;box-shadow:0 5px 15px #0000001a;margin-bottom:2rem;padding:2rem}.enhancement-summary h3{color:#333;margin-bottom:1.5rem}.enhancement-summary h4{border-bottom:2px solid #e0e0e0;color:#555;margin:1.5rem 0 1rem;padding-bottom:.5rem}.confidence-breakdown{margin-bottom:2rem}.confidence-bars{display:flex;flex-direction:column;gap:1rem}.confidence-item{align-items:center;display:flex;gap:1rem}.confidence-item span:first-child{font-weight:500;min-width:120px}.confidence-item span:last-child{font-weight:700;min-width:60px;text-align:right}.confidence-bar{background:#e0e0e0;border-radius:5px;height:10px}.confidence-fill{transition:width .8s ease}.confidence-fill.ai{background:linear-gradient(90deg,#ff6b6b,#ff8e8e)}.confidence-fill.external{background:linear-gradient(90deg,#4ecdc4,#6ed3c4)}.confidence-fill.synthesis{background:linear-gradient(90deg,#45b7d1,#64c5d1)}.confidence-fill.overall{background:linear-gradient(90deg,#667eea,#764ba2)}.confidence-item.overall{border-top:1px solid #e0e0e0;font-weight:700;margin-top:1rem;padding-top:1rem}.sources-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.source-group{background:#f8f9fa;border-radius:8px;padding:1rem}.source-group h5{color:#333;margin-bottom:.8rem}.source-group ul{list-style:none;margin:0;padding:0}.source-group li{border-bottom:1px solid #e0e0e0;color:#666;padding:.3rem 0}.source-group li:last-child{border-bottom:none}.ratings-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.rating-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;padding:.8rem}.rating-value{color:#ff6b6b;font-size:1.2rem;font-weight:700}.rating-consensus{color:#4ecdc4;font-weight:700}.rating-count{color:#667eea;font-weight:700}.insights-content{background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;padding:1.5rem}.insight-item{line-height:1.6;margin-bottom:1rem}.insight-item:last-child{margin-bottom:0}.insight-item strong{color:#333}.error-panel{background:#ffe6e6;border:2px solid #ff6b6b;border-radius:10px;margin-bottom:2rem;padding:2rem;text-align:center}.error-panel h3{color:#d32f2f;margin-bottom:1rem}.error-panel p{color:#666}.demo-info{background:#fff;border-radius:10px;box-shadow:0 5px 15px #0000001a;padding:2rem}.demo-info h3{color:#333;margin-bottom:1.5rem}.info-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;padding:1.5rem}.info-item strong{color:#333;display:block;font-size:1.1rem;margin-bottom:.8rem}.info-item p{color:#666;line-height:1.6;margin:0}@media (max-width:768px){.integrated-enhancement-demo{padding:1rem}.demo-header h1{font-size:2rem}.beverage-grid,.metrics-grid{grid-template-columns:1fr}.confidence-item{align-items:stretch;flex-direction:column;gap:.5rem}.confidence-item span:first-child,.confidence-item span:last-child{min-width:auto;text-align:left}}.analytics-dashboard{background:linear-gradient(135deg,#667eea,#764ba2);color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.analytics-dashboard.loading{align-items:center;display:flex;height:100vh;justify-content:center}.loading-spinner{background:#ffffff1a;color:#fff;font-size:24px;font-weight:600;padding:40px;text-align:center}.dashboard-header,.loading-spinner{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px}.dashboard-header{align-items:center;background:#fffffff2;box-shadow:0 8px 32px #0000001a;display:flex;justify-content:space-between;margin-bottom:32px;padding:24px 32px}.header-content h1{color:#2d3748;font-size:28px;font-weight:700;margin:0 0 8px}.header-content p{color:#718096;font-size:16px;margin:0}.header-actions{align-items:center}.export-btn,.refresh-btn{background:#4299e1;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:all .2s ease}.export-btn:hover,.refresh-btn:hover{background:#3182ce;transform:translateY(-1px)}.refresh-btn.active{background:#48bb78}.export-dropdown{position:relative}.export-menu{background:#fff;border-radius:8px;box-shadow:0 4px 16px #0000001a;display:none;min-width:100px;position:absolute;right:0;top:100%;z-index:10}.export-dropdown:hover .export-menu{display:block}.export-menu button{background:none;border:none;color:#2d3748;cursor:pointer;display:block;padding:8px 12px;text-align:left;width:100%}.export-menu button:hover{background:#f7fafc}.overview-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.metric-card{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:16px;box-shadow:0 4px 16px #0000001a;display:flex;gap:16px;transition:transform .2s ease}.metric-card:hover{transform:translateY(-2px)}.metric-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;font-size:32px;height:60px;justify-content:center;width:60px}.metric-content h3{color:#718096;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 4px;text-transform:uppercase}.metric-value{color:#2d3748;font-size:28px}.section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:16px;box-shadow:0 4px 16px #0000001a;margin-bottom:32px;padding:24px}.section h2{color:#2d3748;font-size:20px;font-weight:700;margin:0 0 20px}.source-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.source-card{background:#f7fafc;border-left:4px solid #4299e1;border-radius:12px;padding:20px}.source-header h3{color:#2d3748;font-size:16px;font-weight:600;margin:0 0 16px}.source-metrics{display:flex;flex-direction:column;gap:8px}.source-metric{align-items:center;display:flex;justify-content:space-between}.metric-label{color:#718096;font-size:14px}.source-metric .metric-value{color:#2d3748;font-weight:600}.category-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.category-card{background:#f7fafc;border-radius:12px;border-top:3px solid #48bb78;padding:16px}.category-header h3{color:#2d3748;font-size:14px;font-weight:600;margin:0 0 12px}.category-stats{display:flex;flex-direction:column;gap:6px}.stat-row{display:flex;font-size:13px;justify-content:space-between}.stat-row span:first-child{color:#718096}.stat-row span:last-child{color:#2d3748;font-weight:600}.sessions-table{overflow-x:auto}.table-header,.table-row{grid-gap:16px;align-items:center;border-bottom:1px solid #e2e8f0;display:grid;gap:16px;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1.5fr;padding:12px 0}.table-header{color:#4a5568;font-size:14px;letter-spacing:.5px;text-transform:uppercase}.table-row{border-radius:8px;cursor:pointer;margin:2px 0;transition:background .2s ease}.table-row:hover{background:#f7fafc}.beverage-name{color:#2d3748}.category{font-size:12px;letter-spacing:.5px;text-transform:uppercase}.status.success{color:#48bb78;font-weight:600}.status.failed{color:#f56565;font-weight:600}.confidence{color:#4299e1;font-weight:600}.processing-time{color:#718096;font-family:Monaco,Menlo,monospace;font-size:13px}.timestamp{color:#a0aec0;font-size:12px}.trends-chart{align-items:end;display:flex;gap:12px;height:120px;padding:20px 0}.trend-day{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:8px}.trend-bar{background:#e2e8f0;border-radius:4px;display:flex;flex-direction:column-reverse;height:80px;overflow:hidden;width:20px}.trend-success{background:linear-gradient(0deg,#48bb78,#68d391);transition:height .3s ease}.trend-failure{background:linear-gradient(0deg,#f56565,#fc8181);transition:height .3s ease}.trend-label{text-align:center}.trend-date{color:#718096;font-size:11px;font-weight:600}.trend-count{color:#a0aec0;font-size:10px}.recommendations-list{display:flex;flex-direction:column;gap:12px}.recommendation{border-left:4px solid;border-radius:8px;display:flex;gap:12px;padding:16px}.recommendation.high{background:#fed7d7;border-left-color:#f56565}.recommendation.medium{background:#fefcbf;border-left-color:#ecc94b}.recommendation.low{background:#c6f6d5;border-left-color:#48bb78}.recommendation-icon{display:flex;font-size:16px;gap:4px}.recommendation-content{flex:1 1}.recommendation-area{color:#2d3748;font-size:14px;font-weight:600;margin-bottom:4px}.recommendation-message{color:#4a5568;font-size:14px;line-height:1.4}.errors-list{display:flex;flex-direction:column;gap:8px}.error-item{align-items:center;background:#fed7d7;border-left:4px solid #f56565;border-radius:8px;display:flex;justify-content:space-between;padding:12px 16px}.error-info{flex:1 1}.error-message{color:#742a2a;font-size:14px;font-weight:600;margin-bottom:4px}.error-meta{color:#c53030;font-size:12px}.error-count{background:#f56565;border-radius:12px;color:#fff;font-size:12px;font-weight:600;min-width:32px;padding:4px 8px;text-align:center}@media (max-width:768px){.analytics-dashboard{padding:16px}.dashboard-header{flex-direction:column;gap:16px;text-align:center}.header-actions{flex-wrap:wrap;justify-content:center}.category-grid,.overview-grid,.source-grid,.table-header,.table-row{grid-template-columns:1fr}.table-header,.table-row{gap:8px}.table-header span,.table-row span{padding:4px 0}.trends-chart{justify-content:center}}.loading{animation:pulse 2s infinite}.phase2-ai-features{margin:0 auto;max-width:1200px;padding:2rem}.ai-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem;padding:1.5rem}.ai-card-header{border-bottom:1px solid #e5e7eb;margin-bottom:1rem;padding-bottom:1rem}.ai-card-title{align-items:center;display:flex;font-size:1.25rem;font-weight:600;gap:.5rem;margin:0}.ai-card-content{padding:0}.ai-button{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background-color .2s}.ai-button:hover{background:#2563eb}.ai-button:disabled{background:#9ca3af;cursor:not-allowed}.ai-input{border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;padding:.5rem;width:100%}.ai-input:focus{border-color:#3b82f6;box-shadow:0 0 0 1px #3b82f6;outline:none}.ai-badge{background:#f3f4f6;border-radius:20px;color:#374151;display:inline-block;font-size:.75rem;font-weight:500;margin-bottom:.25rem;margin-right:.5rem;padding:.25rem .75rem}.ai-tabs{margin-bottom:2rem}.ai-tabs-list{border-bottom:1px solid #e5e7eb;display:flex;margin-bottom:1rem}.ai-tab-trigger{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1rem;transition:all .2s}.ai-tab-trigger:hover{color:#374151}.ai-tab-trigger.active{border-bottom-color:#3b82f6;color:#3b82f6}.ai-tab-content{display:none}.ai-tab-content.active{display:block}.error-state{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;gap:.5rem;padding:1rem}.error-state,.loading-state{align-items:center;display:flex}.loading-state{color:#6b7280;justify-content:center;padding:2rem}.loading-spinner{border:2px solid #e5e7eb;border-top-color:#3b82f6;height:20px;margin-right:.5rem;width:20px}.grid{grid-gap:1rem;display:grid;gap:1rem}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.p-3{padding:.75rem}.p-4{padding:1rem}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-gray-600{color:#4b5563}.text-green-600{color:#059669}.text-blue-600{color:#2563eb}@media (max-width:768px){.grid-cols-2{grid-template-columns:repeat(1,minmax(0,1fr))}.phase2-ai-features{padding:1rem}}.enhancement-test-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:2rem 0}.container{margin:0 auto;max-width:1200px;padding:0 1rem}.test-header{color:#fff;margin-bottom:3rem;text-align:center}.test-header h1{font-size:3rem;font-weight:700;margin-bottom:.5rem}.subtitle{font-size:1.2rem;margin:0;opacity:.9}.test-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin-bottom:3rem}.test-card{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;padding:2rem;transition:transform .2s ease}.test-card:hover{transform:translateY(-2px)}.test-card h2{color:#2d3748;font-size:1.5rem;margin-bottom:.5rem}.test-card p{color:#718096;margin-bottom:1.5rem}.test-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:1rem;padding:12px 24px;transition:all .2s ease;width:100%}.test-button:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.test-button:disabled{cursor:not-allowed;opacity:.6}.test-button.secondary{background:linear-gradient(135deg,#48bb78,#38a169)}.test-button.secondary:hover:not(:disabled){box-shadow:0 4px 12px #48bb7866}.custom-form{margin-bottom:1.5rem}.form-row{display:flex;flex-direction:column;margin-bottom:1rem}.form-row label{color:#2d3748;font-weight:600;margin-bottom:.5rem}.form-row input,.form-row select,.form-row textarea{border:2px solid #e2e8f0;border-radius:6px;font-size:1rem;padding:8px 12px;transition:border-color .2s ease}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:#667eea;outline:none}.result-display{background:#f7fafc;border-left:4px solid #48bb78;border-radius:8px;margin-top:1rem;padding:1.5rem}.result-display.error{background:#fed7d7;border-left-color:#f56565}.result-display.partial{background:#feebc8;border-left-color:#ed8936}.result-display h3{color:#2d3748;margin-bottom:1rem;margin-top:0}.enhancement-summary,.result-details{background:#fff;border-radius:6px;margin-top:1rem;padding:1rem}.enhancement-summary ul{margin:.5rem 0;padding-left:1.5rem}.pairings-preview,.ratings-preview,.tasting-preview{background:#edf2f7;border-radius:6px;margin-top:1rem;padding:1rem}.info-section{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;margin-bottom:2rem;padding:2rem}.info-section h2{color:#2d3748;font-size:2rem;margin-bottom:1.5rem;text-align:center}.capabilities-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.capability-card{background:#f7fafc;border-radius:8px;border-top:4px solid #667eea;padding:1.5rem}.capability-card h3{color:#2d3748;font-size:1.2rem;margin-bottom:1rem}.capability-card ul{list-style:none;margin:0;padding:0}.capability-card li{color:#4a5568;padding:.25rem 0 .25rem 1.5rem;position:relative}.capability-card li:before{color:#48bb78;content:"✓";font-weight:700;left:0;position:absolute}.technical-info{background:linear-gradient(135deg,#2d3748,#4a5568);border-radius:12px;box-shadow:0 10px 30px #0000001a;color:#fff;padding:2rem}.technical-info h2{font-size:2rem;margin-bottom:1.5rem;text-align:center}.tech-details p{font-size:1.1rem;margin:.75rem 0}.tech-details strong{color:#90cdf4}@media (max-width:768px){.test-grid{grid-template-columns:1fr}.test-header h1{font-size:2rem}.container{padding:0 .5rem}.test-card{padding:1.5rem}}.pairing-interface{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 12px #0000000d;margin:16px 0;padding:24px}.pairing-interface.compact{margin:8px 0;padding:16px}.pairing-header{border-bottom:2px solid #f3f4f6;margin-bottom:20px;padding-bottom:16px}.pairing-header h3{align-items:center;color:#111827;display:flex;font-size:1.5rem;font-weight:600;gap:8px;margin:0}.pairing-subtitle{color:#6b7280;font-size:.95rem;line-height:1.4;margin:8px 0 0}.loading-state{padding:40px 20px;text-align:center}.loading-spinner{border:3px solid #f3f4f6;height:40px;margin:0 auto 16px;width:40px}.loading-state p{color:#6b7280;margin:0}.error-state{padding:40px 20px;text-align:center}.retry-button{border-radius:6px;padding:8px 16px}.pairings-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:20px}.pairing-interface.compact .pairings-grid{gap:12px;grid-template-columns:1fr}.pairing-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;overflow:hidden;padding:16px;position:relative;transition:all .2s ease}.pairing-card:hover{border-color:#8b5cf6;box-shadow:0 4px 12px #8b5cf61a;transform:translateY(-2px)}.pairing-info{margin-bottom:12px}.pairing-name{color:#111827;font-size:1.1rem;font-weight:600;line-height:1.3;margin:0 0 4px}.pairing-category{background:#e0e7ff;border-radius:12px;color:#3730a3;display:inline-block;font-size:.75rem;font-weight:500;margin-bottom:8px;padding:2px 8px}.pairing-description{color:#4b5563;font-size:.9rem}.pairing-metrics{margin:12px 0}.confidence-score{margin-bottom:8px}.confidence-bar{border-radius:2px;height:4px;margin-bottom:4px;transition:width .3s ease}.confidence-text{color:#374151;font-size:.8rem;font-weight:500}.science-score{align-items:center;background:#f3f4f6;border-radius:4px;display:flex;font-size:.8rem;justify-content:space-between;padding:4px 8px}.science-score.excellent{background:#dcfce7;color:#166534}.science-score.good{background:#fef3c7;color:#92400e}.science-score.poor{background:#fee2e2;color:#991b1b}.score-label{font-weight:500}.score-value{font-weight:600}.pairing-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.pairing-tag{background:#f3f4f6;border-radius:4px;color:#374151;font-size:.7rem;font-weight:500;padding:2px 6px}.no-pairings{color:#6b7280;padding:40px 20px;text-align:center}.generate-button{background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;margin-top:12px;padding:8px 16px;transition:background-color .2s}.generate-button:hover{background:#059669}.pairing-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.pairing-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-height:80vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px 16px}.modal-header h3{color:#111827;font-size:1.3rem;font-weight:600;margin:0}.close-button{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:1.5rem;padding:4px;transition:background-color .2s}.close-button:hover{background:#f3f4f6;color:#374151}.modal-content{padding:24px}.pairing-hero{background:#f9fafb;border-radius:8px;margin-bottom:24px;padding:16px;text-align:center}.pairing-hero h4{color:#111827;font-size:1.2rem;font-weight:600;margin:0 0 8px}.pairing-hero p{color:#6b7280;font-style:italic;margin:0}.explanation-sections{display:flex;flex-direction:column;gap:20px}.ai-explanation,.pairing-factors,.science-explanation{border:1px solid #e5e7eb;border-radius:8px;padding:16px}.ai-explanation{background:#eff6ff;border-color:#dbeafe}.science-explanation{background:#f0fdf4;border-color:#dcfce7}.pairing-factors{background:#fefce8;border-color:#fef3c7}.explanation-sections h5{align-items:center;color:#111827;display:flex;font-size:1rem;font-weight:600;gap:8px;margin:0 0 12px}.explanation-sections h6{color:#374151;font-size:.9rem;font-weight:600;margin:12px 0 8px}.explanation-sections p{color:#4b5563;line-height:1.5;margin:0 0 8px}.confidence-detail{font-size:.9rem;margin-top:8px}.rationale-breakdown ul{list-style:none;margin:0;padding:0}.rationale-item{background:#ffffff80;border-radius:4px;gap:12px;margin-bottom:8px;padding:8px}.points{font-size:.85rem;font-weight:600;min-width:40px}.points.positive{color:#059669}.points.negative{color:#dc2626}.reason{color:#374151;font-size:.85rem;line-height:1.4}.factors-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.factor-item{background:#ffffffb3;border-radius:4px;display:flex;flex-direction:column;font-size:.8rem;padding:8px}.factor-name{color:#374151;font-weight:600;margin-bottom:2px}.factor-value{color:#6b7280}@media (max-width:768px){.pairing-interface{margin:8px 0;padding:16px}.pairings-grid{gap:12px;grid-template-columns:1fr}.pairing-modal{margin:10px;max-height:90vh}.modal-content{padding:16px}.factors-grid{grid-template-columns:1fr}}@media (max-width:480px){.pairing-header h3{font-size:1.3rem}.pairing-modal-overlay{padding:10px}}.pairing-explorer{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 20px #00000014;margin:20px 0;padding:32px}.explorer-header{border-bottom:2px solid #f3f4f6;margin-bottom:32px;padding-bottom:20px;text-align:center}.explorer-header h2{align-items:center;color:#111827;display:flex;font-size:2rem;font-weight:700;gap:12px;justify-content:center;margin:0 0 8px}.explorer-subtitle{color:#6b7280;font-size:1.1rem;line-height:1.5;margin:0}.search-mode-tabs{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;display:flex;margin-bottom:24px;padding:4px}.mode-tab{align-items:center;background:none;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;flex:1 1;font-size:.95rem;font-weight:500;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s ease}.mode-tab:hover{background:#8b5cf60d;color:#374151}.mode-tab.active{background:#8b5cf6;box-shadow:0 2px 4px #8b5cf633;color:#fff}.search-interface{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:32px;padding:24px}.search-input-group{display:flex;gap:12px;margin-bottom:20px}.search-input{border:2px solid #e5e7eb;border-radius:8px;flex:1 1;font-size:1rem;padding:12px 16px;transition:border-color .2s}.search-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a;outline:none}.search-button{background:#8b5cf6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:12px 20px;transition:background-color .2s;white-space:nowrap}.search-button:hover:not(:disabled){background:#7c3aed}.search-button:disabled{background:#9ca3af;cursor:not-allowed}.food-categories,.menu-items-quick-select{margin-top:20px}.category-label{color:#374151;font-size:.9rem;font-weight:500;margin:0 0 12px}.category-tags{display:flex;flex-wrap:wrap;gap:8px}.category-tag{background:#e0e7ff;border:none;border-radius:20px;color:#3730a3;cursor:pointer;font-size:.85rem;font-weight:500;padding:6px 12px;transition:all .2s}.category-tag:hover{background:#c7d2fe;transform:translateY(-1px)}.menu-items-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.menu-item-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;padding:12px;text-align:left;transition:all .2s}.menu-item-card:hover{border-color:#8b5cf6;box-shadow:0 2px 8px #8b5cf61a;transform:translateY(-1px)}.menu-item-name{color:#111827;display:block;font-size:.9rem;font-weight:600;margin-bottom:4px}.menu-item-category{color:#6b7280;display:block;font-size:.8rem}.occasion-search{text-align:center}.search-description{color:#6b7280;font-size:1rem;line-height:1.5;margin:0 0 20px}.occasions-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.occasion-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;color:#374151;cursor:pointer;font-size:.9rem;font-weight:500;padding:16px 12px;text-align:center;transition:all .2s}.occasion-card:hover{background:#f8fafc;border-color:#8b5cf6;box-shadow:0 4px 12px #8b5cf61a;transform:translateY(-2px)}.occasion-card.selected{background:#8b5cf6;border-color:#8b5cf6;box-shadow:0 4px 12px #8b5cf633;color:#fff}.dietary-search{text-align:center}.dietary-options{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));text-align:left}.dietary-option{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:8px 12px;transition:all .2s}.dietary-option:hover{background:#f8fafc;border-color:#8b5cf6}.dietary-option input[type=checkbox]{accent-color:#8b5cf6;margin:0}.dietary-label{color:#374151;font-size:.9rem;font-weight:500}.suggestions-section{margin-top:32px}.suggestions-title{color:#111827;font-size:1.5rem;font-weight:600;margin:0 0 20px;text-align:center}.suggestions-loading{padding:60px 20px;text-align:center}.suggestions-loading p{color:#6b7280;font-size:1.1rem;margin:0}.suggestions-error{padding:40px 20px;text-align:center}.error-message{font-size:1rem;margin:0}.no-suggestions{color:#6b7280;font-size:1.1rem;padding:60px 20px;text-align:center}.suggestions-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.suggestion-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;overflow:hidden;padding:20px;position:relative;transition:all .2s ease}.suggestion-card:hover{border-color:#8b5cf6;box-shadow:0 8px 25px #8b5cf626;transform:translateY(-4px)}.suggestion-card:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a;outline:none}.suggestion-header{margin-bottom:16px}.beverage-name{font-size:1.2rem;line-height:1.3;margin:0 0 4px}.beverage-type{background:#e0e7ff;border-radius:12px;color:#3730a3;display:inline-block;font-size:.8rem;font-weight:500;padding:2px 8px}.suggestion-metrics{align-items:center;display:flex;gap:12px;justify-content:space-between;margin:16px 0}.confidence-indicator{align-items:center;display:flex;flex:1 1;gap:8px}.metric-label{color:#6b7280;font-size:.8rem;font-weight:500;min-width:40px}.confidence-bar{background:#f3f4f6;border-radius:3px;flex:1 1;height:6px;overflow:hidden}.confidence-fill{background:linear-gradient(90deg,#ef4444,#f97316,#eab308,#84cc16,#22c55e);border-radius:3px;height:100%;transition:width .3s ease}.confidence-value{color:#374151;font-size:.8rem;font-weight:600;min-width:35px}.science-indicator{align-items:center;background:#f3f4f6;border-radius:6px;color:#6b7280;display:flex;font-size:.8rem;font-weight:600;gap:4px;padding:4px 8px}.science-indicator.excellent{background:#dcfce7;color:#166534}.science-indicator.good{background:#fef3c7;color:#92400e}.science-indicator.poor{background:#fee2e2;color:#991b1b}.science-score{font-weight:700}.suggestion-reason{color:#4b5563;font-size:.95rem;line-height:1.5;margin:0 0 12px}.food-suggestion{align-items:center;background:#f0fdf4;border:1px solid #dcfce7;border-radius:8px;display:flex;gap:8px;margin-top:12px;padding:8px 12px}.food-label{color:#166534;font-size:.8rem;font-weight:500}.food-name{color:#15803d;font-weight:600}.generic-suggestion{text-align:center}.generic-suggestion h4{color:#111827;font-size:1.1rem;font-weight:600;margin:0 0 8px}.generic-suggestion p{color:#6b7280;font-size:.95rem;line-height:1.4;margin:0}@media (max-width:768px){.pairing-explorer{margin:10px 0;padding:20px}.explorer-header h2{font-size:1.7rem}.search-mode-tabs{flex-direction:column}.mode-tab{padding:10px 12px}.search-input-group{flex-direction:column}.search-button{width:100%}.dietary-options,.occasions-grid,.suggestions-grid{grid-template-columns:1fr}.suggestions-grid{gap:16px}.menu-items-grid{grid-template-columns:1fr}.suggestion-metrics{align-items:stretch;flex-direction:column;gap:8px}}@media (max-width:480px){.pairing-explorer{padding:16px}.explorer-header{margin-bottom:24px}.explorer-header h2{flex-direction:column;font-size:1.5rem;gap:8px}.search-interface{padding:16px}.category-tags{justify-content:center}}.pairing-analytics{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 20px #00000014;margin:20px 0;overflow:hidden}.analytics-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:32px}.header-content h2{align-items:center;display:flex;font-size:2rem;font-weight:700;gap:12px;margin:0 0 8px}.header-subtitle{font-size:1.1rem;line-height:1.4;margin:0;opacity:.9}.header-actions{display:flex;gap:12px}.refresh-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:10px 16px;transition:all .2s}.refresh-button:hover:not(:disabled){background:#ffffff4d;transform:translateY(-1px)}.refresh-button:disabled{cursor:not-allowed;opacity:.6}.refresh-button.refreshing{animation:pulse 1.5s infinite}.analytics-tabs{background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;overflow-x:auto}.metric-tab{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;display:flex;flex:1 1;font-weight:500;gap:8px;justify-content:center;min-width:200px;padding:16px 20px;transition:all .2s}.metric-tab:hover{background:#f3f4f6;color:#374151}.metric-tab.active{background:#fff;border-bottom-color:#8b5cf6;color:#8b5cf6}.tab-icon{font-size:1.2rem}.tab-label{font-size:.95rem;white-space:nowrap}.analytics-body{min-height:500px;padding:32px}.analytics-content{margin:0 auto;max-width:1200px}.content-header{border-bottom:2px solid #f3f4f6;margin-bottom:32px;padding-bottom:20px;text-align:center}.content-header h3{color:#111827;font-size:1.8rem;font-weight:600;margin:0 0 8px}.content-header p{color:#6b7280;font-size:1.1rem;margin:0}.error-state,.loading-state{padding:80px 20px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#8b5cf6;height:48px;margin:0 auto 20px;width:48px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-message{font-size:1.1rem;margin:0 0 16px}.retry-button{background:#8b5cf6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:background-color .2s}.retry-button:hover{background:#7c3aed}.pairings-table{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.table-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#374151;font-weight:600;padding:16px 20px}.table-header,.table-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:2fr 1fr 1fr 1fr 1fr}.table-row{align-items:center;border-bottom:1px solid #f3f4f6;padding:20px;transition:background-color .2s}.table-row:hover{background:#f9fafb}.table-row:last-child{border-bottom:none}.pairing-info{display:flex;flex-direction:column;gap:4px}.beverage-name{color:#111827;font-size:1rem;font-weight:600}.food-name{color:#6b7280;font-size:.9rem}.orders-count{color:#111827;font-size:1.1rem;font-weight:600}.rating-display{align-items:center;display:flex;flex-direction:column;gap:4px}.rating-value{color:#111827;font-size:1.1rem;font-weight:600}.stars{color:#fbbf24;font-size:.9rem}.revenue-amount{color:#059669;font-size:1.1rem;font-weight:600}.trend{border-radius:4px;font-size:1rem;font-weight:600;padding:4px 8px;text-align:center}.trend.positive{background:#dcfce7;color:#059669}.trend.negative{background:#fee2e2;color:#dc2626}.feedback-metrics{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.metric-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;text-align:center}.metric-card h4{color:#374151;font-size:1.1rem;font-weight:600;margin:0 0 16px}.large-metric{margin:16px 0}.metric-value{color:#111827;display:block;font-size:2.5rem;font-weight:700}.metric-value.positive{color:#059669}.metric-stars{color:#fbbf24;font-size:1.5rem;margin-top:8px}.metric-subtitle{color:#6b7280;font-size:.9rem;margin:8px 0 0}.sentiment-chart{display:flex;flex-direction:column;gap:8px;margin:16px 0}.sentiment-bar{align-items:center;border-radius:6px;color:#fff;display:flex;font-size:.9rem;font-weight:600;height:40px;justify-content:center;overflow:hidden;position:relative}.sentiment-bar.positive{background:linear-gradient(90deg,#10b981,#059669)}.sentiment-bar.neutral{background:linear-gradient(90deg,#f59e0b,#d97706)}.sentiment-bar.negative{background:linear-gradient(90deg,#ef4444,#dc2626)}.keyword-cloud{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:16px 0}.keyword-tag{background:#e0e7ff;border-radius:20px;color:#3730a3;font-size:.85rem;font-weight:500;padding:6px 12px}.trends-content{grid-gap:32px;align-items:start;display:grid;gap:32px;grid-template-columns:1fr 2fr}.trend-metric{text-align:center}.trending-pairings h4{color:#111827;font-size:1.3rem;font-weight:600;margin:0 0 20px}.trending-list{display:flex;flex-direction:column;gap:12px}.trending-item{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:12px;padding:12px 16px;transition:all .2s}.trending-item:hover{background:#f3f4f6;border-color:#d1d5db}.trend-rank{color:#8b5cf6;font-weight:700;min-width:30px}.trend-pairing{color:#111827;flex:1 1;font-weight:500}.trend-indicator{font-size:1.2rem}.revenue-metrics{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.analytics-footer{background:#f9fafb;border-top:1px solid #e5e7eb;padding:16px 32px;text-align:center}.last-updated{color:#6b7280;font-size:.9rem;margin:0}@media (max-width:1024px){.analytics-header{gap:16px;text-align:center}.analytics-header,.analytics-tabs{flex-direction:column}.metric-tab{min-width:auto}.table-header,.table-row{gap:8px;grid-template-columns:1fr;text-align:center}.table-header{display:none}.table-row{align-items:center;display:flex;flex-direction:column;padding:16px}.trends-content{gap:24px;grid-template-columns:1fr}}@media (max-width:768px){.analytics-header{padding:24px 20px}.analytics-body{padding:20px}.feedback-metrics,.revenue-metrics{grid-template-columns:1fr}.analytics-footer{padding:12px 20px}}@media (max-width:480px){.header-content h2{font-size:1.6rem}.header-subtitle{font-size:1rem}.content-header h3{font-size:1.5rem}.metric-value{font-size:2rem}}.pairing-feedback{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 12px #0000000d;margin:16px 0;padding:24px}.pairing-feedback.inline{border-radius:8px;margin:8px 0;padding:16px}.feedback-header{border-bottom:2px solid #f3f4f6;margin-bottom:24px;padding-bottom:16px;text-align:center}.feedback-header h3{align-items:center;color:#111827;display:flex;font-size:1.4rem;font-weight:600;gap:8px;justify-content:center;margin:0 0 8px}.pairing-description{color:#6b7280;font-size:1rem;line-height:1.4;margin:0}.pairing-description strong{color:#374151}.feedback-form{display:flex;flex-direction:column;gap:20px}.feedback-form h4{color:#374151;font-size:1.1rem;font-weight:600;margin:0 0 12px}.star-rating{text-align:center}.stars-container{display:flex;gap:4px;justify-content:center;margin:12px 0}.star{background:none;border:none;border-radius:4px;color:#d1d5db;cursor:pointer;font-size:2rem;padding:4px;transition:all .2s ease}.star.active,.star:hover{color:#fbbf24;transform:scale(1.1)}.rating-label{color:#6b7280;font-size:1rem;font-weight:500;margin:8px 0 0;min-height:24px}.quick-feedback{text-align:center}.quick-options{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:12px 0}.quick-option{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:4px;min-width:70px;padding:12px 8px;transition:all .2s}.quick-option:hover{background:#f8fafc;border-color:#8b5cf6;transform:translateY(-2px)}.quick-option.selected{background:#8b5cf6;border-color:#8b5cf6;color:#fff}.option-emoji{display:block;font-size:1.5rem}.option-label{font-size:.8rem;font-weight:500}.reason-selection{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.reason-options{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.reason-option{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:8px 12px;transition:all .2s}.reason-option:hover{background:#f8fafc;border-color:#8b5cf6}.reason-option input[type=checkbox]{accent-color:#8b5cf6;margin:0}.reason-label{color:#374151;font-size:.9rem;font-weight:500}.text-feedback{position:relative}.feedback-textarea{border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:1rem;min-height:80px;padding:12px 16px;resize:vertical;transition:border-color .2s;width:100%}.feedback-textarea:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a;outline:none}.character-count{background:#fff;border-radius:4px;bottom:8px;color:#6b7280;font-size:.8rem;padding:2px 4px;position:absolute;right:12px}.conditional-section{animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-message{background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-weight:500;padding:12px 16px;text-align:center}.form-actions{border-top:1px solid #f3f4f6;display:flex;gap:12px;justify-content:flex-end;padding-top:16px}.reset-button{background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;color:#6b7280;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .2s}.reset-button:hover{background:#f3f4f6;color:#374151}.submit-button{background:#8b5cf6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;min-width:140px;padding:10px 24px;transition:all .2s}.submit-button:hover:not(:disabled){background:#7c3aed;transform:translateY(-1px)}.submit-button:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.feedback-success{padding:40px 20px;text-align:center}.success-icon{font-size:3rem;margin-bottom:16px}.feedback-success h3{color:#059669;font-size:1.5rem;font-weight:600;margin:0 0 8px}.feedback-success p{color:#6b7280;font-size:1rem;line-height:1.5;margin:0 0 20px}.new-feedback-button{background:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:background-color .2s}.new-feedback-button:hover{background:#059669}.pairing-feedback.inline .feedback-header{margin-bottom:16px;padding-bottom:12px}.pairing-feedback.inline .feedback-header h3{font-size:1.1rem}.pairing-feedback.inline .feedback-form{gap:16px}.pairing-feedback.inline .quick-options{gap:6px}.pairing-feedback.inline .quick-option{min-width:60px;padding:8px 6px}.pairing-feedback.inline .option-emoji{font-size:1.2rem}.pairing-feedback.inline .option-label{font-size:.7rem}.pairing-feedback.inline .reason-options{gap:8px;grid-template-columns:1fr}.pairing-feedback.inline .form-actions{justify-content:center;padding-top:12px}.pairing-feedback.inline .feedback-success{padding:20px 10px}.pairing-feedback.inline .success-icon{font-size:2rem;margin-bottom:8px}.pairing-feedback.inline .feedback-success h3{font-size:1.2rem}@media (max-width:768px){.pairing-feedback{margin:12px 0;padding:20px 16px}.stars-container{gap:2px}.star{font-size:1.8rem}.quick-options{gap:6px}.quick-option{min-width:60px;padding:10px 6px}.reason-options{grid-template-columns:1fr}.form-actions{flex-direction:column}.reset-button,.submit-button{width:100%}}@media (max-width:480px){.feedback-header h3{flex-direction:column;font-size:1.2rem;gap:4px}.pairing-description{font-size:.9rem}.quick-options{justify-content:space-between}.quick-option{flex:1 1;max-width:70px}.option-emoji{font-size:1.4rem!important}.option-label{font-size:.7rem!important}}.phase2-pairing-demo{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1400px;padding:20px}.demo-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff;margin-bottom:40px;padding:40px 20px;position:relative;text-align:center}.demo-header h1{font-size:2.5rem;font-weight:700;margin:0 0 12px}.demo-subtitle{font-size:1.2rem;line-height:1.5;margin:0;opacity:.9}.admin-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:20px;color:#fff;font-size:.9rem;font-weight:500;padding:6px 12px;position:absolute;right:20px;top:20px}.demo-navigation{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.nav-tab{background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:20px;text-align:left;transition:all .2s ease}.nav-tab:hover{border-color:#8b5cf6;box-shadow:0 4px 12px #8b5cf61a;transform:translateY(-2px)}.nav-tab.active{background:#8b5cf6;border-color:#8b5cf6;box-shadow:0 8px 25px #8b5cf633;color:#fff}.tab-label{display:block;font-size:1.1rem;font-weight:600}.tab-description{display:block;font-size:.9rem;opacity:.8}.demo-body{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:32px;overflow:hidden}.tab-content{padding:32px}.demo-section{margin:0 auto;max-width:1200px}.demo-section h3{color:#111827;font-size:1.8rem;font-weight:600;margin:0 0 8px;text-align:center}.section-description{color:#6b7280;font-size:1.1rem;line-height:1.5;margin:0 0 32px;text-align:center}.beverage-showcase{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:32px;padding:24px}.beverage-showcase h4{color:#374151;font-size:1.2rem;font-weight:600;margin:0 0 16px}.beverage-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.beverage-card h5{color:#111827;font-size:1.3rem;font-weight:600;margin:0 0 8px}.beverage-card p{color:#6b7280;line-height:1.5;margin:0 0 12px}.beverage-details{display:flex;flex-wrap:wrap;gap:16px}.beverage-details span{background:#e0e7ff;border-radius:12px;color:#3730a3;font-size:.85rem;font-weight:500;padding:4px 8px}.feedback-demo{display:flex;flex-direction:column;gap:32px}.feedback-demo h4{color:#374151;font-size:1.2rem;font-weight:600;margin:0 0 16px;text-align:center}.feedback-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.feedback-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-height:80vh;max-width:500px;overflow-y:auto;width:100%}.feedback-modal .modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px 16px}.feedback-modal .modal-header h3{color:#111827;font-size:1.3rem;font-weight:600;margin:0;text-align:left}.feedback-modal .close-button{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:1.5rem;padding:4px;transition:background-color .2s}.feedback-modal .close-button:hover{background:#f3f4f6;color:#374151}.feedback-modal .modal-content{padding:0}.feedback-modal .pairing-feedback{border:none;border-radius:0;box-shadow:none;margin:0}.demo-footer{background:#f9fafb;border:1px solid #e5e7eb;border-radius:16px;padding:32px;text-align:center}.implementation-status h4{color:#059669;font-size:1.4rem;font-weight:600;margin:0 0 20px}.completed-features{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.feature{background:#dcfce7;border:1px solid #bbf7d0;border-radius:20px;color:#166534;font-size:.9rem;font-weight:500;padding:8px 16px}@media (max-width:1024px){.phase2-pairing-demo{padding:16px}.demo-header{padding:32px 16px}.demo-navigation{grid-template-columns:1fr}.tab-content{padding:24px 16px}.beverage-details{justify-content:center}.completed-features{align-items:center;flex-direction:column}}@media (max-width:768px){.demo-header h1{font-size:2rem}.demo-subtitle{font-size:1.1rem}.admin-badge{display:inline-block;margin-top:16px;position:static}.nav-tab{padding:16px;text-align:center}.feedback-demo{gap:24px}.feedback-modal{margin:10px;max-height:90vh}}@media (max-width:480px){.demo-header{padding:24px 12px}.demo-header h1{font-size:1.7rem}.demo-subtitle{font-size:1rem}.tab-content{padding:20px 12px}.demo-section h3{font-size:1.5rem}.section-description{font-size:1rem}.beverage-showcase{padding:16px}.demo-footer{padding:24px 16px}}.beer-pairing-interface{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px;box-shadow:0 8px 32px #0000001a;margin:20px 0;padding:20px}.beer-pairing-interface.compact{margin:10px 0;padding:15px}.interface-header{margin-bottom:30px;text-align:center}.interface-header h2{color:#2c3e50;font-size:2rem;font-weight:700;margin-bottom:10px}.subtitle{color:#7f8c8d;font-style:italic;margin-bottom:0}.tab-navigation{background:#ffffff4d;border-radius:12px;display:flex;justify-content:center;margin-bottom:30px;padding:4px}.tab-btn{background:#0000;border:none;border-radius:8px;color:#2c3e50;cursor:pointer;flex:1 1;font-weight:600;padding:12px 24px;transition:all .3s ease}.tab-btn.active{background:#3498db;box-shadow:0 4px 12px #3498db4d;color:#fff}.tab-btn:hover:not(.active){background:#ffffff80}.selection-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 1fr;margin-bottom:30px}.beer-selection h3,.food-selection h3{color:#2c3e50;font-size:1.3rem;font-weight:600;margin-bottom:20px}.item-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:20px}.item-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;cursor:pointer;font-family:inherit;padding:15px;text-align:left;transition:all .3s ease}.item-card:hover{border-color:#3498db;box-shadow:0 4px 12px #3498db33;transform:translateY(-2px)}.item-card.selected{background:#f8fff9;border-color:#2ecc71;box-shadow:0 4px 12px #2ecc714d}.item-card h4{color:#2c3e50;font-size:1rem;font-weight:600;margin:0 0 10px}.profile-preview{display:flex;flex-direction:column;gap:4px}.profile-preview span{color:#7f8c8d;font-size:.85rem}.btn-secondary{background:#95a5a6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-secondary:hover{background:#7f8c8d;transform:translateY(-1px)}.pairing-actions{margin:30px 0;text-align:center}.btn-primary{background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:12px;box-shadow:0 4px 12px #3498db4d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px 30px;transition:all .3s ease}.btn-primary:hover:not(:disabled){box-shadow:0 6px 16px #3498db66;transform:translateY(-2px)}.pairing-result{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-top:30px;padding:25px}.result-header{align-items:center;border-bottom:2px solid #ecf0f1;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.result-header h3{color:#2c3e50;font-size:1.4rem;margin:0}.score-badge{border-radius:20px;font-size:.9rem;font-weight:700;padding:8px 16px}.score-badge.excellent{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.score-badge.good{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff}.score-badge.fair{background:linear-gradient(135deg,#f39c12,#d68910);color:#fff}.rationale-list h4{color:#2c3e50;font-size:1.1rem;margin-bottom:15px}.rationale-item{align-items:flex-start;background:#f8f9fa;border-left:4px solid #3498db;border-radius:8px;display:flex;margin-bottom:12px;padding:10px}.rationale-item .points{background:#3498db;border-radius:12px;color:#fff;font-size:.85rem;font-weight:700;margin-right:12px;min-width:40px;padding:4px 8px;text-align:center}.rationale-item .reason{color:#2c3e50;flex:1 1;line-height:1.4}.course-builder{background:#fff;border-radius:12px;margin-bottom:30px;padding:25px}.course-builder h3{color:#2c3e50;font-size:1.3rem;margin-bottom:20px}.course-adder{align-items:center;display:flex;flex-wrap:wrap;gap:15px;margin-bottom:25px}.course-adder select{border:2px solid #e9ecef;border-radius:8px;flex:1 1;font-size:1rem;min-width:200px;padding:12px}.course-adder select:focus{border-color:#3498db;outline:none}.course-list{margin-bottom:25px}.course-item{align-items:center;background:#f8f9fa;border-left:4px solid #3498db;border-radius:8px;display:flex;gap:15px;margin-bottom:10px;padding:15px}.course-number{color:#3498db;font-weight:700;min-width:80px}.course-food{color:#2c3e50;flex:1 1;font-weight:600}.course-pairing{color:#7f8c8d;flex:1 1;font-style:italic}.btn-remove{align-items:center;background:#e74c3c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:30px;justify-content:center;transition:all .3s ease;width:30px}.btn-remove:hover{background:#c0392b;transform:scale(1.1)}.multicourse-result{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:25px}.multicourse-result .result-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:25px}.total-score{background:#34495e;border-radius:20px;color:#fff;font-weight:600;padding:8px 16px}.course-results{grid-gap:20px;display:grid;gap:20px}.course-result{background:#f8f9fa;border-left:4px solid #3498db;border-radius:8px;padding:20px}.course-result h4{color:#2c3e50;font-size:1.1rem;margin:0 0 10px}.course-score{background:#3498db;border-radius:12px;color:#fff;display:inline-block;font-size:.9rem;font-weight:600;margin-bottom:15px;padding:4px 12px}.rationale-item-mini{align-items:center;display:flex;font-size:.9rem;margin-bottom:8px}.rationale-item-mini .points{background:#95a5a6;border-radius:8px;color:#fff;font-size:.75rem;font-weight:600;margin-right:8px;min-width:30px;padding:2px 6px;text-align:center}.rationale-item-mini .reason{color:#2c3e50;line-height:1.3}.compact-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.compact-header h3{color:#2c3e50;font-size:1.1rem;margin:0}.powered-by{color:#7f8c8d;font-size:.8rem;font-style:italic}.compact-quick-pairing{align-items:center;display:flex;gap:10px}.compact-quick-pairing select{border:2px solid #e9ecef;border-radius:6px;flex:1 1;padding:8px}.compact-quick-pairing .btn-primary{font-size:.9rem;padding:8px 16px}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-height:80vh;max-width:500px;overflow-y:auto;padding:30px;width:90%}.modal-content h3{color:#2c3e50;font-size:1.3rem;margin:0 0 20px}.modal-content input[type=text]{border:2px solid #e9ecef;border-radius:8px;font-size:1rem;margin-bottom:20px;padding:12px;width:100%}.modal-content input[type=text]:focus{border-color:#3498db;outline:none}.profile-sliders{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr;margin-bottom:25px}.slider-group{display:flex;flex-direction:column;gap:5px}.slider-group label{color:#2c3e50;font-size:.9rem;font-weight:600}.slider-group input[type=range]{margin:5px 0;width:100%}.modal-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:20px}.modal-actions button{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .3s ease}.modal-actions button[type=button]{background:#95a5a6;color:#fff}.modal-actions button[type=button]:hover{background:#7f8c8d}.modal-actions button[type=submit]{background:#3498db;color:#fff}.modal-actions button[type=submit]:hover{background:#2980b9}@media (max-width:768px){.selection-grid{gap:20px}.item-grid,.selection-grid{grid-template-columns:1fr}.course-adder{align-items:stretch;flex-direction:column}.course-item{gap:10px}.course-item,.multicourse-result .result-header{align-items:flex-start;flex-direction:column}.profile-sliders{grid-template-columns:1fr}.compact-quick-pairing{flex-direction:column}}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.btn-primary:disabled{animation:pulse 1.5s infinite;cursor:not-allowed;opacity:.6}.score-badge.exceptional{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff}.score-badge.needs-work{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}
/*# sourceMappingURL=main.4abdbda1.css.map*/