:root{
  --zg-neutral-0:#ffffff;
  --zg-neutral-50:#f8fafc;
  --zg-neutral-100:#f1f5f9;
  --zg-neutral-200:#e2e8f0;
  --zg-neutral-300:#cbd5e1;
  --zg-neutral-400:#94a3b8;
  --zg-neutral-500:#64748b;
  --zg-neutral-700:#334155;
  --zg-neutral-900:#0f172a;

  --zg-kitchen-primary:#f59e0b;
  --zg-kitchen-secondary:#fef3c7;
  --zg-marketing-primary:#e11d48;
  --zg-marketing-secondary:#ffe4e6;
  --zg-personal-primary:#0284c7;
  --zg-personal-secondary:#e0f2fe;
  --zg-reservations-primary:#4f46e5;
  --zg-reservations-secondary:#e0e7ff;
  --zg-finance-primary:#16a34a;
  --zg-finance-secondary:#dcfce7;
  --zg-organisation-primary:#2dd4bf;
  --zg-organisation-secondary:#e2e8f0;
  --zg-main-primary:#2f4f59;
  --zg-main-secondary:#e6eef0;

  --zg-state-success:#16a34a;
  --zg-state-success-soft:#dcfce7;
  --zg-state-warning:#f59e0b;
  --zg-state-warning-soft:#fef3c7;
  --zg-state-danger:#dc2626;
  --zg-state-danger-soft:#fee2e2;
  --zg-state-info:#0284c7;
  --zg-state-info-soft:#e0f2fe;

  --zg-surface-page:var(--zg-neutral-50);
  --zg-surface-card:var(--zg-neutral-0);
  --zg-surface-soft:var(--zg-neutral-100);
  --zg-surface-hover:var(--zg-neutral-100);
  --zg-surface-modal:var(--zg-neutral-0);
  --zg-surface-sidebar:var(--zg-neutral-0);
  --zg-surface-floating:var(--zg-neutral-0);

  --zg-text-primary:var(--zg-neutral-900);
  --zg-text-secondary:var(--zg-neutral-700);
  --zg-text-muted:var(--zg-neutral-500);
  --zg-text-placeholder:var(--zg-neutral-400);
  --zg-text-disabled:var(--zg-neutral-400);
  --zg-text-on-accent:var(--zg-neutral-0);

  --zg-border-soft:var(--zg-neutral-200);
  --zg-border-default:var(--zg-neutral-300);
  --zg-border-strong:var(--zg-neutral-400);

  --zg-accent-primary:var(--zg-main-primary);
  --zg-accent-secondary:var(--zg-main-secondary);
  --zg-accent-hover:#263f47;
  --zg-accent-active:var(--zg-accent-primary);
  --zg-accent-border:rgba(47,79,89,0.28);

  --zg-font-family:"Open Sans", Arial, sans-serif;

  --zg-space-1:4px;
  --zg-space-2:8px;
  --zg-space-3:12px;
  --zg-space-4:16px;
  --zg-space-5:20px;
  --zg-space-6:24px;
  --zg-space-8:32px;
  --zg-space-10:40px;

  --zg-radius-sm:6px;
  --zg-radius-md:10px;
  --zg-radius-lg:14px;
  --zg-radius-xl:18px;
  --zg-radius-full:999px;

  --zg-shadow-none:none;
  --zg-shadow-soft:0 1px 3px rgba(15,23,42,0.10);
  --zg-shadow-floating:0 8px 24px rgba(15,23,42,0.12);
  --zg-shadow-modal:0 18px 48px rgba(15,23,42,0.18);

  --zg-page-padding-x:24px;
  --zg-page-padding-y:24px;
  --zg-card-padding:20px;
  --zg-compact-card-padding:16px;
  --zg-section-gap:32px;
  --zg-form-field-gap:16px;
  --zg-toolbar-gap:12px;
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

html,
body{
  margin:0;
  min-height:100%;
}

body{
  font-family:var(--zg-font-family);
  background:var(--zg-surface-page);
  color:var(--zg-text-secondary);
}

button,
input,
select,
textarea{
  font:inherit;
}

button,
a,
input,
select,
textarea{
  outline-color:var(--zg-accent-primary);
}

:focus-visible{
  outline:3px solid rgba(47,79,89,0.24);
  outline-offset:2px;
}

.zg-page{
  min-height:100vh;
  padding:var(--zg-page-padding-y) var(--zg-page-padding-x);
  background:var(--zg-surface-page);
}

.zg-page-shell{
  width:min(1180px, 100%);
  margin:0 auto;
}

.zg-card{
  background:var(--zg-surface-card);
  border:1px solid var(--zg-border-soft);
  border-radius:var(--zg-radius-lg);
  box-shadow:var(--zg-shadow-soft);
}

.zg-card-soft{
  background:var(--zg-surface-soft);
  border:1px solid var(--zg-border-soft);
  border-radius:var(--zg-radius-lg);
}

.zg-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:var(--zg-space-2);
  min-height:40px;
  padding:0 var(--zg-space-4);
  border-radius:var(--zg-radius-md);
  border:1px solid transparent;
  font-size:14px;
  font-weight:600;
  line-height:1.2;
  text-decoration:none;
  cursor:pointer;
  transition:background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}

.zg-btn-primary{
  background:var(--zg-accent-primary);
  border-color:var(--zg-accent-primary);
  color:var(--zg-text-on-accent);
}

.zg-btn-primary:hover{
  background:var(--zg-accent-hover);
  border-color:var(--zg-accent-hover);
}

.zg-btn-secondary{
  background:var(--zg-accent-secondary);
  border-color:var(--zg-accent-secondary);
  color:var(--zg-accent-primary);
}

.zg-btn-ghost{
  background:transparent;
  border-color:var(--zg-border-soft);
  color:var(--zg-text-secondary);
}

.zg-btn-ghost:hover{
  background:var(--zg-surface-hover);
}

.zg-btn-danger{
  background:var(--zg-state-danger);
  border-color:var(--zg-state-danger);
  color:var(--zg-text-on-accent);
}

.zg-btn:disabled,
.zg-is-disabled{
  background:var(--zg-neutral-200) !important;
  border-color:var(--zg-neutral-200) !important;
  color:var(--zg-neutral-400) !important;
  cursor:not-allowed !important;
  box-shadow:none !important;
}

.zg-input,
.zg-select,
.zg-textarea{
  width:100%;
  border:1px solid var(--zg-border-default);
  border-radius:var(--zg-radius-md);
  background:var(--zg-surface-card);
  color:var(--zg-text-secondary);
  font-size:14px;
  transition:border-color 0.16s ease, box-shadow 0.16s ease, background-color 0.16s ease;
}

.zg-input,
.zg-select{
  min-height:42px;
  padding:0 var(--zg-space-3);
}

.zg-textarea{
  min-height:110px;
  padding:var(--zg-space-3);
  resize:vertical;
}

.zg-input::placeholder,
.zg-textarea::placeholder{
  color:var(--zg-text-placeholder);
}

.zg-input:hover,
.zg-select:hover,
.zg-textarea:hover{
  border-color:var(--zg-border-strong);
}

.zg-input:focus,
.zg-select:focus,
.zg-textarea:focus{
  border-color:var(--zg-accent-primary);
  box-shadow:0 0 0 4px rgba(47,79,89,0.10);
}

.zg-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:24px;
  padding:0 10px;
  border-radius:var(--zg-radius-full);
  font-size:12px;
  font-weight:600;
  line-height:1.35;
  white-space:nowrap;
}

.zg-badge-neutral{
  background:var(--zg-neutral-100);
  color:var(--zg-text-secondary);
}

.zg-badge-success{
  background:var(--zg-state-success-soft);
  color:var(--zg-state-success);
}

.zg-badge-warning{
  background:var(--zg-state-warning-soft);
  color:var(--zg-state-warning);
}

.zg-badge-danger{
  background:var(--zg-state-danger-soft);
  color:var(--zg-state-danger);
}

.zg-badge-info{
  background:var(--zg-state-info-soft);
  color:var(--zg-state-info);
}

.zg-badge-tool{
  background:var(--zg-accent-secondary);
  color:var(--zg-accent-primary);
}
