html,body,#root{width:100%;min-height:100vh;margin:0;padding:0}body{min-width:320px}:root{font-family:Inter,system-ui,Arial,sans-serif;line-height:1.5;font-weight:400}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0}button,input,textarea,select,pre{font:inherit}.app-shell{width:100%;min-height:100vh;display:grid;grid-template-columns:280px minmax(0,1fr);transition:background-color .2s ease,color .2s ease}.app-shell.light{background:#f5f7fb;color:#1f2937}.app-shell.dark{background:#111827;color:#f9fafb}.sidebar{padding:24px 20px;border-right:1px solid rgba(128,128,128,.16);display:flex;flex-direction:column;gap:24px}.app-shell.light .sidebar{background:#fff}.app-shell.dark .sidebar{background:#0f172a}.sidebar__brand h2{margin:0 0 8px;font-size:1.4rem}.sidebar__brand p,.sidebar__account p{margin:0;opacity:.8;font-size:.95rem}.sidebar__nav{display:flex;flex-direction:column;gap:10px}.sidebar__link{border:none;background:transparent;color:inherit;text-align:left;padding:12px 14px;border-radius:12px;cursor:pointer;font-size:.98rem;transition:background .15s ease}.sidebar__link:hover{background:#7f7f7f1f}.sidebar__link--active{font-weight:600;background:#3b82f624}.sidebar__controls{display:flex;flex-direction:column;gap:18px}.control-group{display:flex;flex-direction:column;gap:8px}.control-group label{font-size:.9rem;font-weight:700}.toggle-group{display:inline-flex;width:100%;background:#7f7f7f14;border-radius:12px;padding:4px;gap:4px}.toggle-button{flex:1;border:none;border-radius:10px;padding:10px 12px;background:transparent;color:inherit;cursor:pointer;font-weight:600;transition:background .15s ease,color .15s ease}.toggle-button.active{background:#111827;color:#fff}.app-shell.dark .toggle-button.active{background:#f9fafb;color:#111827}.sidebar__account{margin-top:auto;padding:16px;border-radius:14px;background:#7f7f7f14}.sidebar__account h3{margin:0 0 8px;font-size:1rem}.app-content{padding:32px;width:100%;min-width:0}.layout{width:100%;max-width:none;display:flex;flex-direction:column;gap:24px}.hero{margin:0 0 24px;width:100%}.hero h1{margin:0 0 8px;font-size:2rem}.hero p{margin:0}.card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:20px;box-shadow:0 8px 24px #0f172a0a}.upload-section{margin-bottom:0}.upload-section h2,.results-section h2{margin-top:0;margin-bottom:8px}.card h2,.card h3,.hero h1,.upload-section h2,.results-section h2{color:#111827}.muted,.hero p,.summary-label{color:#374151}.upload-controls{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:20px;flex-wrap:wrap}.upload-controls input[type=file]{flex:1;min-width:260px}.upload-controls button{border:none;border-radius:12px;padding:12px 18px;background:#111827;color:#fff;cursor:pointer;font-weight:600;min-width:160px;transition:background .15s ease}.upload-controls button:hover:not(:disabled){background:#1f2937}.upload-controls button:disabled{opacity:.7;cursor:not-allowed}.upload-button-group{display:flex;gap:10px;flex-wrap:wrap}.file-info{margin-top:18px;font-size:1rem;text-align:center;color:#111827}.drop-zone{margin-top:18px;margin-bottom:18px;border:2px dashed #cbd5e1;border-radius:16px;padding:28px 20px;text-align:center;background:#f8fafc;cursor:pointer;transition:border-color .2s ease,background .2s ease,transform .2s ease}.drop-zone:hover{border-color:#94a3b8;background:#f1f5f9}.drop-zone.drag-active{border-color:#111827;background:#e5eefc;transform:scale(1.01)}.drop-zone-title{margin:0 0 6px;font-size:1rem;font-weight:700;color:#111827}.alert{margin-top:16px;padding:12px 14px;border-radius:10px;font-weight:500}.alert.error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.alert.success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.alert.info{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.summary-card{display:flex;flex-direction:column;gap:6px}.summary-label{font-size:.85rem}.results-header{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:18px}.results-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:16px}.results-meta{margin-bottom:16px;color:#4b5563;font-size:.95rem}.tabs{display:flex;gap:8px;flex-wrap:wrap}.tab{border:1px solid #d1d5db;background:#fff;color:#374151;border-radius:10px;padding:8px 14px;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.tab.active{background:#111827;color:#fff;border-color:#111827}.filter-bar{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:14px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-label{font-size:.9rem;font-weight:600;color:#374151}.filter-input,.filter-select{width:100%;border:1px solid #d1d5db;border-radius:12px;padding:10px 12px;background:#fff;color:#111827}.filter-input:focus,.filter-select:focus{outline:none;border-color:#111827}.items-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.menu-card{border:1px solid #e5e7eb;border-radius:14px;padding:16px;background:#fafafa;transition:transform .15s ease,box-shadow .15s ease}.menu-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px #0f172a14}.menu-card-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}.menu-card-header h3{margin:0;font-size:1.05rem}.price{font-weight:700;white-space:nowrap;color:#111827}.description{margin:0 0 12px;color:#4b5563}.meta-row,.allergen-list{display:flex;flex-wrap:wrap;gap:8px}.allergen-list{margin-top:10px}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 10px;font-size:.85rem;font-weight:600}.badge.category{background:#e0f2fe;color:#075985}.badge.allergen{background:#fef3c7;color:#92400e}.copy-toolbar{display:flex;justify-content:flex-end;margin-bottom:12px}.output-box{margin:0;padding:16px;border-radius:12px;background:#0f172a;color:#e5e7eb;overflow-x:auto;white-space:pre-wrap;word-break:break-word}.empty-state{margin-top:20px;text-align:center;padding:40px 20px}.empty-state h2{margin-top:0;margin-bottom:10px;color:#111827}.empty-filter-state{grid-column:1 / -1;padding:24px;border:1px dashed #d1d5db;border-radius:12px;text-align:center;color:#4b5563;background:#fafafa}.export-actions{display:flex;gap:10px;flex-wrap:wrap}.secondary-button{border:1px solid #d1d5db;background:#fff;color:#111827;border-radius:10px;padding:10px 14px;cursor:pointer;font-weight:600;transition:background .15s ease,border-color .15s ease}.secondary-button:hover:not(:disabled){background:#f9fafb}.secondary-button:disabled{opacity:.6;cursor:not-allowed}.danger-button{border-color:#fecaca;color:#b91c1c;background:#fff}.danger-button:hover:not(:disabled){background:#fef2f2}.app-shell.dark .card{background:#1f2937;border-color:#374151;box-shadow:none}.app-shell.dark .hero h1,.app-shell.dark .upload-section h2,.app-shell.dark .results-section h2,.app-shell.dark .card h2,.app-shell.dark .card h3,.app-shell.dark .drop-zone-title,.app-shell.dark .file-info,.app-shell.dark .price,.app-shell.dark .empty-state h2{color:#f9fafb}.app-shell.dark .hero p,.app-shell.dark .muted,.app-shell.dark .summary-label,.app-shell.dark .description,.app-shell.dark .results-meta,.app-shell.dark .filter-label,.app-shell.dark .empty-filter-state,.app-shell.dark .sidebar__brand p,.app-shell.dark .sidebar__account p{color:#d1d5db}.app-shell.dark .menu-card{background:#111827;border-color:#374151}.app-shell.dark .tab{background:#1f2937;color:#f9fafb;border-color:#374151}.app-shell.dark .tab.active{background:#f9fafb;color:#111827;border-color:#f9fafb}.app-shell.dark .secondary-button{background:#1f2937;color:#f9fafb;border-color:#374151}.app-shell.dark .secondary-button:hover:not(:disabled){background:#374151}.app-shell.dark .danger-button{color:#fecaca;border-color:#7f1d1d;background:#1f2937}.app-shell.dark .danger-button:hover:not(:disabled){background:#3f1d1d}.app-shell.dark .filter-input,.app-shell.dark .filter-select{background:#111827;color:#f9fafb;border-color:#374151}.app-shell.dark .drop-zone{background:#111827;border-color:#475569}.app-shell.dark .drop-zone:hover{background:#1e293b;border-color:#64748b}.app-shell.dark .drop-zone.drag-active{background:#1e3a5f;border-color:#93c5fd}.app-shell.dark .empty-filter-state{background:#111827;border-color:#374151}.app-shell.dark .output-box{background:#020617;color:#e5e7eb}.app-shell.dark .badge.category{background:#082f49;color:#bae6fd}.app-shell.dark .badge.allergen{background:#451a03;color:#fde68a}.app-shell.dark .upload-controls button{background:#f9fafb;color:#111827}.app-shell.dark .upload-controls button:hover:not(:disabled){background:#e5e7eb}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid rgba(128,128,128,.2)}.summary-grid{grid-template-columns:repeat(2,1fr)}.items-grid{grid-template-columns:1fr}.app-content{padding:20px}}@media(max-width:700px){.filter-bar{grid-template-columns:1fr}}@media(max-width:600px){.summary-grid{grid-template-columns:1fr}.menu-card-header{flex-direction:column}.hero h1{font-size:1.7rem}.app-content{padding:16px}.sidebar{padding:18px 16px}}.sidebar__brand h2{margin:0 0 8px;font-size:1.4rem;font-weight:800;color:#111827}.sidebar__brand p{margin:0;color:#4b5563;opacity:1;font-size:.95rem}.app-shell.dark .sidebar__brand h2{color:#f9fafb}.app-shell.dark .sidebar__brand p{color:#cbd5e1}.upload-section.card,.results-section.card{width:100%}.upload-controls{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:16px;margin-top:20px}.upload-controls input[type=file]{width:100%;min-width:0}@media(max-width:700px){.upload-controls{grid-template-columns:1fr}}.hidden-file-input{display:none}.file-picker-row{display:flex;align-items:center;gap:12px;min-width:0;flex-wrap:wrap}.file-picker-status{color:inherit;word-break:break-word}.placeholder-page h1{margin-top:0;margin-bottom:10px}.placeholder-page{min-height:220px}.account-panel{margin-top:24px;display:flex;flex-direction:column;gap:20px}.account-actions{display:flex;gap:12px;flex-wrap:wrap}.account-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}@media(max-width:900px){.account-info-grid{grid-template-columns:1fr}}.page-section{display:flex;flex-direction:column;gap:1.5rem}.page-header h1{margin:0 0 .4rem}.page-header p{margin:0;opacity:.8}.account-card{border:1px solid rgba(128,128,128,.2);border-radius:18px;padding:1.5rem;background:#ffffff0a;max-width:760px}.account-card-header{margin-bottom:1.25rem}.account-card-header h2{margin:0 0 .35rem}.account-card-header p{margin:0;opacity:.8}.account-field span{font-size:.95rem;font-weight:600}.account-field input{border:1px solid rgba(128,128,128,.25);border-radius:12px;padding:.8rem .95rem;background:transparent;color:inherit;font:inherit}.account-toggle{display:flex;align-items:center;gap:.7rem;margin-top:.2rem}.account-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.9rem;margin-bottom:1.25rem}.account-meta-item,.account-profile-item{border:1px solid rgba(128,128,128,.2);border-radius:14px;padding:.9rem 1rem;background:#ffffff08}.account-meta-item span,.account-profile-item span{display:block;font-size:.85rem;opacity:.75;margin-bottom:.25rem}.account-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.2rem}.primary-button,.secondary-button{border-radius:12px;padding:.8rem 1rem;font:inherit;cursor:pointer}.primary-button{border:none}.secondary-button{background:transparent;color:inherit;border:1px solid rgba(128,128,128,.3)}.account-card{border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:1.5rem;background:#ffffff08;max-width:820px}.account-tabs{display:inline-flex;gap:.5rem;padding:.35rem;margin-bottom:1.25rem;border-radius:14px;background:#ffffff0a}.account-tab{border:1px solid transparent;background:transparent;color:inherit;padding:.65rem 1rem;border-radius:10px;font:inherit;font-weight:600;cursor:pointer;transition:background-color .18s ease,border-color .18s ease,opacity .18s ease;opacity:.78}.account-tab:hover{opacity:1}.account-tab.active{background:#ffffff1f;border-color:#ffffff1a;opacity:1}.account-card-header{margin-bottom:1.5rem}.account-card-header h2{margin:0 0 .45rem;font-size:2rem;line-height:1.15}.account-card-header p{margin:0;color:#ffffffb8;line-height:1.5}.account-form{display:grid;gap:1rem}.account-field{display:grid;gap:.45rem}.account-field span{font-weight:600}.account-field input{width:100%;min-height:54px;border-radius:14px;border:1px solid rgba(255,255,255,.08);background:#ffffff05;color:inherit;font:inherit;padding:.95rem 1rem;outline:none;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease}.account-field input::placeholder{color:#ffffff61}.account-field input:focus{border-color:#fff3;background:#ffffff0a;box-shadow:0 0 0 3px #ffffff0d}.account-toggle{display:flex;align-items:center;gap:.7rem;margin-top:.25rem}.account-toggle input{width:16px;height:16px}.primary-button,.secondary-button{min-height:50px;border-radius:14px;font:inherit;font-weight:600;padding:.9rem 1.1rem;cursor:pointer;transition:transform .15s ease,opacity .15s ease,background-color .18s ease,border-color .18s ease}.primary-button:hover,.secondary-button:hover{opacity:.96}.primary-button:active,.secondary-button:active{transform:translateY(1px)}.primary-button:disabled,.secondary-button:disabled,.account-tab:disabled{opacity:.6;cursor:not-allowed;transform:none}.primary-button{border:none;background:#f2f2f2;color:#111827}.secondary-button{background:transparent;color:inherit;border:1px solid rgba(255,255,255,.12)}.account-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.4rem}.account-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.9rem;margin-bottom:1.25rem}.account-meta-item,.account-profile-item{border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;padding:1rem}.account-meta-item span,.account-profile-item span{display:block;font-size:.9rem;margin-bottom:.35rem;color:#ffffffa3}.account-profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.9rem}@media(max-width:640px){.account-card{padding:1rem;border-radius:18px}.account-tabs{width:100%;display:grid;grid-template-columns:1fr 1fr}.account-tab{width:100%;text-align:center}.account-card-header h2{font-size:1.7rem}.account-actions{display:grid;grid-template-columns:1fr}}.account-switch{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:.25rem}.account-switch span{font-weight:500}.account-switch__control{position:relative;width:56px;height:32px;border:none;border-radius:999px;background:#ffffff24;cursor:pointer;transition:background-color .18s ease,opacity .18s ease;flex-shrink:0}.account-switch__control:hover{opacity:.95}.account-switch__control.active{background:#ffffffd1}.account-switch__thumb{position:absolute;top:4px;left:4px;width:24px;height:24px;border-radius:50%;background:#0f172a;transition:transform .18s ease,background-color .18s ease}.account-switch__control.active .account-switch__thumb{transform:translate(24px);background:#111827}.button-content{display:inline-flex;align-items:center;justify-content:center;gap:.65rem}.button-spinner{width:16px;height:16px;border-radius:999px;border:2px solid rgba(17,24,39,.25);border-top-color:#111827;animation:button-spin .7s linear infinite}@keyframes button-spin{to{transform:rotate(360deg)}}.account-alert{border-radius:14px;padding:.9rem 1rem;font-weight:500;line-height:1.45}.account-alert--error{background:#ef44441f;border:1px solid rgba(239,68,68,.28);color:#fca5a5}.account-alert--success{background:#22c55e1f;border:1px solid rgba(34,197,94,.28);color:#86efac}.password-field{position:relative;display:flex;align-items:center}.password-field input{padding-right:6.5rem}.password-toggle{position:absolute;right:.65rem;border:none;background:transparent;color:#ffffffb8;font:inherit;font-size:.92rem;font-weight:600;cursor:pointer;padding:.35rem .45rem;border-radius:8px;transition:background-color .18s ease,color .18s ease}.password-toggle:hover{background:#ffffff14;color:#fffffff2}.password-strength{display:grid;gap:.45rem;margin-top:-.35rem}.password-strength__label{font-size:.9rem;color:#ffffffad}.password-strength__value{font-size:.95rem;font-weight:700}.password-strength__bar{width:100%;height:8px;border-radius:999px;background:#ffffff14;overflow:hidden}.password-strength__bar span{display:block;height:100%;border-radius:999px;transition:width .2s ease,background-color .2s ease}.password-strength--weak .password-strength__value{color:#fca5a5}.password-strength--weak .password-strength__bar span{width:33%;background:#ef4444}.password-strength--medium .password-strength__value{color:#fde68a}.password-strength--medium .password-strength__bar span{width:66%;background:#f59e0b}.password-strength--strong .password-strength__value{color:#86efac}.password-strength--strong .password-strength__bar span{width:100%;background:#22c55e}.inline-validation{margin-top:-.35rem;font-size:.92rem;font-weight:600}.inline-validation--error{color:#fca5a5}.inline-validation--success{color:#86efac}.sidebar__account-name{font-weight:700;margin:0 0 .25rem}.sidebar__account-email,.sidebar__account-plan{margin:.15rem 0;opacity:.8;word-break:break-word}.billing-page{display:grid;gap:1.5rem}.billing-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.9rem}.billing-summary-item{border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;padding:1rem}.billing-summary-item span{display:block;margin-bottom:.35rem;color:#ffffffad;font-size:.92rem}.billing-plans{display:grid;gap:1rem}.billing-plans h2{margin:0}.billing-plan-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.billing-plan-card{border-radius:18px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;padding:1rem;display:grid;gap:.9rem}.billing-plan-card--current{border-color:#ffffff38;background:#ffffff0f}.billing-plan-card__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.billing-plan-card__header h3{margin:0}.billing-plan-badge{font-size:.82rem;font-weight:700;padding:.35rem .6rem;border-radius:999px;background:#ffffff24}.page-section{display:grid;gap:1.25rem}.forgot-password-trigger-row{display:flex;justify-content:center;margin:.5rem 0 1rem}.forgot-password-trigger{width:auto;min-width:180px;padding:.7rem 1rem}.account-card--nested{margin:.5rem 0 1rem}.menu-card{position:relative;min-height:215px}.menu-card-header{padding-right:46px}.menu-card-actions{position:absolute;top:12px;right:12px;z-index:2}.icon-button{width:34px;height:34px;border:1px solid rgba(148,163,184,.45);border-radius:999px;background:#0f172ae6;color:#f9fafb;cursor:pointer;font-size:16px;line-height:1;display:inline-flex;align-items:center;justify-content:center;transition:transform .15s ease,border-color .15s ease,background-color .15s ease}.icon-button:hover{border-color:#38bdf8d9;background:#1e293bf2;transform:translateY(-1px)}.menu-card.editing{border-color:#38bdf8a6}.menu-edit-form{display:grid;gap:16px}.menu-edit-form label{display:grid;gap:8px;font-size:.82rem;font-weight:700;color:inherit}.menu-edit-form input,.menu-edit-form textarea{width:100%;border:1px solid transparent;border-radius:12px;background:transparent;color:inherit;padding:10px 12px;font:inherit;outline:none}.menu-edit-form input:hover,.menu-edit-form textarea:hover{background:#7f7f7f14}.menu-edit-form input:focus,.menu-edit-form textarea:focus{border-color:#38bdf8cc;background:#7f7f7f1f}.menu-edit-form textarea{resize:vertical}.menu-edit-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:8px}.menu-edit-actions-right{display:flex;gap:10px}.compact-button{min-height:auto;padding:9px 14px}.add-menu-item-card{min-height:215px;width:100%;border:1px dashed rgba(148,163,184,.55);border-radius:14px;background:#0f172a73;color:inherit;cursor:pointer;display:grid;place-items:center;padding:0;margin:0;align-self:stretch;justify-self:stretch;transition:transform .2s ease,border-color .2s ease,background .2s ease}.add-menu-item-card span{width:64px;height:64px;border-radius:999px;border:1px solid rgba(148,163,184,.55);display:grid;place-items:center;font-size:3rem;line-height:1;padding-bottom:6px}.add-menu-item-card:hover{transform:translateY(-2px);border-color:#38bdf8cc;background:#0ea5e91f}.save-draft-button{white-space:nowrap}.menu-save-message{margin-bottom:16px;border-radius:12px;padding:12px 14px;font-weight:600}.menu-save-message.success{background:#22c55e1f;border:1px solid rgba(34,197,94,.28);color:#86efac}.menu-save-message.error{background:#ef44441f;border:1px solid rgba(239,68,68,.28);color:#fca5a5}.saved-menus-panel{display:grid;gap:16px}.saved-menus-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}.saved-menus-header h2{margin:0 0 6px}.saved-menus-header p{margin:0;color:#4b5563}.app-shell.dark .saved-menus-header p{color:#d1d5db}.saved-menus-empty{margin:0;color:#4b5563}.app-shell.dark .saved-menus-empty{color:#d1d5db}.saved-menus-list{display:grid;gap:12px}.saved-menu-row{display:flex;justify-content:space-between;align-items:center;gap:12px;border:1px solid #e5e7eb;border-radius:14px;padding:14px;background:#fafafa}.saved-menu-row h3{margin:0 0 4px;font-size:1rem}.saved-menu-row p{margin:0;color:#4b5563}.app-shell.dark .saved-menu-row{background:#111827;border-color:#374151}.app-shell.dark .saved-menu-row p{color:#d1d5db}.current-menu-info{display:flex;align-items:center;gap:10px;margin-top:6px;flex-wrap:wrap}.current-menu-info strong{font-size:.95rem}.current-menu-info span{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;font-size:.8rem;font-weight:700;text-transform:capitalize;background:#e0f2fe;color:#075985}.app-shell.dark .current-menu-info span{background:#082f49;color:#bae6fd}.saved-menu-row.active{border-color:#38bdf8cc;box-shadow:0 0 0 3px #38bdf81f}.saved-menu-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}@media(max-width:700px){.saved-menu-row{align-items:flex-start;flex-direction:column}.saved-menu-actions{width:100%;justify-content:flex-start}}.publish-button{white-space:nowrap;background:#16a34a;color:#fff}.publish-button:hover:not(:disabled){background:#15803d}.status-pill.published{background:#dcfce7;color:#166534}.app-shell.dark .status-pill.published{background:#064e3b;color:#bbf7d0}.allergen-edit-section{display:grid;gap:.75rem}.allergen-edit-label{font-size:.9rem;font-weight:700}.allergen-chip-grid{display:flex;flex-wrap:wrap;gap:.55rem}.allergen-chip{border:1px solid #334155;border-radius:999px;background:#111827;color:#cbd5e1;padding:.45rem .75rem;font-size:.85rem;font-weight:700;cursor:pointer}.allergen-chip.selected{border-color:#10b981;background:#10b981;color:#06130d}.menu-image-upload-section{display:grid;gap:.75rem}.menu-image-preview-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.menu-image-preview{width:110px;height:82px;object-fit:cover;border-radius:1rem;border:1px solid #334155}.menu-card-image{width:100%;height:150px;object-fit:cover;border-radius:1.25rem;margin-bottom:1rem}.restaurant-color-section{display:grid;gap:1rem;margin-top:.5rem}.restaurant-color-title{margin:0;font-weight:800;color:var(--text-primary)}.restaurant-color-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.color-picker-card{display:flex;align-items:center;gap:1rem;margin-top:.45rem;border:1px solid var(--border-color);border-radius:1rem;background:var(--surface-secondary);padding:.9rem}.color-picker-card input[type=color]{width:4rem;height:4rem;padding:0;border:0;border-radius:1rem;background:transparent;cursor:pointer}.color-picker-card strong{display:block;font-size:1rem;color:var(--text-primary)}.restaurant-color-preview{min-height:5rem;border-radius:1.4rem;display:flex;align-items:center;justify-content:center;color:#07111f;font-weight:900;box-shadow:0 18px 40px #00000038}@media(max-width:700px){.restaurant-color-grid{grid-template-columns:1fr}}.restaurant-stripe-card{display:grid;gap:1rem;margin-top:1.25rem;border:1px solid var(--border-color);border-radius:1.25rem;background:var(--surface-secondary);padding:1.25rem}.restaurant-stripe-card h2{margin:0;color:var(--text-primary)}.stripe-status-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem}.stripe-status-item{border:1px solid var(--border-color);border-radius:1rem;background:var(--surface-primary);padding:.9rem}.stripe-status-item span{display:block;margin-bottom:.35rem;color:var(--text-secondary);font-size:.85rem}.stripe-status-item strong{color:var(--text-primary);font-size:.95rem;word-break:break-word}@media(max-width:800px){.stripe-status-grid{grid-template-columns:1fr}}.mobile-topbar{display:none}.mobile-menu-button{border:1px solid var(--border-color, rgba(255, 255, 255, .12));border-radius:999px;background:var(--card-bg, #111827);color:inherit;padding:.75rem 1rem;font-weight:700;cursor:pointer}.mobile-topbar__title{font-weight:800;font-size:1.1rem}.sidebar__close{display:none;border:0;background:transparent;color:inherit;font-size:2rem;line-height:1;cursor:pointer}.sidebar-backdrop{display:none}@media(max-width:768px){.mobile-topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem;border-bottom:1px solid rgba(255,255,255,.1);background:var(--app-bg, #020617)}.sidebar{position:fixed;inset:0 auto 0 0;z-index:50;width:min(86vw,340px);max-width:340px;height:100vh;overflow-y:auto;transform:translate(-105%);transition:transform .2s ease}.sidebar.sidebar--open{transform:translate(0)}.sidebar__brand{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.sidebar__close{display:inline-flex}.sidebar-backdrop{position:fixed;inset:0;z-index:40;display:block;border:0;background:#0009}.app-shell{display:block}.main-content,.content,main{width:100%}}.billing-page{display:flex;flex-direction:column;gap:1.75rem}.billing-page h1{margin:0}.billing-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.billing-summary-item{border:1px solid rgba(255,255,255,.08);background:#ffffff08;border-radius:1rem;padding:1rem 1.1rem}.billing-summary-item span{display:block;font-size:.88rem;color:#9ca3af;margin-bottom:.45rem}.billing-summary-item strong{display:block;font-size:1.05rem;color:#fff}.billing-metric-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.billing-metric-card{border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,#ffffff0d,#ffffff06);border-radius:1rem;padding:1rem 1.1rem;min-height:110px;display:flex;flex-direction:column;justify-content:space-between}.billing-metric-card__label{margin:0;font-size:.9rem;color:#9ca3af;line-height:1.4}.billing-metric-card__value{display:block;margin-top:.8rem;font-size:1.5rem;line-height:1.2;color:#fff;font-weight:800}.billing-transactions{border-top:1px solid rgba(255,255,255,.08);padding-top:1.5rem}.billing-transactions__header{display:flex;flex-direction:column;gap:.85rem;margin-bottom:1rem}.billing-transactions__header h2{margin:0}.billing-note{border:1px solid rgba(59,130,246,.22);background:#3b82f614;color:#dbeafe;border-radius:.9rem;padding:.9rem 1rem;font-size:.92rem;line-height:1.5}.billing-table-wrapper{width:100%;overflow-x:auto;border:1px solid rgba(255,255,255,.08);border-radius:1rem;background:#ffffff06}.billing-table{width:100%;min-width:920px;border-collapse:collapse}.billing-table thead th{text-align:left;font-size:.83rem;font-weight:700;color:#9ca3af;padding:1rem;white-space:nowrap;border-bottom:1px solid rgba(255,255,255,.08)}.billing-table tbody td{padding:1rem;vertical-align:top;border-bottom:1px solid rgba(255,255,255,.06);color:#f3f4f6}.billing-table tbody tr:last-child td{border-bottom:none}.billing-table tbody tr:hover{background:#ffffff08}.billing-order-cell{display:flex;flex-direction:column;gap:.3rem}.billing-order-cell strong{color:#fff;font-size:.95rem}.billing-order-cell span{color:#9ca3af;font-size:.82rem}.billing-number-cell{text-align:right;white-space:nowrap}.billing-status{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:.32rem .72rem;font-size:.78rem;font-weight:700;white-space:nowrap;border:1px solid transparent}.billing-status--paid,.billing-status--succeeded,.billing-status--completed{background:#22c55e1f;color:#86efac;border-color:#22c55e33}.billing-status--pending{background:#f59e0b1f;color:#fcd34d;border-color:#f59e0b33}.billing-status--failed{background:#ef44441f;color:#fca5a5;border-color:#ef444433}.billing-status--refunded{background:#a855f71f;color:#d8b4fe;border-color:#a855f733}.billing-empty-state,.billing-error-state{border:1px solid rgba(255,255,255,.08);background:#ffffff08;border-radius:1rem;padding:1rem}.billing-error-state{border-color:#ef444440;color:#fca5a5}@media(max-width:1100px){.billing-metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.billing-summary,.billing-metric-grid{grid-template-columns:1fr}.billing-metric-card__value{font-size:1.35rem}.billing-table-wrapper{border-radius:.9rem}}.billing-page{width:100%;max-width:100%;overflow:hidden}.billing-page>.muted{max-width:720px;line-height:1.6}.billing-summary,.billing-metric-grid{width:100%}.billing-table-wrapper{width:100%;max-width:100%;overflow-x:auto}.billing-table{width:100%}@media(min-width:769px){.billing-table{min-width:920px}}@media(max-width:768px){.layout{width:100%;max-width:100%;padding:1rem;overflow-x:hidden}.app-content{width:100%;max-width:100%;overflow-x:hidden}.card.billing-page{width:100%;max-width:100%;padding:1.25rem;border-radius:1.25rem;overflow:hidden}.billing-page h1{font-size:1.7rem;line-height:1.2}.billing-page>.muted{font-size:.9rem}.billing-summary{grid-template-columns:1fr}.billing-summary-item{padding:.95rem}.billing-summary-item strong{word-break:break-word}.billing-metric-grid{grid-template-columns:1fr;gap:.75rem}.billing-metric-card{min-height:auto;padding:1rem}.billing-metric-card__label{font-size:.85rem}.billing-metric-card__value{font-size:1.35rem}.billing-transactions{padding-top:1.25rem}.billing-transactions__header h2{font-size:1.35rem}.billing-note,.billing-transactions__header .muted{font-size:.85rem;line-height:1.5}.billing-table-wrapper{border:0;background:transparent;overflow:visible}.billing-table{min-width:0;width:100%;border-collapse:separate;border-spacing:0 .85rem}.billing-table thead{display:none}.billing-table tbody{display:block;width:100%}.billing-table tbody tr{display:block;width:100%;border:1px solid rgba(255,255,255,.08);border-radius:1rem;padding:.9rem;background:#ffffff09}.billing-table tbody td{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;border:0;padding:.55rem 0;text-align:right;font-size:.9rem}.billing-table tbody td:before{content:"";flex:0 0 auto;color:#9ca3af;font-size:.82rem;font-weight:700;text-align:left}.billing-table tbody td:nth-child(1):before{content:"Bestellung"}.billing-table tbody td:nth-child(2):before{content:"Datum"}.billing-table tbody td:nth-child(3):before{content:"Status"}.billing-table tbody td:nth-child(4):before{content:"Kunde zahlt"}.billing-table tbody td:nth-child(5):before{content:"Plattform"}.billing-table tbody td:nth-child(6):before{content:"Stripe"}.billing-table tbody td:nth-child(7):before{content:"Restaurant erhält"}.billing-order-cell{align-items:flex-end;text-align:right;max-width:60%}.billing-order-cell strong{font-size:.82rem;word-break:break-all}.billing-order-cell span{font-size:.78rem}.billing-number-cell{text-align:right;white-space:nowrap}.billing-status{font-size:.74rem;padding:.25rem .6rem}}.settings-section{border:1px solid rgba(255,255,255,.08);border-radius:1.25rem;padding:1.25rem;background:#ffffff08;margin-top:1.25rem}.settings-section h2{margin:0 0 .4rem}.settings-toggle-group{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;margin-top:1rem;max-width:420px}@media(max-width:768px){.settings-toggle-group{max-width:none}}.messages-page{display:flex;flex-direction:column;gap:1.5rem}.messages-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.messages-page__header h1{margin:0}.messages-alert,.messages-error,.messages-empty{border:1px solid rgba(255,255,255,.08);border-radius:1rem;padding:1rem;background:#ffffff09;color:#cbd5e1}.messages-alert{border-color:#3b82f640;background:#3b82f614;color:#dbeafe}.messages-error{border-color:#ef444440;background:#ef444414;color:#fecaca}.messages-compose{display:flex;flex-direction:column;gap:1rem;border:1px solid rgba(255,255,255,.08);border-radius:1.25rem;padding:1rem;background:#ffffff08}.messages-compose h2{margin:0}.messages-compose label,.messages-reply label{display:flex;flex-direction:column;gap:.45rem;font-weight:700}.messages-compose input,.messages-compose textarea,.messages-reply textarea{width:100%;border:1px solid rgba(255,255,255,.1);border-radius:.9rem;background:#0f172ad9;color:inherit;padding:.8rem .9rem;resize:vertical}.messages-compose__actions{display:flex;justify-content:flex-end;gap:.75rem}.messages-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:1rem;min-height:560px}.messages-thread-list{display:flex;flex-direction:column;gap:.75rem;border:1px solid rgba(255,255,255,.08);border-radius:1.25rem;padding:1rem;background:#ffffff06;overflow:hidden}.messages-thread-list__title{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.messages-thread-list__title h2{margin:0;font-size:1.15rem}.messages-thread-card{width:100%;text-align:left;border:1px solid rgba(255,255,255,.08);border-radius:1rem;padding:.9rem;background:#ffffff08;color:inherit;cursor:pointer}.messages-thread-card:hover,.messages-thread-card--active{border-color:#60a5fa73;background:#3b82f61a}.messages-thread-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.messages-thread-card p{margin:.55rem 0;color:#cbd5e1;font-size:.9rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.messages-thread-card>span{color:#94a3b8;font-size:.8rem}.messages-unread-badge{display:inline-flex;min-width:1.4rem;height:1.4rem;align-items:center;justify-content:center;border-radius:999px;background:#60a5fa;color:#020617;font-size:.75rem;font-weight:800}.messages-thread-detail{display:flex;flex-direction:column;gap:1rem;min-width:0;border:1px solid rgba(255,255,255,.08);border-radius:1.25rem;padding:1rem;background:#ffffff06}.messages-thread-detail__header h2{margin:0}.messages-chat{display:flex;flex-direction:column;gap:.8rem;min-height:260px}.messages-bubble{max-width:min(78%,620px);border-radius:1.1rem;padding:.9rem 1rem}.messages-bubble--platform{align-self:flex-start;background:#3b82f61f;border:1px solid rgba(59,130,246,.22)}.messages-bubble--restaurant{align-self:flex-end;background:#22c55e1f;border:1px solid rgba(34,197,94,.22)}.messages-bubble__meta{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.45rem;color:#cbd5e1;font-size:.82rem}.messages-bubble p{margin:0;line-height:1.5;white-space:pre-wrap}.messages-reply{display:flex;flex-direction:column;gap:.8rem;margin-top:auto}.messages-reply button{align-self:flex-end}@media(max-width:900px){.messages-layout{grid-template-columns:1fr}.messages-page__header{flex-direction:column}.messages-page__header .primary-button{width:100%}.messages-compose__actions{flex-direction:column}.messages-bubble{max-width:100%}.messages-reply button{width:100%}}.messages-back-button{display:none}@media(max-width:768px){.messages-page{width:100%;max-width:100%;overflow:hidden}.messages-page__header{gap:.9rem}.messages-page__header h1{font-size:1.7rem;line-height:1.2}.messages-page__header .muted{font-size:.9rem;line-height:1.5}.messages-compose{padding:1rem;border-radius:1rem}.messages-compose input,.messages-compose textarea,.messages-reply textarea{font-size:1rem}.messages-layout{display:block;min-height:auto}.messages-thread-list,.messages-thread-detail{width:100%;max-width:100%}.messages-thread-detail,.messages-layout--detail-open .messages-thread-list{display:none}.messages-layout--detail-open .messages-thread-detail{display:flex}.messages-back-button{display:inline-flex;width:fit-content;border:1px solid rgba(255,255,255,.1);border-radius:999px;background:#ffffff0a;color:inherit;padding:.65rem .9rem;font-weight:700;cursor:pointer}.messages-thread-list{padding:.85rem;border-radius:1rem}.messages-thread-card{padding:.95rem}.messages-thread-card__top strong{font-size:.95rem;line-height:1.3}.messages-thread-card p{font-size:.86rem}.messages-thread-detail{padding:.9rem;border-radius:1rem;min-height:auto}.messages-thread-detail__header h2{font-size:1.25rem;line-height:1.25;word-break:break-word}.messages-thread-detail__header .muted{font-size:.82rem}.messages-chat{min-height:220px;max-height:55vh;overflow-y:auto;padding-right:.2rem}.messages-bubble{max-width:100%;padding:.85rem;border-radius:1rem}.messages-bubble__meta{flex-direction:column;align-items:flex-start;gap:.2rem;font-size:.78rem}.messages-bubble p{font-size:.92rem;line-height:1.5;word-break:break-word}.messages-reply{position:sticky;bottom:0;padding-top:.75rem;background:inherit}.messages-reply textarea{min-height:110px}.messages-reply button{width:100%}}.messages-page,.messages-page *{min-width:0}.messages-bubble p,.messages-thread-card p,.messages-thread-detail__header h2{overflow-wrap:anywhere}
