/* Aggreghiamoci.online demo shared visual theme
   Scope: /demo public MVP pages.
   Edit colors, fonts and logo in /demo/gestione-template/ and /demo/gestione-logo/. */

@import url('./demo-template-settings.php');

:root {
  --agg-font: var(--template-font-family, Verdana, Arial, Helvetica, sans-serif);
  --agg-logo-url: var(--template-logo-url, url('./logo-aggreghiamoci.svg'));
  --agg-logo-width: var(--template-logo-width, 330px);
  --agg-logo-height: var(--template-logo-height, 90px);
  --agg-bg: var(--template-color-background, #ffffff);
  --agg-surface: var(--template-color-surface, #ffffff);
  --agg-surface-soft: var(--template-color-surface-soft, #f7f7f7);
  --agg-surface-accent: var(--template-color-surface-accent, #fff4ee);
  --agg-highlight: var(--template-color-highlight, #fff0cc);
  --agg-ink: var(--template-color-text, #2b2b2b);
  --agg-muted: var(--template-color-muted, #5f5f5f);
  --agg-primary: var(--template-color-primary, #e64135);
  --agg-primary-dark: var(--template-color-primary-dark, #9a2f28);
  --agg-primary-deep: var(--template-color-primary-deep, #58261f);
  --agg-accent: var(--template-color-accent, #f38014);
  --agg-accent-dark: var(--template-color-accent-dark, #c4610d);
  --agg-border: var(--template-color-border, #efc8bf);
  --agg-border-strong: var(--template-color-border-strong, #e64135);
  --agg-row: var(--template-table-row-background, #fffaf7);
  --agg-warning: var(--template-color-warning, #f38014);
  --agg-danger: var(--template-color-danger, #9a2f28);
  --agg-info: var(--template-color-info, #2a4570);
  --agg-shadow: var(--template-shadow, 0 8px 22px rgba(154, 47, 40, 0.14));
  --agg-radius: var(--template-radius, 6px);
  --agg-radius-sm: var(--template-radius-small, 4px);
  --agg-space: var(--template-panel-padding, 18px);
  --agg-page-max-width: var(--template-page-max-width, 1180px);
  --agg-page-padding: var(--template-page-padding, 24px);
  --agg-font-size-base: var(--template-font-size-base, 12px);
  --agg-line-height: var(--template-line-height, 1.45);

  --bg: var(--agg-bg);
  --surface: var(--agg-surface);
  --soft: var(--agg-surface-accent);
  --ink: var(--agg-ink);
  --muted: var(--agg-muted);
  --primary: var(--agg-primary);
  --primary-dark: var(--agg-primary-dark);
  --warning: var(--agg-warning);
  --danger: var(--agg-danger);
  --info: var(--agg-info);
  --border: var(--agg-border);
  --shadow: var(--agg-shadow);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: var(--agg-font);
  font-size: var(--agg-font-size-base);
  background: var(--agg-bg);
  color: var(--agg-ink);
  line-height: var(--agg-line-height);
  text-align: left;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--agg-primary-dark); font-weight: 800; }

.shell {
  max-width: var(--agg-page-max-width);
  margin: 0 auto;
  padding: var(--agg-page-padding);
}

.brand-logo,
.topbar::before {
  display: block;
  width: var(--agg-logo-width);
  max-width: 100%;
  height: var(--agg-logo-height);
  background-image: var(--agg-logo-url);
  background-repeat: no-repeat;
  background-position: left center;
  background-size: contain;
  text-indent: -9999px;
  overflow: hidden;
}

.brand-logo.small {
  width: calc(var(--agg-logo-width) * .58);
  height: calc(var(--agg-logo-height) * .58);
}

.topbar::before {
  content: "Aggreghiamoci.online";
  flex: 0 0 var(--agg-logo-width);
}

.topbar,
.panel,
.card,
.service,
.box,
.summary,
.detail,
.request,
.receipt,
.stat,
.notice,
.error,
.success-box {
  background: var(--agg-surface);
  border: 1px solid var(--agg-border);
  border-radius: var(--agg-radius);
  box-shadow: var(--agg-shadow);
}

.topbar {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  padding: 14px;
  margin-bottom: 18px;
  border-top: 4px solid var(--agg-primary);
}

h1,
h2,
h3,
h4,
p { margin-top: 0; }

h1 { line-height: 1.12; color: var(--agg-primary); font-size: 28px; }
h2 { color: var(--agg-primary-dark); font-size: 24px; }
h3 { color: var(--agg-primary-dark); font-size: 18px; }

.muted { color: var(--agg-muted); }

.pill {
  display: inline-flex;
  align-items: center;
  width: max-content;
  padding: 5px 10px;
  border: 1px solid var(--agg-primary);
  border-radius: 999px;
  background: var(--agg-surface-accent);
  color: var(--agg-primary-dark);
  font-weight: 800;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .02em;
}

.panel { padding: var(--agg-space); margin-bottom: 18px; }

.nav,
.actions,
.filters,
.controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.nav { margin-top: 10px; }
.actions { margin-top: 16px; }

.btn,
.nav a,
.actions a,
button.btn,
a.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  border: 1px solid var(--agg-primary);
  border-radius: var(--agg-radius-sm);
  padding: 10px 14px;
  background: var(--agg-surface);
  color: var(--agg-primary-dark);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.2;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
}

.btn:hover,
.nav a:hover,
a.btn:hover,
button.btn:hover { background: var(--agg-surface-accent); }

.btn.primary,
a.btn.primary,
button.btn.primary {
  border-color: var(--agg-primary);
  background: var(--agg-primary);
  color: #ffffff;
}

.btn.primary:hover,
a.btn.primary:hover,
button.btn.primary:hover { background: var(--agg-primary-dark); }

.btn.ghost,
a.btn.ghost,
button.btn.ghost {
  border-color: var(--agg-border);
  background: transparent;
  color: var(--agg-ink);
}

.btn.danger,
a.btn.danger,
button.btn.danger {
  border-color: var(--agg-danger);
  color: var(--agg-danger);
}

input,
select,
textarea {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--agg-border-strong);
  border-radius: var(--agg-radius-sm);
  padding: 8px 10px;
  font: inherit;
  background: var(--agg-surface);
  color: var(--agg-ink);
}

textarea { min-height: 96px; resize: vertical; }

.field { display: grid; gap: 7px; }
label { color: var(--agg-primary-dark); font-weight: 800; font-size: 12px; }

.badge,
.status {
  display: inline-flex;
  align-items: center;
  width: max-content;
  border: 1px solid var(--agg-border-strong);
  border-radius: 999px;
  padding: 5px 10px;
  background: var(--agg-surface-accent);
  color: var(--agg-primary-dark);
  font-size: 11px;
  font-weight: 800;
}

.badge.ok,
.status.ok { background: var(--agg-highlight); color: var(--agg-primary-dark); }
.badge.warn { background: #fff3d6; color: var(--agg-accent-dark); }
.badge.danger,
.status.bad { background: #fee2e2; color: var(--agg-danger); border-color: var(--agg-danger); }
.badge.info { background: #f3f6fb; color: var(--agg-info); border-color: var(--agg-info); }

.card,
.service,
.box,
.request {
  border-left: 5px solid var(--agg-border-strong);
}

.card.ok,
.service.ok,
.box.ok { border-left-color: var(--agg-primary); background: var(--agg-surface-accent); }
.card.warn,
.service.warn,
.box.warn { border-left-color: var(--agg-accent); background: #fffaf2; }
.card.danger,
.service.danger,
.box.danger { border-left-color: var(--agg-danger); background: #fffafa; }
.service.info { border-left-color: var(--agg-info); background: #f8fbff; }

.notice {
  display: none;
  padding: 12px;
  border-left: 6px solid var(--agg-primary);
  background: var(--agg-surface-accent);
  margin-bottom: 18px;
}
.notice.is-visible { display: block; }

.error {
  display: none;
  padding: 14px;
  border-left: 6px solid var(--agg-danger);
  background: #fffafa;
  margin-bottom: 18px;
}
.error.is-visible { display: block; }

.success-box {
  display: none;
  padding: 18px;
  border-left: 6px solid var(--agg-primary);
  background: var(--agg-surface-accent);
  margin-bottom: 18px;
}
.success-box.is-visible { display: block; }

table { width: 100%; border-collapse: collapse; color: var(--agg-ink); }
th,
td { text-align: left; border-top: 1px solid var(--agg-border); padding: 10px 12px; vertical-align: top; }
th { font-size: 11px; text-transform: uppercase; color: var(--agg-primary-dark); background: var(--agg-surface-accent); }
tr:nth-child(even) td { background: var(--agg-row); }

.copy { font-size: 28px; font-weight: normal; color: var(--agg-primary); }
.copyB { font-size: 12px; font-weight: bold; color: var(--agg-muted); }
.copyC { font-size: 18px; font-weight: bold; color: var(--agg-primary-dark); }
.copyD { font-size: 22px; font-weight: bold; color: var(--agg-primary); }
.titolo { font-size: 14px; font-weight: bold; color: var(--agg-primary); }
.piccolo { color: var(--agg-primary-dark); font-size: 11px; }
.piccolor { color: var(--agg-primary); font-size: 11px; }

@media (max-width: 850px) {
  .topbar { display: grid; grid-template-columns: 1fr; }
  .topbar::before,
  .brand-logo { width: min(var(--agg-logo-width), 100%); height: 70px; }
  .shell { padding: 16px; }
  h1 { font-size: 24px; }
  h2 { font-size: 21px; }
}

@page { size: A4; margin: 10mm; }

@media print {
  * { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  body { background: #fff; }
  .topbar,
  .panel.lookup-panel,
  .nav,
  .actions,
  .error,
  .notice { display: none !important; }
  .shell { max-width: none; margin: 0; padding: 0; }
}
