:root{--bg-color:#FFFDF8;--text-dark:#1D1D1B;--primary:#E41B13;--accent-yellow:#FFD100;--accent-orange:#FF6B00;--accent-blue:#06C;--border-color:#DDD;--font-heading:'Staatliches',cursive;--font-body:'Montserrat',sans-serif}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background-color:var(--bg-color);color:var(--text-dark);font-family:var(--font-body);line-height:1.6;font-size:16px;font-weight:400;min-height:100vh;display:flex;flex-direction:column}body.modal-open{overflow:hidden}h1,h2,.logo,.modal-title{font-family:var(--font-heading);letter-spacing:.05em;line-height:1;color:var(--text-dark)}h3{font-family:var(--font-body);font-weight:700;font-size:1.1rem}.container{max-width:1200px;margin:0 auto;padding:0 20px}.back-link{display:inline-block;color:var(--accent-blue);text-decoration:none;margin-bottom:20px;font-size:.9rem;font-weight:700}.btn{position:relative;display:inline-block;background-color:var(--accent-orange);color:var(--bg-color);font-weight:700;font-family:var(--font-body);font-size:1rem;padding:12px 28px;border-radius:0;text-decoration:none;border:2px solid var(--text-dark);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;box-shadow:4px 4px 0 0 var(--primary);text-transform:uppercase}.btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 0 var(--primary);transition:transform .1s ease,box-shadow .1s ease}.btn:disabled{background-color:#aaa;box-shadow:4px 4px 0 0 #777;cursor:not-allowed}.btn:disabled:hover,.btn:disabled:active{transform:none}.btn-secondary{background-color:var(--primary);color:var(--bg-color);border-color:var(--text-dark);box-shadow:4px 4px 0 0 var(--text-dark)}.btn-secondary:active{transform:translate(2px,2px);box-shadow:2px 2px 0 0 var(--text-dark)}.btn-full{width:100%}.admin-card{background:#fff;border:2px solid var(--text-dark);padding:30px;margin-bottom:30px}.analytics-card{background-color:#fff;border:2px solid var(--text-dark);padding:25px;text-align:center;box-shadow:4px 4px 0 0 var(--accent-blue)}.admin-form .form-group{margin-bottom:20px}.admin-form .form-group label{display:block;font-weight:700;margin-bottom:8px;font-size:.9rem}.admin-form .form-group-inline{display:flex;align-items:center;gap:10px;margin-bottom:20px}.admin-form .form-group-inline input[type="checkbox"]{width:auto;height:20px;width:20px}.admin-form .form-group-inline label{margin-bottom:0}.admin-form .form-actions{display:flex;gap:15px;margin-top:30px}.admin-form input,.admin-form textarea,.admin-form select,.export-inputs input[type="date"]{width:100%;border:2px solid var(--text-dark);padding:10px;font-size:1rem;font-family:var(--font-body)}input:disabled{background-color:#f0f0f0;cursor:not-allowed}.form-hint{font-size:.8rem;color:#555;margin-top:5px;display:block;margin-bottom:10px}.user-role-form{display:flex;gap:10px;align-items:center}.user-role-form select{padding:8px;border:2px solid var(--text-dark);flex-grow:1}.user-role-form button{padding:8px 15px;font-size:.9rem}.table-responsive-wrapper{overflow-x:auto}.subscription-table{width:100%;border-collapse:collapse;margin-top:10px}.subscription-table th,.subscription-table td{padding:12px 15px;text-align:left;border-bottom:1px solid var(--border-color)}.subscription-table thead th{background-color:var(--text-dark);color:var(--bg-color);font-family:var(--font-heading);letter-spacing:.05em;font-weight:400;font-size:1.1rem}.subscription-table tbody tr:nth-child(even){background-color:#f8f8f8}.subscription-table tbody tr:hover{background-color:var(--accent-yellow)}.status-badge{padding:5px 10px;border-radius:15px;color:white;font-weight:bold;font-size:.9rem}.status-badge.available{background-color:#28a745}.status-badge.out-of-stock{background-color:var(--primary)}.status-badge.preparing{background-color:var(--accent-orange)}.page-header{text-align:center;font-size:3.5rem;margin-bottom:40px}.section-header{font-size:1.8rem;margin-bottom:20px;color:var(--accent-blue);border-bottom:2px solid var(--border-color);padding-bottom:10px}h2.section-title{font-size:2.2rem;margin-bottom:20px;border-bottom:2px solid var(--text-dark);padding-bottom:10px;margin-top:40px}.analytics-section-title{font-family:var(--font-heading);font-size:1.2rem;letter-spacing:.05em;color:var(--accent-yellow);background-color:var(--text-dark);padding:4px 12px;display:inline-block;margin-bottom:25px}.navbar{position:sticky;top:0;width:100%;padding:15px 0;background:var(--bg-color);z-index:1000;border-bottom:3px solid var(--primary)}.navbar .container{display:flex;align-items:center;justify-content:space-between}.logo{font-size:2rem;text-decoration:none}.logo .fa-paw{color:var(--primary);margin-right:10px;font-size:1.8rem}.nav-links{display:flex;align-items:center;gap:20px}.nav-link{color:var(--text-dark);text-decoration:none;font-weight:700;text-transform:uppercase;font-size:.9rem}.nav-link.admin-link{color:var(--primary)}.nav-cart{position:relative;font-size:1.5rem;color:var(--text-dark);cursor:pointer;text-decoration:none}.cart-counter{position:absolute;top:-8px;right:-8px;background-color:var(--primary);color:var(--bg-color);width:22px;height:22px;border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;border:2px solid var(--bg-color)}.nav-profile{font-size:1.5rem;color:var(--text-dark);text-decoration:none;display:none}main{padding-top:40px;padding-bottom:60px;animation:fadeIn .3s ease-out;flex-grow:1}main#menu-page{padding-top:0}footer{padding:50px 0 40px;text-align:center;border-top:2px solid var(--border-color);margin-top:auto}.footer-links{list-style:none;padding:0;margin:0 0 25px 0;display:flex;justify-content:center;gap:30px;flex-wrap:wrap}.footer-links a{color:var(--accent-blue);text-decoration:none;font-weight:700;text-transform:uppercase}.footer-links a:hover{color:var(--primary)}.footer-copyright p{opacity:.7;font-size:.9rem;margin:0}.flash-messages{padding:0 20px}.flash-message{padding:15px;margin:20px auto 0;max-width:1200px;border:2px solid var(--text-dark);font-weight:700;overflow-wrap:break-word;word-wrap:break-word}.flash-success{background-color:var(--accent-yellow);color:var(--text-dark)}.flash-danger{background-color:var(--primary);color:var(--bg-color)}.flash-warning{background-color:var(--accent-blue);color:var(--bg-color)}.hero{min-height:calc(100vh - 65px);display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:0 20px;background-image:linear-gradient(rgba(255,253,248,0.90),rgba(255,253,248,0.90)),url('../images/hero.webp');background-size:cover;background-position:center;border-bottom:3px solid var(--primary)}.hero h1{font-size:clamp(3.5rem,10vw,8rem);color:var(--primary);text-shadow:3px 3px 0 rgba(0,0,0,0.15)}.hero p{font-size:clamp(1rem,2.5vw,1.25rem);font-weight:700;color:var(--accent-blue);margin-bottom:2rem;max-width:650px;text-transform:uppercase;text-shadow:1px 1px 0 #fff,2px 2px 0 rgba(0,0,0,0.15)}.menu-section{padding:80px 0}.menu-title{text-align:center;font-size:3.5rem;margin-bottom:40px}.menu-controls{margin-bottom:40px}.search-bar-wrapper{position:relative;max-width:600px;margin:0 auto}#menu-search-input{width:100%;padding:15px 20px 15px 50px;font-size:1.1rem;border:2px solid var(--text-dark);font-family:var(--font-body);box-shadow:4px 4px 0 0 var(--border-color)}#menu-search-input:focus{outline:none;box-shadow:4px 4px 0 0 var(--accent-blue)}.search-icon{position:absolute;left:20px;top:50%;transform:translateY(-50%);font-size:1.2rem;color:#999}#category-quick-nav{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 20px;margin:40px 0 50px;padding-bottom:30px;border-bottom:2px solid var(--border-color)}.category-card{display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;text-decoration:none;color:var(--text-dark);transition:transform .2s ease}.category-card img{width:90px;height:90px;border-radius:50%;object-fit:cover;margin-bottom:10px;border:2px solid var(--border-color);background-color:#fff;box-shadow:0 4px 8px rgba(0,0,0,0.05)}.category-card span{font-weight:700;font-size:.9rem}.menu-category-header{font-family:var(--font-body);font-weight:700;font-size:1.5rem;color:var(--accent-blue);margin-top:30px;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--border-color)}.section-title+.menu-category-header{margin-top:0}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:30px}.menu-card{background-color:#fff;padding:20px;border:2px solid var(--text-dark);display:flex;flex-direction:column;box-shadow:4px 4px 0 0 var(--primary);transition:transform .15s ease,box-shadow .15s ease;position:relative}.menu-card img{width:100%;height:180px;object-fit:cover;margin-bottom:15px;border:2px solid var(--text-dark)}.item-price{display:inline-block;background-color:var(--accent-yellow);color:var(--text-dark);padding:2px 8px;border:2px solid var(--text-dark);box-shadow:2px 2px 0 0 var(--primary);font-size:1.2rem;font-weight:700;margin-bottom:15px}.menu-card-actions{display:flex;gap:10px;margin-top:auto}.menu-card-actions .btn{flex-grow:1;padding:10px;font-size:.9rem}.fulfillment-badge{position:absolute;top:10px;right:10px;background:var(--accent-blue);color:var(--bg-color);padding:3px 8px;font-size:.8rem;font-weight:700;border:2px solid var(--text-dark);z-index:2}.admin-menu-card-actions{display:flex;flex-direction:column;gap:10px;margin-top:auto;padding-top:15px;border-top:1px solid var(--border-color)}.admin-menu-card-actions .action-row{display:flex;gap:10px}.admin-menu-card-actions .action-row .btn,.admin-menu-card-actions .action-row form{flex-grow:1}.admin-menu-card-actions .action-row form .btn{width:100%}.admin-card-fulfillment{font-size:.9rem;color:#555}.admin-badge-container{position:absolute;top:10px;left:10px;display:flex;flex-direction:column;gap:5px;z-index:2}.archived-badge,.stock-badge{background-color:var(--primary);color:white;padding:5px 10px;font-weight:700;font-size:.8rem}.stock-badge{background-color:var(--accent-orange)}.menu-card.is-archived{background-color:#f5f5f5;opacity:.6;box-shadow:4px 4px 0 0 #aaa}.menu-card.is-archived:hover{transform:none;box-shadow:4px 4px 0 0 #aaa}.menu-card.is-unavailable img{opacity:.5}.permanent-delete-action{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border-color);text-align:center}.btn-delete-permanent{background:none;border:none;color:var(--primary);font-weight:700;cursor:pointer;font-size:.9rem;text-decoration:none}.btn-delete-permanent:hover{color:var(--text-dark);text-decoration:underline}.admin-action-group{display:flex;gap:10px}.admin-action-group .btn{width:220px;text-align:center}.suggestions-section{padding:60px 0;border-top:2px solid var(--border-color);margin-top:40px}.suggestions-content{text-align:center;max-width:600px;margin:0 auto}.suggestions-content .content-mascot{margin-bottom:20px}.suggestions-content p{font-size:1.1rem;color:#555;margin-bottom:30px}#cart-page .container{padding-top:0}.cart-layout{display:grid;grid-template-columns:2fr 1fr;gap:40px;align-items:start}.cart-section-header{font-family:var(--font-heading);font-size:1.2rem;letter-spacing:.05em;color:var(--accent-yellow);background-color:var(--text-dark);padding:4px 12px;display:inline-block;margin:30px 0 15px}.cart-item-card{background-color:#fff;padding:15px 20px;border:2px solid var(--text-dark);display:flex;align-items:center;gap:20px;margin-bottom:15px;box-shadow:4px 4px 0 0 var(--border-color);flex-wrap:wrap}.item-info{flex-grow:1;margin-right:auto}.item-name{font-weight:700;font-size:1.1rem}.item-details{color:var(--accent-blue);font-size:.9rem;font-style:italic}.quantity-controls{display:flex;align-items:center}.item-quantity{padding:0 15px;font-weight:700;font-size:1.1rem}.quantity-btn{background:#f0f0f0;border:2px solid var(--text-dark);width:32px;height:32px;font-size:1.2rem;cursor:pointer}.remove-btn{background:transparent;border:2px solid var(--text-dark);width:36px;height:36px;font-size:1.5rem;cursor:pointer}.order-summary{background-color:#fff;border:2px solid var(--text-dark);padding:25px}.summary-row{display:flex;justify-content:space-between;margin-bottom:12px}.payment-choice-header{text-align:center;color:var(--accent-blue);margin-bottom:20px;font-weight:700}.share-cart-mobile-wrapper{display:none}.login-form-container{max-width:550px;margin:60px auto;padding:40px 50px;background:#fff;border:2px solid var(--text-dark);box-shadow:8px 8px 0 var(--primary)}.login-form-container h1{text-align:center;margin-bottom:1rem;font-size:2.5rem}.login-form-container p{text-align:center;margin-bottom:2.5rem;font-size:1.1rem;opacity:.9;max-width:400px;margin-left:auto;margin-right:auto}#login-page .form-group{margin-bottom:2rem}#login-page .form-group label{display:block;font-weight:700;margin-bottom:.5rem;text-align:left}#login-page .form-group input{width:100%;border:2px solid var(--text-dark);padding:12px;font-size:1rem}.otp-input-container{display:flex;justify-content:space-between;gap:10px}.otp-input{width:100%;height:60px;text-align:center;font-size:2rem;font-family:var(--font-heading);border:2px solid var(--text-dark);caret-color:var(--primary)}.otp-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(228,27,19,0.2)}.legal-notice{margin-bottom:2rem}.legal-notice p{max-width:350px;margin-left:auto;margin-right:auto;text-align:center;font-size:.85rem;line-height:1.5;color:#555}.legal-notice .legal-link{font-weight:700;color:var(--accent-blue);text-decoration:underline}.resend-link{margin-top:1.5rem;text-align:center;font-size:.9rem}#confirmation-page .container{display:flex;align-items:center;justify-content:center;min-height:70vh;padding-top:0;padding-bottom:0}.confirmation-container{max-width:500px;text-align:center;padding:20px}.confirmation-icon{width:100px;height:100px;background-color:var(--accent-orange);border-radius:50%;margin:0 auto 30px auto;display:flex;align-items:center;justify-content:center;color:var(--bg-color);font-size:3.5rem}#confirmation-page h1{font-size:3rem;margin-bottom:1rem}#confirmation-page .order-details{font-size:1.1rem;margin-bottom:1rem;line-height:1.6}#confirmation-page #confirmation-message{color:var(--text-dark);opacity:.8;margin-bottom:2.5rem}.confirmation-actions{display:flex;justify-content:center;gap:20px;margin-top:2.5rem;flex-wrap:wrap}#error-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 70px);padding-top:0;padding-bottom:0}#error-page .page-header{font-size:3.5rem;margin:1rem 0;color:var(--text-dark);background:none;padding:0}#error-page #confirmation-message{font-size:1.2rem;max-width:450px;margin:0 auto 2.5rem auto}#orders-page .container{max-width:900px}#orders-page .content-container h2.welcome-message{text-align:center;text-transform:uppercase;font-family:var(--font-body);font-size:1.2rem;font-weight:700;margin-bottom:3rem;word-break:break-all}#orders-page .order-history-header{font-family:var(--font-body);font-weight:700;font-size:1.5rem;margin-top:3rem;margin-bottom:1.5rem}.order-card{background:#fff;border:2px solid var(--text-dark);margin-bottom:25px;box-shadow:4px 4px 0 0 var(--border-color)}.order-card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:15px;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:10px}.order-info-left{display:flex;flex-direction:column;gap:5px}.order-id{font-size:1rem}.order-id strong{font-weight:700}.order-date{font-size:.85rem;color:#555}.order-user{font-size:.9rem;color:var(--accent-blue);font-weight:700}.order-info-right{text-align:right;flex-shrink:0}.order-total{font-size:1.1rem;font-weight:700}.payment-method{font-size:.8rem;text-transform:uppercase;color:#555}.order-card-main{padding:15px;border-bottom:1px solid var(--border-color)}.order-status-display{display:flex;align-items:center;gap:10px;font-weight:700}.order-card-body{padding:15px;background-color:#fcfcfc}.order-card-body h4{font-weight:700;font-size:.9rem;margin-bottom:10px;text-transform:uppercase}.order-card-body ul{list-style:none;padding:0;margin:0}.rating-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.rating-form{display:inline-flex;flex-direction:row-reverse}.star-btn{background:none;border:none;cursor:pointer;font-size:1.5rem;color:#ccc;padding:0 2px;transition:color .2s ease}.rating-form:hover .star-btn{color:var(--accent-yellow)}.rating-form .star-btn:hover,.rating-form .star-btn:hover ~ .star-btn{color:var(--accent-yellow)}.rating-form .star-btn:hover i:before,.rating-form .star-btn:hover ~ .star-btn i:before{content:'\f005';font-family:"Font Awesome 6 Free";font-weight:900}.rated-display{color:#555;font-style:italic;display:flex;align-items:center;gap:4px}.rated-star{color:var(--accent-yellow);font-size:1.2rem}#legal-page .page-header,#about-page .page-header,#how-it-works-page .page-header,#contact-page .page-header{background-color:var(--primary);color:var(--bg-color);padding:15px 25px;display:table;margin-left:auto;margin-right:auto;margin-bottom:40px;text-align:center;-webkit-box-decoration-break:clone;box-decoration-break:clone;line-height:1.5}.content-container{max-width:800px;margin:0 auto}.content-container h2{font-size:2rem;margin-bottom:1rem;text-align:center}.content-container p{margin-bottom:1.5rem;font-size:1.1rem;line-height:1.7}.content-mascot{display:block;max-width:200px;margin:0 auto 30px}.steps-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-top:40px}.step-card{background:#fff;border:2px solid var(--text-dark);padding:40px 30px;text-align:center}.step-card h3{text-transform:uppercase;margin-bottom:15px;font-size:1.2rem;font-weight:700}.step-number{font-size:2rem;font-weight:700;color:var(--primary);border:2px solid var(--text-dark);width:60px;height:60px;line-height:56px;border-radius:50%;margin:0 auto 20px}.contact-methods{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin:30px 0 60px}.contact-card{background:#fff;border:2px solid var(--text-dark);padding:30px;text-align:center;text-decoration:none;color:var(--text-dark);transition:transform .2s ease,box-shadow .2s ease}.contact-card i{font-size:3rem;color:var(--accent-blue);margin-bottom:15px}.contact-card h4{font-size:1.2rem;margin-bottom:5px;color:var(--text-dark)}.faq-header{text-align:center;font-size:2.5rem;margin-bottom:30px}.faq-item{border:2px solid var(--text-dark);margin-bottom:15px;background:#fff}.faq-question{padding:20px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:1.1rem}.faq-question i{transition:transform .3s ease}.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}.faq-answer p{padding:0 20px 20px;margin:0}.faq-item.active .faq-question i{transform:rotate(180deg)}.faq-item.active .faq-answer{max-height:200px}#admin-page .container,#canteen-page .container,#bear-page .container{max-width:900px}.admin-nav{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-bottom:40px}.admin-nav-item{background:#fff;border:2px solid var(--text-dark);padding:30px;text-align:center;text-decoration:none;color:var(--text-dark);font-weight:700;transition:transform .2s ease,box-shadow .2s ease}.admin-nav-item i{font-size:3rem;margin-bottom:1rem;color:var(--accent-blue);display:block}.admin-menu-item{border-bottom:2px solid var(--border-color);padding-bottom:20px;margin-bottom:20px}.admin-menu-item:last-child{border:none}.admin-menu-item .form-actions{display:flex;gap:10px;margin-top:10px}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-bottom:40px}.analytics-card h3{font-family:var(--font-body);font-size:1.2rem;color:var(--accent-blue);margin-bottom:10px}.analytics-card p{font-family:var(--font-heading);font-size:3rem;color:var(--primary);line-height:1}.detailed-analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:30px}.analytics-column h4{font-size:1.1rem;font-weight:700;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.analytics-list{list-style:none;padding:0;margin:0 0 30px 0}.analytics-list-item{display:flex;justify-content:space-between;align-items:center;padding:12px 5px;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease-in-out}.analytics-list-item:last-child{border-bottom:none}.analytics-list-item:hover{background-color:#fcfcfc}.analytics-list-item span{flex-grow:1;padding-right:15px}.analytics-list-item strong{color:var(--primary);white-space:nowrap;font-weight:700}.analytics-list-item strong.high-rating{color:var(--accent-blue);text-shadow:none}.analytics-list-item strong.low-rating{color:var(--accent-orange)}.analytics-list-item small{font-weight:400;color:#777;font-size:.8em}.data-export-section{margin-top:20px;padding-top:30px;border-top:2px solid var(--border-color)}.data-export-section p{margin:-15px 0 20px 0;font-size:.9rem;color:#555}.export-form{display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:center}.export-inputs{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.export-form .btn{padding-top:10px;padding-bottom:10px}.canteen-nav{margin-bottom:20px}#admin-page .order-card-header{align-items:center}#admin-page .order-card .order-info-right{flex-grow:1;display:flex;justify-content:space-between;align-items:center}#bear-page .order-card{background:#fff;border:2px solid var(--text-dark);margin-bottom:25px;box-shadow:4px 4px 0 0 var(--border-color)}#bear-page .order-card-header{padding:20px;display:grid;gap:10px 20px;grid-template-columns:1fr auto;grid-template-areas:"id total" "user payment" "location payment"}#bear-page .order-detail{display:flex;flex-direction:column}#bear-page .order-detail-label{font-size:.8rem;color:#555;font-weight:700;text-transform:uppercase}#bear-page .order-detail-value{font-size:1.1rem;font-weight:400;line-height:1.4}#bear-page .order-id{grid-area:id}#bear-page .order-user{grid-area:user}#bear-page .order-location{grid-area:location}#bear-page .order-total{grid-area:total;text-align:right}#bear-page .order-payment{grid-area:payment;text-align:right}#bear-page .order-detail-value.pickup-point-value{font-weight:700;color:var(--accent-blue)}#bear-page .cod-warning{font-size:.9rem;font-weight:700;color:var(--primary)}#bear-page .order-card-body{padding:15px 20px;background-color:#f9f9f9;border-top:2px solid var(--border-color);border-bottom:2px solid var(--border-color)}.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(29,29,27,0.7);backdrop-filter:blur(5px);justify-content:center;align-items:center;padding:20px;z-index:2000}.modal-overlay.active{display:flex}.modal-content{background:var(--bg-color);padding:30px;border:2px solid var(--primary);width:90%;max-width:500px;display:flex;flex-direction:column;max-height:85vh}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.modal-title{font-size:2.5rem;line-height:1.1;color:var(--bg-color);background:var(--primary);padding:10px 15px;display:inline;-webkit-box-decoration-break:clone;box-decoration-break:clone;width:fit-content;max-width:calc(100% - 40px)}.close-modal{background:none;border:none;font-size:2.5rem;font-weight:300;line-height:1;cursor:pointer;color:var(--text-dark);opacity:.7;padding:0}.close-modal:hover{opacity:1}.modal-body{overflow-y:auto;flex-shrink:1;padding-right:15px}.modal-footer{margin-top:10px}.modal-footer .btn{width:100%}.modal-footer{padding-right:15px}.modal-body .form-group{margin-bottom:25px}.modal-body .form-group:last-child{margin-bottom:0}.modal-body select,.modal-body input[type="number"]{width:100%;padding:12px;border:2px solid var(--text-dark);font-size:1rem;background-color:#fff;font-family:var(--font-body)}.modal-body input[type=number]::-webkit-inner-spin-button,.modal-body input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.modal-body input[type=number]{-moz-appearance:textfield}.day-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.day-picker-item input{display:none}.day-picker-item label{display:block;text-align:center;padding:10px 5px;border:2px solid var(--text-dark);cursor:pointer;transition:all .2s ease-in-out;font-weight:700}.day-picker-item span{display:block;line-height:1.2}.day-picker-item .day-name{font-size:clamp(0.8rem,2.5vw,0.9rem)}.day-picker-item .day-date{font-size:clamp(1rem,4vw,1.2rem)}.day-picker-item .day-month{font-size:clamp(0.7rem,2vw,0.8rem);text-transform:uppercase}.day-picker-item input:checked+label{background:var(--primary);color:var(--bg-color);border-color:var(--primary);transform:translateY(0)}.alert-modal-content{max-width:420px;padding:25px}.alert-modal-content .modal-header{justify-content:center;margin-bottom:15px}.alert-modal-content .modal-title{background:none;color:var(--primary);padding:0}.alert-modal-content .modal-body p{font-size:1.1rem;line-height:1.6;text-align:center;margin:10px 0}#alert-modal-ok-btn{display:block;margin:0 auto}.copy-modal-content .copy-input-wrapper{display:flex;gap:10px;margin-top:15px}.copy-modal-content input[type="text"]{flex-grow:1;border:2px solid var(--text-dark);padding:10px;font-size:1rem;background-color:#f0f0f0}.copy-modal-content .copy-btn{flex-shrink:0;padding:10px 20px}#toast-container{position:fixed;top:75%;left:50%;transform:translate(-50%,-50%);z-index:3000;display:flex;flex-direction:column;align-items:center;gap:10px;pointer-events:none}.toast{background-color:var(--accent-yellow);color:var(--text-dark);font-weight:700;padding:12px 24px;border:2px solid var(--text-dark);box-shadow:4px 4px 0 0 var(--text-dark);pointer-events:auto;width:fit-content;animation:toast-fade-in-out 3s ease-in-out forwards}.shake{animation:shake .82s cubic-bezier(.36,.07,.19,.97) both;transform:translate3d(0,0,0)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes toast-fade-in-out{0%{opacity:0;transform:scale(0.9)}10%,90%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(0.9)}}@keyframes shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-4px,0,0)}40%,60%{transform:translate3d(4px,0,0)}}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.mobile-only{display:none}.desktop-only{display:inline-block}.btn-success{background-color:#28a745;box-shadow-color:#1c6f2f}.btn-danger{background-color:var(--primary);box-shadow-color:#a0100a}.admin-menu-card-actions .btn-toggle-stock.available{background-color:var(--accent-orange);box-shadow:4px 4px 0 0 var(--primary)}.admin-menu-card-actions .btn-toggle-stock.unavailable{background-color:#28a745;box-shadow:4px 4px 0 0 #1c6f2f}tr.inactive{opacity:.6;background-color:#f5f5f5!important}tr.inactive:hover{opacity:1;background-color:var(--accent-yellow)!important}form.submitting button[type="submit"]{background-color:#aaa;cursor:not-allowed;transform:none;box-shadow:4px 4px 0 0 #777}form.submitting input,form.submitting select{pointer-events:none;background-color:#f0f0f0}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hidden-by-js{display:none!important}#promo-modal-container,#promo-banner-container{position:relative;z-index:2500}.promo-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(29,29,27,0.7);backdrop-filter:blur(5px);display:flex;justify-content:center;align-items:center;padding:20px;opacity:0;animation:promo-fade-in .3s ease-out forwards}.promo-modal-content{position:relative;background:var(--bg-color);border:3px solid var(--text-dark);box-shadow:8px 8px 0 var(--primary);width:100%;max-width:400px;transform:scale(0.95);animation:promo-scale-up .3s ease-out forwards}.promo-modal-content a{display:block;text-decoration:none}.promo-modal-content img{display:block;width:100%;aspect-ratio:4 / 5;object-fit:cover}.promo-modal-close{position:absolute;top:-15px;right:-15px;width:40px;height:40px;background:var(--primary);color:var(--bg-color);border:2px solid var(--text-dark);border-radius:50%;font-size:1.5rem;line-height:36px;text-align:center;cursor:pointer;box-shadow:4px 4px 0 var(--text-dark);transition:transform .15s ease,box-shadow .15s ease}.promo-banner{position:fixed;bottom:0;left:0;width:100%;background:var(--primary);color:var(--bg-color);border-top:3px solid var(--text-dark);display:flex;align-items:center;overflow:hidden;transform:translateY(100%);animation:promo-slide-up .4s ease-out forwards}body.modal-open .promo-banner{display:none}.promo-banner-link{flex-grow:1;text-decoration:none;color:inherit;padding:12px 0;white-space:nowrap;overflow:hidden}.promo-banner .marquee{display:inline-block;animation:marquee 30s linear infinite;font-weight:700;text-transform:uppercase;will-change:transform}.promo-banner-close{flex-shrink:0;background:none;border:none;color:var(--bg-color);font-size:1.5rem;padding:0 20px;cursor:pointer;align-self:stretch}.promo-inline-card{position:relative;padding:0}.promo-inline-card .promoted-tag{position:absolute;top:10px;right:10px;background:var(--accent-yellow);color:var(--text-dark);padding:4px 8px;font-size:.8rem;font-weight:700;border:2px solid var(--text-dark);z-index:2}.promo-inline-card .promo-image-container{overflow:hidden;aspect-ratio:2 / 1}.promo-inline-card img{width:100%;height:100%;object-fit:cover;border:none;margin-bottom:0}.summary-row.total{font-weight:700;font-size:1.1rem;padding-top:10px;border-top:2px solid var(--text-dark);margin-top:10px}.summary-row.discount span:last-child{color:#28a745;font-weight:700}.payment-section{margin-top:30px}.payment-actions{display:flex;flex-direction:column;gap:10px}.payment-total-display{text-align:center;font-weight:700;font-size:1.1rem;margin-top:-5px;margin-bottom:10px}.payment-total-display small{font-weight:400;font-size:.9rem;color:#555}.promo-box{margin-top:20px;background-color:#fff;border:2px solid var(--text-dark);padding:25px}.promo-box label,#referral-input-container label{font-weight:700;font-size:1.1rem;margin-bottom:10px;display:block;color:var(--text-dark)}#referral-input-container input{width:100%;border:2px solid var(--text-dark);padding:10px;font-size:1rem;text-align:center;margin-bottom:10px}.btn-accent{background-color:var(--accent-blue);color:var(--bg-color)}.btn-accent{box-shadow:4px 4px 0 0 var(--text-dark)!important}hr.dotted{border:none;border-top:2px dashed var(--border-color);margin:25px 0}.wallet-balance{font-size:1rem;color:var(--text-dark);margin-bottom:15px;text-align:left}.wallet-balance strong{font-weight:700}.btn-subtle{background-color:transparent;color:var(--text-dark);box-shadow:4px 4px 0 0 var(--border-color)}.referral-code-box{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;text-align:center;gap:15px;background-color:#fffde7;border:2px dashed var(--border-color);padding:20px}.referral-code-content{flex-basis:100%}.referral-label{display:block;font-size:.9rem;font-weight:700;color:var(--accent-blue)}#referral-code{font-family:var(--font-heading);font-size:2.5rem;color:var(--primary);letter-spacing:.1em}#copy-referral-btn{padding:10px 30px;font-size:.9rem}.wallet-balance-box{margin-top:15px;padding:20px;text-align:center;background-color:#eaf2fa;border:2px dashed var(--border-color)}.wallet-balance-box span{display:block;font-size:.9rem;font-weight:700;color:var(--accent-blue);margin-bottom:10px}.wallet-balance-box strong{font-family:var(--font-heading);font-size:2.5rem;color:var(--primary);letter-spacing:.1em}#pickup-details-page .pickup-container{max-width:800px;margin:40px auto;padding:20px}#pickup-details-page .pickup-header{text-align:center;margin-bottom:40px}#pickup-details-page .pickup-logo{max-width:200px;margin-bottom:10px}#pickup-details-page .pickup-header h1{font-size:2.5rem;color:var(--primary)}#pickup-details-page .section{margin-bottom:30px}#pickup-details-page .section-title{font-family:var(--font-body);font-weight:700;font-size:1.2rem;text-transform:uppercase;color:var(--accent-blue);border-bottom:2px solid var(--border-color);padding-bottom:8px;margin-bottom:20px}#pickup-details-page .instructions-box{background:#fffde7;border-left:5px solid var(--accent-yellow);padding:20px;display:flex;gap:15px;align-items:flex-start}#pickup-details-page .instructions-box i{font-size:1.5rem;color:var(--accent-orange);margin-top:3px}#pickup-details-page .instructions-box p{margin:0;font-size:1.1rem;line-height:1.6}#pickup-details-page .vendor-section{background:#fff;border:2px solid var(--border-color);margin-bottom:20px}#pickup-details-page .vendor-section summary{cursor:pointer;display:flex;justify-content:space-between;align-items:center;padding:20px;outline:none}#pickup-details-page .vendor-section summary::-webkit-details-marker{display:none}#pickup-details-page .vendor-section summary .section-title{margin-bottom:0;border-bottom:none;padding-bottom:0}#pickup-details-page .vendor-section summary i{font-size:1.2rem;transition:transform .2s ease-in-out}#pickup-details-page .vendor-section[open] summary i{transform:rotate(180deg)}#pickup-details-page .checklist-items{padding:0 20px 20px;border-top:1px solid var(--border-color)}.checklist-item{display:flex;align-items:center;background-color:#f9f9f9;padding:15px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background-color .2s ease}.checklist-item:last-child{border-bottom:none}.checklist-item:hover{background-color:#f0f0f0}.checklist-item .item-checkbox{display:none}.checkbox-visual{width:30px;height:30px;border:2px solid var(--text-dark);margin-right:15px;flex-shrink:0;display:flex;justify-content:center;align-items:center;transition:background-color .2s ease}.checkbox-visual i{font-size:1rem;color:var(--bg-color);transform:scale(0);transition:transform .2s ease}.checklist-item input:checked ~ .checkbox-visual{background-color:#28a745;border-color:#28a745}.checklist-item input:checked ~ .checkbox-visual i{transform:scale(1)}.checklist-item .item-image{width:60px;height:60px;margin-right:15px;flex-shrink:0}.checklist-item .item-image img{width:100%;height:100%;object-fit:cover;border:2px solid var(--border-color)}.checklist-item .item-details{display:flex;align-items:baseline;gap:10px;flex-grow:1}.checklist-item .item-quantity{font-family:var(--font-heading);font-size:2rem;color:var(--primary)}.checklist-item .item-name{font-weight:700;font-size:1.1rem}.pickup-action-zone{margin-top:40px;position:sticky;bottom:0;background:var(--bg-color);padding:20px;border-top:2px solid var(--text-dark);box-shadow:0 -4px 10px rgba(0,0,0,0.05)}.progress-bar-container{width:100%;height:10px;background-color:var(--border-color);border:2px solid var(--text-dark);margin-bottom:15px}.progress-bar-fill{width:0;height:100%;background-color:var(--accent-yellow);transition:width .3s ease}#confirm-pickup-btn{background-color:#28a745;box-shadow-color:#1c6f2f;font-size:1.2rem;width:100%;transition:all .2s ease}#confirm-pickup-btn:disabled{background-color:#aaa;box-shadow:4px 4px 0 0 #777;cursor:not-allowed}#confirm-pickup-btn:disabled:hover{transform:none}.pickup-confirmed-wrapper{text-align:center;padding:40px 20px;background:#f0fff4;border:2px solid #28a745;margin-top:40px}.pickup-confirmed-icon{width:80px;height:80px;line-height:80px;font-size:3rem;color:#fff;background:#28a745;border-radius:50%;margin:0 auto 20px}.pickup-confirmed-mascot{max-width:120px;margin-top:20px}.user-role-form{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.user-role-form select{padding:8px;border:2px solid var(--text-dark)}.canteen-location-update-div select{width:100px}@keyframes promo-fade-in{from{opacity:0}to{opacity:1}}@keyframes promo-scale-up{from{transform:scale(0.95)}to{transform:scale(1)}}@keyframes promo-slide-up{from{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}@media(hover:hover){.btn:hover{transform:translate(4px,4px);box-shadow:0 0 0 0 var(--primary)}.btn-secondary:hover{transform:translate(4px,4px);box-shadow:0 0 0 0 var(--text-dark)}.promo-modal-close:hover{transform:translate(4px,4px);box-shadow:0 0 0 var(--text-dark)}.menu-card:hover{transform:translate(-4px,-4px);box-shadow:8px 8px 0 0 var(--accent-yellow)}.admin-nav-item:hover{transform:translateY(-5px);box-shadow:6px 6px 0 var(--accent-yellow)}.contact-card:not(.disabled-contact):hover{transform:translateY(-5px);box-shadow:6px 6px 0 var(--accent-yellow)}.category-card:hover{transform:translateY(-5px)}.btn-subtle:hover{background-color:#f8f8f8;transform:translate(4px,4px);box-shadow:0 0 0 0 var(--border-color)}.day-picker-item label:hover{background:var(--accent-yellow);transform:translateY(-2px)}}@media(max-width:991px){.cart-layout{grid-template-columns:1fr}.detailed-analytics-grid{grid-template-columns:1fr;gap:30px}.share-cart-desktop-wrapper{display:none}.share-cart-mobile-wrapper{display:block}}@media(max-width:767px){.page-header{font-size:2.5rem}.pass-card h2,.menu-title{font-size:2.2rem}.hero h1{font-size:3rem}main{padding-top:20px;padding-bottom:40px}.pass-section,.menu-section{padding:40px 0}.contact-methods,.admin-nav{grid-template-columns:1fr}.footer-links{gap:15px 25px}.subscription-table thead{display:none}.subscription-table,.subscription-table tbody,.subscription-table tr,.subscription-table td{display:block;width:100%}.subscription-table tr{margin-bottom:15px;border:2px solid var(--border-color)}.subscription-table td{text-align:right;padding-left:50%;position:relative;border-bottom:1px solid #eee}.subscription-table td:last-child{border-bottom:none}.subscription-table td::before{content:attr(data-label);position:absolute;left:15px;width:calc(50% - 30px);text-align:left;font-weight:bold;text-transform:uppercase;font-size:.9rem}.subscription-table td[data-label="Action"]{text-align:center}.subscription-table td[data-label="Action"] .btn{display:inline-block;width:auto}}@media(max-width:576px){.desktop-only{display:none}.mobile-only{display:inline-block}.nav-profile{display:block}.menu-card-actions{flex-direction:column}.login-form-container{padding:30px 20px}.cart-item-card{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;grid-template-areas:"info price" "controls remove";gap:15px 10px;align-items:center}.item-info{grid-area:info}.quantity-controls{grid-area:controls}.item-total-price{grid-area:price;text-align:right;font-weight:700}.remove-btn{grid-area:remove;justify-self:end}.confirmation-actions{flex-direction:column;gap:15px}.confirmation-actions .btn{width:100%}.modal-title{font-size:1.8rem;line-height:1.2}#bear-page .order-card-header{grid-template-columns:1fr;grid-template-areas:"id" "user" "location" "total" "payment";gap:12px;padding:15px}#bear-page .order-total,#bear-page .order-payment{text-align:left}#bear-page .order-card-body{padding:15px}#bear-page .order-card-footer{padding:15px}.admin-action-group{flex-direction:column;width:100%}.admin-action-group .btn{width:100%}.promo-modal-content{max-width:300px}.referral-code-box{flex-direction:column}}@media(min-width:992px){#category-quick-nav{grid-template-columns:repeat(6,1fr)}}.toggle-switch-wrapper{display:flex;align-items:center;justify-content:space-between}.toggle-switch-wrapper .toggle-label{font-weight:700}.toggle-switch{position:relative;display:inline-block;width:50px;height:28px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border-color);transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:white;transition:.3s;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,0.2)}input:checked+.toggle-slider{background-color:var(--accent-blue)}input:focus+.toggle-slider{box-shadow:0 0 1px var(--accent-blue)}input:checked+.toggle-slider:before{transform:translateX(22px)}input:disabled+.toggle-slider{cursor:not-allowed;opacity:.6}.scout-bounty{font-size:1.1rem;padding:10px 20px;margin:20px auto 30px;background-color:#fff;border:2px dashed var(--border-color);display:inline-block;text-transform:uppercase}.scout-bounty strong{color:var(--primary);font-weight:700}.scout-missions-grid{display:flex;flex-direction:column;gap:20px;max-width:450px;margin:0 auto}.scout-mission-card{background-color:#fff;padding:30px 25px;border:2px solid var(--border-color);display:flex;flex-direction:column;align-items:center}.scout-mission-card i{font-size:3rem;color:var(--accent-blue);margin-bottom:15px}.scout-mission-card h3{font-family:var(--font-heading);letter-spacing:.08em;font-size:2rem;text-transform:uppercase;color:var(--text-dark);margin-bottom:10px}.scout-mission-card p{color:#555;font-size:.95rem;margin-bottom:25px;flex-grow:1}.scout-mission-card .btn{width:100%;margin-top:auto;padding:14px}@media(min-width:768px){.scout-missions-grid{display:grid;grid-template-columns:1fr 1fr;gap:25px;max-width:none}}.contact-card.disabled-contact{opacity:.6;background-color:#f9f9f9;cursor:not-allowed;pointer-events:none}