* { box-sizing: border-box; }
body { margin: 0; font-family: system-ui, -apple-system, Segoe UI, Roboto, sans-serif; background: #0f1115; color: #e6e8eb; }
.layout { display: flex; min-height: 100vh; }
.sidebar { width: 220px; background: #171a21; padding: 18px 14px; display: flex; flex-direction: column; gap: 18px; }
.brand { font-size: 22px; font-weight: 700; color: #ff7a59; letter-spacing: .5px; }
.sidebar nav { display: flex; flex-direction: column; gap: 4px; }
.sidebar nav a { color: #aeb4bd; text-decoration: none; padding: 9px 12px; border-radius: 8px; font-size: 14px; }
.sidebar nav a:hover { background: #20242d; color: #fff; }
.sidebar nav a.active { background: #ff7a59; color: #15171c; font-weight: 600; }
.lang { margin-top: auto; font-size: 12px; color: #777e8a; display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.lang a { color: #aeb4bd; text-decoration: none; padding: 2px 6px; border: 1px solid #2a2f3a; border-radius: 6px; }
.lang a:hover { color: #fff; border-color: #ff7a59; }
.content { flex: 1; padding: 28px 34px; }
h1 { font-size: 22px; margin: 0 0 22px; }
h2 { font-size: 16px; color: #aeb4bd; margin: 28px 0 12px; }
.live { font-size: 12px; color: #36d399; margin-left: 8px; }
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 14px; }
.card { background: #171a21; border: 1px solid #232833; border-radius: 12px; padding: 16px; display: flex; flex-direction: column; gap: 6px; }
.card .num { font-size: 28px; font-weight: 700; }
.card span:last-child { font-size: 12px; color: #8a909b; }
.card.warn { border-color: #f87171; }
.card.warn .num { color: #f87171; }
table { width: 100%; border-collapse: collapse; font-size: 13px; }
th, td { text-align: left; padding: 9px 12px; border-bottom: 1px solid #232833; }
th { color: #8a909b; font-weight: 600; }
.muted { color: #8a909b; }
.err { color: #f87171; max-width: 360px; }
.btn { background: #20242d; color: #e6e8eb; border: 1px solid #2a2f3a; border-radius: 8px; padding: 6px 12px; cursor: pointer; }
.btn:hover { border-color: #ff7a59; }
.badge { padding: 2px 8px; border-radius: 20px; font-size: 11px; background: #20242d; }
.badge-received { background: #1d4ed8; color: #fff; }
.badge-accepted { background: #047857; color: #fff; }
.badge-ready { background: #b45309; color: #fff; }
.badge-canceled, .badge-rejected { background: #b91c1c; color: #fff; }
.tenant { margin-top: 12px; border-top: 1px solid #232833; padding-top: 12px; display: flex; flex-direction: column; gap: 8px; }
.tname { font-size: 13px; color: #e6e8eb; font-weight: 600; }
.logout { background: transparent; color: #8a909b; border: 1px solid #2a2f3a; border-radius: 6px; padding: 5px 10px; cursor: pointer; font-size: 12px; }
.logout:hover { border-color: #f87171; color: #f87171; }
.auth-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: #0f1115; }
.auth-box { background: #171a21; border: 1px solid #232833; border-radius: 14px; padding: 32px; width: 340px; display: flex; flex-direction: column; gap: 14px; }
.auth-box .brand { font-size: 26px; font-weight: 700; color: #ff7a59; }
.auth-box input { width: 100%; padding: 11px 12px; background: #0f1115; border: 1px solid #2a2f3a; border-radius: 8px; color: #e6e8eb; font-size: 14px; }
.auth-box input:focus { outline: none; border-color: #ff7a59; }
.btn-primary { background: #ff7a59; color: #15171c; border: none; border-radius: 8px; padding: 11px; font-weight: 600; cursor: pointer; text-align: center; text-decoration: none; }
.btn-primary:hover { background: #ff6a45; }
.auth-box .link { display: block; text-align: center; }
.auth-box .muted { font-size: 13px; }
.apikey { display: block; background: #0f1115; border: 1px solid #2a2f3a; border-radius: 8px; padding: 10px; color: #36d399; font-size: 12px; word-break: break-all; }

/* --- Faz 4: restaurants/forms --- */
.card { border:1px solid #e2e6ea; border-radius:8px; padding:16px; margin:16px 0; background:#fff; }
.card h3 { margin:0 0 12px; }
.row { display:flex; gap:8px; align-items:center; }
.row input { flex:1; }
.grid2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px; }
.grid2 label { display:flex; flex-direction:column; font-size:.85rem; color:#444; gap:4px; }
.grid2 label.chk { flex-direction:row; align-items:center; gap:8px; }
.keybox { background:#0f172a; color:#e2e8f0; padding:14px 16px; border-radius:8px; margin:12px 0; }
.keybox code { display:block; font-size:1.05rem; color:#7dd3fc; word-break:break-all; margin:6px 0; }
.keybox .muted { color:#94a3b8; }
.hint { background:#f1f5f9; border-left:3px solid #38bdf8; padding:12px 16px; border-radius:4px; margin:12px 0; font-size:.9rem; }
.hint code { background:#e2e8f0; padding:1px 6px; border-radius:3px; }
.ok { color:#16a34a; }
.err { color:#dc2626; }
button { cursor:pointer; padding:7px 12px; border:1px solid #cbd5e1; border-radius:6px; background:#fff; margin-right:6px; }
.btn-primary { background:#2563eb; color:#fff; border-color:#2563eb; }
input, select { padding:7px 9px; border:1px solid #cbd5e1; border-radius:6px; }
