/* ===================================
   PRIVACY POLICY SPECIFIC STYLES
   =================================== */

/* Hero Section */
.privacy-hero {
    padding: 8rem 0 4rem;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
    text-align: center;
}

.privacy-hero__content {
    max-width: 800px;
    margin: 0 auto;
}

.privacy-hero__title {
    font-size: 3rem;
    margin-bottom: 1.5rem;
}

.privacy-hero__description {
    font-size: 1.25rem;
    color: var(--gray);
    margin-bottom: 2rem;
    line-height: 1.7;
}

.privacy-hero__meta {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
    color: var(--gray);
    font-size: 0.95rem;
}

.separator {
    color: var(--gray-light);
}

/* Quick Navigation */
.privacy-nav {
    background: var(--white);
    padding: 2rem 0;
    border-bottom: 2px solid var(--gray-lighter);
    position: sticky;
    top: 70px;
    z-index: 100;
    box-shadow: var(--shadow-sm);
    overflow: hidden; /* prevent flex children from inflating page width */
}

.privacy-nav__title {
    font-weight: 600;
    margin-bottom: 1rem;
    color: var(--dark);
}

.privacy-nav__links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    max-width: 100%; /* ensure the row never exceeds its container */
}

.privacy-nav__link {
    padding: 0.5rem 1rem;
    background: var(--gray-lighter);
    color: var(--dark);
    text-decoration: none;
    border-radius: 6px;
    font-size: 0.875rem;
    font-weight: 500;
    transition: var(--transition);
    white-space: nowrap;
    flex-shrink: 0;
}

.privacy-nav__link:hover {
    background: var(--primary);
    color: var(--white);
}

/* Content Layout */
.privacy-content {
    padding: 4rem 0;
    background: var(--gray-lighter);
}

.privacy-wrapper {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 3rem;
}

/* Sidebar */
.privacy-sidebar {
    position: relative;
}

.privacy-sidebar__sticky {
    position: sticky;
    top: 150px;
}

.privacy-sidebar__section {
    background: var(--white);
    padding: 1.5rem;
    border-radius: 12px;
    margin-bottom: 1.5rem;
    box-shadow: var(--shadow-sm);
}

.privacy-sidebar__section h3 {
    font-size: 1rem;
    margin-bottom: 1rem;
    color: var(--dark);
}

.privacy-sidebar__section ul {
    list-style: none;
    padding: 0;
}

.privacy-sidebar__section ul li {
    margin-bottom: 0.75rem;
}

.privacy-sidebar__section ul li a {
    color: var(--gray);
    text-decoration: none;
    transition: var(--transition);
    font-size: 0.9rem;
}

.privacy-sidebar__section ul li a:hover {
    color: var(--primary);
}

.compliance-badges {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.badge {
    padding: 0.5rem;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.1), rgba(139, 92, 246, 0.1));
    color: var(--primary);
    border-radius: 6px;
    font-size: 0.875rem;
    font-weight: 600;
    text-align: center;
}

.privacy-sidebar__cta {
    background: var(--dark);
    color: var(--white);
    padding: 1.5rem;
    border-radius: 12px;
    text-align: center;
}

.privacy-sidebar__cta h4 {
    color: var(--white);
    margin-bottom: 0.5rem;
}

.privacy-sidebar__cta p {
    font-size: 0.9rem;
    color: var(--gray-light);
    margin-bottom: 1rem;
}

.btn--small {
    padding: 0.75rem 1.5rem;
    font-size: 0.875rem;
}

/* Main Content */
.privacy-main {
    background: var(--white);
    padding: 3rem;
    border-radius: 16px;
    box-shadow: var(--shadow-md);
    overflow-x: hidden; /* prevent any internal element from widening the card */
    min-width: 0;       /* allow grid item to shrink below its content size */
}

.privacy-section {
    margin-bottom: 4rem;
    scroll-margin-top: 150px;
    word-break: break-word;    /* prevent long strings from overflowing */
    overflow-wrap: break-word;
}

.privacy-section:last-child {
    margin-bottom: 0;
}

.privacy-section h2 {
    font-size: 2rem;
    margin-bottom: 1.5rem;
    color: var(--dark);
    padding-bottom: 0.75rem;
    border-bottom: 3px solid var(--primary);
}

.privacy-section h3 {
    font-size: 1.5rem;
    margin-top: 2rem;
    margin-bottom: 1rem;
    color: var(--dark);
}

.privacy-section h4 {
    font-size: 1.125rem;
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
    color: var(--dark);
}

.privacy-section p {
    color: var(--gray);
    line-height: 1.8;
    margin-bottom: 1rem;
}

.privacy-section ul,
.privacy-section ol {
    color: var(--gray);
    line-height: 1.8;
    margin-bottom: 1rem;
    padding-left: 1.5rem;
}

.privacy-section li {
    margin-bottom: 0.5rem;
}

/* Info Boxes */
.info-box,
.warning-box {
    display: flex;
    gap: 1rem;
    padding: 1.5rem;
    border-radius: 12px;
    margin: 2rem 0;
}

.info-box {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.05), rgba(139, 92, 246, 0.05));
    border-left: 4px solid var(--primary);
}

.warning-box {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.05), rgba(239, 68, 68, 0.05));
    border-left: 4px solid #f59e0b;
}

.info-box__icon,
.warning-box__icon {
    font-size: 1.5rem;
    flex-shrink: 0;
}

.info-box__content,
.warning-box__content {
    flex: 1;
}

.info-box__content p,
.warning-box__content p {
    margin-bottom: 0.5rem;
}

.info-box__content p:last-child,
.warning-box__content p:last-child {
    margin-bottom: 0;
}

/* Data Categories */
.data-category {
    background: var(--gray-lighter);
    padding: 1.5rem;
    border-radius: 12px;
    margin: 1.5rem 0;
}

.data-category h4 {
    color: var(--primary);
    margin-top: 0;
}

/* App Specific Sections */
.app-specific {
    background: var(--gray-lighter);
    padding: 2rem;
    border-radius: 12px;
    margin: 2rem 0;
}

.app-specific__header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.app-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 14px;
    flex-shrink: 0;
    padding: 8px;
    overflow: hidden;
}

.app-icon--serena-mente {
    background: linear-gradient(135deg, #e8f6fd 0%, #f0f9ff 100%);
    border: 1px solid #b3e0f7;
}

.app-icon--gomoove {
    background: var(--white);
    border: 1px solid var(--gray-light);
}

.app-icon--serena-mente svg,
.app-icon--gomoove img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.app-specific h4 {
    margin: 0;
    font-size: 1.5rem;
}

/* Sidebar app links with icon */
.sidebar-app-link {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.sidebar-app-link__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 7px;
    flex-shrink: 0;
    padding: 4px;
    overflow: hidden;
    border: 1px solid var(--gray-light);
    background: var(--white);
}

.sidebar-app-link__icon--serena {
    background: linear-gradient(135deg, #e8f6fd 0%, #f0f9ff 100%);
    border-color: #b3e0f7;
}

.sidebar-app-link__icon svg,
.sidebar-app-link__icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

/* Purpose Grid */
.purpose-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    margin: 2rem 0;
}

.purpose-card {
    background: var(--gray-lighter);
    padding: 1.5rem;
    border-radius: 12px;
}

.purpose-card__icon {
    font-size: 2rem;
    margin-bottom: 1rem;
}

.purpose-card h4 {
    margin-top: 0;
    margin-bottom: 1rem;
    color: var(--dark);
}

.purpose-card ul {
    padding-left: 1.25rem;
    margin: 0;
}

/* Security Grid */
.security-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    margin: 2rem 0;
}

.security-item {
    text-align: center;
    padding: 1.5rem;
    background: var(--gray-lighter);
    border-radius: 12px;
}

.security-item__icon {
    font-size: 2.5rem;
    margin-bottom: 1rem;
}

.security-item h4 {
    margin: 0 0 0.5rem 0;
    font-size: 1rem;
}

.security-item p {
    font-size: 0.875rem;
    margin: 0;
}

/* Rights List */
.rights-list {
    display: grid;
    gap: 1rem;
    margin: 2rem 0;
}

.right-item {
    display: flex;
    gap: 1.5rem;
    padding: 1.5rem;
    background: var(--gray-lighter);
    border-radius: 12px;
    align-items: flex-start;
}

.right-item__number {
    width: 40px;
    height: 40px;
    background: var(--gradient);
    color: var(--white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.125rem;
    flex-shrink: 0;
}

.right-item__content h4 {
    margin: 0 0 0.5rem 0;
    font-size: 1.125rem;
}

.right-item__content p {
    margin: 0;
    font-size: 0.95rem;
}

/* CTA Box */
.cta-box {
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.1), rgba(139, 92, 246, 0.1));
    padding: 2rem;
    border-radius: 12px;
    margin: 2rem 0;
}

.cta-box h4 {
    margin-top: 0;
    color: var(--primary);
}

/* Retention Table */
.retention-table {
    width: 100%;
    border-collapse: collapse;
    margin: 2rem 0;
    background: var(--white);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.retention-table thead {
    background: var(--dark);
    color: var(--white);
}

.retention-table th,
.retention-table td {
    padding: 1rem;
    text-align: left;
    border-bottom: 1px solid var(--gray-lighter);
}

.retention-table th {
    font-weight: 600;
}

.retention-table tbody tr:hover {
    background: var(--gray-lighter);
}

/* Cookies Grid */
.cookies-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    margin: 2rem 0;
}

.cookie-type {
    background: var(--gray-lighter);
    padding: 1.5rem;
    border-radius: 12px;
}

.cookie-type h4 {
    margin: 0 0 0.75rem 0;
    font-size: 1.125rem;
}

.cookie-type p {
    margin-bottom: 1rem;
    font-size: 0.95rem;
}

.cookie-status {
    display: inline-block;
    padding: 0.4rem 0.8rem;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
}

.cookie-status.required {
    background: var(--dark);
    color: var(--white);
}

.cookie-status.optional {
    background: var(--gray-light);
    color: var(--white);
}

/* Contact Grid */
.contact-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    margin: 2rem 0;
}

.contact-card {
    background: var(--gray-lighter);
    padding: 1.5rem;
    border-radius: 12px;
    text-align: center;
}

.contact-card__icon {
    font-size: 2.5rem;
    margin-bottom: 1rem;
}

.contact-card h4 {
    margin: 0 0 0.5rem 0;
    font-size: 1.125rem;
}

.contact-card p {
    margin: 0;
    font-size: 0.95rem;
}

.contact-card a {
    color: var(--primary);
    text-decoration: none;
}

.contact-card a:hover {
    text-decoration: underline;
}

/* Legal Info */
.legal-info {
    background: var(--gray-lighter);
    padding: 2rem;
    border-radius: 12px;
}

.legal-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
}

.legal-grid strong {
    display: block;
    color: var(--dark);
    margin-bottom: 0.25rem;
}

.legal-grid p {
    margin: 0;
    color: var(--gray);
}

/* ===================================
   ANIMATION OVERRIDE
   Fix: script.js sets all <section> elements to opacity:0 for
   the index.html scroll-in animation. On this page the large
   .privacy-content section never reaches the 10% threshold on
   first load, so the whole content area stays invisible until
   the user scrolls. Force the three page-level sections to
   always be fully visible.
   =================================== */
.privacy-hero,
.privacy-nav,
.privacy-content {
    opacity: 1 !important;
    transform: none !important;
}

/* ===================================
   RESPONSIVE TABLE WRAPPER
   =================================== */
.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin: 2rem 0;
    border-radius: 8px;
}

.table-responsive .retention-table {
    margin: 0;
    min-width: 480px;
}

/* ===================================
   RESPONSIVE DESIGN
   =================================== */
@media (max-width: 1024px) {
    .privacy-wrapper {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .privacy-sidebar {
        display: none;
    }

    .purpose-grid,
    .security-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .privacy-hero {
        padding: 5.5rem 0 2rem;
    }

    .privacy-hero__title {
        font-size: 1.875rem;
    }

    .privacy-hero__description {
        font-size: 1rem;
    }

    .privacy-hero__meta {
        flex-direction: column;
        gap: 0.5rem;
    }

    .separator {
        display: none;
    }

    /* Reduce the gray gap that appears above the content card */
    .privacy-content {
        padding: 2rem 0;
    }

    .privacy-nav {
        top: 60px;
        padding: 1rem 0;
    }

    .privacy-nav__title {
        margin-bottom: 0.75rem;
        font-size: 0.875rem;
    }

    /* Allow the pill row to scroll horizontally; nowrap + flex-shrink:0
       on each link (set above) prevents text wrapping inside pills.
       width: 100% is critical — without it a nowrap flex container can
       grow beyond its parent and inflate the page width on iOS Safari. */
    .privacy-nav__links {
        overflow-x: auto;
        flex-wrap: nowrap;
        padding-bottom: 0.5rem;
        width: 100%;
        scrollbar-width: none;
        -ms-overflow-style: none;
    }

    .privacy-nav__links::-webkit-scrollbar {
        display: none;
    }

    .privacy-main {
        padding: 2rem 1.25rem;
    }

    .privacy-section h2 {
        font-size: 1.375rem;
    }

    .privacy-section h3 {
        font-size: 1.125rem;
    }

    .cookies-grid,
    .contact-grid,
    .legal-grid {
        grid-template-columns: 1fr;
    }

    .retention-table {
        font-size: 0.875rem;
    }

    .retention-table th,
    .retention-table td {
        padding: 0.75rem 0.5rem;
    }
}

@media (max-width: 480px) {
    .privacy-hero {
        padding: 5rem 0 1.5rem;
    }

    .privacy-hero__title {
        font-size: 1.625rem;
    }

    .privacy-content {
        padding: 1.5rem 0;
    }

    .privacy-main {
        padding: 1.5rem 1rem;
        border-radius: 12px;
    }

    .info-box,
    .warning-box {
        flex-direction: column;
        padding: 1rem;
    }

    .right-item {
        gap: 1rem;
    }

    .right-item__number {
        width: 32px;
        height: 32px;
        font-size: 1rem;
    }

    .app-specific {
        padding: 1.25rem;
    }

    .cta-box {
        padding: 1.25rem;
    }

    .purpose-card,
    .security-item,
    .cookie-type,
    .contact-card {
        padding: 1rem;
    }
}
