:root{--bg: #0f0f12;--surface: #1a1a22;--border: #2a2a36;--text: #f4f4f8;--muted: #9a9ab0;--accent: #ff6b35;--accent-dim: #c44f28;font-family:Segoe UI,system-ui,sans-serif;color:var(--text);background:var(--bg)}*{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:var(--accent);text-decoration:none}button,input,select,textarea{font:inherit}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;max-width:960px;width:100%;margin:0 auto;padding:1rem 1rem 5rem}.site-header{position:relative;z-index:200;background:var(--surface);border-bottom:1px solid var(--border);width:100%}.site-header__inner{max-width:1280px;margin:0 auto}.site-header__bar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem 1rem;min-height:56px}.site-header__bar-tools{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.site-header__toggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;padding:0;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);cursor:pointer;flex-shrink:0}.site-header__toggle:hover{border-color:var(--muted)}.site-header__menu{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex:1;padding:0 1.5rem .85rem}.site-header__backdrop{display:none}.site-header__brand{display:flex;align-items:center;gap:.65rem;flex-shrink:0;color:var(--text);text-decoration:none}.site-header__brand:hover{color:var(--text)}.site-header__logo-icon{width:36px;height:36px;color:var(--accent);flex-shrink:0}.site-header__brand-text{display:flex;flex-direction:column;line-height:1.15}.site-header__brand-name{font-size:1.05rem;font-weight:700;letter-spacing:.02em;color:var(--accent)}.site-header__brand-tag{font-size:.72rem;font-weight:400;color:var(--muted);text-transform:lowercase}.site-header__nav{display:flex;align-items:center;gap:1.75rem;flex:1;justify-content:center;flex-wrap:wrap}.site-header__nav a{color:var(--muted);text-decoration:none;font-size:.95rem;font-weight:500;white-space:nowrap;transition:color .15s}.site-header__nav a:hover{color:var(--text)}.site-header__nav a.active{color:var(--accent);font-weight:600}.site-header__actions{display:flex;align-items:center;gap:1rem;flex-shrink:0}.site-header__meta{color:var(--muted);font-size:.9rem;white-space:nowrap;text-decoration:none}.site-header__meta:hover{color:var(--text)}.site-header__socials{display:flex;align-items:center;gap:.5rem}.site-header__social{display:flex;align-items:center;justify-content:center;color:var(--muted);transition:color .15s}.site-header__social:hover{color:var(--text)}.site-header__cta{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:.65rem 1.25rem;background:var(--accent);color:#fff!important;font-weight:600;font-size:.9rem;text-decoration:none;white-space:nowrap;clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%);transition:filter .15s}.site-header__cta:hover{filter:brightness(1.06)}.site-header__logout{background:none;border:none;color:var(--muted);font-size:.85rem;cursor:pointer;padding:.25rem 0;white-space:nowrap}.site-header__logout:hover{color:var(--text)}.site-header__settings{color:var(--muted);font-size:1.1rem;text-decoration:none;line-height:1}.site-header__link-secondary{color:var(--muted);font-size:.9rem;text-decoration:none;padding:.5rem .75rem}.site-header__link-secondary:hover{color:var(--text)}.site-header__cta--bar{display:none;padding:.45rem .85rem;font-size:.85rem}@media(min-width:901px){.site-header__inner{display:flex;align-items:center;gap:1.5rem;padding:.85rem 1.5rem;min-height:72px}.site-header__bar{padding:0;min-height:auto;flex-shrink:0}.site-header__bar-tools{display:none}.site-header__menu{display:flex;flex:1;padding:0;min-width:0}.site-header__nav-extra{display:none}.site-header__brand-tag{display:block}}@media(max-width:900px){.site-header__inner{position:relative;z-index:201}.site-header__toggle{display:flex}.site-header__cta--bar{display:inline-flex}.site-header__menu{display:none;flex-direction:column;align-items:stretch;gap:0;padding:0;border-top:1px solid var(--border);background:var(--surface);max-height:min(70vh,calc(100dvh - 56px));overflow-y:auto;-webkit-overflow-scrolling:touch}.site-header.is-open .site-header__menu{display:flex}.site-header__nav{flex-direction:column;align-items:stretch;gap:0;flex:none;justify-content:flex-start;padding:.5rem 0}.site-header__nav a{padding:.75rem 1rem;font-size:1rem;border-bottom:1px solid var(--border)}.site-header__nav a:last-child{border-bottom:none}.site-header__actions{flex-direction:column;align-items:stretch;gap:.75rem;padding:1rem;border-top:1px solid var(--border);background:var(--bg)}.site-header__meta{white-space:normal;word-break:break-word}.site-header__socials{justify-content:center}.site-header__cta{width:100%;text-align:center;clip-path:none;border-radius:8px}.site-header__logout,.site-header__link-secondary{width:100%;text-align:center;padding:.65rem;border:1px solid var(--border);border-radius:8px}.site-header__backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;border:none;padding:0;margin:0;background:#0000008c;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .2s}.site-header.is-open .site-header__backdrop{opacity:1;pointer-events:auto}}@media(max-width:480px){.site-header__brand-tag{display:none}.site-header__logo-icon{width:32px;height:32px}.site-header__brand-name{font-size:.95rem}}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem;margin-bottom:1rem}.settings-section--incomplete{border-left:3px solid var(--accent)}.settings-section__badge{display:inline-block;margin-left:.5rem;padding:.15rem .45rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--accent);border:1px solid var(--accent-dim);border-radius:4px;vertical-align:middle}.card img.cover{width:100%;height:160px;object-fit:cover;border-radius:8px;margin-bottom:.75rem;background:var(--border)}.page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem}.page-header h2{margin:0}.kitchen-list-card,.list-card{display:flex;gap:1rem;align-items:flex-start}.kitchen-list-card__image,.list-card__image{flex-shrink:0;width:96px;height:96px;border-radius:8px;overflow:hidden;background:var(--border)}.kitchen-list-card__image img,.list-card__image img{width:100%;height:100%;object-fit:cover}.kitchen-list-card__placeholder,.list-card__placeholder{width:100%;height:100%;background:var(--border)}.kitchen-list-card__body,.list-card__body{flex:1;min-width:0}.kitchen-detail-header__image{width:120px;height:120px}.dish-grid-item{display:flex;flex-direction:column}.dish-grid-item__order{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-top:.5rem}.dish-grid-item__order label{display:flex;align-items:center;gap:.25rem;font-size:.9rem;color:var(--muted)}.btn{background:var(--accent);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer}.btn.secondary{background:var(--border);color:var(--text)}.btn.danger{background:transparent;border:1px solid #8b3030;color:#f5a0a0}.btn.danger:hover:not(:disabled){background:#3a1818}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:.4rem;min-width:2rem;min-height:2rem}.dish-manage--hidden{opacity:.72;border-style:dashed}.dish-manage__head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.dish-manage__badge{display:inline-block;margin-left:.5rem;padding:.15rem .45rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);border:1px solid var(--border);border-radius:4px;vertical-align:middle}.dish-manage__actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.form-error{color:#f5a0a0}.role-switcher{display:flex;flex-direction:column;gap:.5rem}.role-switcher--compact{width:100%}.role-switcher__label{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.role-switcher__track{display:inline-flex;padding:3px;border-radius:10px;background:var(--bg);border:1px solid var(--border);gap:2px}.role-switcher--compact .role-switcher__track{width:100%}.role-switcher__option{flex:1;border:none;background:transparent;color:var(--muted);padding:.4rem .75rem;border-radius:7px;cursor:pointer;font-size:.85rem;font-weight:600}.role-switcher__option.is-active{background:var(--accent);color:#fff}.role-switcher__option:disabled{opacity:.6;cursor:not-allowed}.role-switcher__error{margin:0;font-size:.85rem;color:#f5a0a0}.btn:disabled{opacity:.5;cursor:not-allowed}.form label{display:block;margin-bottom:.75rem;color:var(--muted);font-size:.9rem}.form input,.form textarea,.form select{width:100%;padding:.5rem;margin-top:.25rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text)}.combo-dish-picker{border:none;padding:0;margin:0}.combo-dish-picker__legend{font-weight:600;margin-bottom:.5rem;color:var(--text)}.combo-dish-list{display:flex;flex-direction:column;gap:.5rem}.combo-dish-row{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;margin-bottom:0;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.95rem;cursor:pointer;transition:border-color .15s ease,background-color .15s ease}.form label.combo-dish-row{display:flex}.combo-dish-row:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--border))}.combo-dish-row--selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}.combo-dish-row input[type=checkbox]{width:1.1rem;height:1.1rem;margin:0;flex-shrink:0;accent-color:var(--accent)}.form .combo-dish-row input[type=checkbox]{width:1.1rem;height:1.1rem;margin-top:0}.form .combo-dish-row__qty input{width:3.5rem;margin-top:0;padding:.35rem .4rem;text-align:center}.combo-dish-row__info{flex:1;min-width:0}.combo-dish-row__price{color:var(--muted);white-space:nowrap}.combo-dish-row__qty{display:flex;align-items:center;gap:.35rem;flex-shrink:0;color:var(--muted);font-size:.85rem}.combo-dish-picker__summary{margin-top:.75rem;color:var(--muted);font-size:.9rem}.image-upload-field{margin-bottom:.75rem}.image-upload-field__label{display:block;color:var(--muted);font-size:.9rem;margin-bottom:.5rem}.image-upload-field__preview img{display:block;width:100%;max-width:240px;aspect-ratio:4 / 3;object-fit:cover;border-radius:8px;margin-bottom:.5rem}.image-upload-field__actions{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.image-upload-field__hint{color:var(--muted);font-size:.85rem;line-height:1.35}.image-upload-field__choose{margin-top:0}.dish-image-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.dish-image-grid__item{position:relative;width:96px;height:96px}.dish-image-grid__item img{width:100%;height:100%;object-fit:cover;border-radius:8px}.dish-image-grid__remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border:none;border-radius:50%;background:#000000a6;color:#fff;cursor:pointer;font-size:1rem;line-height:1;padding:0}.dish-image-grid__remove:disabled{opacity:.5;cursor:not-allowed}.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:.75rem 0}.chip{padding:.35rem .75rem;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer;font-size:.85rem}.chip.selected{border-color:var(--accent);background:#ff6b3526}.empty{text-align:center;color:var(--muted);padding:2rem}.grid{display:grid;gap:1rem}@media(min-width:640px){.grid.two{grid-template-columns:1fr 1fr}}.search-bar{display:flex;align-items:stretch;width:100%;margin:0;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--surface);transition:border-color .15s}.search-bar:focus-within{border-color:var(--accent)}.search-bar input{flex:1;min-width:0;padding:.75rem 1rem;border:none;border-radius:0;background:transparent;color:var(--text)}.search-bar input:focus{outline:none}.search-bar .btn{flex-shrink:0;margin:0;padding:.75rem 1.25rem;border-radius:0;font-weight:600;clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%)}.search-bar--compact .btn{padding:.5rem .85rem;font-size:.9rem}.search-page__hero{margin-bottom:1.5rem}.search-page--idle .search-page__hero{max-width:640px;margin:3rem auto 2rem;text-align:center}.search-page__eyebrow{margin:0 0 .35rem;color:var(--accent);font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.search-page__title{margin:0 0 1.25rem;font-size:clamp(1.5rem,4vw,2rem);font-weight:700;line-height:1.2}.search-page--idle .search-page__title{margin-bottom:1.5rem}.search-filters{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:1rem}.search-page--idle .search-filters{justify-content:center}.search-tabs{display:flex;flex-wrap:wrap;gap:.5rem}.search-filters__communities{display:flex;flex-wrap:wrap;gap:.5rem;margin:0}.search-filters__communities:not(:empty):before{content:"";width:1px;height:1.5rem;background:var(--border);margin:0 .15rem;align-self:center}.search-page__body{min-height:0}.search-page__hint,.search-page__status{color:var(--muted);margin:0;text-align:center}.search-page--idle .search-page__hint{margin-top:.5rem}.search-page__section{margin-top:1.5rem}.search-page__section h2{margin:0 0 1rem;font-size:1.1rem;font-weight:600}.form-row{display:grid;gap:.75rem}@media(min-width:640px){.form-row{grid-template-columns:1fr 1fr}}.places-search{position:relative}.places-search__hint{margin:.35rem 0 0;color:var(--muted);font-size:.85rem}.places-search__results{position:absolute;z-index:20;top:calc(100% - .25rem);left:0;right:0;margin:0;padding:.35rem 0;list-style:none;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px #00000059;max-height:240px;overflow-y:auto}.places-search__option{display:block;width:100%;padding:.65rem .85rem;border:0;background:transparent;color:var(--text);text-align:left;cursor:pointer}.places-search__option:hover,.places-search__option:focus-visible{background:#ff6b351f}.places-search__option strong{display:block;font-weight:600}.places-search__option span{display:block;margin-top:.15rem;color:var(--muted);font-size:.85rem}.page-title-with-info{display:flex;align-items:center;gap:.4rem}.page-title-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.25rem}.page-title-row .page-title-with-info{flex-shrink:0;margin:0}.favorite-communities{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;flex:1;min-width:0}.favorite-communities__measure{position:absolute;visibility:hidden;pointer-events:none;display:flex;gap:.5rem;white-space:nowrap}.favorite-communities__overflow{position:relative;flex-shrink:0}.favorite-communities__more-btn,.favorite-communities__add-btn{min-width:2rem;padding-left:.5rem;padding-right:.5rem;font-size:1.1rem;line-height:1}.favorite-communities__add-btn{flex-shrink:0;margin-left:auto}.favorite-communities__popover{position:absolute;top:calc(100% + .35rem);right:0;z-index:50;min-width:10rem;max-width:16rem;padding:.35rem;border:1px solid var(--border);border-radius:10px;background:var(--surface);box-shadow:0 8px 24px #00000059}.favorite-communities__popover-item{display:block;width:100%;padding:.45rem .65rem;border:0;border-radius:6px;background:transparent;color:var(--text);text-align:left;cursor:pointer;font-size:.85rem}.favorite-communities__popover-item:hover,.favorite-communities__popover-item.selected{background:#ff6b3526;color:var(--text)}.favorite-communities .chip{flex-shrink:0;max-width:11rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:1rem;background:#000000a6}.modal{width:min(100%,28rem);max-height:min(85vh,32rem);display:flex;flex-direction:column;padding:1.25rem;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:0 16px 48px #00000073}.modal__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.modal__header h3{margin:0;font-size:1.1rem}.modal__close{border:0;border-radius:8px;background:transparent;color:var(--muted);font-size:1.4rem;line-height:1;cursor:pointer}.modal__close:hover{color:var(--text);background:#ffffff0f}.modal__hint{margin:0 0 .75rem;color:var(--muted);font-size:.9rem}.modal__actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.favorite-communities-modal__search{margin:0 0 .75rem}.favorite-communities-modal__list{flex:1;min-height:0;max-height:16rem;overflow-y:auto;margin:0;align-content:flex-start}.favorite-communities-modal__empty{width:100%;margin:0;color:var(--muted);font-size:.9rem}.info-tooltip{position:relative;display:inline-flex;vertical-align:middle}.info-tooltip__trigger{display:inline-flex;align-items:center;justify-content:center;padding:0;border:0;background:transparent;color:var(--muted);cursor:help;line-height:0}.info-tooltip__trigger:hover,.info-tooltip__trigger:focus-visible{color:var(--text)}.info-tooltip__content{position:absolute;left:50%;top:calc(100% + .45rem);z-index:50;width:max-content;max-width:min(18rem,70vw);padding:.55rem .7rem;border-radius:8px;background:var(--surface);border:1px solid var(--border);box-shadow:0 8px 24px #00000059;color:var(--muted);font-size:.85rem;font-weight:400;line-height:1.4;text-align:left;white-space:normal;pointer-events:none;opacity:0;visibility:hidden;transform:translate(-50%,-.25rem);transition:opacity .15s ease,transform .15s ease,visibility .15s ease}.info-tooltip__trigger:hover+.info-tooltip__content,.info-tooltip__trigger:focus-visible+.info-tooltip__content{opacity:1;visibility:visible;transform:translate(-50%)}
