/* Traslogo - stili globali */
:root {
    --tl-primary: #4f46e5;
    --tl-primary-dark: #4338ca;
    --tl-primary-soft: #eef2ff;
    --tl-accent: #f59e0b;
    --tl-success: #10b981;
    --tl-danger: #ef4444;
    --tl-muted: #6b7280;
    --tl-bg: #f8fafc;
    --tl-radius: 12px;
}

html, body { height: 100%; }
body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    background: var(--tl-bg);
    color: #1f2937;
    -webkit-font-smoothing: antialiased;
}
[data-bs-theme="dark"] body { background: #0f172a; color: #e2e8f0; }

.text-indigo { color: var(--tl-primary) !important; }
.bg-indigo { background: var(--tl-primary) !important; color: #fff; }
.bg-indigo-soft { background: var(--tl-primary-soft) !important; }

.btn-indigo, .btn-primary {
    background: var(--tl-primary);
    border-color: var(--tl-primary);
    color: #fff;
}
.btn-indigo:hover, .btn-primary:hover {
    background: var(--tl-primary-dark);
    border-color: var(--tl-primary-dark);
    color: #fff;
}
.btn-outline-indigo {
    color: var(--tl-primary);
    border-color: var(--tl-primary);
}
.btn-outline-indigo:hover {
    background: var(--tl-primary);
    color: #fff;
}

/* App layout: topbar + sidebar + contenuto */
.app-topbar { min-height: 62px; z-index: 1020; }

.app-layout { display: flex; min-height: calc(100vh - 62px); }
.app-sidebar {
    width: 250px;
    background: #fff;
    border-right: 1px solid #e5e7eb;
}
[data-bs-theme="dark"] .app-sidebar { background: #1e293b; border-right-color: #334155; }

.app-sidebar .nav-link {
    color: #475569;
    padding: 10px 14px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    gap: 12px;
    font-weight: 500;
    transition: background .15s;
}
.app-sidebar .nav-link:hover { background: var(--tl-primary-soft); color: var(--tl-primary); }
.app-sidebar .nav-link.active { background: var(--tl-primary); color: #fff; }
.app-sidebar .nav-link i { font-size: 1.1rem; }

.app-main { flex: 1; padding: 24px; min-width: 0; }
@media (max-width: 991.98px) { .app-main { padding: 16px; } }

.app-footer { border-top: 1px solid #e5e7eb; }

.card { border: 1px solid #e5e7eb; border-radius: var(--tl-radius); }
.card-header { background: #fff; border-bottom: 1px solid #e5e7eb; }
[data-bs-theme="dark"] .card,
[data-bs-theme="dark"] .card-header { background: #1e293b; border-color: #334155; }

.badge-soft {
    display: inline-block;
    padding: 4px 10px;
    font-size: 12px;
    border-radius: 999px;
    background: var(--tl-primary-soft);
    color: var(--tl-primary);
    font-weight: 600;
}

.stat-card { padding: 18px; border-radius: var(--tl-radius); background: #fff; border: 1px solid #e5e7eb; }
.stat-card .stat-label { color: var(--tl-muted); font-size: 12px; text-transform: uppercase; letter-spacing: .05em; }
.stat-card .stat-value { font-size: 28px; font-weight: 700; line-height: 1; margin-top: 4px; }

.wizard-steps { display: flex; gap: 8px; margin-bottom: 24px; }
.wizard-steps .step {
    flex: 1;
    padding: 12px;
    text-align: center;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    color: var(--tl-muted);
    font-weight: 600;
}
.wizard-steps .step.active { background: var(--tl-primary); color: #fff; border-color: var(--tl-primary); }
.wizard-steps .step.done { background: var(--tl-primary-soft); color: var(--tl-primary); border-color: var(--tl-primary-soft); }

.quota-bar { height: 8px; background: #e5e7eb; border-radius: 999px; overflow: hidden; }
.quota-bar > div { height: 100%; background: var(--tl-primary); transition: width .3s; }
.quota-bar.warn > div { background: var(--tl-accent); }
.quota-bar.full > div { background: var(--tl-danger); }

.foto-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 8px; }
.foto-grid img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 8px; }

.qr-scatola-card {
    text-align: center;
    padding: 20px;
    border: 1px solid #e5e7eb;
    border-radius: var(--tl-radius);
    background: #fff;
}
.qr-scatola-card .numero { font-size: 42px; font-weight: 800; color: var(--tl-primary); }
