*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:Inter,Arial,sans-serif;background:#f3f6fb;color:#0f172a;line-height:1.45}
body.mobile-menu-open{overflow:hidden}
a{color:#2563eb;text-decoration:none}
a:hover{text-decoration:underline}
code{background:#e2e8f0;padding:2px 6px;border-radius:6px}
img{max-width:100%;height:auto}

.mobile-topbar{display:none}
.sidebar-backdrop{display:none}

.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh}
.sidebar{background:#0f172a;color:#e2e8f0;padding:24px;display:flex;flex-direction:column;gap:24px;min-width:0}
.content{padding:28px;overflow:auto;min-width:0}

.brand-box{display:flex;gap:14px;align-items:center;min-width:0}
.brand-box.solo{margin-bottom:24px}
.brand-box h1{margin:0;font-size:18px;color:#fff;line-height:1.25}
.brand-box p{margin:4px 0 0;font-size:13px;color:#93c5fd;line-height:1.4}
.brand-logo{width:54px;height:54px;min-width:54px;border-radius:18px;background:linear-gradient(135deg,#2563eb,#14b8a6);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:20px;box-shadow:0 10px 30px rgba(37,99,235,.35)}

.user-box{background:rgba(255,255,255,.06);padding:14px;border-radius:16px;word-break:break-word}
.user-box strong{display:block;font-size:14px}
.user-box span{display:block;font-size:12px;color:#cbd5e1;margin-top:4px}
.role-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.role-list span{font-size:11px;background:#1e293b;border:1px solid rgba(255,255,255,.08);padding:4px 8px;border-radius:999px}

.menu{display:flex;flex-direction:column;gap:6px}
.menu a{display:block;padding:12px 14px;border-radius:12px;color:#cbd5e1;font-weight:600;word-break:break-word}
.menu a.active,.menu a:hover{background:#1e293b;color:#fff;text-decoration:none}

.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:22px}
.page-header h2{margin:0 0 6px;font-size:28px;line-height:1.15}
.page-header p{margin:0;color:#475569}

.cards-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:22px}
.stat-card{background:#fff;border-radius:20px;padding:18px 20px;box-shadow:0 8px 24px rgba(15,23,42,.06);border:1px solid #e2e8f0}
.stat-card span{display:block;color:#64748b;font-size:13px}
.stat-card strong{display:block;margin-top:10px;font-size:28px;line-height:1.15;word-break:break-word}
.stat-card.success strong{color:#16a34a}
.stat-card.danger strong{color:#dc2626}

.panel{background:#fff;border-radius:22px;padding:20px;box-shadow:0 8px 24px rgba(15,23,42,.06);border:1px solid #e2e8f0;margin-bottom:22px}
.panel.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
.panel-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.panel-head h3{margin:0;font-size:18px;line-height:1.25}

.table-wrap{overflow:auto;-webkit-overflow-scrolling:touch;border:1px solid #e2e8f0;border-radius:16px;background:#fff}
.table-wrap.max-h{max-height:520px}
table{width:100%;min-width:640px;border-collapse:collapse}
th,td{padding:12px 14px;border-bottom:1px solid #e2e8f0;text-align:left;font-size:14px;vertical-align:top}
thead th{background:#f8fafc;color:#334155;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
tbody tr:hover{background:#f8fbff}

.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.form-grid.one{grid-template-columns:1fr}
.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.form-grid .full{grid-column:1/-1}
.compact-block{padding:14px;border:1px solid #e2e8f0;border-radius:16px;margin-bottom:12px;background:#f8fafc}
label{display:block;font-size:13px;color:#475569;font-weight:600;margin-bottom:6px}
input,select,textarea{width:100%;max-width:100%;padding:12px 14px;border:1px solid #cbd5e1;border-radius:12px;background:#fff;font:inherit;font-size:16px;color:#0f172a}
textarea{resize:vertical}
input:focus,select:focus,textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.12)}

.btn{appearance:none;border:0;border-radius:12px;padding:12px 16px;font-weight:700;background:#e2e8f0;color:#0f172a;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;max-width:100%;text-align:center}
.btn:hover{text-decoration:none;opacity:.95}
.btn.primary{background:#2563eb;color:#fff}
.btn.ghost{background:#eef2ff;color:#1d4ed8}
.btn.full{width:100%}
.btn.sm{padding:8px 12px;border-radius:10px;font-size:12px}
.inline-form{display:inline-flex;gap:8px;align-items:center;flex-wrap:wrap;max-width:100%}

.callout{padding:14px 16px;border-radius:16px;margin-bottom:18px;font-size:14px;border:1px solid transparent;overflow-wrap:anywhere}
.callout.info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}
.callout.success{background:#ecfdf5;border-color:#86efac;color:#166534}
.callout.error{background:#fef2f2;border-color:#fecaca;color:#991b1b}

.badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:12px;font-weight:700;background:#e2e8f0;color:#334155}
.badge.success{background:#dcfce7;color:#166534}
.badge.warning{background:#fef3c7;color:#92400e}
.badge.danger{background:#fee2e2;color:#991b1b}
.badge.info{background:#dbeafe;color:#1d4ed8}
.badge.neutral{background:#e2e8f0;color:#475569}

.check-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.check-card{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid #e2e8f0;border-radius:14px;background:#fff}
.check-card small{color:#64748b}
.option-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.option-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1px solid #dbe5f0;border-radius:16px;background:#f8fafc;min-height:100%}
.option-card input[type="checkbox"]{width:18px;height:18px;margin-top:2px;flex:0 0 auto}
.option-card span{display:block}
.option-card strong{display:block;font-size:14px;line-height:1.3;color:#0f172a}
.option-card small{display:block;margin-top:4px;font-size:12px;line-height:1.45;color:#64748b}
.employee-form-grid{align-items:start}
.employee-form-actions{display:flex;gap:10px;flex-wrap:wrap}
.table-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.helper-text{margin:12px 2px 0;color:#64748b;font-size:13px;line-height:1.5}
.align-end{display:flex;align-items:flex-end}

.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at top,#dbeafe,#eff6ff 45%,#f8fafc)}
.login-panel{width:min(460px,100%);background:#fff;padding:28px;border-radius:24px;box-shadow:0 20px 60px rgba(37,99,235,.12);border:1px solid #dbeafe}
.login-panel.wide{width:min(720px,100%)}
.login-panel .brand-box{align-items:flex-start}
.login-panel .brand-box h1{color:#0f172a}
.login-panel .brand-box p{color:#475569}
.auth-links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:16px}
.auth-links a{font-weight:600}


.filters-bar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:end}
.filters-bar--orders{grid-template-columns:repeat(3,minmax(0,1fr))}
.monthly-menu-layout{align-items:start}
.calendar-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;margin-bottom:10px}
.calendar-weekdays span{font-size:12px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.04em;text-align:center}
.month-calendar{display:flex;flex-direction:column;gap:10px}
.calendar-row{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px}
.calendar-day{min-height:124px;padding:12px;border:1px solid #dbe5f0;border-radius:16px;background:#fff;color:#0f172a;display:flex;flex-direction:column;gap:6px;box-shadow:0 6px 16px rgba(15,23,42,.04);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;text-decoration:none}
.calendar-day:hover{text-decoration:none;transform:translateY(-1px);border-color:#93c5fd;box-shadow:0 10px 24px rgba(37,99,235,.12)}
.calendar-day strong{font-size:20px;line-height:1}
.calendar-day span{font-size:12px;font-weight:700;color:#64748b;text-transform:uppercase}
.calendar-day small{font-size:12px;color:#334155;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.calendar-day em{margin-top:auto;font-style:normal;font-size:11px;color:#2563eb;font-weight:700}
.calendar-day.has-menu{border-color:#bfdbfe;background:linear-gradient(180deg,#ffffff 0%,#eff6ff 100%)}
.calendar-day.is-selected{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.14)}
.calendar-day.is-weekend{background:#f8fafc}
.calendar-day.empty{min-height:124px;background:transparent;border:1px dashed #e2e8f0;box-shadow:none}
.component-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.copy-actions-block h4{margin:0 0 12px;font-size:16px}.copy-actions-grid{display:grid;gap:12px}.compact-form{margin:0}.compact-form .align-end{width:100%}
.no-print{display:initial}.print-only{display:none}.print-report-head{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #cbd5e1}.print-report-head h3{margin:0 0 6px;font-size:22px}.print-report-head p{margin:0;color:#475569}.company-group+.company-group{margin-top:18px}.company-group__head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin:0 0 10px;padding:10px 12px;border-radius:14px;background:#f8fafc;border:1px solid #e2e8f0}.company-group__head h4{margin:0;font-size:16px}

@media print{
  body{background:#fff}
  .sidebar,.mobile-topbar,.sidebar-backdrop,.no-print{display:none !important}
  .app-shell{display:block}
  .content{padding:0}
  .panel,.table-wrap{box-shadow:none;border:1px solid #cbd5e1}
  .print-only{display:block !important}
  .print-area{margin:0}
  .company-group+.company-group{page-break-before:always}
  .company-group__head{background:#fff;border-color:#cbd5e1}
  table{min-width:0}
  thead th{background:#fff;color:#0f172a}
}

@media (max-width:1100px){
  .cards-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .panel.two-col{grid-template-columns:1fr}
  .filters-bar{grid-template-columns:repeat(2,minmax(0,1fr))}
  .content{padding:18px}
}


@media (max-width:720px){
  .mobile-topbar{position:sticky;top:0;z-index:1100;display:flex;align-items:center;gap:10px;padding:10px 12px;background:#0f172a;color:#fff;box-shadow:0 8px 20px rgba(15,23,42,.16)}
  .mobile-topbar__brand{display:flex;align-items:center;gap:8px;min-width:0}
  .mobile-topbar__brand strong,.mobile-topbar__brand small{display:block;line-height:1.15}
  .mobile-topbar__brand strong{font-size:13px}
  .mobile-topbar__brand small{font-size:10px;color:#cbd5e1}
  .mobile-topbar .brand-logo{width:34px;height:34px;min-width:34px;border-radius:10px;font-size:14px;box-shadow:none}
  .menu-toggle{width:40px;height:40px;min-width:40px;border:0;border-radius:12px;background:#1e293b;color:#fff;display:inline-flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;cursor:pointer}
  .menu-toggle span{display:block;width:16px;height:2px;border-radius:999px;background:#fff}

  .app-shell{display:block;min-height:auto}
  .sidebar{position:fixed;top:0;left:0;bottom:0;z-index:1200;width:min(78vw,280px);padding:14px 12px 18px;gap:14px;overflow:auto;transform:translateX(-104%);transition:transform .25s ease,box-shadow .25s ease}
  .sidebar .brand-box{gap:10px}
  .sidebar .brand-logo{width:42px;height:42px;min-width:42px;border-radius:12px;font-size:16px;box-shadow:none}
  .sidebar .brand-box h1{font-size:16px}
  .sidebar .brand-box p{font-size:12px}
  .sidebar .user-box{padding:12px;border-radius:14px}
  .sidebar .role-list{gap:4px}
  .sidebar .role-list span{font-size:10px;padding:3px 7px}
  .sidebar .menu{gap:4px}
  .sidebar .menu a{padding:10px 12px;border-radius:10px;font-size:14px;min-height:40px}
  .sidebar-backdrop{position:fixed;inset:0;z-index:1150;background:rgba(15,23,42,.48);opacity:0;pointer-events:none;transition:opacity .25s ease}
  body.mobile-menu-open .sidebar{transform:translateX(0);box-shadow:0 20px 50px rgba(15,23,42,.32)}
  body.mobile-menu-open .sidebar-backdrop{display:block;opacity:1;pointer-events:auto}

  .login-page{padding:14px;align-items:flex-start}
  .login-panel,.login-panel.wide{width:100%;padding:18px;border-radius:20px}
  .brand-box,.login-panel .brand-box{align-items:flex-start}
  .brand-box.solo{margin-bottom:18px}
  .page-header{flex-direction:column;align-items:stretch}
  .page-header h2{font-size:24px}
  .cards-grid,.form-grid.two,.check-grid,.component-fields,.filters-bar,.filters-bar--orders,.option-grid{grid-template-columns:1fr}
  .calendar-weekdays,.calendar-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .calendar-day,.calendar-day.empty{min-height:112px}
  .content{padding:12px}
  .panel{padding:14px;border-radius:18px}
  .panel-head{align-items:flex-start}
  th,td{padding:10px 12px;font-size:13px}
  .btn,.menu a{min-height:44px}
}

@media (max-width:480px){
  .mobile-topbar{padding:8px 10px}
  .mobile-topbar__brand strong{font-size:12px}
  .mobile-topbar__brand small{font-size:9px}
  .mobile-topbar .brand-logo{width:30px;height:30px;min-width:30px;font-size:12px;border-radius:9px}
  .menu-toggle{width:36px;height:36px;min-width:36px;border-radius:10px}
  .sidebar{width:min(82vw,250px);padding:12px 10px 16px}
  .brand-box{gap:10px}
  .brand-logo{width:40px;height:40px;min-width:40px;border-radius:12px;font-size:16px}
  .brand-box h1{font-size:15px}
  .brand-box p{font-size:11px}
  .sidebar .menu a{padding:9px 10px;font-size:13px;min-height:38px}
  .cards-grid{gap:12px}
  .stat-card{padding:16px}
  .stat-card strong{font-size:24px}
  .callout{padding:12px 14px;font-size:13px}
  .calendar-weekdays,.calendar-row{gap:8px}
  .calendar-day,.calendar-day.empty{min-height:102px;padding:10px;border-radius:14px}
  .calendar-day strong{font-size:18px}
  .calendar-day small{font-size:11px;-webkit-line-clamp:2}
  table{min-width:560px}
}


/* ===== Ações Editar/Excluir/Inativar — adicionado em 09/05/2026 ===== */
.actions-cell{white-space:nowrap;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.actions-cell form{margin:0}
.btn.sm{padding:4px 10px;font-size:12px;border-radius:8px;line-height:1.4}
.btn.ghost{background:transparent;color:#3057d5;border:1px solid #c9d4ee}
.btn.ghost:hover{background:#eef2fb}
.btn.danger{background:#e74c3c;color:#fff;border:1px solid #c0392b}
.btn.danger:hover{background:#c0392b}
.btn.danger.sm{padding:4px 10px;font-size:12px}

/* ===== Botão de ajuda (?) no topo direito + modal — atualizado em 09/05/2026 ===== */
.help-fab{
  position:fixed;right:22px;top:18px;width:48px;height:48px;border-radius:50%;
  background:#FFC107;color:#1f2a44;border:2px solid #E0A800;font-size:24px;font-weight:800;
  box-shadow:0 6px 18px rgba(245,184,0,.45);cursor:pointer;z-index:99999;
  display:flex;align-items:center;justify-content:center;line-height:1;
  transition:transform .15s ease, background .15s ease;
}
.help-fab:hover{background:#FFB300;transform:scale(1.08)}
.help-fab:active{transform:scale(.96)}

.help-modal{position:fixed;inset:0;z-index:100000;display:flex;align-items:center;justify-content:center}
.help-modal[hidden]{display:none}
.help-modal__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.55);backdrop-filter:blur(2px)}
.help-modal__panel{
  position:relative;background:#fff;border-radius:14px;max-width:760px;width:94vw;
  max-height:88vh;display:flex;flex-direction:column;
  box-shadow:0 20px 60px rgba(0,0,0,.35);overflow:hidden;animation:helpIn .18s ease-out;
}
@keyframes helpIn{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
.help-modal__head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 18px;border-bottom:1px solid #eef0f4;background:#FFF8E1;
}
.help-modal__head h3{margin:0;font-size:17px;color:#1f2a44}
.help-modal__close{
  background:transparent;border:none;font-size:26px;color:#6b7280;cursor:pointer;
  width:32px;height:32px;border-radius:8px;line-height:1;
}
.help-modal__close:hover{background:#eef2f7;color:#1f2a44}
.help-modal__body{padding:18px 22px;overflow-y:auto;font-size:14px;color:#2c3a55;line-height:1.6}
.help-modal__body h4{margin:16px 0 8px;color:#1f2a44;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.help-modal__body h4:first-child{margin-top:0}
.help-modal__body ul,.help-modal__body ol{margin:6px 0 12px 22px;padding:0}
.help-modal__body li{margin-bottom:6px}
.help-modal__body code{background:#fff8e1;padding:2px 6px;border-radius:4px;font-size:12px;color:#7a5a00}
.help-modal__body p{margin:6px 0}
.help-modal__body kbd{background:#eef2f7;border:1px solid #cbd5e0;border-radius:4px;padding:1px 6px;font-size:11px;font-family:monospace}
@media (max-width:720px){
  .help-fab{right:14px;top:12px;width:42px;height:42px;font-size:20px}
  .help-modal__panel{width:96vw;max-height:90vh}
  .help-modal__body{padding:14px 16px}
}

/* ===== Relatório de Pedidos de Refeição — fonte compacta 12px ===== */
.company-group table { font-size: 12px; }
.company-group table th,
.company-group table td { padding: 4px 8px; line-height: 1.35; }
.company-group table small { font-size: 10px; }
.company-group__head h4 { font-size: 14px; }
@media print {
  .company-group table { font-size: 12px; }
  .company-group table th,
  .company-group table td { padding: 3px 6px; }
}
