html{font-size:16px;scroll-behavior:smooth;overflow-x:hidden}body{margin:0;padding:0;min-width:320px;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-main);color:var(--text-primary);overflow-x:hidden;font-family:Source Sans Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}h1{font-family:Playfair Display,serif;font-size:clamp(2rem,5vw,3.5rem);line-height:1.1}h2{font-family:Playfair Display,serif;font-size:clamp(1.5rem,4vw,2.5rem);line-height:1.2}h3{font-family:Playfair Display,serif;font-size:clamp(1.25rem,3vw,1.75rem);line-height:1.3}button{border-radius:8px;border:1px solid transparent;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;font-family:inherit;background-color:var(--primary-color);color:#fff;cursor:pointer;transition:all .3s ease;min-height:44px}button:hover{background-color:var(--primary-dark);transform:translateY(-2px)}button:focus,button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}button:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (min-width: 768px){button{padding:.875rem 2rem;min-height:auto}}:root{--primary-purple: #8B6B80;--purple-light: #A584A0;--purple-dark: #6B4A5F;--purple-muted: #C8B8C5;--purple-pale: #E6D6E0;--glass-bg: rgba(139, 107, 128, .1);--glass-bg-medium: rgba(139, 107, 128, .15);--glass-border: rgba(255, 255, 255, .2);--glass-border-strong: rgba(255, 255, 255, .3);--bg-main: #ffffff;--bg-warm: #F9F7F4;--bg-white: #ffffff;--bg-glass: rgba(255, 255, 255, .25);--text-primary: #A584A0;--text-secondary: #6B4A5F;--text-light: #777777;--text-on-purple: #ffffff;--primary-color: #8B6B80;--primary-light: #A584A0;--primary-dark: #6B4A5F;--secondary-color: #C8B8C5;--accent-color: #E6D6E0;--shadow-soft: 0 4px 30px rgba(139, 107, 128, .1);--shadow-medium: 0 8px 32px rgba(139, 107, 128, .15);--shadow-strong: 0 12px 40px rgba(139, 107, 128, .2);--shadow-glow: 0 0 20px rgba(139, 107, 128, .3);--border-glass: 1px solid rgba(255, 255, 255, .18);--border-light: 1px solid rgba(139, 107, 128, .1);--border-medium: 1px solid rgba(139, 107, 128, .2);--gradient-purple: linear-gradient(135deg, var(--primary-purple) 0%, var(--purple-dark) 100%);--gradient-purple-light: linear-gradient(135deg, var(--purple-light) 0%, var(--primary-purple) 100%);--gradient-glass: linear-gradient(135deg, rgba(255, 255, 255, .1) 0%, rgba(255, 255, 255, .05) 100%);--z-base: 1;--z-navigation: 10;--z-menu-categories: 15;--z-back-button: 20;--z-dropdown: 100;--z-modal-overlay: 900;--z-modal: 1000;--z-hamburger: 1001}.App{min-height:100vh;display:flex;flex-direction:column}main{flex:1}*{box-sizing:border-box}.glass{background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:var(--border-glass);border-radius:16px}.glass-card{background:var(--bg-glass);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:var(--border-glass);border-radius:20px;box-shadow:var(--shadow-soft);transition:all .3s ease}.glass-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-medium);border:1px solid rgba(255,255,255,.3)}h1,h2,h3,h4,h5,h6{font-family:Playfair Display,serif;font-weight:600;margin-top:0;color:var(--text-primary)}p{font-family:Source Sans Pro,sans-serif;line-height:1.6;color:var(--text-secondary)}a{color:var(--primary-color);text-decoration:none;transition:color .3s ease}a:hover{color:var(--primary-dark);text-decoration:underline}.container{width:100%;margin:0 auto;padding:0 1rem}@media (min-width: 768px){.container{padding:0 2rem}}@media (min-width: 1024px){.container{max-width:1200px}}.about{min-height:100vh;animation:fadeIn .8s ease-out;background-image:url(/about-bg.jpeg);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;position:relative}.about:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffd9;z-index:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes potatoBounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-8px)}60%{transform:translateY(-4px)}}.about-content{padding:2rem 1rem;position:relative;z-index:1}.about-grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:center;margin-bottom:2rem}.about-text{animation:slideInLeft 1s ease-out .5s both}.about-image{animation:slideInRight 1s ease-out .7s both;display:none}.restaurant-image{width:100%;height:auto;border-radius:20px;object-fit:cover;box-shadow:0 10px 30px #8b6b8033;transition:all .3s ease;border:1px solid rgba(139,107,128,.2);background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.restaurant-image:hover{transform:translateY(-5px) scale(1.02);box-shadow:0 20px 50px #8b6b804d;border:1px solid rgba(139,107,128,.4)}.about-text h2{color:var(--primary-color);margin-bottom:1.5rem;text-align:center}.about-text p{font-size:1rem;line-height:1.7;color:var(--text-secondary);margin-bottom:1.5rem}.image-placeholder{background:var(--bg-white);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:var(--border-glass);height:250px;border-radius:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--primary-color);font-size:1.1rem;font-weight:500;text-align:center;padding:1rem;position:relative;overflow:hidden;transition:all .3s ease}.image-placeholder:hover{transform:scale(1.02);box-shadow:var(--shadow-medium)}.potato-icons{display:flex;gap:1rem;margin-bottom:1rem;font-size:2rem}.potato-icon{animation:potatoBounce 2s infinite;display:inline-block}.potato-icon:nth-child(2){animation-delay:.2s}.potato-icon:nth-child(3){animation-delay:.4s}.image-placeholder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-purple-light);opacity:.1;z-index:-1}.values{text-align:center;animation:fadeIn 1s ease-out .9s both}.values h2{color:var(--text-primary);margin-bottom:2rem;font-size:2.5rem}.values-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.value{background:var(--bg-glass);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:var(--border-glass);padding:1.5rem;border-radius:20px;box-shadow:var(--shadow-soft);transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:relative;overflow:hidden;animation:slideInLeft .8s ease-out calc(1.1s + var(--delay, 0s)) both}.value:nth-child(1){--delay: 0s}.value:nth-child(2){--delay: .1s}.value:nth-child(3){--delay: .2s}.value:nth-child(4){--delay: .3s}.value:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-glass);opacity:.3;z-index:-1}.value:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-strong);border:1px solid rgba(255,255,255,.4)}.value:hover:before{opacity:.5}.value h3{font-size:1.25rem;color:var(--primary-color);margin-bottom:1rem}.value p{color:var(--text-secondary);line-height:1.6;margin:0}@media (min-width: 768px){.about{background-image:none}.about:before{display:none}.about-content{padding:4rem 2rem}.about-image{display:block}.about-grid{grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:4rem}.about-text,.about-text h2{text-align:left}.about-text p{font-size:1.1rem}.image-placeholder{height:350px;font-size:1.2rem}.values h2{margin-bottom:2rem}.values-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.value{padding:2rem}}@media (min-width: 1024px){.about{background-image:none}.about:before{display:none}.about-content{padding:5rem 2rem}.about-image{display:block}.about-grid{gap:4rem;margin-bottom:5rem;max-width:1200px;margin-left:auto;margin-right:auto}.image-placeholder{height:400px}.values-grid{max-width:1200px;margin:0 auto}}.contact{min-height:100vh}.contact-content{padding:2rem 1rem;background-color:var(--background-light)}.contact-grid{display:grid;grid-template-columns:1fr;gap:2rem;max-width:800px;margin:0 auto}.contact-info h2{color:var(--text-primary);margin-bottom:1.5rem;text-align:center}.info-card{background:var(--bg-glass);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:var(--border-glass);padding:1.5rem;border-radius:16px;box-shadow:var(--shadow-soft);margin-bottom:1.5rem;transition:all .3s ease;position:relative;overflow:hidden}.info-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-glass);opacity:.3;z-index:-1}.info-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-medium);border:1px solid rgba(255,255,255,.3)}.info-card h3{color:var(--primary-color);margin-bottom:.5rem;font-size:1.2rem}.info-card p{color:var(--text-secondary);line-height:1.6;margin:0}.info-card a{color:var(--primary-color);text-decoration:none;transition:color .3s ease}.info-card a:hover{color:var(--primary-dark);text-decoration:underline}.hours p{margin:.5rem 0}.map-link{display:inline-block;margin-top:.5rem;padding:.5rem 1rem;background:var(--primary-color);color:#fff!important;text-decoration:none;border-radius:8px;font-size:.9rem;font-weight:500;transition:all .3s ease}.map-link:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #8b6b804d;text-decoration:none}.whatsapp-interface{margin-top:1rem}.whatsapp-label{display:block;font-weight:600;color:var(--primary-color);margin-bottom:.5rem;font-size:.9rem}.whatsapp-textarea{width:100%;min-height:80px;padding:.75rem;border:2px solid rgba(139,107,128,.2);border-radius:8px;font-family:inherit;font-size:.9rem;line-height:1.4;color:var(--text-primary);background:var(--bg-white);resize:vertical;transition:border-color .3s ease,box-shadow .3s ease;margin-bottom:.75rem;box-sizing:border-box}.whatsapp-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #8b6b801a}.whatsapp-textarea::placeholder{color:var(--text-light)}.whatsapp-contact-btn{display:flex;align-items:center;gap:.5rem;background:#25d366;color:#fff;border:none;padding:.75rem 1rem;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .3s ease;min-height:44px;justify-content:center;width:100%}.whatsapp-contact-btn:hover:not(:disabled){background:#22c55e;transform:translateY(-2px);box-shadow:0 4px 12px #25d3664d}.whatsapp-contact-btn:active:not(:disabled){transform:translateY(0);transition:all .1s ease}.whatsapp-contact-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}@media (min-width: 768px){.contact-content{padding:3rem 2rem}.contact-grid{grid-template-columns:1fr;gap:3rem}.contact-info h2{text-align:left}.whatsapp-textarea{font-size:16px}}@media (min-width: 1024px){.contact-content{padding:4rem 2rem}.contact-grid{gap:3rem;max-width:1200px;margin:0 auto}}.events{min-height:100vh;padding:2rem 0}.events-content{padding:2rem 1rem}.events-content h1{text-align:center;color:var(--primary-color);margin-bottom:1rem;font-size:2.5rem}.events-intro{text-align:center;color:var(--text-secondary);max-width:600px;margin:0 auto 3rem;line-height:1.6;font-size:1.1rem}.events-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:3rem}.event-card{background:transparent;border:none;border-radius:0;overflow:visible;box-shadow:none;transition:none;padding:0;margin-bottom:0}.event-card:hover{transform:none;box-shadow:none}.event-caption,.event-caption p{display:none}.event-embed{width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;display:flex;justify-content:center;align-items:center}.event-embed iframe,.event-embed blockquote{max-width:540px;width:540px;margin:0 auto;border-radius:0;overflow:hidden;transition:none;position:relative;left:0}.event-embed iframe[src*="instagram.com"]{height:600px!important;max-height:600px!important;overflow:hidden!important}.events-loading{text-align:center;padding:4rem 2rem;color:var(--text-secondary);font-size:1.1rem}.events-error{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.events-error p{margin-bottom:1.5rem;color:#c62828}.retry-btn{background:var(--primary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:500;transition:background-color .3s ease}.retry-btn:hover{background:var(--primary-dark)}.no-events{text-align:center;padding:4rem 2rem;color:var(--text-secondary);font-size:1.1rem;background:var(--accent-color);border-radius:12px;margin-bottom:3rem}.events-contact{text-align:center;padding:2rem;background:var(--accent-color);border-radius:12px;margin-top:2rem}.events-contact h2{color:var(--primary-color);margin-bottom:1rem}.events-contact p{color:var(--text-secondary);line-height:1.6}.events-contact a{color:var(--primary-color);text-decoration:none;font-weight:500}.events-contact a:hover{text-decoration:underline}@media (max-width: 768px){.events-content{padding:0}.events-content h1{margin:1rem;font-size:2rem}.events-intro{margin:0 1rem 2rem;font-size:1rem}.events-grid{gap:0}.event-card{border-radius:0;padding:0;border:none;box-shadow:none;background:transparent;margin-bottom:0}.event-card:hover{transform:none;box-shadow:none}.event-embed{width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;display:flex;justify-content:center;align-items:center}.event-embed iframe,.event-embed blockquote{max-width:100vw;width:100vw;margin:0 auto}.event-embed iframe[src*="instagram.com"]{width:100vw!important;border-radius:0!important;margin:0 auto!important;position:relative!important;left:0!important;height:600px!important;max-height:600px!important;overflow:hidden!important}}@media (min-width: 768px){.events-content{padding:3rem 2rem}.events-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2.5rem}.event-banner{height:250px}.event-details{flex-direction:row;gap:2rem}}@media (min-width: 1024px){.events-content{padding:4rem 2rem;max-width:1200px;margin:0 auto}.events-grid{grid-template-columns:repeat(auto-fit,minmax(450px,1fr))}.event-banner{height:280px}}.home{background-image:url(/bg-1.JPG);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;position:relative;min-height:100vh;filter:contrast(1) brightness(.85)}.home:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffd9;z-index:0}.home-header{position:absolute;top:2rem;left:50%;transform:translate(-50%);text-align:center;font-size:1.1rem;z-index:var(--z-menu-categories)}.header-bold{font-weight:700;color:var(--text-primary)}.header-gray{color:#888;font-weight:400}.home-content{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;padding:2rem;text-align:center;position:relative;z-index:1}.home-logo{width:60%;height:60%;object-fit:contain;margin-bottom:2rem;filter:drop-shadow(0 4px 20px rgba(139,107,128,.15))}.home-buttons{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;justify-content:center}.home-btn{color:var(--text-primary);padding:1rem 1.5rem;border:1px solid rgba(255,255,255,.2);border-radius:16px;text-decoration:none;font-weight:600;font-size:1rem;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;transition:all .2s cubic-bezier(.25,.46,.45,.94);letter-spacing:-.01em;min-width:110px;text-align:center;border:1px solid var(--text-primary)}.home-btn:hover{background:#fffffff2;transform:translateY(-1px) scale(1.02);box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a}.home-btn:active{transform:translateY(0) scale(.98);transition:all .1s ease}.home-btn:has(svg){display:flex;align-items:center;justify-content:center;min-width:50px;padding:1rem}.home-description{color:var(--text-secondary);font-size:1.1rem;line-height:1.6;max-width:500px;margin:0;font-weight:300}.restaurant-footer{background:transparent;color:var(--text-primary);text-align:center;position:relative;z-index:1}.footer-content{max-width:600px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.footer-contact{display:flex;flex-direction:column;gap:.5rem}.footer-address,.footer-phone{font-size:1.1rem;font-weight:400;margin:0;color:var(--text-secondary);line-height:1.4}.footer-social{display:flex;justify-content:center;gap:1.5rem}.social-icon{font-size:1.8rem;text-decoration:none;padding:.75rem;border-radius:50%;background:#8b6b801a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(139,107,128,.2);transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;width:50px;height:50px;color:var(--primary-color)}.social-icon:hover{background:#8b6b8033;transform:translateY(-3px) scale(1.1);box-shadow:0 10px 25px #8b6b8026;color:var(--primary-dark)}.footer-copyright{display:flex;flex-direction:column;gap:.25rem;color:var(--text-secondary)}.footer-copyright p{font-size:.9rem;margin:0;line-height:1.4}.footer-copyright strong{color:var(--primary-color);font-weight:600}@media (max-width: 768px){.home{background-image:url(/mobile-cover.jpeg)}.home-header{top:1.5rem;font-size:1rem}.home-content{padding:2rem 1rem 1rem;min-height:100vh}.home-content h1,.home-content h2,.home-content h3,.home-content p,.home-description{text-shadow:0 1px 3px rgba(255,255,255,.8);font-weight:500}.home-logo{width:90%;height:90%;margin-bottom:3.5rem}.home-buttons{flex-direction:column;gap:.5rem;margin-bottom:1.5rem;width:100%;max-width:280px}.home-btn{padding:.8rem 1.2rem;font-size:.95rem;width:100%;min-width:unset;text-shadow:0 1px 3px rgba(255,255,255,.8);background:#ffffff4d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:2px solid var(--primary-color)}.home-description{font-size:.9rem;margin-top:.5rem}.restaurant-footer{padding:1.5rem 1rem;margin-top:2rem}.footer-content{gap:1.5rem}.footer-address,.footer-phone{font-size:1rem}.social-icon{font-size:1.5rem;width:45px;height:45px}}@media (min-width: 768px){.home-header{left:50%;transform:translate(-50%);text-align:center}}@media (min-width: 1024px){.home-header{top:2.5rem;font-size:1.2rem;left:50%;transform:translate(-50%);text-align:center}.home-logo{width:50%;height:50%;margin-bottom:3rem}.home-buttons{gap:1.5rem;margin-bottom:3rem}.home-btn{padding:1.2rem 2rem;font-size:1.1rem;min-width:130px}.home-description{font-size:1.2rem;max-width:600px}.footer-content{max-width:1200px;gap:2.5rem;flex-direction:row;justify-content:space-between;align-items:center}.footer-address,.footer-phone{font-size:1.2rem}.social-icon{font-size:2rem;width:55px;height:55px}.footer-copyright{flex:1;text-align:left;order:1;align-items:flex-start}.footer-contact{flex:1;text-align:center;order:2;align-items:center}.footer-social{flex:1;justify-content:flex-end;order:3;align-items:flex-end}.footer-copyright p{font-size:1rem}}.instagram-section{padding:0;background:none;display:flex;flex-direction:column;gap:0;align-items:center;max-width:none;margin:0;position:relative;z-index:1}.instagram-post{position:relative;max-width:540px;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:0}.instagram-caption{display:none}.instagram-caption:hover{transform:rotate(0) scale(1.05);box-shadow:0 12px 40px #8b6b8033}.instagram-caption p{margin:0;font-size:.9rem;color:var(--primary-color);font-weight:500;line-height:1.4;text-align:center}.instagram-embed{width:100%;max-width:540px;display:flex;justify-content:center}.instagram-embed iframe,.instagram-embed blockquote{max-width:540px;width:100%;margin:0;border-radius:0;overflow:hidden;transition:none;position:relative;left:0}.instagram-embed iframe[src*="instagram.com"]{height:600px!important;max-height:600px!important;overflow:hidden!important}.instagram-embed iframe[src*="instagram.com"]:after{display:none!important}.instagram-embed iframe:hover,.instagram-embed blockquote:hover{transform:none;box-shadow:none}@media (max-width: 768px){.instagram-section{padding:0;gap:0}.instagram-post{max-width:100%;width:100%;margin-bottom:0;padding:0 1rem}.instagram-caption{display:none}.instagram-embed{width:100%;max-width:100%}.instagram-embed iframe,.instagram-embed blockquote{max-width:100%;width:100%}.instagram-embed iframe[src*="instagram.com"]{width:100%!important;border-radius:0!important;margin:0!important;position:relative!important;left:0!important}}@media (min-width: 768px) and (max-width: 1024px){.instagram-section{padding:0}.instagram-caption{display:none}}.menu{min-height:100vh}.menu-hero{background:var(--gradient-purple);color:var(--text-on-purple);padding:2rem 1rem;text-align:center;position:relative;overflow:hidden}.menu-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="dots" x="0" y="0" width="20" height="20" patternUnits="userSpaceOnUse"><circle cx="10" cy="10" r="1.5" fill="rgba(255,255,255,0.1)"/></pattern></defs><rect width="100" height="100" fill="url(%23dots)"/></svg>');opacity:.4}.menu-hero h1{margin-bottom:1rem;font-weight:700}.menu-hero p{font-size:1.1rem;opacity:.95;line-height:1.5}.menu-content{padding:4rem 0rem 2rem;background-color:#8b718064;position:relative}.menu-categories{display:flex;flex-direction:row;align-items:center;gap:.75rem;margin:0;overflow-x:auto;overflow-y:hidden;padding:.75rem 1rem .75rem 6rem;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;position:fixed;top:0;left:0;right:0;z-index:var(--z-menu-categories);background:#fffffffa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-light);box-shadow:0 2px 15px #8b6b8026;transition:transform .3s ease,opacity .3s ease}.menu-categories::-webkit-scrollbar{display:none}.menu-categories:before,.menu-categories:after{content:"";position:absolute;top:0;bottom:0;width:20px;pointer-events:none;z-index:1}.menu-categories:before{left:0;background:linear-gradient(to right,rgba(255,255,255,.95),transparent)}.menu-categories:after{right:0;background:linear-gradient(to left,rgba(255,255,255,.95),transparent)}.category-btn{padding:.5rem 1rem;background:var(--bg-glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:var(--border-glass);border-radius:20px;font-size:.85rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .3s ease;white-space:nowrap;min-width:max-content;min-height:36px;position:relative;overflow:hidden;flex-shrink:0}.category-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-purple-light);opacity:0;transition:opacity .3s ease;z-index:-1}.category-btn:hover{color:var(--primary-color);transform:translateY(-3px);box-shadow:var(--shadow-medium);border:1px solid rgba(255,255,255,.3)}.category-btn:hover:before{opacity:.1}.menu-btn{position:fixed;left:.75rem;top:.75rem;z-index:calc(var(--z-menu-categories) + 1);display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-glass);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:var(--border-glass);border-radius:25px;font-size:.85rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .3s ease;white-space:nowrap;box-shadow:var(--shadow-soft);min-height:36px}.menu-btn:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-medium)}.menu-btn-icon{display:flex;flex-direction:column;gap:2px;width:16px;height:12px}.menu-btn-line{width:100%;height:2px;background:currentColor;border-radius:1px;transition:all .3s ease}.menu-btn:hover .menu-btn-line{background:#fff}.menu-btn-text{font-size:.8rem;font-weight:500}.menu-items{padding-top:1.5rem}.category-section{margin-bottom:2rem}.category-section:last-child{margin-bottom:0}.category-header{color:var(--text-primary);text-align:center;margin-bottom:1rem;font-size:1.4rem;font-weight:700}.items-grid{display:grid;grid-template-columns:1fr;gap:.75rem;animation:fadeInUp .5s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.menu-item{background-color:#8b718064;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:var(--border-glass);padding:.5rem;border-radius:12px;box-shadow:var(--shadow-soft);transition:all .3s ease;display:flex;flex-direction:column;position:relative;overflow:hidden}.menu-item:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-glass);opacity:.3;z-index:-1}.menu-item.clickable{cursor:pointer}.menu-item:hover{transform:translateY(-6px);box-shadow:var(--shadow-medium);border:1px solid rgba(255,255,255,.3)}.menu-item.clickable:hover{transform:translateY(-8px);box-shadow:var(--shadow-strong);border:1px solid var(--primary-color)}.menu-item.clickable:hover:before{background:var(--gradient-purple-light);opacity:.1}.menu-item-content{display:flex;flex-direction:row;align-items:flex-start;gap:.75rem;flex:1}.item-info{flex:1;display:flex;flex-direction:column}.item-image{flex-shrink:0;width:60px;height:60px}.item-image img{width:100%;height:100%;object-fit:contain;border-radius:8px;transition:transform .3s ease,opacity .3s ease;display:block}.menu-item.clickable:hover .item-image img{transform:scale(1.05)}.secondary{color:var(--text-secondary);font-size:.8rem;font-style:italic;margin:.1rem 0}.item-header{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;margin-bottom:.5rem}.item-header h3{font-size:1.1rem;color:var(--text-primary);margin:0;line-height:1.2;font-weight:600}.price{font-size:1.1rem;font-weight:700;color:var(--primary-color)}.description{color:var(--text-secondary);line-height:1.4;margin:.25rem 0 0;flex:1;font-size:.85rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.item-indicators{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-light)}.spice-indicator{font-size:1.1rem;display:flex;align-items:center}.allergen-indicators{display:flex;align-items:center;gap:.25rem}.allergen-indicator{font-size:.9rem;display:inline-flex;align-items:center;background:var(--background-light);padding:.2rem .4rem;border-radius:12px;border:1px solid var(--border-light)}.more-allergens{font-size:.8rem;color:var(--text-secondary);background:var(--accent-color);padding:.2rem .4rem;border-radius:10px;margin-left:.25rem}.click-hint{margin-top:.5rem;text-align:right;opacity:0;transition:opacity .3s ease}.menu-item.clickable:hover .click-hint{opacity:1}.click-hint span{font-size:.75rem;color:var(--primary-color);font-weight:500}@media (min-width: 768px){.menu-hero{padding:3rem 2rem}.menu-hero p{font-size:1.2rem}.menu-content{padding:3rem 2rem;background-color:#8b718064}.menu-categories{gap:1rem;margin-bottom:2rem;padding:1rem 2rem 1rem 6.5rem;position:sticky;top:80px}.menu-btn{left:2rem;top:calc(80px + 1rem);padding:1rem 1.5rem;font-size:1rem;border-radius:30px}.menu-btn-icon{width:18px;height:14px;gap:3px}.menu-btn-text{font-size:.9rem}.category-btn{padding:1rem 2rem;font-size:1rem;min-width:max-content}.items-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem}.menu-item{padding:2rem}.item-indicators{margin-top:1.25rem;padding-top:1.25rem}.spice-indicator{font-size:1.2rem}.allergen-indicator{font-size:1rem;padding:.3rem .5rem}.item-header{flex-direction:row;justify-content:space-between;align-items:flex-start;gap:1rem}.item-header h3{font-size:1.4rem;flex:1}.price{font-size:1.3rem;margin-left:1rem}}@media (min-width: 1024px){.menu-hero,.menu-content{padding:4rem 2rem}.menu-categories{gap:1.25rem;padding:1.25rem 2rem 1.25rem 7rem;position:sticky;top:100px}.menu-btn{left:2rem;top:calc(100px + 1.25rem);padding:1.25rem 2rem;font-size:1.1rem;border-radius:35px}.menu-btn-icon{width:20px;height:16px;gap:3px}.menu-btn-text{font-size:1rem}.category-btn{padding:1.25rem 2.5rem;font-size:1.1rem;min-width:max-content}.items-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));max-width:1200px;margin:0 auto}.menu-item{padding:2.5rem}}.item-image .image-with-loader{width:100%;height:100%;border-radius:8px;overflow:hidden}.item-image .image-skeleton-overlay{border-radius:8px}.item-image .image-with-loader-img{border-radius:8px;transition:transform .3s ease,opacity .3s ease}.menu-item.clickable:hover .item-image .image-with-loader-img.loaded{transform:scale(1.05)}.image-with-loader{position:relative;display:inline-block;width:100%;height:100%}.image-skeleton-overlay{position:absolute;top:0;left:0;right:0;bottom:0;z-index:1}.image-with-loader-img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .3s ease}.image-with-loader-img.loading{opacity:0}.image-with-loader-img.loaded{opacity:1}.image-skeleton{position:relative;background-color:#f0f0f0;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;overflow:hidden;display:flex;align-items:center;justify-content:center}.skeleton-shimmer{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.6) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.image-skeleton{background-color:#f8f9fa;background:linear-gradient(90deg,#f8f9fa 25%,#e9ecef,#f8f9fa 75%)}.skeleton-shimmer{background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.8) 50%,transparent 100%)}@media (prefers-reduced-motion: reduce){.skeleton-shimmer{animation:none}.image-skeleton{background:#f8f9fa}}@media (prefers-contrast: high){.image-skeleton{background-color:#e0e0e0;border:1px solid #999}.skeleton-shimmer{background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.9) 50%,transparent 100%)}}.menu-item-detail{min-height:100vh;background-color:#8b718064;padding:2rem 1rem}.back-btn{background:var(--primary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;margin-bottom:2rem;display:inline-flex;align-items:center;gap:.5rem;position:relative;z-index:var(--z-back-button)}.back-btn:hover{background:var(--primary-dark);transform:translateY(-2px)}.detail-content{background:var(--background-white);border-radius:16px;overflow:hidden;box-shadow:0 8px 32px var(--shadow-medium);display:flex;flex-direction:column;max-width:800px;margin:0 auto}.detail-image{width:100%;aspect-ratio:1;overflow:hidden;position:relative;background:var(--background-light)}.detail-image img{width:100%;height:100%;object-fit:contain;transition:transform .3s ease;display:block}.detail-image:hover img{transform:scale(1.05)}.detail-info{padding:2rem 1.5rem}.detail-header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border-light)}.detail-header h1{font-size:1.8rem;color:var(--text-primary);margin:0;line-height:1.2}.detail-price{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.detail-badges{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.spice-badge,.allergen-badge{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--background-light);border-radius:8px;border-left:4px solid var(--primary-color)}.badge-label{font-weight:600;color:var(--text-primary);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.spice-icons{font-size:1.2rem;display:flex;align-items:center;gap:.25rem}.allergen-icons{display:flex;flex-wrap:wrap;gap:.75rem}.allergen-item{display:flex;align-items:center;gap:.25rem;font-size:.9rem;color:var(--text-secondary);background:var(--background-white);padding:.5rem .75rem;border-radius:20px;border:1px solid var(--border-light);text-transform:capitalize}.detail-description,.detail-ingredients{margin-bottom:2rem}.detail-description h3,.detail-ingredients h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.2rem;border-bottom:2px solid var(--accent-color);padding-bottom:.5rem;display:inline-block}.detail-description p{color:var(--text-secondary);line-height:1.7;font-size:1.1rem}.detail-ingredients ul{list-style:none;padding:0;display:grid;grid-template-columns:1fr;gap:.5rem}.detail-ingredients li{color:var(--text-secondary);padding:.5rem .75rem;background:var(--background-light);border-radius:6px;border-left:3px solid var(--secondary-color);font-size:.95rem}.detail-ingredients li:before{content:"•";color:var(--primary-color);font-weight:700;margin-right:.5rem}.not-found{text-align:center;padding:3rem 2rem}.not-found h1{color:var(--text-primary);margin-bottom:1rem}.not-found p{color:var(--text-secondary);margin-bottom:2rem;font-size:1.1rem}@media (min-width: 768px){.menu-item-detail{padding:2rem}.detail-content{flex-direction:column;max-width:900px}.detail-image{width:100%;aspect-ratio:1}.detail-info{width:100%;padding:2rem 2.5rem}.detail-header{flex-direction:row;justify-content:space-between;align-items:flex-start}.detail-header h1{font-size:2.2rem;flex:1}.detail-price{font-size:1.8rem;margin-left:1rem}.detail-badges{flex-direction:row;gap:1.5rem}.spice-badge,.allergen-badge{flex:1;flex-direction:column}.detail-ingredients ul{grid-template-columns:repeat(2,1fr);gap:.75rem}}@media (min-width: 1024px){.menu-item-detail{padding:3rem 2rem}.detail-content{max-width:1000px;flex-direction:row;align-items:stretch}.detail-image{width:400px;max-width:40%;aspect-ratio:1;flex-shrink:0}.detail-info{flex:1;padding:3rem}.detail-header h1{font-size:2.2rem}.detail-price{font-size:1.8rem}.detail-description p{font-size:1.1rem}.detail-ingredients ul{grid-template-columns:repeat(2,1fr)}.back-btn{font-size:1.1rem;padding:1rem 2rem}}.detail-secondary{margin:1rem 0}.secondary-text{color:var(--text-secondary);font-size:1.1rem;font-style:italic;margin:0}@media (min-width: 1200px){.detail-content{max-width:1200px}}.detail-image .image-with-loader{width:100%;height:100%}.detail-image .image-skeleton-overlay{border-radius:0}.detail-image .image-with-loader-img{transition:transform .3s ease,opacity .3s ease;border-radius:0}.detail-image:hover .image-with-loader-img.loaded{transform:scale(1.05)}.qr-page{min-height:100vh;padding:2rem 0}.qr-content{padding:2rem 1rem}.qr-content h1{text-align:center;color:var(--primary-color);margin-bottom:1rem;font-size:2.5rem;display:flex;align-items:center;justify-content:center}.qr-intro{text-align:center;color:var(--text-secondary);max-width:800px;margin:0 auto 3rem;line-height:1.6;font-size:1.1rem}.qr-grid{display:grid;grid-template-columns:1fr;gap:3rem;margin-bottom:4rem}.qr-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:12px;padding:2rem;box-shadow:0 2px 10px #0000001a;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.qr-card:hover{transform:translateY(-5px);box-shadow:0 4px 20px #8b6b8026}.qr-header{margin-bottom:2rem}.qr-header h2{color:var(--primary-color);margin-bottom:.5rem;font-size:1.5rem}.qr-header p{color:var(--text-secondary);line-height:1.5}.qr-canvas-container{display:flex;justify-content:center;margin:2rem 0;padding:1rem;background:var(--accent-color);border-radius:8px}.qr-image{border-radius:8px;background:#fff;box-shadow:0 2px 8px #0000001a;max-width:100%;height:auto}.qr-details{margin-top:2rem}.qr-url{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem;word-break:break-all;padding:.5rem;background:var(--accent-color);border-radius:6px;font-family:monospace}.download-btn{background:var(--primary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem}.download-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #8b6b804d}.download-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.qr-instructions{text-align:center;margin-top:3rem}.qr-instructions h2{color:var(--primary-color);margin-bottom:2rem;font-size:2rem}.instructions-grid{display:grid;grid-template-columns:1fr;gap:2rem;max-width:900px;margin:0 auto}.instruction{background:var(--accent-color);padding:2rem;border-radius:12px;transition:transform .3s ease}.instruction:hover{transform:translateY(-3px)}.instruction h3{color:var(--primary-color);margin-bottom:1rem;font-size:1.3rem}.instruction p{color:var(--text-secondary);line-height:1.6;margin:0}@media (min-width: 768px){.qr-content{padding:3rem 2rem}.qr-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:3rem}.instructions-grid{grid-template-columns:repeat(3,1fr);gap:2rem}}@media (min-width: 1024px){.qr-content{padding:4rem 2rem;max-width:1200px;margin:0 auto}.qr-grid{grid-template-columns:repeat(2,1fr);gap:4rem}}.navigation{padding:0rem 0;position:sticky;top:0;z-index:var(--z-navigation);transition:all .3s ease}.nav-container{display:flex;justify-content:space-between;align-items:center;padding:0 1rem;max-width:100%}.nav-menu{display:flex;list-style:none;margin:0;padding:0;gap:.5rem}.nav-item{margin:0}.nav-link{color:var(--text-primary);text-decoration:none;font-weight:500;padding:.5rem .75rem;border-radius:12px;transition:all .3s ease;font-size:.9rem;min-height:44px;display:flex;align-items:center;position:relative}.nav-link:hover,.nav-link.active{background:transparent;transform:translateY(-2px);color:var(--primary-color);box-shadow:var(--shadow-soft);border:var(--border-glass)}.nav-link:hover:before,.nav-link.active:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gradient-purple-light);opacity:.1;border-radius:12px;z-index:-1}.nav-menu-desktop{display:none}.hamburger{position:fixed;top:2rem;left:2rem;background:transparent;color:#fff;padding:.75rem;border-radius:50%;border:none;width:44px;height:44px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;transition:all .3s ease;z-index:var(--z-hamburger);cursor:pointer;box-shadow:0 2px 10px #8b6b8026;isolation:isolate}.hamburger:hover{background:transparent;box-shadow:0 4px 15px #8b6b8040;transform:translateY(-1px)}.hamburger:focus{outline:1px solid var(--primary-color);outline-offset:1px}.hamburger-line{width:20px;height:2px;background-color:var(--primary-color);border-radius:1px;transition:all .3s cubic-bezier(.4,0,.2,1);transform-origin:center}.hamburger.active .hamburger-line:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active .hamburger-line:nth-child(2){opacity:0;transform:scale(0)}.hamburger.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.drawer-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:var(--z-modal-overlay);animation:fadeIn .3s ease}.nav-drawer{position:fixed;top:0;right:0;width:100vw;height:100vh;background:var(--bg-main);box-shadow:none;z-index:var(--z-modal);padding-top:80px;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);visibility:hidden;will-change:transform}.nav-drawer.open{transform:translate(0);visibility:visible}body:has(.nav-drawer.open) .menu-categories{transform:translateY(-100%);opacity:0;pointer-events:none}.nav-menu-mobile{flex-direction:column;gap:0;padding:2rem;max-width:400px;margin:0 auto}.nav-menu-mobile .nav-item{width:100%}.nav-menu-mobile .nav-link{width:100%;padding:1.25rem 1.5rem;font-size:1.2rem;font-weight:600;border-radius:12px;justify-content:center;margin-bottom:.75rem;min-height:60px;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--text-primary);background:var(--bg-white);border:2px solid var(--border-light);text-align:center}.nav-menu-mobile .nav-link:hover{background:var(--primary-color);color:var(--text-on-purple);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-medium)}.nav-menu-mobile .nav-link.active{background:var(--gradient-purple);color:var(--text-on-purple);border-color:var(--primary-dark);box-shadow:var(--shadow-glow)}@media (min-width: 768px){.navigation{padding:1rem 0}.nav-container{padding:0 2rem;justify-content:center}.nav-menu-desktop{display:flex;gap:1rem}.hamburger,.nav-drawer{display:none}.nav-link{padding:.75rem 1.25rem;font-size:1rem;color:var(--text-primary)}.nav-link:hover,.nav-link.active{background:transparent;border:1px solid rgba(139,107,128,.3);color:var(--primary-color);box-shadow:0 4px 15px #8b6b8026}}@media (min-width: 1024px){.nav-container{max-width:1200px;margin:0 auto;justify-content:center}.nav-menu-desktop{gap:2rem}.nav-link{padding:.75rem 1.5rem;font-size:1.1rem;color:var(--text-primary)}}.language-toggle{color:var(--text-primary);text-decoration:none;font-weight:500;padding:.5rem .75rem;border-radius:12px;transition:all .3s ease;font-size:.9rem;min-height:44px;display:flex;align-items:center;position:relative;background:none;border:none;cursor:pointer}.language-toggle:hover{background:transparent;border:1px solid rgba(139,107,128,.2);color:var(--primary-color)}.language-toggle.mobile{width:100%;padding:1.25rem 1.5rem;font-size:1.2rem;font-weight:600;border-radius:12px;justify-content:center;margin-bottom:.75rem;min-height:60px;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--text-primary);background:var(--bg-white);border:2px solid var(--border-light);text-align:center}.language-toggle.mobile:hover{background:var(--primary-color);color:var(--text-on-purple);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-medium)}@media (min-width: 768px){.language-toggle{font-size:1rem;padding:.75rem 1.25rem;color:var(--text-primary)}.language-toggle:hover{background:transparent;border:1px solid rgba(139,107,128,.3);color:var(--primary-color);box-shadow:0 4px 15px #8b6b8026}}@media (min-width: 1024px){.language-toggle{padding:.75rem 1.5rem;font-size:1.1rem;color:var(--text-primary)}}.logout-btn{color:var(--text-primary);text-decoration:none;font-weight:500;padding:.5rem .75rem;border-radius:12px;transition:all .3s ease;font-size:.9rem;min-height:44px;display:flex;align-items:center;position:relative;background:none;border:none;cursor:pointer}.logout-btn:hover{background:#ffebee;color:#c62828;transform:translateY(-2px);box-shadow:var(--shadow-soft)}.logout-btn.mobile{width:100%;padding:1.25rem 1.5rem;font-size:1.2rem;font-weight:600;border-radius:12px;justify-content:center;margin-bottom:.75rem;min-height:60px;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--text-primary);background:var(--bg-white);border:2px solid var(--border-light);text-align:center}.logout-btn.mobile:hover{background:#f44336;color:#fff;border-color:#f44336;transform:translateY(-2px);box-shadow:var(--shadow-medium)}@media (min-width: 768px){.logout-btn{font-size:1rem;padding:.75rem 1.25rem;color:var(--text-primary)}.logout-btn:hover{background:#ffebee;color:#c62828}}@media (min-width: 1024px){.logout-btn{padding:.75rem 1.5rem;font-size:1.1rem;color:var(--text-primary)}}.login-container{display:flex;justify-content:center;align-items:center;min-height:80vh;padding:2rem}.login-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a;max-width:400px;width:100%;text-align:center}.login-card h2{color:var(--primary-color);margin-bottom:1rem}.login-card p{color:#666;margin-bottom:1.5rem}.google-signin-btn{background:#4285f4;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;cursor:pointer;transition:background-color .3s;width:100%}.google-signin-btn:hover{background:#357ae8}.google-signin-btn:disabled{background:#ccc;cursor:not-allowed}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:8px;margin-bottom:1rem;border:1px solid #fcc}.admin-dashboard{padding:2rem;max-width:1200px;margin:0 auto}.admin-dashboard h2{color:var(--primary-color);margin-bottom:2rem;text-align:center}.admin-dashboard.loading{text-align:center;padding:4rem;color:#666}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a;border:1px solid #e0e0e0;text-align:center}.stat-card h3{color:var(--primary-color);margin:0 0 1rem;font-size:1.1rem;font-weight:600}.stat-number{font-size:2.5rem;font-weight:700;color:var(--primary-color);margin-bottom:.5rem}.stat-detail{color:#666;font-size:.9rem;line-height:1.4}.users-section h3{color:var(--primary-color);margin-bottom:1.5rem}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.user-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a;border:1px solid #e0e0e0}.user-info{display:flex;align-items:center;margin-bottom:1rem}.user-avatar{width:50px;height:50px;border-radius:50%;margin-right:1rem;object-fit:cover}.user-details h4{margin:0 0 .25rem;color:#333}.user-details p{margin:0 0 .5rem;color:#666;font-size:.9rem}.user-role{display:inline-block;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.8rem;font-weight:500;margin-right:.5rem;text-transform:uppercase}.user-status{display:inline-block;padding:.25rem .5rem;border-radius:12px;font-size:.8rem;font-weight:500;text-transform:uppercase}.user-status.active{background:#e8f5e8;color:#2e7d32}.user-status.inactive{background:#ffebee;color:#c62828}.user-actions{display:flex;gap:1rem;margin-bottom:1rem}.user-actions select{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem}.toggle-btn{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .3s}.toggle-btn.activate{background:#4caf50;color:#fff}.toggle-btn.activate:hover{background:#45a049}.toggle-btn.deactivate{background:#f44336;color:#fff}.toggle-btn.deactivate:hover{background:#da190b}.user-metadata{display:flex;flex-direction:column;gap:.25rem}.user-metadata small{color:#888;font-size:.8rem}@media (max-width: 768px){.users-grid{grid-template-columns:1fr}.user-actions{flex-direction:column}.admin-dashboard{padding:1rem}}.events-manager{padding:2rem;max-width:1200px;margin:0 auto}.events-manager.loading{text-align:center;padding:4rem;color:#666}.events-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.events-manager-header h2{color:var(--primary-color);margin:0}.add-event-btn{background:var(--primary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .3s ease}.add-event-btn:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #8b6b804d}.event-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.event-form{background:#fff;border-radius:12px;padding:2rem;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0003}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.form-header h3{color:var(--primary-color);margin:0}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:0;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#f0f0f0}.form-errors{background:#fee;border:1px solid #fcc;border-radius:8px;padding:1rem;margin-bottom:1rem}.form-error{color:#c33;font-size:.9rem;margin-bottom:.5rem}.form-error:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #8b6b801a}.form-hint{display:block;margin-top:.5rem;color:#666;font-size:.8rem}.form-checkboxes{display:flex;gap:1.5rem;margin-bottom:1.5rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500}.checkbox-label input[type=checkbox]{width:auto;margin:0}.form-actions{display:flex;gap:1rem;justify-content:flex-end}.cancel-btn{background:#f8f9fa;color:#666;border:1px solid #dee2e6;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;transition:all .3s ease}.cancel-btn:hover{background:#e9ecef;color:#495057}.save-btn{background:var(--primary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .3s ease}.save-btn:hover{background:var(--primary-dark)}.save-btn:disabled{background:#ccc;cursor:not-allowed}.events-list{display:flex;flex-direction:column;gap:1.5rem}.empty-state{text-align:center;padding:4rem 2rem;color:#666}.empty-state p{margin-bottom:1rem}.event-item{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000001a;border:1px solid #e0e0e0}.event-preview,.event-caption{margin-bottom:1rem}.event-caption p{color:#333;font-size:1rem;line-height:1.5;margin:0}.event-embed-preview{max-width:100%;overflow:hidden}.event-embed-preview iframe,.event-embed-preview blockquote{max-width:100%;margin:0 auto}.event-embed-preview iframe[src*="instagram.com"]{height:600px!important;max-height:600px!important;overflow:hidden!important}.event-embed-preview iframe[src*="instagram.com"]:after{display:none!important}.event-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.event-settings{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.status{padding:.25rem .5rem;border-radius:12px;font-size:.8rem;font-weight:500;text-transform:uppercase}.status.active{background:#e8f5e8;color:#2e7d32}.status.inactive{background:#ffebee;color:#c62828}.display-order{background:#f8f9fa;padding:.25rem .5rem;border-radius:12px;font-size:.8rem;color:#666}.visibility{display:flex;gap:.5rem}.visibility-tag{background:var(--primary-color);color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.8rem;font-weight:500}.event-actions{display:flex;gap:.5rem;flex-wrap:wrap}.edit-btn{background:#007bff;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .3s ease}.edit-btn:hover{background:#0056b3}.toggle-btn{border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .3s ease}.toggle-btn.activate{background:#28a745;color:#fff}.toggle-btn.activate:hover{background:#1e7e34}.toggle-btn.deactivate{background:#ffc107;color:#212529}.toggle-btn.deactivate:hover{background:#e0a800}.delete-btn{background:#dc3545;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .3s ease}.delete-btn:hover{background:#c82333}@media (max-width: 768px){.events-manager{padding:1rem}.events-manager-header{flex-direction:column;gap:1rem;align-items:stretch}.event-form{padding:1.5rem}.form-checkboxes{flex-direction:column;gap:1rem}.form-actions{flex-direction:column}.event-meta{flex-direction:column;align-items:stretch}.event-settings,.event-actions{justify-content:center}}.master-detail-layout{padding:2rem;max-width:1400px;margin:0 auto;height:calc(100vh - 120px);display:flex;flex-direction:column}.layout-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.layout-filters{margin-bottom:2rem}.filter-tabs{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.filter-tab{padding:.5rem 1rem;border:2px solid #e9ecef;background:#fff;border-radius:6px;cursor:pointer;transition:all .3s ease;font-size:.9rem;font-weight:500}.filter-tab:hover{border-color:var(--primary-light)}.filter-tab.active{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.search-section{display:flex;align-items:center;gap:1rem}.search-input{flex:1;max-width:400px;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.layout-content{display:flex;flex:1;gap:2rem;min-height:0}.list-panel{flex:0 0 350px;background:#fff;border:1px solid #e9ecef;border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.panel-loading{display:flex;align-items:center;justify-content:center;height:200px;color:#666;font-size:1.1rem}.empty-state{display:flex;align-items:center;justify-content:center;height:200px;color:#666;font-size:1.1rem;text-align:center;padding:2rem;background:#f8f9fa;border:2px dashed #e9ecef;border-radius:12px;margin:1rem}.items-list{flex:1;overflow-y:auto}.list-item{padding:1rem;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:all .3s ease;background:#fff}.list-item:hover{background:#f8f9fa}.list-item.selected{background:var(--accent-color);border-left:4px solid var(--primary-color)}.list-item:last-child{border-bottom:none}.detail-panel{flex:1;background:#fff;border:1px solid #e9ecef;border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.detail-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.detail-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #f0f0f0;background:#f8f9fa}.detail-header h3{margin:0;color:var(--primary-color);font-size:1.2rem}.detail-empty{flex:1;display:flex;align-items:center;justify-content:center}.empty-detail-message{text-align:center;color:#666;padding:2rem}.empty-detail-message h3{color:#999;margin-bottom:.5rem;font-size:1.2rem}.empty-detail-message p{color:#aaa;font-size:.9rem;margin:0}.detail-form{flex:1;padding:1.5rem;overflow-y:auto}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid #f0f0f0;background:#f8f9fa}.form-actions .btn{min-width:100px}.mobile-header{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-bottom:1px solid #e9ecef;position:sticky;top:0;z-index:100}.mobile-header h2{margin:0;color:var(--primary-color);font-size:1.2rem;flex:1}.mobile-back{padding:.5rem 1rem;background:#f8f9fa;border:1px solid #e9ecef;color:var(--primary-color);font-weight:500}.mobile-back:hover{background:#e9ecef}.mobile-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.mobile-list{flex:1;display:flex;flex-direction:column;overflow:hidden;animation:slideInFromLeft .3s ease-out}.mobile-detail{flex:1;display:flex;flex-direction:column;overflow:hidden;animation:slideInFromRight .3s ease-out}.mobile-detail .detail-content{flex:1;overflow-y:auto}@keyframes slideInFromLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInFromRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-header{animation:slideInFromTop .3s ease-out}@keyframes slideInFromTop{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 1024px){.list-panel{flex:0 0 300px}.form-row{grid-template-columns:1fr}}@media (max-width: 768px){.master-detail-layout{padding:0;height:100vh;max-width:none;margin:0;display:flex;flex-direction:column}.master-detail-layout.mobile{padding:0}.layout-header{flex-shrink:0;padding:1rem;margin-bottom:0;background:#fff;border-bottom:1px solid #e9ecef;position:sticky;top:0;z-index:100}.title-section h1{font-size:1.5rem;margin-bottom:.25rem}.title-section p{font-size:.9rem}.layout-filters{flex-shrink:0;padding:0 1rem 1rem;background:#fff;border-bottom:1px solid #f0f0f0}.filter-tabs{gap:.5rem;margin-bottom:1rem;overflow-x:auto;padding-bottom:.5rem}.filter-tab{white-space:nowrap;flex-shrink:0}.search-input{max-width:none;width:100%}.layout-content{flex:1;overflow:hidden}.items-list{flex:1;overflow-y:auto;padding:.5rem}.list-item{padding:1rem;margin-bottom:.5rem;background:#fff;border:1px solid #e9ecef;border-radius:8px;cursor:pointer;transition:all .2s ease}.list-item:hover{background:#f8f9fa;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.list-item:active{transform:translateY(0) scale(.98);box-shadow:0 1px 4px #0000001a}.detail-header{padding:1rem;background:#fff;border-bottom:1px solid #f0f0f0;position:sticky;top:0;z-index:50}.detail-form{padding:1rem;overflow-y:auto}.form-actions{padding:1rem;border-top:1px solid #f0f0f0;background:#fff;position:sticky;bottom:0;z-index:50}.form-actions .btn{width:100%;margin-bottom:.5rem}.form-actions .btn:last-child{margin-bottom:0}.empty-state,.panel-loading{padding:3rem 1rem;text-align:center;color:#666}.error-message{margin:1rem;padding:1rem;background:#fee;color:#c33;border:1px solid #fcc;border-radius:8px}.detail-empty{display:none}}@media (max-width: 480px){.layout-header{padding:.75rem}.title-section h1{font-size:1.3rem}.layout-filters{padding:0 .75rem .75rem}.items-list{padding:.25rem}.list-item{padding:.75rem;margin-bottom:.25rem}.detail-header,.detail-form,.form-actions,.mobile-header{padding:.75rem}.btn{padding:.75rem 1rem;font-size:.9rem;border-radius:6px;transition:all .2s ease;transform:translateY(0)}.btn:active{transform:translateY(1px) scale(.95)}.btn:hover{transform:translateY(-1px)}.form-group{margin-bottom:1rem}.form-group label{font-size:.9rem;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{font-size:16px;padding:.75rem}}.inventory-manager{padding:2rem;max-width:1200px;margin:0 auto}.inventory-manager.loading{text-align:center;padding:4rem;color:#666}.inventory-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.btn{border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .3s ease;text-decoration:none;display:inline-block;text-align:center}.inventory-filters{margin-bottom:2rem}.category-tabs{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.category-tab{background:#f8f9fa;border:1px solid #e9ecef;color:#495057;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .3s ease}.category-tab:hover{background:#e9ecef}.category-tab.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.search-section{margin-top:1rem}.search-input{width:100%;max-width:400px;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem}.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.inventory-item{background:#fff;border:1px solid #e9ecef;border-radius:12px;padding:1.5rem;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.inventory-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:var(--primary-light)}.item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.item-header h3{margin:0;color:var(--primary-color);font-size:1.2rem;line-height:1.3}.category-badge{background:var(--accent-color);color:var(--primary-dark);padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.item-details{margin-bottom:1.5rem}.detail-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.detail-row:last-child{margin-bottom:0}.detail-row .label{color:#666;font-size:.9rem;font-weight:500}.detail-row .value{color:#333;font-weight:500}.detail-row .value.price{color:var(--primary-color);font-weight:600;font-size:1.1rem}.item-actions{display:flex;gap:.5rem;margin-bottom:1rem}.item-actions .btn{flex:1;padding:.5rem 1rem;font-size:.9rem}.item-meta{padding-top:1rem;border-top:1px solid #f0f0f0}.item-meta small{color:#999;font-size:.8rem}.inventory-form{padding:0 2rem 2rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.inventory-list-item{display:flex;flex-direction:column;gap:.5rem}.inventory-list-item .item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.inventory-list-item .item-header h4{margin:0;color:var(--primary-color);font-size:1rem;line-height:1.2}.inventory-list-item .category-badge{background:var(--accent-color);color:var(--primary-dark);padding:.2rem .5rem;border-radius:12px;font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}.inventory-list-item .item-details{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.inventory-list-item .price{color:var(--primary-color);font-weight:600}.inventory-list-item .unit{color:#666;font-size:.8rem}.inventory-list-item .item-vendor{color:#666;font-size:.8rem;margin-top:.25rem}@media (max-width: 768px){.inventory-manager{padding:0}.inventory-header{flex-direction:column;align-items:stretch;gap:1rem}.title-section h1{font-size:1.5rem}.inventory-grid{grid-template-columns:1fr}.category-tabs{justify-content:center}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.modal-content{margin:1rem;max-height:calc(100vh - 2rem)}.item-header{flex-direction:column;align-items:stretch;gap:.5rem}.category-badge{align-self:flex-start}.inventory-list-item{padding:1rem;border:1px solid #e9ecef;border-radius:8px;margin-bottom:.5rem;background:#fff;transition:all .2s ease}.inventory-list-item:active{transform:scale(.98);background:#f8f9fa}.inventory-list-item .item-header h4{font-size:1.1rem;margin-bottom:.5rem}.inventory-list-item .category-badge{font-size:.65rem;padding:.25rem .5rem}.inventory-list-item .item-details{gap:.5rem}.inventory-list-item .item-vendor{font-size:.85rem;color:#777}.form-group input,.form-group select{font-size:16px;padding:.75rem;border:2px solid #e9ecef;border-radius:6px;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #8b6b801a}.form-group label{font-size:.9rem;font-weight:600;margin-bottom:.5rem}.detail-actions{flex-direction:column;gap:.5rem}.detail-actions .btn{width:100%}}@media (max-width: 480px){.inventory-manager{padding:.5rem}.modal-header,.inventory-form{padding-left:1rem;padding-right:1rem}.item-actions{flex-direction:column}}.shopping-list-manager{padding:2rem;max-width:1400px;margin:0 auto}.shopping-list-item{display:flex;flex-direction:column;gap:.5rem}.shopping-list-item .item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.shopping-list-item .item-header h4{margin:0;color:var(--primary-color);font-size:1rem;line-height:1.2}.shopping-list-item .status-badge{padding:.2rem .5rem;border-radius:12px;font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0;color:#fff}.shopping-list-item .item-details{display:flex;flex-direction:column;gap:.25rem;font-size:.9rem}.shopping-list-item .detail-row{display:flex;justify-content:space-between;align-items:center}.shopping-list-item .detail-row .label{color:#666;font-size:.8rem}.shopping-list-item .detail-row .value{color:#333;font-weight:500}.items-section{margin-top:1rem}.items-section h4{margin-bottom:.5rem;color:var(--primary-color)}.item-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.5rem;background:#f8f9fa;border-radius:6px}.item-row .item-name{flex:1;font-weight:500}.item-row .quantity-input{width:80px;padding:.25rem;border:1px solid #ddd;border-radius:4px;text-align:center}.item-row .unit{font-size:.8rem;color:#666}.list-info{margin-bottom:1.5rem}.info-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.info-row .label{color:#666;font-weight:500}.info-row .value{color:#333;font-weight:500}.items-list h4{margin-bottom:.5rem;color:var(--primary-color)}.item-detail{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#f8f9fa;border-radius:6px;margin-bottom:.5rem}.item-detail .item-name{flex:1;font-weight:500}.item-detail .item-quantity{color:#666;font-size:.9rem}.item-detail .item-cost{color:var(--primary-color);font-weight:600}.shopping-list-manager.loading{text-align:center;padding:4rem;color:#666}.shopping-list-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.btn-success{background:#28a745;color:#fff}.btn-success:hover{background:#218838}.shopping-lists-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.shopping-list-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;padding:1.5rem;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.shopping-list-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:var(--primary-light)}.list-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.list-header h3{margin:0;color:var(--primary-color);font-size:1.2rem;line-height:1.3}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:#fff;white-space:nowrap}.list-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem;padding:1rem;background:#f8f9fa;border-radius:8px}.vendor-preview{margin-bottom:1.5rem}.vendor-group{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #eee}.vendor-group:last-child{border-bottom:none}.vendor-group strong{color:#333}.vendor-group span{color:#666;font-size:.9rem}.more-vendors{color:#666;font-style:italic;text-align:center;padding:.5rem 0}.list-actions{display:flex;gap:.5rem;margin-bottom:1rem}.list-actions .btn{flex:1;padding:.5rem 1rem;font-size:.85rem}.list-meta{padding-top:1rem;border-top:1px solid #f0f0f0}.list-meta small{color:#999;font-size:.8rem}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0003}.modal-content.large{max-width:1200px}.shopping-list-form{padding:0 2rem 2rem}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #8b6b801a}.workflow-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e9ecef}.workflow-header h2{color:var(--primary-color);margin:0;font-size:1.5rem}.vendor-selection{min-height:400px}.vendors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.vendor-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.vendor-card:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #8b6b8026}.vendor-card h3{color:var(--primary-color);margin:0 0 .5rem;font-size:1.2rem}.vendor-card p{color:#666;margin:0;font-size:.9rem}.item-selection{min-height:400px}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.item-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;padding:1.5rem;transition:all .3s ease}.item-card:has(.quantity-input:not([value="0"])){border-color:var(--primary-color);box-shadow:0 2px 8px #8b6b801a}.item-info h4{color:var(--primary-color);margin:0 0 .5rem;font-size:1.1rem}.item-info p{color:#666;margin:0 0 1rem;font-size:.9rem}.quantity-control{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.quantity-control label{color:#333;font-weight:500;font-size:.9rem}.quantity-input{padding:.5rem;border:1px solid #ddd;border-radius:6px;width:80px;font-size:1rem}.quantity-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #8b6b801a}.unit{color:#666;font-size:.9rem}.item-total{background:var(--accent-color);color:var(--primary-dark);padding:.5rem;border-radius:6px;text-align:center;font-weight:600}.summary-section{position:sticky;bottom:2rem;margin-top:2rem}.summary-card{background:var(--primary-color);color:#fff;border-radius:12px;padding:1.5rem;text-align:center;box-shadow:0 4px 12px #8b6b804d}.summary-card h3{margin:0 0 1rem;font-size:1.2rem}.summary-card p{margin:.5rem 0;font-size:1rem}.summary-actions{margin-top:1.5rem}.summary-actions .btn{background:#fff;color:var(--primary-color);font-weight:600;padding:.75rem 2rem}.summary-actions .btn:hover{background:var(--accent-color);transform:translateY(-2px)}.whatsapp-preview{padding:0 2rem 2rem}.phone-input{margin-bottom:1.5rem}.phone-input label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.phone-input input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem}.message-preview h3{color:var(--primary-color);margin-bottom:1rem}.message-content{background:#e7f3ff;border:1px solid #b3d9ff;border-radius:12px;padding:1rem;white-space:pre-line;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.9rem;line-height:1.4;max-height:300px;overflow-y:auto}@media (max-width: 1024px){.shopping-lists-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.vendors-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.items-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (max-width: 768px){.shopping-list-manager{padding:0}.shopping-list-header{flex-direction:column;align-items:stretch;gap:1rem}.title-section h1{font-size:1.5rem}.shopping-lists-grid,.vendors-grid,.items-grid{grid-template-columns:1fr}.list-summary{grid-template-columns:1fr;gap:.5rem}.list-actions{flex-direction:column}.modal-content{margin:1rem;max-height:calc(100vh - 2rem)}.form-actions{flex-direction:column-reverse}.workflow-header{flex-direction:column;align-items:stretch;gap:.5rem}.workflow-header h2{font-size:1.2rem}.summary-section{position:static;margin-top:1rem}.quantity-control{flex-wrap:wrap}.shopping-list-item{padding:1rem;border:1px solid #e9ecef;border-radius:8px;margin-bottom:.5rem;background:#fff;transition:all .2s ease}.shopping-list-item:active{transform:scale(.98);background:#f8f9fa}.shopping-list-item .item-header h4{font-size:1.1rem;margin-bottom:.5rem}.shopping-list-item .status-badge{font-size:.65rem;padding:.25rem .5rem}.shopping-list-item .item-details{gap:.25rem;margin-top:.5rem}.shopping-list-item .detail-row{margin-bottom:.25rem}.shopping-list-item .detail-row .label{font-size:.75rem}.shopping-list-item .detail-row .value{font-size:.85rem}.form-group input,.form-group select{font-size:16px;padding:.75rem;border:2px solid #e9ecef;border-radius:6px;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #8b6b801a}.form-group label{font-size:.9rem;font-weight:600;margin-bottom:.5rem}.detail-actions{flex-direction:column;gap:.5rem}.detail-actions .btn{width:100%}.item-row{flex-direction:column;align-items:stretch;padding:.75rem;gap:.5rem}.item-row .item-name{font-size:1rem;margin-bottom:.25rem}.item-row .quantity-input{width:100%;max-width:120px}.item-row .unit{font-size:.9rem;margin-left:.5rem}.list-info{padding:1rem;background:#f8f9fa;border-radius:8px;margin-bottom:1rem}.info-row{margin-bottom:.75rem}.info-row .label{font-size:.85rem}.info-row .value{font-size:.95rem}.items-list{padding:0}.items-list h4{font-size:1.1rem;margin-bottom:.75rem}.item-detail{padding:.75rem;margin-bottom:.5rem}.item-detail .item-name{font-size:.95rem;margin-bottom:.25rem}.item-detail .item-quantity{font-size:.85rem}.item-detail .item-cost{font-size:.9rem;font-weight:600}}@media (max-width: 480px){.shopping-list-manager{padding:.5rem}.modal-header,.shopping-list-form,.whatsapp-preview{padding-left:1rem;padding-right:1rem}.list-header{flex-direction:column;gap:.5rem}.status-badge{align-self:flex-start}.vendor-group{flex-direction:column;align-items:flex-start;gap:.25rem}}.recipe-manager{padding:2rem;max-width:1400px;margin:0 auto}.recipe-list-item{display:flex;flex-direction:column;gap:.5rem}.recipe-list-item .item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.recipe-list-item .item-header h4{margin:0;color:var(--primary-color);font-size:1rem;line-height:1.2}.recipe-list-item .category-badge{background:var(--accent-color);color:var(--primary-dark);padding:.2rem .5rem;border-radius:12px;font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}.recipe-list-item .item-summary{display:flex;justify-content:space-between;font-size:.9rem;gap:1rem}.recipe-list-item .summary-detail{display:flex;align-items:center;gap:.25rem}.recipe-list-item .summary-detail .label{color:#666;font-size:.8rem}.recipe-list-item .summary-detail .value{color:#333;font-weight:500}.detail-actions{display:flex;gap:.5rem}.recipe-manager.loading{text-align:center;padding:4rem;color:#666}.recipe-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:2rem}.title-section h1{color:var(--primary-color);margin:0 0 .5rem;font-size:2rem}.title-section p{color:#666;margin:0;font-size:1rem}.btn{border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .3s ease;text-decoration:none;display:inline-block;text-align:center;font-size:.9rem}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #8b6b804d}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#545b62}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.btn-small{padding:.5rem 1rem;font-size:.8rem}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #fcc;text-align:center}.filters-section{display:flex;gap:1rem;margin-bottom:2rem;align-items:center}.search-input{padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;min-width:300px;transition:border-color .3s ease}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #8b6b801a}.category-select{padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;background:#fff;min-width:200px}.loading{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.empty-state{text-align:center;padding:3rem;color:#666;font-size:1.1rem;background:#f8f9fa;border-radius:12px;border:2px dashed #e9ecef}.recipes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.recipe-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;padding:1.5rem;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.recipe-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:var(--primary-light)}.recipe-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.recipe-header h3{margin:0;color:var(--primary-color);font-size:1.2rem;line-height:1.3}.category-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;background:var(--accent-color);color:var(--primary-dark);white-space:nowrap}.recipe-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem;padding:1rem;background:var(--accent-color);border-radius:8px}.summary-item{text-align:center}.summary-item .label{display:block;color:#666;font-size:.85rem;margin-bottom:.25rem}.summary-item .value{display:block;color:var(--primary-color);font-weight:600;font-size:1.1rem}.recipe-actions{display:flex;gap:.5rem;margin-bottom:1rem}.recipe-actions .btn{flex:1;padding:.5rem 1rem;font-size:.85rem}.recipe-meta{padding-top:1rem;border-top:1px solid #f0f0f0}.recipe-meta small{color:#999;font-size:.8rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0003}.modal-content.large{max-width:1000px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem 2rem 0;margin-bottom:1.5rem}.modal-header h2{color:var(--primary-color);margin:0;font-size:1.5rem}.modal-close{background:none;border:none;font-size:2rem;cursor:pointer;color:#666;padding:0;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.modal-close:hover{background:#f0f0f0;color:#333}.recipe-form{padding:0 2rem 2rem}.error-list{background:#fee;border:1px solid #fcc;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.error-item{color:#c33;font-size:.9rem;margin-bottom:.5rem}.error-item:last-child{margin-bottom:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #8b6b801a}.form-group textarea{resize:vertical;min-height:80px}.ingredients-section,.instructions-section{margin-bottom:2rem;padding:1.5rem;border:1px solid #e9ecef;border-radius:12px;background:#f8f9fa}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h3{color:var(--primary-color);margin:0;font-size:1.2rem}.add-buttons{display:flex;gap:.5rem}.ingredient-item{background:#fff;border:1px solid #ddd;border-radius:8px;padding:1rem;margin-bottom:1rem}.ingredient-row{display:grid;grid-template-columns:1fr 2fr 1fr 1fr auto;gap:1rem;align-items:end;margin-bottom:1rem}.ingredient-item .form-group{margin-bottom:0}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e9ecef}.form-actions .btn{min-width:120px}@media (max-width: 1024px){.recipes-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.ingredient-row{grid-template-columns:1fr;gap:.5rem}}@media (max-width: 768px){.recipe-manager{padding:0}.recipe-header{flex-direction:column;align-items:stretch;gap:1rem}.title-section h1{font-size:1.5rem}.filters-section{flex-direction:column;align-items:stretch}.search-input{min-width:auto}.recipes-grid,.form-row{grid-template-columns:1fr}.recipe-summary{grid-template-columns:1fr;gap:.5rem}.recipe-actions{flex-direction:column}.modal-content{margin:1rem;max-height:calc(100vh - 2rem)}.form-actions{flex-direction:column-reverse}.section-header{flex-direction:column;align-items:stretch;gap:1rem}.add-buttons{justify-content:center}.recipe-list-item{padding:1rem;border:1px solid #e9ecef;border-radius:8px;margin-bottom:.5rem;background:#fff;transition:all .2s ease}.recipe-list-item:active{transform:scale(.98);background:#f8f9fa}.recipe-list-item .item-header h4{font-size:1.1rem;margin-bottom:.5rem}.recipe-list-item .category-badge{font-size:.65rem;padding:.25rem .5rem}.recipe-list-item .item-summary{gap:1rem;margin-top:.5rem}.recipe-list-item .summary-detail{gap:.25rem}.recipe-list-item .summary-detail .label{font-size:.75rem}.recipe-list-item .summary-detail .value{font-size:.85rem}.form-group input,.form-group select{font-size:16px;padding:.75rem;border:2px solid #e9ecef;border-radius:6px;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #8b6b801a}.form-group label{font-size:.9rem;font-weight:600;margin-bottom:.5rem}.detail-actions{flex-direction:column;gap:.5rem}.detail-actions .btn{width:100%}.ingredient-item{background:#f8f9fa;border-radius:8px;padding:1rem;margin-bottom:1rem;border:1px solid #e9ecef}.ingredient-row{display:flex;flex-direction:column;gap:.75rem}.ingredient-row .form-group{margin-bottom:0}.ingredient-row .btn{align-self:flex-start;margin-top:.5rem}.add-buttons{display:flex;flex-direction:column;gap:.5rem}.add-buttons .btn{width:100%}}@media (max-width: 480px){.recipe-manager{padding:.5rem}.modal-header,.recipe-form{padding-left:1rem;padding-right:1rem}.recipe-header h3{font-size:1rem}.category-badge{font-size:.7rem;padding:.2rem .5rem}.ingredient-row{gap:.25rem}}.unauthorized-container{display:flex;justify-content:center;align-items:center;min-height:80vh;padding:2rem}.unauthorized-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a;max-width:400px;width:100%;text-align:center}.unauthorized-card h2{color:var(--primary-color);margin-bottom:1rem}.unauthorized-card p{color:#666;margin-bottom:1.5rem}.home-link{display:inline-block;background:var(--primary-color);color:#fff;padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;transition:background-color .3s}.home-link:hover{background:var(--primary-dark)}.pending-container{display:flex;justify-content:center;align-items:center;min-height:80vh;padding:2rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.pending-card{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 8px 32px #0000001a;max-width:500px;width:100%;text-align:center;border:1px solid rgba(255,255,255,.2)}.pending-icon{color:var(--primary-color);margin-bottom:1.5rem;opacity:.8}.pending-card h2{color:var(--primary-color);margin-bottom:2rem;font-size:1.5rem;font-weight:600}.pending-user-info{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef}.pending-avatar{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid var(--primary-color)}.pending-user-details h3{margin:0 0 .25rem;color:#333;font-size:1.1rem}.pending-user-details p{margin:0;color:#666;font-size:.9rem}.pending-message{margin-bottom:2rem;text-align:left}.pending-message p{color:#555;line-height:1.6;margin-bottom:1rem}.pending-actions{display:flex;gap:1rem;margin-bottom:2rem}.pending-btn{flex:1;padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:500;transition:all .3s ease;border:none;cursor:pointer;font-size:.9rem}.pending-btn.primary{background:var(--primary-color);color:#fff}.pending-btn.primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #8b6b804d}.pending-btn.secondary{background:#f8f9fa;color:#666;border:1px solid #dee2e6}.pending-btn.secondary:hover{background:#e9ecef;color:#495057;transform:translateY(-2px)}.pending-contact{border-top:1px solid #e9ecef;padding-top:1.5rem}.contact-text{color:#666;font-size:.9rem;margin-bottom:.5rem}.contact-link{color:var(--primary-color);text-decoration:none;font-weight:500}.contact-link:hover{color:var(--primary-dark);text-decoration:underline}@media (max-width: 768px){.pending-container{padding:1rem}.pending-card{padding:2rem}.pending-user-info{flex-direction:column;text-align:center}.pending-actions{flex-direction:column}.pending-btn{width:100%}}
