:root { --brand-color: #ff5722; --brand-dark: #e64a19 !important; --bg-body: #f4f6f8; --font-head: 'Roboto Condensed', sans-serif; --font-body: 'Inter', sans-serif; --text-muted: #6c757d; --dark-bg: #1a1a2e; --dark-bg-secondary: #16213e; }
body { font-family: var(--font-body); background-color: var(--bg-body); }
.access-modal .modal-dialog { max-width: 480px; margin: 1.75rem auto; }
.access-modal .modal-content { border: none; border-radius: 20px; overflow: hidden; box-shadow: 0 25px 80px rgba(0, 0, 0, 0.3); }
.access-modal .modal-body { padding: 0; }
.access-modal .btn-close-custom { position: absolute; top: 15px; right: 15px; width: 36px; height: 36px; border-radius: 50%; background: rgba(255, 255, 255, 0.15); border: none; display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 10; transition: all 0.3s ease; }
.access-modal .btn-close-custom:hover { background: rgba(255, 255, 255, 0.3); transform: rotate(90deg); }
.access-modal .btn-close-custom i { color: #fff; font-size: 14px; }
.access-modal-header { background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%); padding: 50px 40px 40px; text-align: center; position: relative; overflow: hidden; }
.access-modal-header::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); opacity: 0.5; }
.access-modal-header .icon-circle { width: 90px; height: 90px; border-radius: 50%; background: linear-gradient(135deg, var(--brand-color) 0%, var(--brand-dark) 100%); display: flex; align-items: center; justify-content: center; margin: 0 auto 25px; position: relative; z-index: 1; box-shadow: 0 10px 30px rgba(255, 87, 34, 0.4); }
.access-modal-header .icon-circle i { font-size: 36px; color: #fff; }
.access-modal-header h3 { font-family: var(--font-head); font-weight: 800; font-size: 24px; color: #fff; margin-bottom: 12px; position: relative; z-index: 1; line-height: 1.3; }
.access-modal-header p { font-size: 14px; color: rgba(255, 255, 255, 0.7); margin: 0; position: relative; z-index: 1; line-height: 1.7; }
.access-modal-body { padding: 35px 40px 40px; background: #fff; }
.access-features { display: flex; flex-direction: column; gap: 15px; margin-bottom: 30px; }
.access-feature-item { display: flex; align-items: center; gap: 15px; }
.access-feature-item .icon { width: 42px; height: 42px; border-radius: 12px; background: linear-gradient(135deg, rgba(255, 87, 34, 0.1) 0%, rgba(255, 87, 34, 0.05) 100%); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.access-feature-item .icon i { font-size: 16px; color: var(--brand-color); }
.access-feature-item .text { font-size: 13px; color: #555; line-height: 1.5; }
.access-feature-item .text strong { color: #111; font-weight: 600; }
.access-buttons { display: flex; flex-direction: column; gap: 12px; }
.btn-signup { display: flex; align-items: center; justify-content: center; gap: 10px; padding: 16px 30px; background: linear-gradient(135deg, var(--brand-color) 0%, var(--brand-dark) 100%); color: #fff; border: none; border-radius: 12px; font-size: 15px; font-weight: 700; cursor: pointer; transition: all 0.3s ease; text-transform: uppercase; letter-spacing: 0.5px; }
.btn-signup:hover { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(255, 87, 34, 0.4); }
.btn-signup i { font-size: 14px; }
.btn-login { display: flex; align-items: center; justify-content: center; gap: 10px; padding: 16px 30px; background: #fff; color: var(--dark-bg); border: 2px solid #e0e0e0; border-radius: 12px; font-size: 15px; font-weight: 700; cursor: pointer; transition: all 0.3s ease; text-transform: uppercase; letter-spacing: 0.5px; }
.btn-login:hover { border-color: var(--brand-color); color: var(--brand-color); transform: translateY(-3px); box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1); }
.btn-login i { font-size: 14px; }
.access-divider { display: flex; align-items: center; gap: 15px; margin: 20px 0; }
.access-divider::before, .access-divider::after { content: ''; flex: 1; height: 1px; background: #e0e0e0; }
.access-divider span { font-size: 12px; color: var(--text-muted); font-weight: 500; text-transform: uppercase; letter-spacing: 1px; }
.btn-cancel-link { display: block; text-align: center; padding: 12px; color: var(--text-muted); font-size: 14px; font-weight: 500; cursor: pointer; transition: all 0.3s ease; background: none; border: none; width: 100%; }
.btn-cancel-link:hover { color: var(--brand-color); }
.social-login-buttons { display: flex; gap: 12px; margin-bottom: 15px; }
.btn-social { flex: 1; display: flex; align-items: center; justify-content: center; gap: 8px; padding: 14px 15px; border: 2px solid #e0e0e0; border-radius: 12px; font-size: 13px; font-weight: 600; cursor: pointer; transition: all 0.3s ease; background: #fff; color: #333; }
.btn-social:hover { transform: translateY(-3px); box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1); }
.btn-social.google:hover { border-color: #ea4335; color: #ea4335; }
.btn-social.facebook:hover { border-color: #1877f2; color: #1877f2; }
.btn-social i { font-size: 18px; }
.btn-social.google i { color: #ea4335; }
.btn-social.facebook i { color: #1877f2; }
.demo-trigger { position: fixed; bottom: 30px; right: 30px; padding: 15px 30px; background: var(--brand-color); color: #fff; border: none; border-radius: 50px; font-size: 14px; font-weight: 600; cursor: pointer; box-shadow: 0 10px 30px rgba(255, 87, 34, 0.4); transition: all 0.3s ease; }
.demo-trigger:hover { transform: translateY(-3px); box-shadow: 0 15px 40px rgba(255, 87, 34, 0.5); }
@media (max-width: 575px) {
.access-modal .modal-dialog { margin: 10px; }
.access-modal-header { padding: 40px 25px 30px; }
.access-modal-header h3 { font-size: 20px; }
.access-modal-header .icon-circle { width: 70px; height: 70px; }
.access-modal-header .icon-circle i { font-size: 28px; }
.access-modal-body { padding: 25px; }
.social-login-buttons { flex-direction: column; }
.btn-signup, .btn-login { padding: 14px 25px; font-size: 14px; }
}