/* Protezione Civile – Prove ENCI cani da soccorso */

:root {
    --pc-orange:       #F47920;
    --pc-orange-dark:  #C45E0E;
    --pc-orange-light: #FEF0E6;
    --pc-blue:         #002D72;
    --pc-blue-mid:     #0047B3;
    --pc-blue-light:   #E6EBF5;
    --green:           #1a7f4b;
    --green-light:     #e6f5ee;
    --red:             #c0392b;
    --red-light:       #fdecea;
    --amber:           #9a6000;
    --amber-light:     #fff4dc;
    --ink:             #12233d;
    --muted:           #5a6e87;
    --line:            #d8e2ef;
    --surface:         #ffffff;
    --page:            #f0f3f8;
}

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

html, body {
    background: #f0f3f8;
    color: #12233d;
    font-family: "Segoe UI", system-ui, Arial, sans-serif;
    font-size: 16px;
    line-height: 1.6;
    margin: 0;
}

a { color: #0047B3; }
a:hover { color: #F47920; }

/* ── Orange top strip ─────────────────────────────────────── */
body::before {
    background: #F47920;
    content: "";
    display: block;
    height: 5px;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 200;
}

/* ── Header ───────────────────────────────────────────────── */
header.site-header {
    background: #002D72 !important;
    box-shadow: 0 2px 16px rgba(0,45,114,.3);
    position: sticky;
    top: 5px;
    z-index: 100;
}

header.site-header .site-nav {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    margin: 0 auto;
    max-width: 1080px;
    padding: .9rem 1.25rem;
}

.brand {
    align-items: center;
    color: #ffffff !important;
    display: inline-flex;
    gap: .7rem;
    font-size: 1rem;
    font-weight: 800;
    text-decoration: none;
}

.brand-mark {
    align-items: center;
    background: #F47920;
    border-radius: 7px;
    color: #fff;
    display: inline-flex;
    font-size: .75rem;
    font-weight: 900;
    height: 2.1rem;
    justify-content: center;
    width: 2.1rem;
}

.nav-links {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .4rem .8rem;
}

header.site-header .nav-link,
header.site-header .link-button {
    background: transparent;
    border: 0;
    color: rgba(255,255,255,.85) !important;
    cursor: pointer;
    font: inherit;
    font-size: .95rem;
    padding: .3rem .1rem;
    text-decoration: none;
    transition: color .15s;
}

header.site-header .nav-link:hover,
header.site-header .link-button:hover { color: #ffffff !important; }

header.site-header .nav-link.active {
    border-bottom: 2px solid #F47920;
    color: #ffffff !important;
    font-weight: 700;
}

header.site-header .nav-admin {
    background: #F47920;
    border-radius: 6px;
    color: #fff !important;
    font-weight: 700;
    padding: .45rem .9rem;
    transition: background .15s;
}

header.site-header .nav-admin:hover,
header.site-header .nav-admin.active {
    background: #C45E0E;
    color: #fff !important;
}

/* ── Layout ───────────────────────────────────────────────── */
.main-content { padding-bottom: 4rem; }

.container-narrow {
    margin: 0 auto;
    max-width: 1080px;
    padding: 0 1.25rem;
}

.page-stack {
    display: grid;
    gap: 1.25rem;
    padding-top: 1.5rem;
}

/* ── Hero ─────────────────────────────────────────────────── */
.hero {
    background: linear-gradient(130deg, #002D72 0%, #0047B3 65%, #1a6dd4 100%) !important;
    border-bottom: 4px solid #F47920;
    overflow: hidden;
    padding: 3.5rem 0 2.5rem;
    position: relative;
}

.eyebrow {
    align-items: center;
    color: #F47920;
    display: flex;
    font-size: .88rem;
    font-weight: 800;
    gap: .5rem;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.eyebrow::before {
    background: #F47920;
    border-radius: 50%;
    content: "";
    display: inline-block;
    height: .55rem;
    width: .55rem;
}

.hero h1 {
    color: #ffffff;
    font-size: clamp(1.9rem, 4.5vw, 3.2rem);
    margin: .5rem 0 .75rem;
    max-width: 800px;
}

.lead {
    color: rgba(255,255,255,.88);
    font-size: 1.15rem;
    margin: 0;
    max-width: 720px;
}

/* ── Panels ───────────────────────────────────────────────── */
.panel {
    background: #ffffff;
    border: 1px solid #d8e2ef;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,45,114,.07);
    padding: 1.5rem;
}

.panel h1 {
    color: #002D72;
    font-size: 1.6rem;
    margin-bottom: .5rem;
}

.panel h2 {
    border-left: 4px solid #F47920;
    color: #002D72;
    font-size: 1.1rem;
    margin-bottom: 1rem;
    padding-left: .75rem;
}

/* ── Download cards ───────────────────────────────────────── */
.download-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.download-card {
    background: #ffffff;
    border: 1px solid #d8e2ef;
    border-radius: 10px;
    border-top: 4px solid #F47920;
    box-shadow: 0 2px 8px rgba(0,45,114,.06);
    display: flex;
    flex-direction: column;
    gap: .5rem;
    padding: 1.25rem;
    transition: box-shadow .15s, transform .15s;
}

.download-card:hover {
    box-shadow: 0 6px 20px rgba(0,45,114,.12);
    transform: translateY(-2px);
}

.download-card h3 { color: #002D72; font-size: .95rem; margin: 0; overflow-wrap: anywhere; }
.download-card p  { color: #5a6e87; flex: 1; font-size: .88rem; margin: 0; }

/* ── Upload cards ─────────────────────────────────────────── */
.upload-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.upload-card {
    background: #f0f3f8;
    border: 1px solid #d8e2ef;
    border-radius: 10px;
    padding: 1rem;
    transition: border-color .15s;
}

.upload-card:hover { border-color: #F47920; }

/* ── Alert boxes ──────────────────────────────────────────── */
.alert-box {
    border-left: 4px solid;
    border-radius: 8px;
    padding: .9rem 1.1rem;
}

.alert-box.danger  { background: #fdecea; border-color: #c0392b; color: #c0392b; }
.alert-box.warning { background: #fff4dc; border-color: #F47920; color: #9a6000; }
.alert-box.success { background: #e6f5ee; border-color: #1a7f4b; color: #1a7f4b; }

/* ── Payment panel ────────────────────────────────────────── */
.payment-panel { border-top: 4px solid #F47920; }

.payment-list {
    background: #E6EBF5;
    border-radius: 8px;
    display: grid;
    gap: 0;
    margin-bottom: 1.25rem;
    overflow: hidden;
}

.payment-list div {
    align-items: center;
    border-bottom: 1px solid #d8e2ef;
    display: grid;
    gap: .1rem;
    grid-template-columns: 160px 1fr;
    padding: .75rem 1rem;
}

.payment-list div:last-child { border-bottom: none; }
.payment-list dt { color: #5a6e87; font-size: .88rem; font-weight: 600; }
.payment-list dd { color: #002D72; font-weight: 700; margin: 0; overflow-wrap: anywhere; }

/* ── Forms ────────────────────────────────────────────────── */
.form-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.field-wide { grid-column: 1 / -1; }

.form-label {
    color: #5a6e87;
    display: block;
    font-size: .82rem;
    font-weight: 600;
    letter-spacing: .03em;
    margin-bottom: .3rem;
    text-transform: uppercase;
}

.form-control, .form-select {
    border: 1.5px solid #d8e2ef;
    border-radius: 6px;
    font: inherit;
    padding: .5rem .75rem;
    transition: border-color .15s, box-shadow .15s;
    width: 100%;
}

.form-control:focus, .form-select:focus {
    border-color: #F47920;
    box-shadow: 0 0 0 3px rgba(244,121,32,.18);
    outline: none;
}

/* ── Buttons ──────────────────────────────────────────────── */
.btn {
    border-radius: 6px;
    cursor: pointer;
    display: inline-block;
    font: inherit;
    font-weight: 600;
    padding: .45rem 1rem;
    text-align: center;
    text-decoration: none;
    transition: background .15s, color .15s, border-color .15s;
}

.btn-lg  { font-size: 1.05rem; padding: .7rem 1.5rem; }
.btn-sm  { font-size: .82rem;  padding: .3rem .65rem; }

.btn-primary         { background: #F47920; border: 2px solid #F47920; color: #fff; }
.btn-primary:hover   { background: #C45E0E; border-color: #C45E0E;     color: #fff; }

.btn-outline-primary       { background: transparent; border: 2px solid #0047B3; color: #0047B3; }
.btn-outline-primary:hover { background: #0047B3;     color: #fff; }

.btn-success       { background: #1a7f4b; border: 2px solid #1a7f4b; color: #fff; }
.btn-success:hover { filter: brightness(1.1); }

.btn-warning       { background: #fff4dc; border: 2px solid #F47920; color: #9a6000; }
.btn-warning:hover { background: #F47920; color: #fff; }

.btn-danger        { background: #c0392b; border: 2px solid #c0392b; color: #fff; }
.btn-danger:hover  { filter: brightness(1.1); }

.btn-outline-secondary       { background: transparent; border: 2px solid #d8e2ef; color: #5a6e87; }
.btn-outline-secondary:hover { border-color: #5a6e87; color: #12233d; }

.btn-outline-danger       { background: transparent; border: 2px solid #c0392b; color: #c0392b; }
.btn-outline-danger:hover { background: #c0392b; color: #fff; }

/* ── Step indicator ───────────────────────────────────────── */
.step-indicator {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: .5rem;
}

.step-indicator span {
    background: #E6EBF5;
    border-radius: 999px;
    color: #002D72;
    font-size: .82rem;
    font-weight: 700;
    padding: .3rem .8rem;
}

/* ── Badge status ─────────────────────────────────────────── */
.badge-status {
    border-radius: 999px;
    display: inline-block;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .03em;
    padding: .25rem .7rem;
    text-transform: uppercase;
}

.status-Mancante, .status-NonValido, .status-Respinta   { background: #fdecea; color: #c0392b; }
.status-Caricato,  .status-Inviata                      { background: #E6EBF5; color: #0047B3; }
.status-Approvato, .status-Completa, .status-Accettata  { background: #e6f5ee; color: #1a7f4b; }
.status-DaIntegrare, .status-Incompleta                 { background: #fff4dc; color: #9a6000; }
.status-Bozza, .status-NonNecessario                    { background: #edf1f6; color: #5a6e87; }

/* ── Table ────────────────────────────────────────────────── */
.table-responsive { overflow-x: auto; }

.table { border-collapse: collapse; width: 100%; }

.table th {
    background: #E6EBF5;
    border-bottom: 2px solid #002D72;
    color: #002D72;
    font-size: .8rem;
    font-weight: 700;
    letter-spacing: .04em;
    padding: .7rem .75rem;
    text-align: left;
    text-transform: uppercase;
    white-space: nowrap;
}

.table td { border-bottom: 1px solid #d8e2ef; padding: .7rem .75rem; vertical-align: middle; }
.table tbody tr:hover { background: #f7f9fc; }
.align-middle td { vertical-align: middle; }

/* ── Summary list ─────────────────────────────────────────── */
.summary-list { display: grid; gap: .5rem; }
.summary-list dt { color: #5a6e87; font-size: .8rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }
.summary-list dd { font-weight: 600; margin: 0 0 .5rem; }

/* ── Validation ───────────────────────────────────────────── */
.validation-message { color: #c0392b; font-size: .88rem; margin-top: .25rem; }

/* ── Auth page ────────────────────────────────────────────── */
.auth-page { margin: 0 auto; max-width: 480px; padding: 3rem 1rem; }

.auth-panel {
    background: #fff;
    border: 1px solid #d8e2ef;
    border-radius: 10px;
    border-top: 5px solid #F47920;
    box-shadow: 0 6px 24px rgba(0,45,114,.12);
    overflow: hidden;
}

.auth-heading {
    background: linear-gradient(135deg, #002D72 0%, #0047B3 100%);
    color: #fff;
    padding: 1.75rem 2rem;
}

.auth-heading h1 { font-size: 1.4rem; margin: 0 0 .25rem; }
.auth-heading p  { margin: 0; opacity: .8; font-size: .95rem; }

.auth-form  { padding: 2rem; }
.auth-links { font-size: .9rem; margin-top: 1rem; }

/* ── Modal ────────────────────────────────────────────────── */
.modal-backdrop-custom {
    align-items: center;
    background: rgba(0,20,50,.55);
    bottom: 0;
    display: flex;
    justify-content: center;
    left: 0;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 900;
}

.modal-box {
    background: #fff;
    border-radius: 10px;
    border-top: 4px solid #c0392b;
    box-shadow: 0 16px 48px rgba(0,45,114,.22);
    max-width: 480px;
    padding: 2rem;
    width: 90%;
}

.modal-box h3 { color: #c0392b; margin-top: 0; }

/* ── Utilities ────────────────────────────────────────────── */
.d-flex             { display: flex; }
.flex-wrap          { flex-wrap: wrap; }
.gap-2              { gap: .5rem; }
.gap-1              { gap: .25rem; }
.mt-3               { margin-top: 1rem; }
.mb-2               { margin-bottom: .5rem; }
.me-3               { margin-right: 1rem; }
.align-self-end     { align-self: flex-end; }
.justify-content-between { justify-content: space-between; }
.text-muted         { color: #5a6e87; font-size: .9rem; }
.clean-list         { padding-left: 1.25rem; }

/* ── Blazor error ─────────────────────────────────────────── */
#blazor-error-ui {
    background: #fff4dc;
    bottom: 0;
    box-shadow: 0 -2px 8px rgba(0,0,0,.12);
    display: none;
    left: 0;
    padding: .75rem 1.5rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

/* ── Contact panel ────────────────────────────────────────── */
.contact-panel {
    border-left: 4px solid #002D72;
    background: #E6EBF5;
}

.contact-panel h2 { border-left: none; padding-left: 0; }
.contact-panel a  { color: #F47920; font-weight: 600; }

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 720px) {
    .site-nav  { align-items: flex-start; flex-direction: column; gap: .75rem; }
    .nav-links { align-items: flex-start; flex-direction: column; }
    .hero      { padding: 2.5rem 0 1.75rem; }
    .hero h1   { font-size: 1.7rem; }
    .payment-list div { grid-template-columns: 1fr; }
}
