/* public/assets/css/app.css — stile pubblico + admin (mobile-first, AA contrast) */

:root {
    --c-text: #1a1a1a;
    --c-muted: #5a5a5a;
    --c-bg: #ffffff;
    --c-bg-alt: #f5f7f6;
    --c-border: #d2d8d4;
    --c-primary: #0a5d33;        /* verde CBVO – contrasto AA su bianco */
    --c-primary-fg: #ffffff;
    --c-danger: #b3261e;
    --c-warn: #8a5a00;
    --c-ok: #0a5d33;
    --c-link: #0a5d33;
    --c-focus: #ffbf00;
    --radius: 4px;
    --space: 1rem;
}

*, *::before, *::after { box-sizing: border-box; }
html { font-size: 100%; }
body {
    margin: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", Arial, sans-serif;
    color: var(--c-text);
    background: var(--c-bg);
    line-height: 1.55;
}

a { color: var(--c-link); text-underline-offset: 0.18em; }
a:hover { text-decoration-thickness: 2px; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
    outline: 3px solid var(--c-focus);
    outline-offset: 2px;
}

.skip-link {
    position: absolute; left: -9999px; top: 0; padding: .5rem 1rem;
    background: #000; color: #fff; z-index: 1000;
}
.skip-link:focus-visible { left: .5rem; top: .5rem; }

.container { max-width: 960px; margin: 0 auto; padding: var(--space); }

/* Header / Footer */
.site-header, .admin-header {
    background: var(--c-bg-alt); border-bottom: 1px solid var(--c-border);
}
.site-header .container, .admin-header .container {
    display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 1rem;
}
.brand { display: flex; align-items: center; gap: .75rem; text-decoration: none; color: inherit; font-weight: 600; }
.brand img { width: 48px; height: 48px; }
.site-header nav, .admin-header nav { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; }
.site-footer { border-top: 1px solid var(--c-border); margin-top: 3rem; padding: 1rem 0; color: var(--c-muted); }

/* Heading */
h1 { font-size: 1.7rem; margin-top: 0; }
h2 { font-size: 1.3rem; margin-top: 1.5rem; }
.muted { color: var(--c-muted); }
.visually-hidden { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* Event list */
.event-list { list-style: none; padding: 0; }
.event-item { padding: 1rem 0; border-bottom: 1px solid var(--c-border); }
.event-item h2 { margin: 0 0 .25rem 0; font-size: 1.15rem; }
.event-meta { color: var(--c-muted); margin: .25rem 0; }
.dot { padding: 0 .25rem; }

/* Form */
form { margin-top: 1rem; }
fieldset { border: 1px solid var(--c-border); border-radius: var(--radius); padding: 1rem; margin: 1rem 0; }
legend { padding: 0 .35rem; font-weight: 600; }
.field { margin-bottom: 1rem; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1rem; }
@media (max-width: 600px) { .field-row { grid-template-columns: 1fr; } }
.field-checkbox { display: flex; align-items: flex-start; gap: .5rem; margin: .75rem 0; }
.field-checkbox label { line-height: 1.4; }
.model-resources { background: var(--c-bg-alt); }
.model-resource-row { max-width: 420px; }
label { display: block; font-weight: 600; margin-bottom: .25rem; }
input[type="text"], input[type="email"], input[type="tel"], input[type="password"],
input[type="number"], input[type="date"], input[type="datetime-local"],
input[type="search"], select, textarea {
    width: 100%; padding: .55rem .65rem;
    border: 1px solid var(--c-border); border-radius: var(--radius);
    background: var(--c-bg); color: var(--c-text); font: inherit;
}
input[aria-invalid="true"] { border-color: var(--c-danger); }
.form-error { color: var(--c-danger); display: block; margin-top: .25rem; }
.form-error-summary {
    background: #fdecea; border-left: 4px solid var(--c-danger);
    padding: .75rem 1rem; margin-bottom: 1rem; border-radius: var(--radius);
}

/* Honeypot — visivamente nascosto ma non a screen reader (volutamente lasciato accessibile in HTML; sr-only aria-hidden) */
.hp-field { position: absolute !important; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

/* Bottoni */
.btn {
    display: inline-block; padding: .55rem 1rem; border: 1px solid var(--c-border);
    background: #fff; color: var(--c-text); text-decoration: none; border-radius: var(--radius);
    cursor: pointer; font: inherit;
}
.btn-primary { background: var(--c-primary); color: var(--c-primary-fg); border-color: var(--c-primary); }
.btn-primary:hover { filter: brightness(1.05); }
.btn-secondary { background: #fff; }
.btn-danger { background: var(--c-danger); color: #fff; border-color: var(--c-danger); }

/* Callout */
.callout { padding: 1rem 1.25rem; border: 1px solid var(--c-border); border-radius: var(--radius); margin: 1.25rem 0; background: var(--c-bg-alt); }
.callout-ok    { background: #e6f4ec; border-color: #9bd6ad; }
.callout-warn  { background: #fff5e0; border-color: #f0c45a; }
.callout-danger{ background: #fdecea; border-color: #efa9a3; }

.flash { padding: .75rem 1rem; margin-bottom: 1rem; border-radius: var(--radius); border: 1px solid var(--c-border); }
.flash-success { background: #e6f4ec; border-color: #9bd6ad; }
.flash-error   { background: #fdecea; border-color: #efa9a3; }

/* Tabelle data */
.data-table { width: 100%; border-collapse: collapse; margin-top: 1rem; }
.data-table th, .data-table td { text-align: left; padding: .55rem .75rem; border-bottom: 1px solid var(--c-border); vertical-align: top; }
.data-table th { background: var(--c-bg-alt); font-weight: 700; }
.data-table tr:hover td { background: #fafbfa; }
.data-table code { font-size: .95em; }

.badge { display: inline-block; padding: .15rem .5rem; border-radius: 999px; font-size: .85rem; background: #e7e7e7; color: #333; }
.badge-draft     { background: #e7e7e7; }
.badge-published { background: #d2efd9; color: #075425; }
.badge-closed    { background: #ddd; }
.badge-cancelled { background: #fde0de; color: #8a201b; }
.badge-pending_email_verification { background: #fff5e0; color: #6a430a; }
.badge-confirmed { background: #d2efd9; color: #075425; }
.badge-expired   { background: #ddd; }
.badge-used      { background: #cfe7ff; color: #064c83; }
.badge-queued, .badge-sending { background: #eee; }
.badge-sent { background: #d2efd9; color: #075425; }
.badge-failed, .badge-bounced, .badge-complained { background: #fde0de; color: #8a201b; }

/* Form inline */
.inline-form { display: inline; margin: 0; }
.admin-actions { display: flex; flex-wrap: wrap; gap: .75rem; margin: 1rem 0; }
.filter-form { display: flex; flex-wrap: wrap; gap: .5rem; align-items: end; margin: 1rem 0; }
.filter-form label { margin-bottom: 0; }

.audit-list { list-style: none; padding: 0; font-family: ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace; font-size: .85rem; }
.audit-list li { padding: .25rem 0; border-bottom: 1px dotted #eee; }

/* Login */
.login-form { max-width: 380px; }
.admin-user { color: var(--c-muted); margin-right: .5rem; }

/* Print */
@media print { .site-header, .site-footer, form { display: none; } }
