      .content-wrapper { flex: 1; display: flex; justify-content: center; padding: 40px 20px; }
        .container {
            background: rgba(255, 255, 255, 0.85);
            backdrop-filter: blur(5px);
            padding: 40px;
            border-radius: 16px;
            box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
            width: 100%;
            max-width: 800px;
        }


        .policy-content h1 {
            text-align: center;
            margin-bottom: 30px;
            font-size: 30px;
            background: linear-gradient(135deg, #0a3c64, #1976d2, #4fc3f7);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            font-weight: 800;
        }

        .reveal {
            opacity: 0;
            transform: translateY(18px);
            transition: all 0.6s cubic-bezier(0.22, 1, 0.36, 1);
        }

        .reveal.visible {
            opacity: 1;
            transform: translateY(0);
        }

        .policy-section {
            margin-bottom: 16px;
            background: linear-gradient(135deg, #fafbfc 0%, #f8fbff 100%);
            border-radius: 12px;
            border-left: 4px solid #1976d2;
            overflow: hidden;
            transition: all 0.3s ease;
        }

        .policy-section:hover {
            box-shadow: 0 6px 20px rgba(25, 118, 210, 0.15);
            transform: translateX(3px);
        }

        .policy-section h2 {
            background: linear-gradient(135deg, #1976d2, #0a3c64);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            margin: 0;
            padding: 16px 20px;
            font-size: 19px;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: space-between;
            user-select: none;
            font-weight: 700;
        }

.policy-section h2::after {
    content: '▼';
    font-size: 12px;
    transition: transform 0.3s ease;
    background: linear-gradient(135deg, #4fc3f7, #1976d2);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    transform: rotate(90deg);
}

.policy-section.collapsed h2::after {
    transform: rotate(0deg);
}

        .policy-section .content {
            padding: 0 20px;
            max-height: 0;
            opacity: 0;
            overflow: hidden;
            transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease, padding 0.3s ease;
            color: #455a64;
            line-height: 1.7;
        }

        .policy-section:not(.collapsed) .content {
            padding: 4px 20px 16px;
            max-height: 800px;
            opacity: 1;
        }

        .policy-section ul {
            list-style: none;
            padding-left: 0;
            margin: 10px 0;
        }

        .policy-section li {
            position: relative;
            padding-left: 28px;
            margin-bottom: 12px;
            color: #455a64;
        }

        .policy-section li::before {
            content: '✓';
            position: absolute;
            left: 0;
            top: 2px;
            width: 20px;
            height: 20px;
            background: linear-gradient(135deg, #43a047, #66bb6a);
            color: white;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 12px;
            font-weight: bold;
        }

        .policy-section strong {
            color: #0a3c64;
            font-weight: 700;
        }

        .highlight-box {
            background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
            border-left: 4px solid #2196f3;
            padding: 16px 20px;
            border-radius: 10px;
            margin: 20px 0;
        }

        .highlight-box p {
            color: #0d47a1;
            margin: 0;
            font-weight: 600;
        }

        .contact-link {
            color: #1976d2;
            font-weight: 700;
            text-decoration: none;
        }

        .contact-link:hover {
            text-decoration: underline;
        }

        .privacy-date {
            font-size: 14px;
            color: #64748b;
            font-weight: 500;
            margin-bottom: 12px;
        }

        .privacy-intro {
            font-size: 16px;
            color: #334155;
            line-height: 1.7;
            margin-bottom: 24px;
        }

        .privacy-intro strong {
            color: #0a3c64;
            font-weight: 700;
        }

@media (max-width: 768px) {
    .content-wrapper {
        padding: 20px 15px;
    }
    .container {
        padding: 25px 20px;
    }

    .policy-content h1 {
        font-size: 24px;
        margin-bottom: 20px;
    }

    .policy-content {
        min-height: auto;
    }

    .policy-section h2 {
        font-size: 17px;
        padding: 14px 16px;
        text-align: left;
        justify-content: space-between;
    }

    .policy-section .content,
    .policy-section .content p,
    .policy-section .content ul,
    .policy-section .content li {
        text-align: left !important;
    }

    .policy-section .content {
        padding: 0 16px;
        font-size: 14px;
    }

    .policy-section:not(.collapsed) .content {
        padding: 4px 16px 14px;
    }

    .policy-section li {
        padding-left: 24px;
        font-size: 14px;
    }

    .policy-section li::before {
        width: 18px;
        height: 18px;
        font-size: 11px;
        top: 3px;
    }

    .highlight-box {
        padding: 14px 16px;
    }

    .highlight-box p {
        font-size: 14px;
    }

    .privacy-date {
        font-size: 13px;
    }

    .privacy-intro {
        font-size: 15px;
    }

    .contact-link {
        font-size: 15px;
    }
}
@media (min-width: 768px) and (max-width: 1024px) {
    .content-wrapper {
        align-items: flex-start !important;
        padding-bottom: 20px;
    }
    .container {
        margin-bottom: 0 !important;
    }
}

        body.guest-mode .mobile-menu-profile,
        body.guest-mode .mobile-menu-nav:first-of-type,
        body.guest-mode #authMenuItems,
        body.guest-mode .mobile-menu-divider {
            display: none !important;
        }
        body.guest-mode .mobile-menu-guest {
            display: flex !important;
        }
        .guest-nav {
            display: flex;
            align-items: center;
            gap: 12px;
            animation: fadeIn 0.3s ease;
        }

        .btn-header-login {
            color: white;
            text-decoration: none;
            font-size: 14px;
            font-weight: 500;
            padding: 8px 16px;
            border: 1px solid rgba(255, 255, 255, 0.4);
            border-radius: 8px;
            transition: all 0.3s;
        }
        .btn-header-login:hover {
            background: rgba(255, 255, 255, 0.1);
            border-color: white;
        }
        .btn-header-reg {
            background: white;
            color: #0a3c64;
            text-decoration: none;
            font-size: 14px;
            font-weight: 700;
            padding: 8px 20px;
            border-radius: 8px;
            transition: all 0.3s;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
        }
        .btn-header-reg:hover {
            transform: translateY(-2px);
            box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
        }
        @keyframes fadeIn {
            from { opacity: 0; transform: translateY(-10px); }
            to { opacity: 1; transform: translateY(0); }
        }

        body.guest-mode .site-header nav,
        body.guest-mode .user-menu {
            display: none !important;
        }

        body.guest-mode .site-footer {
            display: flex !important;
            justify-content: center;
            align-items: center;
        }
        body.guest-mode .copyright { margin: 0; }
        body.guest-mode .copyright { margin: 0; }

        .user-info {
            transition: box-shadow 0.25s ease, background 0.25s ease;
        }
        .user-info:hover,
        .user-info:active,
        .user-info-wrapper:focus-within .user-info {
            box-shadow: 0 0 18px rgba(25, 118, 210, 0.45);
            background: rgba(255, 255, 255, 0.1);
            border-radius: 8px;
        }

        @media (max-width: 950px) {
            .site-header { flex-direction: row; padding: 10px 15px; height: 60px; gap: 10px; }
            .site-header nav { display: none; }
            .hamburger-btn { display: flex; }
            .site-header .logo { flex: 1; justify-content: center; }
            .site-header .logo img { height: 40px; }
            .site-header .logo span { font-size: 18px; }
            .user-menu { display: none !important; }
            .guest-nav { display: none !important; }
            .container { padding: 25px 20px; }
            .form-row { flex-direction: column; gap: 0; }
            .avatar-upload { flex-direction: column; text-align: center; }
            .modal-content { padding: 20px; }
            .hero h1 { font-size: 28px; }
            .hero p { font-size: 16px; }
            .info-grid { grid-template-columns: 1fr; }
            .glass-card { padding: 25px 20px; }
        }
        @media (max-width: 360px) {
            .glass-card[style*="margin-top: 30px"] { padding: 25px 15px !important; }
            .glass-card[style*="margin-top: 30px"] > div[style*="grid"] {
                grid-template-columns: 1fr !important; gap: 20px !important;
            }
            .glass-card[style*="margin-top: 30px"] h3 { font-size: 15px !important; margin-bottom: 8px !important; }
            .glass-card[style*="margin-top: 30px"] p { font-size: 13px !important; line-height: 1.5 !important; }
            .glass-card[style*="margin-top: 30px"] > div[style*="grid"] > div { padding: 0 5px; }
        }
        @media (min-width: 361px) and (max-width: 400px) {
            .glass-card[style*="margin-top: 30px"] > div[style*="grid"] { gap: 15px !important; }
            .glass-card[style*="margin-top: 30px"] h3 { font-size: 16px !important; }
            .glass-card[style*="margin-top: 30px"] p { font-size: 13px !important; line-height: 1.5 !important; }
        }

        .mobile-menu-guest {
            padding: 20px 15px;
            display: flex;
            flex-direction: column;
            gap: 12px;
            animation: fadeIn 0.3s ease;
        }
        .mobile-menu-btn {
            display: block;
            padding: 14px 20px;
            text-align: center;
            border-radius: 10px;
            text-decoration: none;
            font-weight: 600;
            font-size: 15px;
            transition: all 0.3s ease;
        }
        .mobile-menu-login {
            background: rgba(255, 255, 255, 0.1);
            color: white;
            border: 2px solid rgba(255, 255, 255, 0.3);
        }
        .mobile-menu-login:hover {
            background: rgba(255, 255, 255, 0.2);
            border-color: white;
        }
        .mobile-menu-reg {
            background: white;
            color: #0a3c64;
            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
        }
        .mobile-menu-reg:hover {
            transform: translateY(-2px);
            box-shadow: 0 6px 16px rgba(0, 0, 0, 0.3);
        }

        body.guest-mode .mobile-menu-profile,
        body.guest-mode .mobile-menu-nav:first-of-type,
        body.guest-mode #authMenuItems,
        body.guest-mode .mobile-menu-divider {
            display: none !important;
        }
        body.guest-mode .mobile-menu-guest {
            display: flex !important;
        }

        .back-home-link {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            color: #1976d2;
            text-decoration: none;
            font-size: 14px;
            font-weight: 600;
            margin-bottom: 20px;
            transition: all 0.3s ease;
            cursor: pointer;
        }

        .back-home-link span {
            font-size: 18px;
            transition: transform 0.3s ease;
        }

        .back-home-link:hover {
            color: #0a3c64;
        }

        .back-home-link:hover span {
            transform: translateX(-5px);
        }

        @media (max-width: 768px) {
            .back-home-link {
                font-size: 13px;
                margin-bottom: 15px;
            }
        }