@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #92400e;--color-secondary: #b45309;--color-tertiary: #78350f;--color-amber-50: #fffbeb;--color-amber-100: #fef3c7;--color-amber-200: #fde68a;--color-amber-600: #d97706;--color-amber-700: #b45309;--color-amber-800: #92400e;--color-amber-900: #78350f;--color-orange-50: #fff7ed;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-white: #ffffff;--color-yellow-400: #fbbf24}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;min-height:100vh;color:var(--color-gray-900);background-color:var(--color-white)}html{scroll-behavior:smooth}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--color-tertiary)}a{text-decoration:none;color:inherit}button{border:none;background:none;cursor:pointer;font-family:inherit;transition:all .2s ease-in-out}button:focus,input:focus,select:focus{outline:2px solid var(--color-primary);outline-offset:2px}img{max-width:100%;height:auto;display:block}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.cafe-card{display:block;background-color:var(--color-white);border-radius:.75rem;box-shadow:0 4px 6px -1px #0000001a;overflow:hidden;transition:all .3s;transform:translateY(0)}.cafe-card:hover{box-shadow:0 20px 25px -5px #0000001a;transform:translateY(-4px)}.cafe-card-image{position:relative;height:12rem;background:linear-gradient(to bottom right,var(--color-amber-600),var(--color-amber-800));display:flex;align-items:center;justify-content:center}.cafe-card-letter{color:var(--color-white);text-align:center;font-size:3.75rem;font-weight:700;opacity:.2;transition:opacity .3s}.cafe-card:hover .cafe-card-letter{opacity:.3}.cafe-card-badge{position:absolute;top:1rem;right:1rem;background-color:#ffffffe6;padding:.25rem .75rem;border-radius:9999px}.cafe-card-badge-text{color:var(--color-amber-800);font-size:.875rem;font-weight:600}.cafe-card-content{padding:1.5rem}.cafe-card-title{font-size:1.5rem;font-weight:700;color:var(--color-gray-800);margin-bottom:.5rem;transition:color .3s}.cafe-card:hover .cafe-card-title{color:var(--color-amber-700)}.cafe-card-description{color:var(--color-gray-600);font-size:.875rem;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cafe-card-location{display:flex;align-items:center;font-size:.875rem;color:var(--color-gray-500)}.cafe-card-location-icon{height:1rem;width:1rem;margin-right:.25rem}.cafe-card-footer{margin-top:1rem;display:flex;align-items:center;justify-content:space-between}.cafe-card-cta{color:var(--color-amber-700);font-weight:600;transition:color .3s}.cafe-card:hover .cafe-card-cta{color:var(--color-amber-800)}.global-search{width:100%;background-color:var(--color-white);border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;padding:1rem;margin-bottom:1.5rem}.search-input-wrapper{position:relative}.search-icon-btn{position:absolute;top:50%;left:.75rem;transform:translateY(-50%);color:var(--color-gray-400);padding:.25rem;display:flex;align-items:center;border-radius:.375rem}.search-icon-btn:hover{color:var(--color-gray-600)}.search-icon{height:1.25rem;width:1.25rem}.search-input{display:block;width:100%;padding:.75rem 2.5rem;border:1px solid var(--color-gray-300);border-radius:.5rem;font-size:1rem;color:var(--color-gray-900);transition:all .2s}.search-input::placeholder{color:var(--color-gray-400)}.search-input:focus{outline:none;border-color:var(--color-amber-700);box-shadow:0 0 0 3px #b453091a}.search-clear-btn{position:absolute;top:50%;right:.75rem;transform:translateY(-50%);color:var(--color-gray-400);padding:.25rem;display:flex;align-items:center}.search-clear-btn:hover{color:var(--color-gray-600)}.search-clear-icon{height:1.25rem;width:1.25rem}.search-term-display{margin-top:.5rem;font-size:.875rem;color:var(--color-gray-600)}.search-term-highlight{font-weight:600;color:var(--color-amber-700)}.global-search-controls-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:1rem}.global-search-control-group{display:flex;flex-direction:column}.global-search-control-label{display:block;font-size:.875rem;font-weight:500;color:var(--color-gray-700);margin-bottom:.5rem}.global-search-select{width:100%;padding:.5rem 1rem;border:1px solid var(--color-gray-300);border-radius:.5rem;font-size:1rem;background-color:var(--color-white);transition:all .2s}.global-search-select:focus{outline:none;border-color:var(--color-amber-500);box-shadow:0 0 0 3px #b453091a}@media(min-width:768px){.global-search-controls-grid{grid-template-columns:repeat(2,1fr)}}.homepage{min-height:100vh;background:linear-gradient(to bottom right,var(--color-amber-50),var(--color-orange-50),var(--color-amber-100))}.homepage-hero{background:linear-gradient(to right,var(--color-amber-800),var(--color-amber-900));color:var(--color-white);padding:4rem 1rem}.homepage-hero-content{max-width:1280px;margin:0 auto;text-align:center}.homepage-hero-title{font-size:3rem;font-weight:700;margin-bottom:1rem}.homepage-hero-subtitle{font-size:1.25rem;color:var(--color-amber-100)}.homepage-container{max-width:1280px;margin:0 auto;padding:2rem 1rem}.homepage-section-title{font-size:1.875rem;font-weight:700;color:var(--color-gray-800);margin-bottom:1.5rem;text-align:center}.homepage-cafes-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.homepage-loading,.homepage-no-results{text-align:center;padding:3rem 0}.homepage-spinner{width:3rem;height:3rem;border:2px solid var(--color-gray-200);border-top-color:var(--color-amber-800);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}.homepage-loading-text,.homepage-no-results-text{margin-top:1rem;color:var(--color-gray-600)}.homepage-search-results{margin-bottom:2rem}.homepage-results-card{background-color:var(--color-white);border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;padding:1.5rem}.homepage-results-title{font-size:1.5rem;font-weight:700;color:var(--color-gray-800);margin-bottom:1rem}.homepage-results-list{display:flex;flex-direction:column;gap:1rem}.homepage-result-item{border:1px solid var(--color-gray-200);border-radius:.5rem;padding:1rem;transition:all .2s;cursor:pointer}.homepage-result-item:hover{border-color:var(--color-amber-500);box-shadow:0 4px 6px -1px #0000001a}.homepage-result-content{display:flex;justify-content:space-between;align-items:flex-start}.homepage-result-info{flex:1}.homepage-result-name{font-weight:600;font-size:1.125rem;color:var(--color-gray-800)}.homepage-result-meta{font-size:.875rem;color:var(--color-gray-600);margin-top:.25rem}.homepage-result-cafe{font-weight:500;color:var(--color-amber-700)}.homepage-result-category{display:inline-block;background-color:var(--color-amber-100);color:var(--color-amber-800);padding:.125rem .5rem;border-radius:.25rem;font-size:.75rem;margin-left:.5rem}.homepage-result-price{font-size:1.125rem;font-weight:700;color:var(--color-amber-700);margin-left:1rem;white-space:nowrap}.homepage-no-results-icon{width:3rem;height:3rem;color:var(--color-gray-400);margin:0 auto}@media(min-width:768px){.homepage-hero-title{font-size:3.75rem}.homepage-hero-subtitle{font-size:1.5rem}.homepage-cafes-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.homepage-cafes-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1280px){.homepage-cafes-grid{grid-template-columns:repeat(3,1fr)}}.menu-card{background-color:var(--color-white);border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a;padding:1rem;border:1px solid var(--color-gray-100);transition:all .3s}.menu-card:hover{box-shadow:0 10px 15px -3px #0000001a;border-color:var(--color-amber-300)}.menu-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.menu-card-title{font-size:1.125rem;font-weight:600;color:var(--color-gray-800);flex:1;padding-right:.5rem}.menu-card-price{color:var(--color-amber-700);font-weight:700;font-size:1.125rem;white-space:nowrap}.menu-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.75rem}.menu-card-category{display:inline-block;background-color:var(--color-amber-100);color:var(--color-amber-800);font-size:.75rem;font-weight:500;padding:.25rem .75rem;border-radius:9999px}.menu-card-rating{display:flex;align-items:center}.menu-card-rating-icon{height:1rem;width:1rem;color:var(--color-yellow-400);fill:currentColor}.menu-card-rating-value{margin-left:.25rem;font-size:.875rem;color:var(--color-gray-600)}.cafe-menu{min-height:100vh;background:linear-gradient(to bottom right,var(--color-amber-50),var(--color-orange-50),var(--color-amber-100))}.cafe-menu-header{background:linear-gradient(to right,var(--color-amber-800),var(--color-amber-900));color:var(--color-white);padding:2rem 1rem;box-shadow:0 10px 15px -3px #0000001a}.cafe-menu-sticky-title{position:sticky;top:0;z-index:10;background:linear-gradient(to right,var(--color-amber-800),var(--color-amber-900));color:var(--color-white);padding:.75rem 1rem;box-shadow:0 4px 8px -2px #00000026}.cafe-menu-header-content{max-width:1280px;margin:0 auto}.cafe-menu-back-btn{display:flex;align-items:center;margin-bottom:1rem;color:var(--color-amber-200);padding:.5rem 0;transition:color .2s}.cafe-menu-back-btn:hover{color:var(--color-white)}.cafe-menu-back-icon{height:1.25rem;width:1.25rem;margin-right:.5rem}.cafe-menu-title{font-size:1.5rem;font-weight:700;margin-bottom:0}.cafe-menu-description{color:var(--color-amber-100)}.cafe-menu-item-count{color:var(--color-amber-200);font-size:.875rem;margin-top:.5rem}.cafe-menu-container{max-width:1280px;margin:0 auto;padding:2rem 1rem}.cafe-menu-controls{background-color:var(--color-white);border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;padding:1.5rem;margin-bottom:1.5rem}.cafe-menu-controls-grid{display:grid;grid-template-columns:1fr;gap:1rem}.cafe-menu-control-group{display:flex;flex-direction:column}.cafe-menu-control-label{display:block;font-size:.875rem;font-weight:500;color:var(--color-gray-700);margin-bottom:.5rem}.cafe-menu-search-wrapper{position:relative}.cafe-menu-search-input{width:100%;padding:.5rem .5rem .5rem 2.5rem;border:1px solid var(--color-gray-300);border-radius:.5rem;font-size:1rem;transition:all .2s}.cafe-menu-search-input:focus{outline:none;border-color:var(--color-amber-500);box-shadow:0 0 0 3px #b453091a}.cafe-menu-search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);height:1.25rem;width:1.25rem;color:var(--color-gray-400);pointer-events:none}.cafe-menu-select{width:100%;padding:.5rem 1rem;border:1px solid var(--color-gray-300);border-radius:.5rem;font-size:1rem;background-color:var(--color-white);transition:all .2s}.cafe-menu-select:focus{outline:none;border-color:var(--color-amber-500);box-shadow:0 0 0 3px #b453091a}.cafe-menu-category-pills{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.cafe-menu-category-pill{padding:.5rem 1rem;border-radius:9999px;font-weight:500;transition:all .2s;border:none;cursor:pointer}.cafe-menu-category-pill.active{background-color:var(--color-amber-700);color:var(--color-white)}.cafe-menu-category-pill:not(.active){background-color:var(--color-white);color:var(--color-gray-700)}.cafe-menu-category-pill:not(.active):hover{background-color:var(--color-amber-100)}.cafe-menu-items-container{display:flex;flex-direction:column;gap:2rem}.cafe-menu-category-section{background-color:var(--color-white);border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;padding:1.5rem}.cafe-menu-category-title{font-size:1.5rem;font-weight:700;color:var(--color-gray-800);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-amber-500)}.cafe-menu-category-count{font-size:.875rem;font-weight:400;color:var(--color-gray-600);margin-left:.5rem}.cafe-menu-items-grid{display:grid;grid-template-columns:1fr;gap:1rem}.cafe-menu-empty{background-color:var(--color-white);border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;padding:3rem 1.5rem;text-align:center}.cafe-menu-empty-icon{width:4rem;height:4rem;color:var(--color-gray-400);margin:0 auto}.cafe-menu-empty-title{margin-top:1rem;color:var(--color-gray-600);font-size:1.125rem}.cafe-menu-empty-subtitle{color:var(--color-gray-500);font-size:.875rem;margin-top:.5rem}.cafe-menu-loading,.cafe-menu-not-found{min-height:100vh;background:linear-gradient(to bottom right,var(--color-amber-50),var(--color-orange-50));display:flex;align-items:center;justify-content:center}.cafe-menu-loading-content,.cafe-menu-not-found-content{text-align:center}.cafe-menu-spinner{width:4rem;height:4rem;border:2px solid var(--color-gray-200);border-top-color:var(--color-amber-800);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}.cafe-menu-loading-text{margin-top:1rem;color:var(--color-gray-600);font-size:1.125rem}.cafe-menu-not-found-title{font-size:1.5rem;font-weight:700;color:var(--color-gray-800);margin-bottom:1rem}.cafe-menu-not-found-btn{margin-top:1rem;background-color:var(--color-amber-700);color:var(--color-white);padding:.5rem 1.5rem;border-radius:.5rem;font-weight:500;transition:background-color .2s}.cafe-menu-not-found-btn:hover{background-color:var(--color-amber-800)}@media(min-width:768px){.cafe-menu-title{font-size:1.75rem}.cafe-menu-controls-grid{grid-template-columns:repeat(3,1fr)}.cafe-menu-items-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.cafe-menu-items-grid{grid-template-columns:repeat(3,1fr)}}.footer{background:linear-gradient(to right,var(--color-amber-800),var(--color-amber-900));color:var(--color-white);margin-top:auto}.footer-container{max-width:1280px;margin:0 auto;padding:2rem 1rem}.footer-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.footer-header{text-align:center}.footer-title{font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.footer-subtitle{color:var(--color-amber-200);font-size:.875rem}.footer-divider{border-top:1px solid var(--color-amber-700);width:100%;margin:.5rem 0}.footer-credits{text-align:center}.footer-credits-label{font-size:.875rem;font-weight:600;margin-bottom:.5rem;color:var(--color-amber-100)}.footer-names{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem}.footer-name{background-color:#b4530980;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500;transition:background-color .2s;color:var(--color-white);text-decoration:none}.footer-name:hover{background-color:#d9770680}.footer-copyright{text-align:center;margin-top:.5rem}.footer-copyright p{font-size:.75rem;color:var(--color-amber-300)}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100vh;background:linear-gradient(135deg,#f59e0b,#ea580c,#dc2626);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;transition:opacity .5s ease-out}.loading-screen.fade-out{opacity:0;pointer-events:none}.loading-content{display:flex;flex-direction:column;align-items:center;gap:2rem}.loading-title{color:var(--color-white);font-size:2.5rem;font-weight:700;text-align:center;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.loading-subtitle{color:#ffffffe6;font-size:1.125rem;text-align:center;margin:0}.loading-animation{display:flex;align-items:center;justify-content:center;gap:1rem;height:80px}.loading-line{width:8px;height:60px;background-color:var(--color-white);border-radius:4px;animation:bounce 1.2s ease-in-out infinite;box-shadow:0 4px 8px #0003}.loading-line:nth-child(1){animation-delay:0s}.loading-line:nth-child(2){animation-delay:.2s}.loading-line:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,to{height:40px;transform:translateY(0)}50%{height:70px;transform:translateY(-10px)}}.loading-circles{display:flex;align-items:flex-end;justify-content:center;gap:1rem;height:80px}.loading-circle{width:20px;height:20px;background-color:var(--color-white);border-radius:50%;animation:bounceCircle 1.2s ease-in-out infinite;box-shadow:0 4px 8px #0003}.loading-circle:nth-child(1){animation-delay:0s}.loading-circle:nth-child(2){animation-delay:.2s}.loading-circle:nth-child(3){animation-delay:.4s}@keyframes bounceCircle{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-40px) scale(1.1)}}@media(min-width:768px){.loading-title{font-size:3.5rem}.loading-subtitle{font-size:1.5rem}}.app{display:flex;flex-direction:column;min-height:100vh}
