:root{--color-primary: #CF2E2E;--color-primary-dark: #A62424;--color-primary-light: #E04848;--color-primary-subtle: #FCE8E8;--color-secondary: #8B4513;--color-secondary-dark: #6B3410;--color-secondary-light: #A0613F;--color-neutral-100: #FDFCFB;--color-neutral-200: #F5F3F0;--color-neutral-300: #E8E4DF;--color-neutral-400: #CCC6BE;--color-neutral-500: #968F85;--color-neutral-600: #6B655C;--color-neutral-700: #4A453E;--color-neutral-800: #2C2923;--color-neutral-900: #1A1816;--color-text-primary: #1A1816;--color-text-secondary: #4A453E;--color-text-subtle: #6B655C;--color-text-inverse: #FDFCFB;--color-background: #FDFCFB;--color-background-subtle: #F5F3F0;--color-background-elevated: #FFFFFF;--color-border: #E8E4DF;--color-border-subtle: #F5F3F0;--color-border-strong: #CCC6BE;--color-focus: #0066CC;--color-link: #8B4513;--color-link-hover: #6B3410;--color-success: #6B8E23;--color-warning: #D2691E;--color-error: #8B2500;--color-info: #4682B4;--font-family-body: "Cardo", Georgia, "Times New Roman", serif;--font-family-heading: "Josefin Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-family-mono: "Courier New", Courier, monospace;--font-size-xs: clamp(.75rem, .7rem + .25vw, .875rem);--font-size-sm: clamp(.875rem, .8rem + .375vw, 1rem);--font-size-base: clamp(1rem, .95rem + .25vw, 1.125rem);--font-size-md: clamp(1.125rem, 1rem + .625vw, 1.25rem);--font-size-lg: clamp(1.25rem, 1.1rem + .75vw, 1.5rem);--font-size-xl: clamp(1.5rem, 1.3rem + 1vw, 2rem);--font-size-2xl: clamp(2rem, 1.6rem + 2vw, 3rem);--font-size-3xl: clamp(2.5rem, 2rem + 2.5vw, 4rem);--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-snug: 1.35;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--line-height-loose: 1.75;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0;--letter-spacing-wide: .025em;--letter-spacing-wider: .05em;--letter-spacing-widest: .1em;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 1.75rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-gutter: var(--space-4);--space-section: var(--space-12);--space-component: var(--space-6);--container-xs: 20rem;--container-sm: 36rem;--container-md: 48rem;--container-lg: 62rem;--container-xl: 75rem;--container-2xl: 87.5rem;--content-width: 65ch;--gap-xs: var(--space-2);--gap-sm: var(--space-4);--gap-md: var(--space-6);--gap-lg: var(--space-8);--gap-xl: var(--space-12);--border-width-thin: 1px;--border-width-medium: 2px;--border-width-thick: 4px;--radius-none: 0;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(44, 41, 35, .05);--shadow-sm: 0 1px 3px rgba(44, 41, 35, .08), 0 1px 2px rgba(44, 41, 35, .06);--shadow-md: 0 4px 6px rgba(44, 41, 35, .08), 0 2px 4px rgba(44, 41, 35, .06);--shadow-lg: 0 10px 15px rgba(44, 41, 35, .1), 0 4px 6px rgba(44, 41, 35, .05);--shadow-xl: 0 20px 25px rgba(44, 41, 35, .1), 0 10px 10px rgba(44, 41, 35, .04);--shadow-2xl: 0 25px 50px rgba(44, 41, 35, .15);--shadow-focus: 0 0 0 3px rgba(0, 102, 204, .3);--duration-instant: 0ms;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .35s;--duration-slower: .5s;--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--transition-base: all var(--duration-normal) var(--ease-in-out);--transition-fast: all var(--duration-fast) var(--ease-in-out);--transition-slow: all var(--duration-slow) var(--ease-in-out);--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-notification: 800;--z-max: 9999;--touch-target-min: 44px;--focus-width: 2px;--focus-offset: 2px}@media print{:root{--color-background: white;--color-text-primary: black;--shadow-sm: none;--shadow-md: none;--shadow-lg: none}}.container{width:100%;max-width:var(--container-xl);margin-inline:auto;padding-inline:var(--space-gutter)}.container-sm{max-width:var(--container-sm)}.container-md{max-width:var(--container-md)}.container-lg{max-width:var(--container-lg)}.container-fluid{max-width:100%}.stack{display:flex;flex-direction:column;justify-content:flex-start}.stack>*{margin-block:0}.stack>*+*{margin-block-start:var(--stack-space, var(--space-4))}.stack-xs>*+*{margin-block-start:var(--space-2)}.stack-sm>*+*{margin-block-start:var(--space-4)}.stack-md>*+*{margin-block-start:var(--space-6)}.stack-lg>*+*{margin-block-start:var(--space-8)}.stack-xl>*+*{margin-block-start:var(--space-12)}.cluster{display:flex;flex-wrap:wrap;gap:var(--cluster-gap, var(--gap-sm));justify-content:flex-start;align-items:center}.cluster-start{justify-content:flex-start}.cluster-center{justify-content:center}.cluster-end{justify-content:flex-end}.cluster-between{justify-content:space-between}.grid{display:grid;gap:var(--grid-gap, var(--gap-md))}.grid-auto-fit{grid-template-columns:repeat(auto-fit,minmax(min(var(--grid-min-width, 250px),100%),1fr))}.grid-auto-fill{grid-template-columns:repeat(auto-fill,minmax(min(var(--grid-min-width, 250px),100%),1fr))}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}@media (min-width: 769px) and (max-width: 1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}.sidebar{display:flex;flex-wrap:wrap;gap:var(--sidebar-gap, var(--gap-md))}.sidebar>:first-child{flex-basis:var(--sidebar-width, 250px);flex-grow:1}.sidebar>:last-child{flex-basis:0;flex-grow:999;min-inline-size:var(--sidebar-content-min, 50%)}.switcher{display:flex;flex-wrap:wrap;gap:var(--switcher-gap, var(--gap-md))}.switcher>*{flex-grow:1;flex-basis:calc((var(--switcher-breakpoint, 30rem) - 100%) * 999)}.cover{display:flex;flex-direction:column;min-block-size:var(--cover-min-height, 100vh);padding:var(--space-4)}.cover>*{margin-block:var(--space-4)}.cover>:first-child:not(.cover-center){margin-block-start:0}.cover>:last-child:not(.cover-center){margin-block-end:0}.cover>.cover-center{margin-block:auto}.center{box-sizing:content-box;margin-inline:auto;max-inline-size:var(--center-max-width, var(--content-width))}.center-text{text-align:center}.frame{aspect-ratio:var(--frame-ratio, 16 / 9);overflow:hidden;display:flex;justify-content:center;align-items:center}.frame>img,.frame>video{inline-size:100%;block-size:100%;object-fit:cover}.frame-square{aspect-ratio:1 / 1}.frame-portrait{aspect-ratio:3 / 4}.frame-landscape{aspect-ratio:4 / 3}.region{padding-block:var(--region-space, var(--space-section))}.region-sm{padding-block:var(--space-8)}.region-lg{padding-block:var(--space-16)}.repel{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:var(--repel-gap, var(--gap-sm))}.flow>*+*{margin-block-start:var(--flow-space, 1em)}.wrapper{max-inline-size:var(--wrapper-max-width, var(--container-xl));margin-inline:auto;padding-inline:var(--wrapper-padding, var(--space-gutter));position:relative}.block{display:block!important}.inline-block{display:inline-block!important}.inline{display:inline!important}.flex{display:flex!important}.inline-flex{display:inline-flex!important}.grid{display:grid!important}.hidden{display:none!important}.visible{visibility:visible!important}.invisible{visibility:hidden!important}.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}.font-body{font-family:var(--font-family-body)!important}.font-heading{font-family:var(--font-family-heading)!important}.font-mono{font-family:var(--font-family-mono)!important}.text-xs{font-size:var(--font-size-xs)!important}.text-sm{font-size:var(--font-size-sm)!important}.text-base{font-size:var(--font-size-base)!important}.text-md{font-size:var(--font-size-md)!important}.text-lg{font-size:var(--font-size-lg)!important}.text-xl{font-size:var(--font-size-xl)!important}.text-2xl{font-size:var(--font-size-2xl)!important}.text-3xl{font-size:var(--font-size-3xl)!important}.font-light{font-weight:var(--font-weight-light)!important}.font-normal{font-weight:var(--font-weight-normal)!important}.font-medium{font-weight:var(--font-weight-medium)!important}.font-semibold{font-weight:var(--font-weight-semibold)!important}.font-bold{font-weight:var(--font-weight-bold)!important}.text-left{text-align:left!important}.text-center{text-align:center!important}.text-right{text-align:right!important}.text-justify{text-align:justify!important}.uppercase{text-transform:uppercase!important}.lowercase{text-transform:lowercase!important}.capitalize{text-transform:capitalize!important}.normal-case{text-transform:none!important}.underline{text-decoration:underline!important}.line-through{text-decoration:line-through!important}.no-underline{text-decoration:none!important}.italic{font-style:italic!important}.not-italic{font-style:normal!important}.leading-tight{line-height:var(--line-height-tight)!important}.leading-snug{line-height:var(--line-height-snug)!important}.leading-normal{line-height:var(--line-height-normal)!important}.leading-relaxed{line-height:var(--line-height-relaxed)!important}.leading-loose{line-height:var(--line-height-loose)!important}.tracking-tight{letter-spacing:var(--letter-spacing-tight)!important}.tracking-normal{letter-spacing:var(--letter-spacing-normal)!important}.tracking-wide{letter-spacing:var(--letter-spacing-wide)!important}.tracking-wider{letter-spacing:var(--letter-spacing-wider)!important}.tracking-widest{letter-spacing:var(--letter-spacing-widest)!important}.text-primary{color:var(--color-text-primary)!important}.text-secondary{color:var(--color-text-secondary)!important}.text-subtle{color:var(--color-text-subtle)!important}.text-inverse{color:var(--color-text-inverse)!important}.text-brand{color:var(--color-primary)!important}.bg-primary{background-color:var(--color-primary)!important}.bg-secondary{background-color:var(--color-secondary)!important}.bg-background{background-color:var(--color-background)!important}.bg-elevated{background-color:var(--color-background-elevated)!important}.bg-subtle{background-color:var(--color-background-subtle)!important}.bg-transparent{background-color:transparent!important}.bg-white{background-color:#fff!important}.m-0{margin:var(--space-0)!important}.m-1{margin:var(--space-1)!important}.m-2{margin:var(--space-2)!important}.m-3{margin:var(--space-3)!important}.m-4{margin:var(--space-4)!important}.m-6{margin:var(--space-6)!important}.m-8{margin:var(--space-8)!important}.m-auto{margin:auto!important}.mt-0{margin-top:var(--space-0)!important}.mt-1{margin-top:var(--space-1)!important}.mt-2{margin-top:var(--space-2)!important}.mt-3{margin-top:var(--space-3)!important}.mt-4{margin-top:var(--space-4)!important}.mt-6{margin-top:var(--space-6)!important}.mt-8{margin-top:var(--space-8)!important}.mb-0{margin-bottom:var(--space-0)!important}.mb-1{margin-bottom:var(--space-1)!important}.mb-2{margin-bottom:var(--space-2)!important}.mb-3{margin-bottom:var(--space-3)!important}.mb-4{margin-bottom:var(--space-4)!important}.mb-6{margin-bottom:var(--space-6)!important}.mb-8{margin-bottom:var(--space-8)!important}.p-0{padding:var(--space-0)!important}.p-1{padding:var(--space-1)!important}.p-2{padding:var(--space-2)!important}.p-3{padding:var(--space-3)!important}.p-4{padding:var(--space-4)!important}.p-6{padding:var(--space-6)!important}.p-8{padding:var(--space-8)!important}.pt-0{padding-top:var(--space-0)!important}.pt-1{padding-top:var(--space-1)!important}.pt-2{padding-top:var(--space-2)!important}.pt-3{padding-top:var(--space-3)!important}.pt-4{padding-top:var(--space-4)!important}.pt-6{padding-top:var(--space-6)!important}.pt-8{padding-top:var(--space-8)!important}.pb-0{padding-bottom:var(--space-0)!important}.pb-1{padding-bottom:var(--space-1)!important}.pb-2{padding-bottom:var(--space-2)!important}.pb-3{padding-bottom:var(--space-3)!important}.pb-4{padding-bottom:var(--space-4)!important}.pb-6{padding-bottom:var(--space-6)!important}.pb-8{padding-bottom:var(--space-8)!important}.rounded-none{border-radius:var(--radius-none)!important}.rounded-sm{border-radius:var(--radius-sm)!important}.rounded-md{border-radius:var(--radius-md)!important}.rounded-lg{border-radius:var(--radius-lg)!important}.rounded-xl{border-radius:var(--radius-xl)!important}.rounded-full{border-radius:var(--radius-full)!important}.border-0{border-width:0!important}.border{border-width:var(--border-width-thin)!important}.border-2{border-width:var(--border-width-medium)!important}.border-4{border-width:var(--border-width-thick)!important}.border-default{border-color:var(--color-border)!important}.border-subtle{border-color:var(--color-border-subtle)!important}.border-strong{border-color:var(--color-border-strong)!important}.shadow-xs{box-shadow:var(--shadow-xs)!important}.shadow-sm{box-shadow:var(--shadow-sm)!important}.shadow-md{box-shadow:var(--shadow-md)!important}.shadow-lg{box-shadow:var(--shadow-lg)!important}.shadow-xl{box-shadow:var(--shadow-xl)!important}.shadow-none{box-shadow:none!important}.relative{position:relative!important}.absolute{position:absolute!important}.fixed{position:fixed!important}.sticky{position:sticky!important}.static{position:static!important}.overflow-auto{overflow:auto!important}.overflow-hidden{overflow:hidden!important}.overflow-visible{overflow:visible!important}.overflow-scroll{overflow:scroll!important}.w-full{width:100%!important}.w-auto{width:auto!important}.h-full{height:100%!important}.h-auto{height:auto!important}.flex-row{flex-direction:row!important}.flex-col{flex-direction:column!important}.flex-wrap{flex-wrap:wrap!important}.flex-nowrap{flex-wrap:nowrap!important}.items-start{align-items:flex-start!important}.items-center{align-items:center!important}.items-end{align-items:flex-end!important}.items-stretch{align-items:stretch!important}.justify-start{justify-content:flex-start!important}.justify-center{justify-content:center!important}.justify-end{justify-content:flex-end!important}.justify-between{justify-content:space-between!important}.justify-around{justify-content:space-around!important}.flex-1{flex:1 1 0%!important}.flex-auto{flex:1 1 auto!important}.flex-none{flex:none!important}.gap-0{gap:var(--space-0)!important}.gap-1{gap:var(--space-1)!important}.gap-2{gap:var(--space-2)!important}.gap-3{gap:var(--space-3)!important}.gap-4{gap:var(--space-4)!important}.gap-6{gap:var(--space-6)!important}.gap-8{gap:var(--space-8)!important}.opacity-0{opacity:0!important}.opacity-50{opacity:.5!important}.opacity-100{opacity:1!important}.pointer-events-none{pointer-events:none!important}.pointer-events-auto{pointer-events:auto!important}.cursor-pointer{cursor:pointer!important}.cursor-default{cursor:default!important}.cursor-not-allowed{cursor:not-allowed!important}@media (max-width: 768px){.hidden-mobile{display:none!important}.visible-mobile{display:block!important}}@media (min-width: 769px){.hidden-desktop{display:none!important}.visible-desktop{display:block!important}}.skip-link{position:absolute!important;top:-40px;left:var(--space-2);background:var(--color-neutral-900);color:var(--color-text-inverse);padding:var(--space-2) var(--space-4);text-decoration:none;border-radius:var(--radius-sm);z-index:var(--z-max)}.skip-link:focus{top:var(--space-2);outline:var(--focus-width) solid var(--color-focus);outline-offset:var(--focus-offset)}.menu-header{background-color:var(--color-primary);color:var(--color-text-inverse);text-align:center;padding:var(--space-8) var(--space-4);box-shadow:var(--shadow-md)}.menu-header__title{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide);margin:0;text-transform:uppercase}.menu-header__tagline{font-family:var(--font-family-body);font-size:var(--font-size-lg);font-weight:var(--font-weight-light);font-style:italic;margin:var(--space-2) 0 0;opacity:.95}.category-nav{background-color:var(--color-background-elevated);border-bottom:var(--border-width-medium) solid var(--color-primary);position:sticky;top:0;z-index:var(--z-sticky);box-shadow:var(--shadow-md);padding:var(--space-4) var(--space-2)}.category-nav__list,.category-list{display:flex;flex-wrap:wrap;gap:var(--gap-sm);justify-content:center;list-style:none;margin:0;padding:var(--space-2);max-width:var(--container-xl);margin-inline:auto}.category-nav__item,.category-item{margin:0}.category-nav__button,.category-button{font-family:var(--font-family-heading);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;background-color:var(--color-background-elevated);border:var(--border-width-medium) solid var(--color-primary);border-radius:var(--radius-full);color:var(--color-primary);padding:var(--space-3) var(--space-6);min-height:var(--touch-target-min);min-width:var(--touch-target-min);cursor:pointer;transition:var(--transition-fast);display:inline-flex;align-items:center;justify-content:center}.category-nav__button:hover,.category-button:hover{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse);transform:translateY(-1px);box-shadow:var(--shadow-md)}.category-nav__button:focus,.category-button:focus{outline:var(--focus-width) solid var(--color-focus);outline-offset:var(--focus-offset)}.category-nav__button--active,.category-button.active{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse);box-shadow:var(--shadow-sm)}.category-nav__button--active:hover,.category-button.active:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);color:var(--color-text-inverse)}@media (max-width: 768px){.category-nav__list,.category-list{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--color-primary) var(--color-neutral-200);padding:var(--space-2) 0}.category-nav__button,.category-button{white-space:nowrap;flex-shrink:0;font-size:.8125rem;padding:var(--space-2) var(--space-4)}}.category-header{margin-bottom:var(--space-8);text-align:center;padding:var(--space-8) var(--space-4)}.category-title{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-primary);margin:0 0 var(--space-3) 0;text-align:center;letter-spacing:var(--letter-spacing-wide)}.category-description{font-family:var(--font-family-body);font-size:var(--font-size-md);color:var(--color-text-secondary);max-width:600px;margin:0 auto;line-height:var(--line-height-relaxed);text-align:center}.dish-card{background-color:var(--color-background-elevated);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:var(--transition-base);cursor:pointer;border:var(--border-width-thin) solid var(--color-border)}.dish-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--color-primary-light)}.dish-card:focus-within{outline:var(--focus-width) solid var(--color-focus);outline-offset:var(--focus-offset)}.dish-card__image-container{position:relative;width:100%;aspect-ratio:4 / 3;overflow:hidden;background-color:var(--color-neutral-200)}.dish-card__image{width:100%;height:100%;object-fit:cover;transition:transform var(--duration-slow) var(--ease-out)}.dish-card:hover .dish-card__image{transform:scale(1.05)}.dish-card__content{padding:var(--space-5)}.dish-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--gap-sm);margin-bottom:var(--space-3)}.dish-card__title{font-family:var(--font-family-heading);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-snug)}.dish-card__price{font-family:var(--font-family-heading);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary);white-space:nowrap;flex-shrink:0}.dish-card__description{font-family:var(--font-family-body);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);color:var(--color-text-secondary);margin:0 0 var(--space-4);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.dish-card__footer{display:flex;gap:var(--gap-xs);flex-wrap:wrap;align-items:center}.dish-detail-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn .2s ease-out}.dish-detail-modal{background:var(--color-background-elevated);border-radius:var(--radius-xl);max-width:var(--container-md);width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-2xl);animation:slideUp .2s ease-out;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-6);gap:var(--space-4);border-bottom:var(--border-width-thin) solid var(--color-border)}.dish-title{font-family:var(--font-family-heading);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight);flex:1;min-width:0}.header-badges{display:flex;gap:var(--gap-xs);flex-wrap:wrap;margin-top:var(--space-3)}.detail-badge{display:inline-flex;align-items:center;padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);line-height:1}.close-button{background:var(--color-neutral-200);border:none;border-radius:50%;width:var(--touch-target-min);height:var(--touch-target-min);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-fast);flex-shrink:0;color:var(--color-text-secondary)}.close-button:hover{background:var(--color-neutral-300);color:var(--color-text-primary)}.close-button:focus{outline:var(--focus-width) solid var(--color-focus);outline-offset:var(--focus-offset)}.modal-content{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-8)}.price-section{text-align:center;padding:var(--space-6);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border-radius:var(--radius-lg);color:var(--color-text-inverse)}.price-display{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);line-height:1;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.description-section h3,.spicy-section h3,.dietary-section h3,.allergen-section h3{font-family:var(--font-family-heading);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-4) 0}.full-description{font-family:var(--font-family-body);font-size:var(--font-size-base);line-height:var(--line-height-relaxed);color:var(--color-text-secondary);margin:0}.detailed-dietary-icon,.detailed-allergen-icon{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--color-background-subtle);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.detailed-dietary-icon svg,.detailed-allergen-icon svg{flex-shrink:0}@media (max-width: 768px){.dish-detail-backdrop{padding:var(--space-2);align-items:flex-end}.dish-detail-modal{max-height:95vh;border-bottom-left-radius:0;border-bottom-right-radius:0}.modal-header{padding:var(--space-4);flex-wrap:wrap}.dish-title{font-size:var(--font-size-xl)}.modal-content{padding:var(--space-4);gap:var(--space-6)}.price-display{font-size:var(--font-size-2xl)}.description-section h3,.spicy-section h3,.dietary-section h3,.allergen-section h3{font-size:var(--font-size-md)}}@media (max-width: 480px){.dish-detail-backdrop{padding:0}.dish-detail-modal{max-height:100vh;border-radius:0}.modal-header,.modal-content{padding:var(--space-3)}}.icon-container{display:inline-flex;align-items:center;gap:var(--space-4);padding:var(--space-2) var(--space-5);border:1px solid;border-radius:var(--radius-md);font-size:var(--font-size-sm);line-height:1;transition:var(--transition-fast);vertical-align:middle;min-width:fit-content}.icon-container .icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.125rem;line-height:1;height:1.125rem;width:1.125rem}.icon-container .icon-label{font-family:var(--font-family-heading);font-weight:var(--font-weight-semibold);white-space:nowrap;font-size:var(--font-size-sm);line-height:1.2;display:flex;align-items:center}.spicy-level-container{display:inline-flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border:1px solid;border-radius:var(--radius-md);font-size:var(--font-size-sm);line-height:1;vertical-align:middle}.spicy-level-container .spicy-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:var(--font-size-lg);line-height:1;width:1.125rem}.spicy-level-container .spicy-label{font-family:var(--font-family-heading);font-weight:var(--font-weight-semibold);white-space:nowrap;font-size:var(--font-size-sm);line-height:1.2;display:flex;align-items:center}.allergen-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);background-color:var(--color-neutral-200);color:var(--color-text-secondary);font-size:var(--font-size-sm);transition:var(--transition-fast)}.allergen-icon:hover{background-color:var(--color-neutral-300);transform:scale(1.1)}.allergen-icon--vegetarian{background-color:#e8f5e9;color:#2e7d32}.allergen-icon--vegan{background-color:#c8e6c9;color:#1b5e20}.allergen-icon--gluten-free{background-color:#fff3e0;color:#e65100}.allergen-icon--spicy{background-color:#ffebee;color:#c62828}.menu-footer{background-color:var(--color-neutral-800);color:var(--color-text-inverse);text-align:center;padding:var(--space-8) var(--space-4);margin-top:var(--space-section)}.menu-footer__text{font-family:var(--font-family-body);font-size:var(--font-size-sm);margin:var(--space-2) 0;opacity:.9}*,*:before,*:after{box-sizing:border-box}body,h1,h2,h3,h4,h5,h6,p,figure,blockquote,dl,dd{margin:0}body{min-height:100vh;text-rendering:optimizeSpeed;line-height:var(--line-height-normal);font-family:var(--font-family-body);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-background);margin:0;padding:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}input,button,textarea,select{font:inherit}ul[class],ol[class]{list-style:none;padding:0;margin:0}a:not([class]){text-decoration-skip-ink:auto}img,picture{max-width:100%;display:block}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}*:focus{outline:var(--focus-width) solid var(--color-focus);outline-offset:var(--focus-offset)}#app{min-height:100vh;display:flex;flex-direction:column}header{background-color:var(--color-primary);color:var(--color-text-inverse);text-align:center;padding:var(--space-8) var(--space-4);box-shadow:var(--shadow-md)}.header-container h1,.restaurant-name{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide);margin:0;text-transform:uppercase}.header-container p,.restaurant-tagline{font-family:var(--font-family-body);font-size:var(--font-size-lg);font-weight:var(--font-weight-light);font-style:italic;margin:var(--space-2) 0 0;opacity:.95}main{flex:1;padding:var(--space-4)}.menu-content{padding:var(--space-8) var(--space-4);max-width:var(--container-xl);margin:0 auto}footer{background-color:var(--color-neutral-800);color:var(--color-text-inverse);text-align:center;padding:var(--space-8) var(--space-4);margin-top:var(--space-section)}.footer-container p{margin:var(--space-2) 0;font-size:var(--font-size-sm);opacity:.9}.category-button.active{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse)}.loading-state,.error-state,.offline-state{text-align:center;padding:var(--space-12) var(--space-4)}.loading-state{font-family:var(--font-family-body);font-size:var(--font-size-lg);color:var(--color-text-secondary)}.error-state,.offline-state{background-color:#fff3cd;border:var(--border-width-medium) solid #ffc107;border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family-body);font-size:var(--font-size-base);padding:var(--space-6);max-width:var(--container-sm);margin:var(--space-8) auto}.modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:var(--z-modal)}.modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#000000bf;z-index:var(--z-modal-backdrop)}.modal-content{position:relative;background:var(--color-background-elevated);margin:var(--space-8);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);max-height:calc(100vh - var(--space-16));overflow-y:auto;z-index:var(--z-modal)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);border-bottom:var(--border-width-thin) solid var(--color-border)}.modal-close{background:none;border:none;font-size:var(--font-size-2xl);cursor:pointer;padding:var(--space-2);color:var(--color-text-secondary);min-width:var(--touch-target-min);min-height:var(--touch-target-min);border-radius:var(--radius-sm);transition:var(--transition-fast)}.modal-close:hover{color:var(--color-text-primary);background-color:var(--color-neutral-200)}
