/* ==========================================================
   LEGAL PAGES
   CONFORMIZEI ENTERPRISE V1
========================================================== */

/* ==========================================================
   01. PAGE LAYOUT
========================================================== */

.legal-content-section {

    position: relative;

    padding-top: 140px;

    padding-bottom: 100px;

    background:
        linear-gradient(
            180deg,
            #FFFFFF 0%,
            #F8FAFC 100%
        );
}

/* ==========================================================
   02. GRID
========================================================== */

.legal-sidebar-col {

    position: relative;
}

.legal-document-col {
	padding-left: 28px;
    position: relative;
}

/* ==========================================================
   03. SIDEBAR
========================================================== */

.legal-sidebar {
	
	width: 270px;
	
    position: sticky;

    top: 110px;
}

.legal-sidebar-card {

    background: #FFFFFF;

    border: 1px solid #E2E8F0;

    border-radius: 28px;

    padding: 28px;

    box-shadow:
        0 12px 35px rgba(15,23,42,.05);
}

.sidebar-badge {

    display: inline-flex;

    align-items: center;

    padding: 10px 16px;

    margin-bottom: 24px;

    border-radius: 999px;

    background: #EEF2FF;

    color: #3344B7;

    font-size: 11px;

    font-weight: 700;

    letter-spacing: 1.4px;

    text-transform: uppercase;
}

/* ==========================================================
   04. SIDEBAR NAV
========================================================== */

.legal-nav {

    list-style: none;

    padding: 0;

    margin: 0;
}

.legal-nav li {

    margin-bottom: 4px;
}

.legal-nav a {

    display: flex;

    align-items: center;

    padding: 12px 14px;

    border-radius: 12px;

    text-decoration: none;

    color: #64748B;

    font-size: .92rem;

    font-weight: 500;

    transition: all .25s ease;
}

.legal-nav a:hover {

    background: #F8FAFC;

    color: #3344B7;

    transform: translateX(4px);
}

/* ==========================================================
   SECTION HEADER
========================================================== */

.legal-section-header {

    display: flex;

    align-items: center;

    gap: 18px;

    margin-bottom: 10px;
}

/* ==========================================================
   05. DOCUMENT HEADER
========================================================== */

.legal-document {

    background: #FFFFFF;

    border: 1px solid #E2E8F0;

    border-radius: 32px;

    padding: 56px;

    box-shadow:
        0 18px 45px rgba(15,23,42,.05);

    margin-bottom: 36px;
}

.document-badge {

    display: inline-flex;

    align-items: center;

    padding: 12px 18px;

    margin-bottom: 24px;

    border-radius: 999px;

    background: #EEF2FF;

    color: #3344B7;

    font-size: .75rem;

    font-weight: 700;

    letter-spacing: 1.5px;

    text-transform: uppercase;
}

.legal-document-header {

    margin-bottom: 56px;
}

.legal-document-header h2 {

    margin: 0 0 20px;

    color: #0F172A;

    font-size: clamp(
        2rem,
        4vw,
        3.4rem
    );

    font-weight: 800;

    line-height: .95;

    letter-spacing: -0.04em;
}

.legal-document-header p {

    margin: 0;

    max-width: 860px;

    color: #64748B;

    font-size: 1.12rem;

    line-height: 1.9;
}

/* ==========================================================
   06. DOCUMENT META
========================================================== */

.legal-mini-meta {

    display: flex;

    flex-wrap: wrap;

    gap: 14px;

    margin-top: 32px;
}

.legal-mini-meta span {

    display: inline-flex;

    align-items: center;

    gap: 8px;

    padding: 10px 16px;

    border-radius: 999px;

    background: #F8FAFC;

    border: 1px solid #E2E8F0;

    color: #475569;

    font-size: .85rem;

    font-weight: 600;
}

.legal-mini-meta i {

    color: #3344B7;

    font-size: .9rem;
}

/* ==========================================================
   07. INTRODUCTION BLOCK
========================================================== */

.legal-intro {

    padding-top: 28px;

    border-top: 1px solid #E2E8F0;
}

.legal-intro p:last-child {

    margin-bottom: 0;
}

/* ==========================================================
   08. HIGHLIGHT INTRO
========================================================== */

.legal-highlight {

    margin-top: 28px;

    padding: 24px 28px;

    border-radius: 24px;

    background:
        linear-gradient(
            180deg,
            #F8FAFF 0%,
            #EEF2FF 100%
        );

    border: 1px solid rgba(51,68,183,.12);
}

.legal-highlight strong {

    color: #0F172A;
}

.legal-highlight p {

    margin: 0;

    color: #475569;

    line-height: 1.85;
}

/* ==========================================================
   09. DOCUMENT DIVIDER
========================================================== */

.legal-divider {

    width: 100%;

    height: 1px;

    margin: 40px 0;

    background:
        linear-gradient(
            90deg,
            transparent,
            #E2E8F0,
            transparent
        );
}
/* ==========================================================
   10. LEGAL CONTENT SECTIONS
========================================================== */

.legal-section-top {

    position: relative;

    padding: 36px 0;

    margin: 0;

    border: 0;

    background: transparent;

    box-shadow: none;
}

.legal-section-top:last-child {

    padding-bottom: 0;
}
/* DIVISOR ENTRE SEÇÕES */

.legal-section-top::before {

    content: "";

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 1px;

    background:
        linear-gradient(
            90deg,
            transparent,
            #E2E8F0 15%,
            #E2E8F0 85%,
            transparent
        );
}

/* ==========================================================
   11. SECTION TITLES
========================================================== */

.legal-section h2 {

    margin: 0 0 24px;

    color: #0F172A;

    font-size: 2rem;

    font-weight: 800;

    line-height: 1.1;

    letter-spacing: -0.02em;
}

.legal-section-top h3 {

    margin: 0;

    color: #0F172A;

    font-size: 1.5rem;

    font-weight: 700;

    line-height: 1.3;
}

.legal-section-top h4 {

	font-size: 1.2rem;

    font-weight: 700;

    margin-bottom: 18px;

    color: #000000;
}

/* ==========================================================
   12. PARAGRAPHS
========================================================== */

.legal-section-top p {

    margin: 0 0 14px;

    color: #475569;

    font-size: 1rem;

    line-height: 1.9;
}

.legal-section-top p:last-child {

    margin-bottom: 0;
}

/* ==========================================================
   13. LISTS
========================================================== */

.legal-section ul,
.legal-section ol {

    margin: 22px 0;

    padding-left: 26px;
}

.legal-section li {

    margin-bottom: 12px;

    color: #475569;

    line-height: 1.8;
}

.legal-section li:last-child {

    margin-bottom: 0;
}

/* ==========================================================
   14. EMPHASIS
========================================================== */

.legal-section strong {

    color: #0F172A;

    font-weight: 700;
}

.legal-section em {

    color: #3344B7;

    font-style: normal;

    font-weight: 600;
}

/* ==========================================================
   15. LINKS
========================================================== */

.legal-section a {

    color: #3344B7;

    text-decoration: none;

    font-weight: 600;

    transition: all .25s ease;
}

.legal-section a:hover {

    color: #233A95;

    text-decoration: underline;
}

/* ==========================================================
   16. SECTION NUMBER
========================================================== */

.legal-index {

    display: block;

    margin-bottom: 0px;

    color: #4459E8;

    font-size: 1.5rem;

    font-weight: 800;

    letter-spacing: 1px;

    text-transform: uppercase;
}

/* ==========================================================
   17. CONTENT DIVIDER
========================================================== */

.legal-section-divider {

    width: 100%;

    height: 1px;

    margin: 36px 0;

    background:
        linear-gradient(
            90deg,
            transparent,
            #E2E8F0,
            transparent
        );
}

/* ==========================================================
   18. INLINE HIGHLIGHT
========================================================== */

.legal-inline-highlight {

    display: inline-block;

    padding: 2px 8px;

    border-radius: 8px;

    background: #EEF2FF;

    color: #3344B7;

    font-weight: 600;
}

/* ==========================================================
   19. BLOCKQUOTE / CITATION
========================================================== */

.legal-section blockquote {

    margin: 24px 0;

    padding: 24px 28px;

    border-left: 4px solid #3344B7;

    background: #F8FAFC;

    border-radius: 0 18px 18px 0;
}

.legal-section blockquote p {

    margin: 0;

    color: #475569;

    font-style: italic;
}

/* ==========================================================
   20. SMALL TEXT
========================================================== */

.legal-small {

    font-size: .90rem;

    color: #64748B;
}
/* ==========================================================
   21. INFO CARDS
========================================================== */

.legal-info-card {

    background:
        linear-gradient(
            180deg,
            #F8FAFF 0%,
            #EEF2FF 100%
        );

    border: 1px solid #E2E8F0;

    border-radius: 24px;

    padding: 24px;

    margin-bottom: 0px;

    transition: all .25s ease;
}

.legal-info-card:hover {

    transform: translateY(-3px);

    box-shadow:
        0 15px 35px rgba(15,23,42,.06);
}

.legal-section > p:first-of-type {

    margin-bottom: 36px;
}

.legal-info-card-icon {

    width: 58px;

    height: 58px;

    display: flex;

    align-items: center;

    justify-content: center;

    margin-bottom: 18px;

    border-radius: 18px;

    background:
        linear-gradient(
            135deg,
            #3344B7,
            #4459E8
        );

    color: #FFFFFF;

    font-size: 1.35rem;
}

.legal-info-card h3 {

    margin: 0 0 12px;

    color: #0F172A;

    font-size: 1.15rem;

    font-weight: 700;
}

.legal-info-card p {

    margin: 0;

    color: #64748B;

    line-height: 1.8;
}

/* ==========================================================
   22. LEGAL NOTES
========================================================== */

.legal-note {

    margin: 28px 0;

    padding: 22px 26px;

    border-radius: 22px;

    background:
        linear-gradient(
            180deg,
            #F8FAFF 0%,
            #EEF2FF 100%
        );

    border: 1px solid rgba(51,68,183,.12);
}

.legal-note-title {

    display: flex;

    align-items: center;

    gap: 10px;

    margin-bottom: 12px;

    color: #0F172A;

    font-weight: 700;
}

.legal-note-title i {

    color: #3344B7;
}

.legal-note p {

    margin: 0;

    color: #000000;

    line-height: 1.85;
}

/* ==========================================================
   23. WARNING NOTE
========================================================== */

.legal-warning {

    margin: 28px 0;

    padding: 22px 26px;

    border-radius: 22px;

    background:
        linear-gradient(
            180deg,
            #FFF8E8 0%,
            #FEF3C7 100%
        );

    border: 1px solid rgba(245,158,11,.18);
}

.legal-warning .legal-note-title i {

    color: #D97706;
}

/* ==========================================================
   24. SUCCESS NOTE
========================================================== */

.legal-success {

    margin: 28px 0;

    padding: 22px 26px;

    border-radius: 22px;

    background:
        linear-gradient(
            180deg,
            #F0FDF4 0%,
            #DCFCE7 100%
        );

    border: 1px solid rgba(34,197,94,.15);
}

.legal-success .legal-note-title i {

    color: #16A34A;
}

/* ==========================================================
   25. LEGAL CHIPS
========================================================== */

.legal-chips {

    display: flex;

    flex-wrap: wrap;

    gap: 12px;

    margin-top: 20px;
}

.legal-chips span {

    display: inline-flex;

    align-items: center;

    justify-content: center;

    padding: 12px 18px;

    border-radius: 999px;

    background: #EEF2FF;

    color: #3344B7;

    font-size: .88rem;

    font-weight: 600;
}

/* ==========================================================
   26. DPO BOX
========================================================== */

.legal-dpo-box {

    margin-top: 36px;

    padding: 34px;

    border-radius: 28px;

    background:
        linear-gradient(
            135deg,
            #233A95 0%,
            #4459E8 100%
        );

    color: #FFFFFF;

    overflow: hidden;

    position: relative;
}

.legal-dpo-box::before {

    content: "";

    position: absolute;

    top: -80px;

    right: -80px;

    width: 220px;

    height: 220px;

    border-radius: 50%;

    background:
        rgba(255,255,255,.08);
}

.legal-dpo-box h3 {

    position: relative;

    margin: 0 0 14px;

    color: #FFFFFF;

    font-size: 1.4rem;

    font-weight: 700;
}

.legal-dpo-box p {

    position: relative;

    margin: 0 0 20px;

    color: rgba(255,255,255,.90);

    line-height: 1.8;
}

.legal-dpo-box a {

    position: relative;

    color: #FFFFFF;

    font-weight: 700;

    text-decoration: none;
}

.legal-dpo-box a:hover {

    text-decoration: underline;
}

/* ==========================================================
   27. LEGAL TABLES
========================================================== */

.legal-table-wrapper {

    overflow-x: auto;

    margin: 28px 0;
}

.legal-table {

    width: 100%;

    border-collapse: separate;

    border-spacing: 0;

    overflow: hidden;

    border-radius: 22px;

    border: 1px solid #E2E8F0;

    background: #FFFFFF;
}

.legal-table thead {

    background:
        linear-gradient(
            180deg,
            #F8FAFC 0%,
            #F1F5F9 100%
        );
}

.legal-table th {

    padding: 18px 20px;

    text-align: left;

    color: #0F172A;

    font-size: .92rem;

    font-weight: 700;

    border-bottom: 1px solid #E2E8F0;
}

.legal-table td {

    padding: 18px 20px;

    color: #475569;

    line-height: 1.7;

    border-bottom: 1px solid #F1F5F9;
}

.legal-table tr:last-child td {

    border-bottom: none;
}

.legal-table tbody tr:hover {

    background: #FAFBFF;
}

/* ==========================================================
   28. SUMMARY CARD
========================================================== */

.legal-summary {

    margin-bottom: 32px;

    padding: 28px;

    border-radius: 28px;

    background:
        linear-gradient(
            180deg,
            #FFFFFF 0%,
            #F8FAFC 100%
        );

    border: 1px solid #E2E8F0;
}

.legal-summary h3 {

    margin: 0 0 16px;

    color: #0F172A;

    font-size: 1.25rem;

    font-weight: 700;
}

.legal-summary ul {

    margin: 0;

    padding-left: 20px;
}

/* ==========================================================
   29. SECTION ANCHOR OFFSET
========================================================== */

.legal-section[id] {

    scroll-margin-top: 120px;
}
/* ==========================================================
   30. RESPONSIVE — TABLET
========================================================== */

@media (max-width: 1199px) {

    .legal-content-section {

        padding-top: 120px;

        padding-bottom: 80px;
    }

    .legal-document {

        padding: 42px;
    }

    .legal-section {

        padding: 36px;
    }

    .legal-document-header h1 {

        font-size:
            clamp(
                2.4rem,
                5vw,
                3.5rem
            );
    }

    .legal-sidebar {

        top: 95px;
    }

}

/* ==========================================================
   31. RESPONSIVE — MOBILE MENU
========================================================== */

@media (max-width: 991px) {

    .legal-content-section {

        padding-top: 110px;

        padding-bottom: 70px;
    }

    .legal-sidebar {

        position: relative;

        top: auto;

        margin-bottom: 28px;
    }

    .legal-sidebar-card {

        padding: 24px;
    }

    .legal-nav {

        display: flex;

        flex-wrap: wrap;

        gap: 8px;
    }

    .legal-nav li {

        margin-bottom: 0;
    }

    .legal-nav a {

        padding: 10px 14px;

        background: #F8FAFC;

        border-radius: 999px;

        font-size: .85rem;
    }

    .legal-document {

        padding: 32px;
    }

    .legal-document-header h1 {

        font-size:
            clamp(
                2rem,
                8vw,
                3rem
            );

        line-height: 1.05;
    }

    .legal-document-header p {

        font-size: 1rem;
    }

    .legal-mini-meta {

        gap: 10px;
    }

    .legal-mini-meta span {

        width: 100%;

        justify-content: center;
    }

    .legal-section {

        padding: 30px;
    }

    .legal-section h2 {

        font-size: 1.7rem;
    }

    .legal-section h3 {

        font-size: 1.15rem;
    }

    .legal-info-card {

        padding: 24px;
    }

    .legal-note,
    .legal-warning,
    .legal-success {

        padding: 20px;
    }

    .legal-dpo-box {

        padding: 28px;
    }

}

/* ==========================================================
   32. RESPONSIVE — SMALL MOBILE
========================================================== */

@media (max-width: 767px) {

    .legal-content-section {

        padding-top: 100px;

        padding-bottom: 60px;
    }

    .legal-document {

        padding: 24px;

        border-radius: 24px;
    }

    .legal-section {

        padding: 24px;

        border-radius: 24px;
    }

    .legal-document-header {

        margin-bottom: 24px;
    }

    .document-badge {

        font-size: .70rem;

        padding: 10px 14px;
    }

    .legal-document-header h1 {

        font-size:
            clamp(
                1.8rem,
                8vw,
                2.6rem
            );
    }

    .legal-document-header p {

        font-size: .95rem;

        line-height: 1.8;
    }

    .legal-section h2 {

        font-size: 1.45rem;
    }

    .legal-section h3 {

        font-size: 1.05rem;
    }

    .legal-section p,
    .legal-section li {

        font-size: .95rem;
    }

    .legal-section-number {

        width: 34px;

        height: 34px;

        margin-right: 10px;

        font-size: .85rem;
    }

    .legal-info-card-icon {

        width: 50px;

        height: 50px;

        font-size: 1.15rem;
    }

    .legal-chips {

        gap: 8px;
    }

    .legal-chips span {

        font-size: .80rem;

        padding: 10px 14px;
    }

    .legal-dpo-box {

        padding: 24px;
    }

    .legal-dpo-box h3 {

        font-size: 1.2rem;
    }

}

/* ==========================================================
   33. TABLE RESPONSIVE
========================================================== */

@media (max-width: 767px) {

    .legal-table {

        min-width: 650px;
    }

    .legal-table-wrapper {

        border-radius: 18px;

        overflow-x: auto;

        -webkit-overflow-scrolling: touch;
    }

}

/* ==========================================================
   34. ACCESSIBILITY
========================================================== */

.legal-nav a:focus,
.legal-section a:focus {

    outline: 2px solid #4459E8;

    outline-offset: 3px;
}

/* ==========================================================
   35. PRINT
========================================================== */

@media print {

    .legal-sidebar {

        display: none;
    }

    .legal-content-section {

        padding: 0;

        background: #FFFFFF;
    }

    .legal-document,
    .legal-section {

        box-shadow: none;

        border: 1px solid #D1D5DB;
    }

}

/* ==========================================================
   36. FINAL POLISH
========================================================== */

html {

    scroll-behavior: smooth;
}

.legal-document,
.legal-section,
.legal-sidebar-card,
.legal-info-card {

    transition:
        box-shadow .25s ease,
        transform .25s ease;
}

.legal-document:hover,
.legal-section:hover {

    transform: translateY(-2px);

    box-shadow:
        0 20px 50px rgba(15,23,42,.08);
}
/* GRID 2 */

.legal-grid-2 {

    display: grid;

    grid-template-columns:
        repeat(2, minmax(0, 1fr));

    gap: 24px;

    margin-top: 32px;
}

/* GRID 3 */

.legal-grid-3 {

    display: grid;

    grid-template-columns:
        repeat(3, minmax(0, 1fr));

    gap: 24px;

    margin-top: 32px;
}