/* ═══════════════════════════════════════════════════════════════════
   Glocal Legal Suite — UI v2.5 "Filament Pro"
   ═══════════════════════════════════════════════════════════════════ */

/* ── Reset & Base ─────────────────────────────────────────────────── */
.gls-hub, .gls-hub *,
.gls-page, .gls-page *,
.gls-tools-list, .gls-tools-list * {
    box-sizing: border-box !important;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
}

/* ════════════════════════════════════════════════════════════════════
   HUB — CENTRALE
   ════════════════════════════════════════════════════════════════════ */
.gls-hub {
    font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
    max-width: 1040px !important;
    margin: 0 auto !important;
    padding: 0 0 56px !important;
    color: #111827 !important;
}

.gls-hub__header {
    background: #0f1c38 !important;
    border-radius: 20px !important;
    padding: 52px 48px !important;
    margin-bottom: 36px !important;
    text-align: center !important;
    position: relative !important;
    overflow: hidden !important;
}

/* Blob decorativi */
.gls-hub__header::before {
    content: '' !important;
    position: absolute !important;
    top: -80px !important; right: -80px !important;
    width: 320px !important; height: 320px !important;
    background: radial-gradient(circle, rgba(201,168,76,.18) 0%, transparent 65%) !important;
    border-radius: 50% !important;
    pointer-events: none !important;
}
.gls-hub__header::after {
    content: '' !important;
    position: absolute !important;
    bottom: -60px !important; left: -60px !important;
    width: 260px !important; height: 260px !important;
    background: radial-gradient(circle, rgba(99,130,201,.14) 0%, transparent 65%) !important;
    border-radius: 50% !important;
    pointer-events: none !important;
}

.gls-hub__title {
    font-family: 'Playfair Display', 'Georgia', serif !important;
    font-size: 36px !important;
    font-weight: 700 !important;
    color: #e8d48a !important;
    margin: 0 0 12px !important;
    padding: 0 !important;
    letter-spacing: -.5px !important;
    position: relative !important;
    z-index: 1 !important;
    line-height: 1.2 !important;
}

.gls-hub__sub {
    font-size: 16px !important;
    color: rgba(255,255,255,.45) !important;
    margin: 0 !important;
    font-weight: 400 !important;
    position: relative !important;
    z-index: 1 !important;
    letter-spacing: .01em !important;
}

/* Grid cards */
.gls-hub__grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 16px !important;
    margin-bottom: 28px !important;
}

.gls-hub__card {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 14px !important;
    padding: 24px 22px !important;
    background: #fff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 16px !important;
    text-decoration: none !important;
    color: #111827 !important;
    transition: all .22s cubic-bezier(.4,0,.2,1) !important;
    position: relative !important;
    overflow: hidden !important;
    min-height: 130px !important;
}

.gls-hub__card::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(135deg, rgba(201,168,76,.06) 0%, transparent 60%) !important;
    opacity: 0 !important;
    transition: opacity .22s !important;
}

.gls-hub__card:hover {
    border-color: #c9a84c !important;
    box-shadow: 0 12px 32px rgba(26,39,68,.12), 0 2px 8px rgba(26,39,68,.06) !important;
    transform: translateY(-4px) !important;
    text-decoration: none !important;
    color: #111827 !important;
}
.gls-hub__card:hover::before { opacity: 1 !important; }
.gls-hub__card:hover .gls-hub__card-arrow {
    opacity: 1 !important;
    transform: translateX(4px) !important;
    color: #c9a84c !important;
}

.gls-hub__card-icon {
    font-size: 32px !important;
    line-height: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 52px !important;
    height: 52px !important;
    background: linear-gradient(135deg, #f3f0e8, #ede9df) !important;
    border-radius: 14px !important;
    flex-shrink: 0 !important;
    position: relative !important;
    z-index: 1 !important;
}

.gls-hub__card-label {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #1f2937 !important;
    line-height: 1.35 !important;
    flex: 1 !important;
    position: relative !important;
    z-index: 1 !important;
}

.gls-hub__card-arrow {
    font-size: 18px !important;
    color: #9ca3af !important;
    opacity: .4 !important;
    transition: all .22s !important;
    align-self: flex-end !important;
    margin-top: auto !important;
    position: relative !important;
    z-index: 1 !important;
}

.gls-hub__note {
    font-size: 13px !important;
    color: #6b7280 !important;
    text-align: center !important;
    padding: 16px 24px !important;
    background: #f9fafb !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    margin: 0 !important;
    line-height: 1.6 !important;
}
.gls-hub__note strong { color: #1f2937 !important; }
.gls-hub__note code {
    background: #0f1c38 !important;
    color: #e8d48a !important;
    padding: 2px 8px !important;
    border-radius: 6px !important;
    font-size: 12px !important;
    letter-spacing: .02em !important;
}

/* ════════════════════════════════════════════════════════════════════
   PAGINA CATEGORIA
   ════════════════════════════════════════════════════════════════════ */
.gls-page {
    font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
    max-width: 1040px !important;
    margin: 0 auto !important;
    color: #111827 !important;
}

.gls-page__header {
    display: flex !important;
    align-items: center !important;
    gap: 20px !important;
    padding: 28px 32px !important;
    background: #0f1c38 !important;
    border-radius: 20px !important;
    margin-bottom: 32px !important;
    position: relative !important;
    overflow: hidden !important;
}
.gls-page__header::after {
    content: '' !important;
    position: absolute !important;
    top: -60px !important; right: -60px !important;
    width: 200px !important; height: 200px !important;
    background: radial-gradient(circle, rgba(201,168,76,.15) 0%, transparent 65%) !important;
    border-radius: 50% !important;
}

.gls-page__icon {
    font-size: 42px !important;
    line-height: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 72px !important;
    height: 72px !important;
    background: rgba(255,255,255,.07) !important;
    border-radius: 18px !important;
    flex-shrink: 0 !important;
    position: relative !important;
    z-index: 1 !important;
    border: 1px solid rgba(255,255,255,.1) !important;
}

.gls-page__header-text {
    flex: 1 !important;
    position: relative !important;
    z-index: 1 !important;
}

.gls-page__title {
    font-family: 'Playfair Display', 'Georgia', serif !important;
    font-size: 24px !important;
    font-weight: 700 !important;
    color: #e8d48a !important;
    margin: 0 0 6px !important;
    padding: 0 !important;
    line-height: 1.2 !important;
}

.gls-page__subtitle {
    font-size: 13px !important;
    color: rgba(255,255,255,.4) !important;
    margin: 0 !important;
}

/* Bottone TORNA INDIETRO — grande e comodo */
.gls-page__back-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 10px 20px !important;
    background: rgba(255,255,255,.08) !important;
    border: 1px solid rgba(255,255,255,.15) !important;
    border-radius: 10px !important;
    color: rgba(255,255,255,.7) !important;
    text-decoration: none !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: all .18s !important;
    flex-shrink: 0 !important;
    position: relative !important;
    z-index: 1 !important;
}
.gls-page__back-btn:hover {
    background: rgba(255,255,255,.14) !important;
    border-color: rgba(255,255,255,.25) !important;
    color: #fff !important;
    text-decoration: none !important;
    transform: translateX(-2px) !important;
}
.gls-page__back-btn-icon {
    font-size: 16px !important;
    font-style: normal !important;
}

/* Old back link — nascondi, usiamo il nuovo bottone */
.gls-page__back { display: none !important; }

.gls-page__body { padding: 0 !important; }

/* ════════════════════════════════════════════════════════════════════
   STRUMENTI
   ════════════════════════════════════════════════════════════════════ */
.gls-tools-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
    padding: 0 !important;
    margin: 0 !important;
}

.gls-tool {
    background: #fff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    margin: 0 !important;
    transition: box-shadow .22s, border-color .22s !important;
}
.gls-tool:hover {
    box-shadow: 0 4px 24px rgba(26,39,68,.08) !important;
    border-color: #d1d5db !important;
}

.gls-tool__header {
    padding: 20px 24px 16px !important;
    border-bottom: 1px solid #f3f4f6 !important;
    background: #fafafa !important;
}

.gls-tool__title {
    font-family: 'Playfair Display', 'Georgia', serif !important;
    font-size: 17px !important;
    font-weight: 600 !important;
    color: #111827 !important;
    margin: 0 0 4px !important;
    padding: 0 !important;
    line-height: 1.3 !important;
}

.gls-tool__desc {
    font-size: 13px !important;
    color: #6b7280 !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.5 !important;
}

/* ════════════════════════════════════════════════════════════════════
   FORM
   ════════════════════════════════════════════════════════════════════ */
.gls-form-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(195px, 1fr)) !important;
    gap: 16px !important;
    padding: 22px 24px 8px !important;
    margin: 0 !important;
}

.gls-fg {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
}

.gls-fg.gls-fg--full { grid-column: 1 / -1 !important; }

.gls-fg label {
    font-size: 11px !important;
    font-weight: 600 !important;
    color: #6b7280 !important;
    text-transform: uppercase !important;
    letter-spacing: .07em !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
}

.gls-req {
    color: #ef4444 !important;
    font-size: 13px !important;
}

.gls-inp {
    background: #f9fafb !important;
    border: 1.5px solid #e5e7eb !important;
    border-radius: 10px !important;
    color: #111827 !important;
    font-family: 'Inter', system-ui, sans-serif !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    padding: 10px 14px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    transition: border-color .15s, background .15s, box-shadow .15s !important;
    outline: none !important;
    -webkit-appearance: none !important;
}
.gls-inp:focus {
    border-color: #1a2744 !important;
    background: #fff !important;
    box-shadow: 0 0 0 3px rgba(26,39,68,.1) !important;
}
.gls-inp:hover:not(:focus) { border-color: #d1d5db !important; }
select.gls-inp { cursor: pointer !important; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important; background-repeat: no-repeat !important; background-position: right 12px center !important; padding-right: 36px !important; }
textarea.gls-inp { resize: vertical !important; min-height: 88px !important; line-height: 1.5 !important; }

/* ════════════════════════════════════════════════════════════════════
   PULSANTI
   ════════════════════════════════════════════════════════════════════ */
.gls-btn-row {
    padding: 8px 24px 2px !important;
}

.gls-calc-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 11px 26px !important;
    background: #0f1c38 !important;
    border: none !important;
    border-radius: 10px !important;
    font-family: 'Inter', system-ui, sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #e8d48a !important;
    cursor: pointer !important;
    transition: all .2s cubic-bezier(.4,0,.2,1) !important;
    letter-spacing: .01em !important;
    white-space: nowrap !important;
    margin: 0 !important;
}
.gls-calc-btn:hover {
    background: #1a2d55 !important;
    box-shadow: 0 6px 18px rgba(15,28,56,.28) !important;
    transform: translateY(-2px) !important;
}
.gls-calc-btn:active { transform: translateY(0) !important; box-shadow: none !important; }
.gls-calc-btn:disabled {
    opacity: .6 !important;
    cursor: wait !important;
    transform: none !important;
    box-shadow: none !important;
}

.gls-btn-spinner {
    display: inline-block !important;
    animation: glsSpin .65s linear infinite !important;
    font-style: normal !important;
}
@keyframes glsSpin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

.gls-calc-btn--pdf {
    background: linear-gradient(135deg, #78350f, #b45309) !important;
    color: #fef3c7 !important;
}
.gls-calc-btn--pdf:hover {
    background: linear-gradient(135deg, #92400e, #d97706) !important;
}

/* ════════════════════════════════════════════════════════════════════
   RISULTATI
   ════════════════════════════════════════════════════════════════════ */
.gls-result-box {
    margin: 6px 24px 22px !important;
    animation: glsFadeUp .24s ease !important;
}
.gls-result-box:empty { display: none !important; }

@keyframes glsFadeUp {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Card totali */
.gls-res-total {
    background: #0f1c38 !important;
    border-radius: 12px !important;
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)) !important;
    overflow: hidden !important;
    margin-bottom: 14px !important;
}

.gls-res-total__item {
    padding: 18px 20px !important;
    border-right: 1px solid rgba(255,255,255,.06) !important;
    border-bottom: 1px solid rgba(255,255,255,.06) !important;
}

.gls-res-total__label {
    display: block !important;
    font-size: 10px !important;
    font-weight: 600 !important;
    color: rgba(255,255,255,.32) !important;
    text-transform: uppercase !important;
    letter-spacing: .1em !important;
    margin-bottom: 6px !important;
}

.gls-res-total__value {
    display: block !important;
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 24px !important;
    font-weight: 700 !important;
    color: #e8d48a !important;
    line-height: 1.1 !important;
}

.gls-res-total__value--small {
    font-family: 'Inter', system-ui, sans-serif !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    color: rgba(255,255,255,.6) !important;
}

/* Righe dati */
.gls-res-rows {
    background: #fff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    overflow: hidden !important;
}

.gls-res-row {
    display: flex !important;
    align-items: center !important;
    padding: 12px 18px !important;
    border-bottom: 1px solid #f3f4f6 !important;
    gap: 12px !important;
    transition: background .12s !important;
}
.gls-res-row:last-child { border-bottom: none !important; }
.gls-res-row:hover { background: #fafafa !important; }

.gls-res-row--highlight {
    background: #fffbeb !important;
}
.gls-res-row--danger { background: #fef2f2 !important; }

.gls-res-row__label {
    flex: 1 !important;
    font-size: 13px !important;
    color: #6b7280 !important;
    font-weight: 400 !important;
}

.gls-res-row__value {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #111827 !important;
    cursor: pointer !important;
}
.gls-res-row__value:hover { color: #1a2744 !important; }

/* Badge */
.gls-res-badge {
    display: inline-flex !important;
    align-items: center !important;
    padding: 3px 10px !important;
    border-radius: 100px !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: .02em !important;
}
.gls-res-badge--ok    { background: #dcfce7 !important; color: #15803d !important; }
.gls-res-badge--error { background: #fee2e2 !important; color: #b91c1c !important; }
.gls-res-badge--warn  { background: #fef3c7 !important; color: #b45309 !important; }

/* Tabelle */
.gls-res-table {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 13px !important;
}
.gls-res-table thead { background: #0f1c38 !important; }
.gls-res-table th {
    padding: 10px 16px !important;
    text-align: left !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    color: #e8d48a !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
    border: none !important;
}
.gls-res-table td {
    padding: 10px 16px !important;
    border-bottom: 1px solid #f3f4f6 !important;
    color: #374151 !important;
    border-left: none !important;
    border-right: none !important;
    border-top: none !important;
}
.gls-res-table tr:last-child td { border-bottom: none !important; }
.gls-res-table tr:hover td { background: #f9fafb !important; }
.gls-res-table tr:nth-child(even) td { background: #fafafa !important; }

/* Notice */
.gls-calc-notice {
    padding: 12px 16px !important;
    border-radius: 10px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    border-left: 3px solid !important;
    margin-top: 8px !important;
    line-height: 1.5 !important;
    border-radius: 0 10px 10px 0 !important;
}
.gls-calc-notice--success { background: #f0fdf4 !important; color: #15803d !important; border-color: #22c55e !important; }
.gls-calc-notice--error   { background: #fef2f2 !important; color: #b91c1c !important; border-color: #ef4444 !important; }
.gls-calc-notice--info    { background: #eff6ff !important; color: #1d4ed8 !important; border-color: #3b82f6 !important; }

/* Info box */
.gls-info-box {
    background: #fffbeb !important;
    border-left: 3px solid #c9a84c !important;
    border-radius: 0 10px 10px 0 !important;
    color: #92400e !important;
    font-size: 13px !important;
    line-height: 1.6 !important;
    margin: 12px 24px 6px !important;
    padding: 11px 16px !important;
}

/* PDF link */
.gls-pdf-link {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 12px 22px !important;
    background: #14532d !important;
    border-radius: 10px !important;
    color: #dcfce7 !important;
    text-decoration: none !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    margin-top: 10px !important;
    transition: all .2s !important;
}
.gls-pdf-link:hover {
    background: #166534 !important;
    color: #dcfce7 !important;
    text-decoration: none !important;
    box-shadow: 0 6px 18px rgba(20,83,45,.3) !important;
    transform: translateY(-2px) !important;
}

/* Checkbox group */
.gls-checkbox-group {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px 24px !important;
    background: #f9fafb !important;
    border: 1.5px solid #e5e7eb !important;
    border-radius: 10px !important;
    padding: 14px 16px !important;
}
.gls-checkbox-group label {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #374151 !important;
    cursor: pointer !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}
.gls-checkbox-group input[type="checkbox"] {
    width: 16px !important;
    height: 16px !important;
    accent-color: #0f1c38 !important;
    cursor: pointer !important;
}

/* Nota risultato */
.gls-res-nota {
    font-size: 11px !important;
    color: #9ca3af !important;
    padding: 10px 0 0 !important;
    font-style: italic !important;
    line-height: 1.6 !important;
}

/* Divisore sezione */
.gls-section-divider {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    margin: 4px 0 !important;
    color: #9ca3af !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .07em !important;
}
.gls-section-divider::before,
.gls-section-divider::after {
    content: '' !important;
    flex: 1 !important;
    height: 1px !important;
    background: #e5e7eb !important;
}

/* Titolo statico */
.gls-static-title {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #111827 !important;
    margin: 18px 0 10px !important;
}

/* ════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
    .gls-hub__grid { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 700px) {
    .gls-hub__grid { grid-template-columns: repeat(2, 1fr) !important; }
    .gls-hub__header { padding: 36px 28px !important; }
    .gls-hub__title { font-size: 28px !important; }
    .gls-form-grid { grid-template-columns: 1fr !important; padding: 16px 18px 6px !important; }
    .gls-page__header { flex-direction: column !important; text-align: center !important; padding: 24px 20px !important; }
    .gls-page__back-btn { width: 100% !important; justify-content: center !important; }
    .gls-res-total { grid-template-columns: repeat(2, 1fr) !important; }
    .gls-tool__header, .gls-btn-row, .gls-result-box { padding-left: 18px !important; padding-right: 18px !important; }
}
@media (max-width: 480px) {
    .gls-hub__grid { grid-template-columns: 1fr !important; }
    .gls-hub__card { flex-direction: row !important; align-items: center !important; min-height: auto !important; }
    .gls-hub__card-icon { width: 44px !important; height: 44px !important; font-size: 24px !important; }
    .gls-res-total { grid-template-columns: 1fr !important; }
}

/* Print */
@media print {
    .gls-calc-btn, .gls-btn-row, .gls-page__back-btn { display: none !important; }
    .gls-tool { break-inside: avoid !important; page-break-inside: avoid !important; }
    .gls-hub__card:hover { transform: none !important; box-shadow: none !important; }
}

/* ── Disclaimer legale ────────────────────────────────── */
.gls-disclaimer {
    display: flex !important;
    align-items: flex-start !important;
    gap: 8px !important;
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 10px 14px !important;
    margin: 0 24px 16px !important;
    font-size: 11px !important;
    color: #64748b !important;
    line-height: 1.5 !important;
}
.gls-disclaimer-icon {
    font-size: 13px !important;
    flex-shrink: 0 !important;
    margin-top: 1px !important;
}
