*,:before,:after{box-sizing:border-box}html,body{color:#1a1a1a;background:#fff;margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:16px;line-height:1.5}body{min-height:100vh}img,svg{max-width:100%;display:block}button,input,select,textarea{font:inherit;color:inherit}h1,h2,h3,h4{margin:0 0 1rem;font-weight:600;line-height:1.25}h1{font-size:1.75rem}h2{margin-top:2rem;font-size:1.4rem}h3{margin-top:1.5rem;font-size:1.15rem}p{margin:0 0 .75rem}a{color:#c2410c;text-decoration:none}a:hover{text-decoration:underline}code{background:#f8f9fa;border-radius:3px;padding:.1rem .35rem;font-family:SF Mono,Menlo,Consolas,monospace;font-size:.9em}pre{background:#f8f9fa;border-radius:6px;padding:.75rem;font-family:SF Mono,Menlo,Consolas,monospace;font-size:.9em;overflow-x:auto}small{color:#6c757d;font-size:.85em}blockquote{color:#6c757d;border-left:3px solid #e2e2e2;margin:.75rem 0;padding-left:.75rem;font-style:italic}label{margin-bottom:.75rem;font-weight:600;display:block}input[type=text],input[type=email],input[type=tel],input[type=password],input[type=number],input[type=date],input[type=time],input[type=datetime-local],input[type=search],select,textarea{background:#fff;border:1px solid #e2e2e2;border-radius:6px;width:100%;margin-top:.25rem;padding:.5rem .75rem;font-weight:400;display:block}input[type=text]:focus,input[type=email]:focus,input[type=tel]:focus,input[type=password]:focus,input[type=number]:focus,input[type=date]:focus,input[type=time]:focus,input[type=datetime-local]:focus,input[type=search]:focus,select:focus,textarea:focus{border-color:#c2410c;outline:none;box-shadow:0 0 0 3px #c2410c26}textarea{resize:vertical;min-height:4rem}input[type=checkbox],input[type=radio]{accent-color:#c2410c;margin-right:.5rem}fieldset{border:1px solid #e2e2e2;border-radius:6px;margin:0 0 1rem;padding:1rem 1.5rem}fieldset legend{color:#6c757d;text-transform:uppercase;letter-spacing:.05em;padding:0 .5rem;font-size:.9rem;font-weight:600}button{cursor:pointer;background:#fff;border:1px solid #e2e2e2;border-radius:6px;padding:.5rem 1rem;font-weight:600;transition:background .15s,border-color .15s;display:inline-block}button:hover:not(:disabled){background:#f8f9fa}button:disabled{opacity:.5;cursor:not-allowed}button[type=submit],button.btn-primary{color:#fff;background:#c2410c;border-color:#c2410c}button[type=submit]:hover:not(:disabled),button.btn-primary:hover:not(:disabled){background:#9a3412;border-color:#9a3412}main{max-width:1100px;margin:0 auto;padding:1.5rem 1rem}.iframe-page{max-width:100%;padding:1rem}section{margin-bottom:2rem}nav{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}header.app-header{z-index:10;background:#f8f9fa;border-bottom:1px solid #e2e2e2;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}header.app-header .app-header-links{align-items:center;gap:.75rem;display:flex}header.app-header .app-header-links a{color:#1a1a1a}table{border-collapse:collapse;width:100%;margin-bottom:1rem}table th,table td{text-align:left;vertical-align:top;border-bottom:1px solid #e2e2e2;padding:.75rem}table th{text-transform:uppercase;letter-spacing:.05em;color:#6c757d;background:#f8f9fa;font-size:.75rem;font-weight:600}ul{margin:0 0 .75rem;padding-left:1.5rem}hr{border:0;border-top:1px solid #e2e2e2;margin:1.5rem 0}.card{background:#fff;border:1px solid #e2e2e2;border-radius:6px;margin-bottom:1rem;padding:1rem 1.5rem;box-shadow:0 1px 2px #0000000f}.badge{text-transform:uppercase;letter-spacing:.03em;border-radius:3px;padding:.15rem .5rem;font-size:.8rem;font-weight:600;display:inline-block}.badge.badge-pending{color:#b45309;background:#fff3cd}.badge.badge-validated,.badge.badge-confirmed{color:#1e40af;background:#cce5ff}.badge.badge-preparing{color:#1a1a1a;background:#e2e3e5}.badge.badge-ready{color:#15803d;background:#d4edda}.badge.badge-picked_up,.badge.badge-honored{color:#1e40af;background:#cce5ff}.badge.badge-refused,.badge.badge-cancelled_by_customer,.badge.badge-no_show{color:#b91c1c;background:#f8d7da}.status-pending{background:#b453090d}.status-validated,.status-confirmed{background:#1e40af0d}.status-ready{background:#15803d0f}.status-refused,.status-cancelled_by_customer,.status-no_show{background:#b91c1c0d}.live-indicator{border-radius:3px;align-items:center;gap:.25rem;margin-left:auto;padding:.15rem .5rem;font-size:.85rem;display:inline-flex}.live-indicator.live-live{color:#15803d;background:#d4edda}.live-indicator.live-offline{color:#b91c1c;background:#f8d7da}.live-indicator.live-connecting{color:#b45309;background:#fff3cd}.honeypot{position:absolute;left:-9999px}.modal-backdrop{z-index:100;background:#0006;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:10px;width:100%;max-width:480px;max-height:90vh;padding:1.5rem;overflow-y:auto;box-shadow:0 4px 12px #00000014}.cart-bar{background:#f8f9fa;border-top:1px solid #e2e2e2;border-radius:6px 6px 0 0;margin-top:1.5rem;padding:1rem;position:sticky;bottom:0}.muted{color:#6c757d}.error-message{color:#b91c1c}.success-message{color:#15803d}.option-list{margin:0;padding:0;list-style:none}.option-list li{margin-bottom:.5rem}.option-list button{text-align:left;width:100%}.iframe-preview{background:#fff;border:2px solid #e2e2e2;border-radius:6px;margin-top:1rem;overflow:hidden}.iframe-preview iframe{border:0;width:100%;height:800px;display:block}.embed-snippet{white-space:pre-wrap;word-break:break-all;background:#f8f9fa;border-radius:6px;padding:.75rem;font-family:SF Mono,Menlo,Consolas,monospace;font-size:.85rem;overflow-x:auto}.controls{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.dish-list{grid-template-columns:1fr;gap:.5rem;margin-bottom:1rem;display:grid}.dish-list button{text-align:left;padding:.75rem}.dish-list .dish-name{font-weight:600}.cart-line{border-bottom:1px dashed #e2e2e2;justify-content:space-between;gap:.75rem;padding:.5rem 0;display:flex}.cart-line:last-child{border-bottom:0}.category-list{padding:0;list-style:none}.category-list li{border-bottom:1px solid #e2e2e2;align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.option-row{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.option-row input[type=text],.option-row input[type=number]{margin-top:0}.option-row input[type=number]{max-width:8rem}
