/* ═══════════════════════════════════════════════════════════
   KYNK — POLICY PAGES SHARED STYLES
   File: app/static/css/pages/policy.css
   Used by: terms, privacy, guidelines, seller_policy, about
   ═══════════════════════════════════════════════════════════ */

/* ═══ TOP NAV ═══ */
.policy-nav {
    position: sticky;
    top: 0;
    z-index: var(--z-fixed);
    background: rgba(30, 0, 10, 0.95);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: var(--spacing-md) var(--spacing-xl);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.policy-nav__inner {
    max-width: 900px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.policy-nav__logo {
    font-family: var(--font-heading);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: #ffffff;
    text-decoration: none;
    letter-spacing: 3px;
}

.policy-nav__back {
    font-family: var(--font-body);
    font-size: var(--font-size-sm);
    color: rgba(255, 255, 255, 0.65);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    transition: color var(--transition-fast);
}

.policy-nav__back:hover {
    color: #ffffff;
}

/* ═══ HERO HEADER ═══ */
.policy-hero {
    background: linear-gradient(135deg, #1a0008 0%, #3d0012 60%, #1a0008 100%);
    padding: var(--spacing-3xl) var(--spacing-xl);
    text-align: center;
}

.policy-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: rgba(255, 255, 255, 0.85);
    font-family: var(--font-body);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    padding: var(--spacing-xs) var(--spacing-md);
    border-radius: var(--radius-full);
    margin-bottom: var(--spacing-lg);
    letter-spacing: 1px;
    text-transform: uppercase;
}

.policy-hero__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: #ffffff;
    margin: 0 0 var(--spacing-md) 0;
}

.policy-hero__meta {
    font-family: var(--font-body);
    font-size: var(--font-size-sm);
    color: rgba(255, 255, 255, 0.55);
    margin: 0;
}

/* ═══ CONTENT AREA ═══ */
.policy-body {
    background: var(--body-bg);
    min-height: 60vh;
}

.policy-container {
    max-width: 900px;
    margin: 0 auto;
    padding: var(--spacing-3xl) var(--spacing-xl);
}

/* ═══ TABLE OF CONTENTS ═══ */
.policy-toc {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-left: 4px solid var(--oxblood);
    border-radius: var(--radius-md);
    padding: var(--spacing-xl);
    margin-bottom: var(--spacing-3xl);
}

.policy-toc__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    margin: 0 0 var(--spacing-md) 0;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.policy-toc__list {
    list-style: none;
    margin: 0;
    padding: 0;
    columns: 2;
    column-gap: var(--spacing-xl);
}

.policy-toc__list li {
    margin-bottom: var(--spacing-sm);
    break-inside: avoid;
}

.policy-toc__list a {
    font-family: var(--font-body);
    font-size: var(--font-size-sm);
    color: var(--oxblood);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.policy-toc__list a:hover {
    color: var(--oxblood-dark);
    text-decoration: underline;
}

/* ═══ SECTIONS ═══ */
.policy-section {
    margin-bottom: var(--spacing-3xl);
    padding-top: var(--spacing-md);
}

.policy-section__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
    margin: 0 0 var(--spacing-lg) 0;
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid var(--oxblood);
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.policy-section__number {
    background: var(--oxblood);
    color: #ffffff;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    width: 32px;
    height: 32px;
    border-radius: var(--radius-full);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.policy-section h3 {
    font-family: var(--font-heading);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    margin: var(--spacing-xl) 0 var(--spacing-md) 0;
}

.policy-section p {
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    color: var(--text-primary);
    line-height: 1.8;
    margin: 0 0 var(--spacing-md) 0;
}

.policy-section ul,
.policy-section ol {
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    color: var(--text-primary);
    line-height: 1.8;
    margin: 0 0 var(--spacing-md) 0;
    padding-left: var(--spacing-xl);
}

.policy-section li {
    margin-bottom: var(--spacing-sm);
}

.policy-section strong {
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
}

/* ═══ HIGHLIGHT BOX ═══ */
.policy-highlight {
    background: linear-gradient(135deg, rgba(128,0,32,0.08), rgba(128,0,32,0.04));
    border: 1px solid rgba(128, 0, 32, 0.2);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    margin: var(--spacing-xl) 0;
}

.policy-highlight p {
    margin: 0;
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
}

/* ═══ FOOTER ═══ */
.policy-footer {
    background: #1a0008;
    padding: var(--spacing-xl) 0;
    text-align: center;
}

.policy-footer__inner {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 var(--spacing-xl);
}

.policy-footer__links {
    display: flex;
    justify-content: center;
    gap: var(--spacing-xl);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-md);
}

.policy-footer__links a {
    font-family: var(--font-body);
    font-size: var(--font-size-xs);
    color: rgba(255, 255, 255, 0.45);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.policy-footer__links a:hover {
    color: rgba(255, 255, 255, 0.85);
}

.policy-footer__copy {
    font-family: var(--font-body);
    font-size: var(--font-size-xs);
    color: rgba(255, 255, 255, 0.25);
    margin: 0;
}

/* ═══ RESPONSIVE ═══ */
@media (max-width: 768px) {
    .policy-toc__list {
        columns: 1;
    }

    .policy-hero__title {
        font-size: var(--font-size-2xl);
    }

    .policy-container {
        padding: var(--spacing-xl) var(--spacing-md);
    }

    .policy-nav__inner {
        padding: 0;
    }
}